/* ============================================================
   ECONO ROOFING — SHARED STYLESHEET v2
   ============================================================ */

/* --- Tokens --- */
:root {
  --red:       #d5160c;
  --red-deep:  #a81009;
  --red-glow:  rgba(213,22,12,.15);
  --grey:      #9c9c9c;
  --grey-light:#f5f5f7;
  --grey-mid:  #d2d2d7;
  --black:     #000;
  --white:     #fff;
  --ink:       #1d1d1f;
  --ink-2:     #424245;
  --ink-3:     #6e6e73;
  --nav-h:     76px;
  --r-card:    clamp(14px, 2.5vw, 20px);
  --r-pill:    980px;
  --sp-sec:    clamp(72px, 10vw, 120px);
  --sp-sec-sm: clamp(48px, 7vw, 72px);
  --sp-side:   max(20px, 5vw);
  --sp-card:   clamp(24px, 4vw, 40px);
  --sp-gap:    clamp(16px, 2.5vw, 24px);
  --ease:      cubic-bezier(.4,0,.2,1);
  --ease-spring: cubic-bezier(.22,1.5,.36,1);
  --ease-out:  cubic-bezier(.16,1,.3,1);
  --sh-card:   0 2px 12px rgba(0,0,0,.07),0 24px 64px rgba(0,0,0,.09);
  --sh-lift:   0 4px 20px rgba(0,0,0,.1),0 32px 80px rgba(0,0,0,.13);
}

/* --- Ultra-wide containment --- */
.sec > *,.sec-sm > *,.il-section > *{max-width:1200px;margin-left:auto;margin-right:auto}
.svc-list,.rev-grid,.il-grid,.stat-grid{max-width:1200px;margin-left:auto;margin-right:auto}

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','Helvetica Neue',Arial,sans-serif;background:var(--white);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");mix-blend-mode:multiply}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,textarea,select{font-family:inherit}

/* --- Type --- */
.eyebrow{font-size:clamp(11px, 0.5vw + 9px, 12px);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.h-xl{font-size:clamp(48px,6.5vw,96px);font-weight:700;letter-spacing:-.04em;line-height:1.02;color:var(--ink)}
.h-lg{font-size:clamp(36px,5vw,62px);font-weight:700;letter-spacing:-.03em;line-height:1.06;color:var(--ink)}
.h-md{font-size:clamp(26px,3.2vw,42px);font-weight:700;letter-spacing:-.025em;line-height:1.1;color:var(--ink)}
.h-sm{font-size:clamp(20px,2.2vw,28px);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.b-lg{font-size:clamp(16px, 1.2vw + 12px, 19px);line-height:1.65;color:var(--ink-3);font-weight:400}
.b-md{font-size:clamp(15px, 1vw + 11px, 17px);line-height:1.6;color:var(--ink-3)}
.b-sm{font-size:clamp(13px, 0.5vw + 11px, 14px);line-height:1.6;color:var(--ink-3)}

/* --- Reveal animation --- */
.rv{opacity:0;transform:translateY(24px);filter:blur(6px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out),filter .6s var(--ease-out);will-change:opacity,transform}
.rv.vis{opacity:1;transform:none;filter:blur(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}

/* --- Nav --- */
#nav{position:fixed;inset:0 0 auto;z-index:900;height:var(--nav-h);background:rgba(255,255,255,.88);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid rgba(0,0,0,.06);display:flex;align-items:center;justify-content:space-between;padding:0 max(20px,4vw);transition:background .25s,border-color .25s;will-change:background}
#nav.scrolled{background:rgba(255,255,255,.96);box-shadow:0 1px 0 rgba(0,0,0,.06)}
#nav.dark{background:rgba(0,0,0,.82);border-bottom-color:rgba(255,255,255,.06)}
.nav-logo{display:flex;align-items:center;flex-shrink:0;margin-right:12px}
.nav-logo img{height:48px;width:auto;max-width:240px;display:block;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:24px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--ink-2);transition:color .15s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--red);border-radius:1px;transform:scaleX(0);transition:transform .25s var(--ease);transform-origin:center}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a.active{color:var(--red);font-weight:600}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--red);border-radius:2px}
#nav.dark .nav-links a{color:rgba(255,255,255,.6)}
#nav.dark .nav-links a:hover{color:var(--white)}
#nav.dark .nav-links a.active{color:var(--white)}
.nav-pill{background:var(--red)!important;color:var(--white)!important;padding:7px 16px;border-radius:var(--r-pill);font-size:12px!important;font-weight:600!important;transition:background .2s,transform .15s,box-shadow .2s!important;box-shadow:0 2px 8px var(--red-glow)}
.nav-pill:hover{background:var(--red-deep)!important;transform:scale(1.04);box-shadow:0 4px 16px rgba(213,22,12,.3)!important}
.nav-pill.active::after{display:none}

/* Hamburger button */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;border-radius:8px;transition:background .15s}
.hamburger:hover{background:rgba(0,0,0,.05)}
#nav.dark .hamburger:hover{background:rgba(255,255,255,.08)}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s,background .25s;transform-origin:center}
#nav.dark .hamburger span{background:var(--white)}
/* Hamburger → X animation */
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav overlay */
.mob-nav{
  position:fixed;inset:var(--nav-h) 0 0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  z-index:850;padding:24px 24px 40px;
  flex-direction:column;gap:4px;
  /* hidden state */
  display:flex;
  opacity:0;
  transform:translateY(-8px);
  pointer-events:none;
  transition:opacity .22s var(--ease),transform .22s var(--ease);
  overflow-y:auto;
}
.mob-nav.open{opacity:1;transform:translateY(0);pointer-events:auto}
.mob-nav a{font-size:clamp(17px, 2vw + 12px, 19px);font-weight:600;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--grey-light);transition:color .15s,padding-left .2s var(--ease);display:flex;align-items:center;min-height:44px}
.mob-nav a:hover{color:var(--red);padding-left:10px}
.mob-nav a:last-child{border-bottom:none}
.mob-cta{background:var(--red)!important;color:var(--white)!important;text-align:center;border-radius:var(--r-pill);padding:15px!important;margin-top:14px;border-bottom:none!important;box-shadow:0 4px 16px var(--red-glow)}

/* --- Desktop Dropdown --- */
.has-dd{position:relative}
.has-dd>a{display:flex;align-items:center;gap:3px}
.has-dd>a .dd-arrow{display:inline-block;width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-top:-2px;transition:transform .2s var(--ease);flex-shrink:0}
.has-dd:hover>a .dd-arrow{transform:rotate(-135deg)}
.dd{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(4px);min-width:200px;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:8px;list-style:none;opacity:0;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease);box-shadow:0 4px 24px rgba(0,0,0,.08),0 12px 48px rgba(0,0,0,.06)}
.has-dd:hover>.dd,.has-dd:focus-within>.dd{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dd li a{display:block;padding:8px 14px;font-size:13px;color:var(--ink-2);border-radius:8px;transition:background .15s,color .15s;white-space:nowrap}
.dd li a:hover{background:var(--grey-light);color:var(--red)}
.dd li a::after{display:none!important}
#nav.dark .dd{background:rgba(0,0,0,.88);border-color:rgba(255,255,255,.08)}
#nav.dark .dd li a{color:rgba(255,255,255,.7)}
#nav.dark .dd li a:hover{background:rgba(255,255,255,.08);color:var(--white)}
.has-dd::before{content:'';position:absolute;top:100%;left:0;right:0;height:12px}

/* --- Areas Dropdown (County Groups) --- */
.dd-areas{display:grid;grid-template-columns:repeat(4,1fr);gap:0;min-width:520px;padding:12px 6px}
.dd-group{display:flex;flex-direction:column;padding:0 6px;border-right:1px solid rgba(0,0,0,.06)}
.dd-group:last-child{border-right:none}
.dd-group a{display:block;padding:5px 10px;font-size:12.5px;color:var(--ink-2);border-radius:6px;transition:background .15s,color .15s;white-space:nowrap}
.dd-group a:hover{background:var(--grey-light);color:var(--red)}
.dd-group a::after{display:none!important}
.dd-county{font-weight:700!important;color:var(--ink)!important;font-size:12px!important;letter-spacing:.02em;text-transform:uppercase;padding:6px 10px 4px!important;margin-bottom:2px}
.dd-county:hover{color:var(--red)!important}
#nav.dark .dd-group{border-right-color:rgba(255,255,255,.08)}
#nav.dark .dd-group a{color:rgba(255,255,255,.6)}
#nav.dark .dd-group a:hover{background:rgba(255,255,255,.08);color:var(--white)}
#nav.dark .dd-county{color:rgba(255,255,255,.9)!important}

/* --- Mobile Accordion Sections --- */
.mob-section{border-bottom:1px solid var(--grey-light)}
.mob-section:last-of-type{border-bottom:none}
.mob-section-btn{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;font-size:clamp(17px,2vw + 12px,19px);font-weight:600;color:var(--ink);padding:14px 0;cursor:pointer;min-height:44px;font-family:inherit;transition:color .15s}
.mob-section-btn:hover{color:var(--red)}
.mob-section-btn .mob-arrow{font-size:14px;transition:transform .2s var(--ease);color:var(--ink-3)}
.mob-section.open .mob-arrow{transform:rotate(90deg)}
.mob-section-links{max-height:0;overflow:hidden;transition:max-height .3s var(--ease);padding-left:16px}
.mob-section.open .mob-section-links{max-height:900px}
.mob-section-links a{font-size:15px!important;font-weight:500!important;padding:10px 0!important;min-height:40px;border-bottom:1px solid rgba(0,0,0,.03)!important}
.mob-section-links a:last-child{border-bottom:none!important}
.mob-county{display:block;font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;padding:14px 0 4px;margin-top:4px}
.mob-county:first-child{padding-top:4px;margin-top:0}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:clamp(12px, 1.5vw, 14px) clamp(20px, 3vw, 26px);border-radius:var(--r-pill);font-size:clamp(14px, 1vw + 11px, 15px);font-weight:600;border:none;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s;letter-spacing:-.01em;text-decoration:none;min-height:44px}
.btn:hover{transform:scale(1.035)}
.btn:active{transform:scale(.97);transition-duration:.1s}
.btn-red{background:var(--red);color:var(--white);box-shadow:0 4px 14px rgba(213,22,12,.18)}
.btn-red:hover{box-shadow:0 10px 32px rgba(213,22,12,.3)}
.btn-outline{background:transparent;color:var(--red);border:1.5px solid var(--red)}
.btn-outline:hover{background:var(--red);color:var(--white)}
.btn-white{background:var(--white);color:var(--red)}
.btn-white:hover{background:#f0f0f0}
.btn-glass{background:rgba(255,255,255,.12);color:var(--white);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(12px)}
.btn-glass:hover{background:rgba(255,255,255,.2)}
.btn-dark{background:var(--ink);color:var(--white)}
.btn-dark:hover{background:#333}

/* --- Section wrapper --- */
.sec{padding:var(--sp-sec) var(--sp-side)}
.sec-sm{padding:var(--sp-sec-sm) var(--sp-side)}

/* --- Section header --- */
.sec-hdr{max-width:720px}
.sec-hdr.ctr{margin:0 auto;text-align:center}
.sec-hdr .eyebrow{margin-bottom:12px}
.sec-hdr .b-lg{margin-top:16px;max-width:580px}
.sec-hdr.ctr .b-lg{margin:16px auto 0}

/* --- Card base --- */
.card{border-radius:var(--r-card);padding:var(--sp-card);background:var(--grey-light);transition:transform .25s var(--ease),box-shadow .25s}
.card:hover{transform:translateY(-2px);box-shadow:0 2px 8px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.08),0 24px 48px rgba(0,0,0,.06)}
.card-white{background:var(--white);box-shadow:var(--sh-card)}
.card-dark{background:var(--ink)}
.card-red{background:var(--red)}
.card-black{background:#111}

/* --- Form elements --- */
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-field label{font-size:clamp(12px, 0.5vw + 11px, 13px);font-weight:600;color:var(--ink-2)}
.form-field input,.form-field textarea,.form-field select{background:var(--white);border:1.5px solid var(--grey-mid);border-radius:12px;padding:clamp(11px, 1.5vw, 13px) 16px;font-size:16px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;font-family:inherit}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--grey)}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--red);box-shadow:0 0 0 2px rgba(213,22,12,.12)}
.form-field textarea{resize:none;height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-submit{width:100%;background:var(--red);color:var(--white);border:none;padding:15px;border-radius:var(--r-pill);font-size:17px;font-weight:700;cursor:pointer;margin-top:6px;transition:background .2s,transform .2s,box-shadow .2s}
.form-submit:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 8px 24px var(--red-glow)}

/* --- Trust chips --- */
.trust-strip{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px;justify-content:center}
.trust-chip{display:inline-flex;align-items:center;gap:7px;background:var(--white);border:1px solid var(--grey-mid);border-radius:var(--r-pill);padding:9px 18px;font-size:13px;font-weight:500;color:var(--ink-2);transition:background .2s,box-shadow .2s,border-color .2s}
.trust-chip:hover{background:#f8f8fa;border-color:rgba(213,22,12,.2);box-shadow:0 2px 8px rgba(0,0,0,.05)}
.trust-chip-icon{font-size:14px}

/* --- Star rating --- */
.stars{color:var(--red);letter-spacing:2px;font-size:15px}

/* --- CTA banner --- */
.cta-banner{background:linear-gradient(135deg,#d5160c 0%,#b5120a 40%,#a81009 100%);padding:clamp(64px, 9vw, 100px) var(--sp-side);text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.1) 0%,transparent 60%)}
.cta-banner .h-lg{color:var(--white);position:relative;z-index:1}
.cta-banner .b-lg{color:rgba(255,255,255,.7);max-width:500px;margin:14px auto 0;position:relative;z-index:1}
.cta-acts{display:flex;gap:12px;justify-content:center;margin-top:36px;flex-wrap:wrap;position:relative;z-index:1}

/* --- Page hero (inner pages) --- */
.page-hero{padding:calc(var(--nav-h) + clamp(48px, 6vw, 80px)) var(--sp-side) clamp(60px, 8vw, 96px);background:var(--black);position:relative;overflow:hidden;text-align:center}
.page-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:100px 100px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);pointer-events:none}
.page-hero-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:min(960px, 200vw);height:min(720px, 150vw);background:radial-gradient(ellipse,rgba(213,22,12,.12) 0%,transparent 60%);pointer-events:none}
.page-hero-content{position:relative;z-index:2;max-width:min(760px, 88vw);margin:0 auto}
.page-hero .eyebrow{color:rgba(213,22,12,.85);margin-bottom:16px}
.page-hero .h-xl{color:var(--white)}
.page-hero .b-lg{color:rgba(255,255,255,.5);margin:clamp(16px, 2.5vw, 24px) auto 0;max-width:580px;font-size:clamp(16px, 1.5vw + 12px, 20px)}
.page-hero-acts{display:flex;gap:12px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.4);margin-bottom:20px;justify-content:center}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .2s}
.breadcrumb a:hover{color:rgba(255,255,255,.8)}
.breadcrumb-sep{opacity:.3}

/* --- Footer --- */
#footer{background:linear-gradient(180deg,#050505 0%,#000 100%);padding:clamp(40px, 6vw, 64px) var(--sp-side) clamp(20px, 3vw, 32px)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px, 4vw, 40px);padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-logo{margin-bottom:12px}
.footer-logo img{height:52px;width:auto;display:block}
.footer-desc{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7;max-width:270px}
.footer-phone{display:inline-flex;align-items:center;gap:8px;color:var(--white);font-size:19px;font-weight:700;letter-spacing:-.02em;margin-top:18px;transition:color .2s}
.footer-phone:hover{color:var(--red)}
.footer-email{display:block;color:rgba(255,255,255,.6);font-size:13px;margin-top:5px;transition:color .2s}
.footer-email:hover{color:var(--white)}
.footer-col-h{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.footer-ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-ul a{font-size:14px;color:rgba(255,255,255,.65);transition:color .2s}
.footer-ul a:hover{color:var(--white)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:12px;color:rgba(255,255,255,.22)}
.footer-parent-line{text-align:center;padding:14px 0 0;font-size:11.5px;color:rgba(255,255,255,.18);letter-spacing:.01em}
.footer-parent-line strong{font-weight:600;color:rgba(255,255,255,.28)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.22);transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.55)}
.footer-badges{display:flex;gap:8px}
.f-badge{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:var(--r-pill);padding:4px 11px;font-size:11px;color:rgba(255,255,255,.35);font-weight:600}
.f-badge-gold{background:rgba(213,22,12,.12);border-color:rgba(213,22,12,.25);color:rgba(255,255,255,.7)}

/* --- Footer: Main column (address, hours, social) --- */
.ft-col-main{display:flex;flex-direction:column;gap:0}
.ft-address{display:flex;align-items:flex-start;gap:10px;margin-top:18px;font-size:14px;color:rgba(255,255,255,.55);line-height:1.6}
.ft-address svg{flex-shrink:0;margin-top:2px;color:rgba(255,255,255,.35)}
.footer-phone{display:inline-flex;align-items:center;gap:10px;color:var(--white);font-size:19px;font-weight:700;letter-spacing:-.02em;margin-top:16px;transition:color .2s}
.footer-phone:hover{color:var(--red)}
.footer-phone svg{flex-shrink:0;color:var(--red)}
.footer-email{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.7);font-size:14px;font-weight:500;margin-top:8px;transition:color .2s}
.footer-email:hover{color:var(--white)}
.footer-email svg{flex-shrink:0;color:rgba(255,255,255,.35)}
.ft-hours{display:flex;align-items:flex-start;gap:10px;margin-top:14px;font-size:13px;color:rgba(255,255,255,.45);line-height:1.65}
.ft-hours svg{flex-shrink:0;margin-top:2px;color:rgba(255,255,255,.3)}

/* --- Footer: Social media icons --- */
.ft-social{display:flex;gap:10px;margin-top:20px}
.ft-social a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.45);transition:background .2s,color .2s,border-color .2s,transform .15s}
.ft-social a:hover{background:rgba(213,22,12,.15);border-color:rgba(213,22,12,.3);color:var(--white);transform:scale(1.1)}
.ft-social a svg{width:18px;height:18px}

/* --- Footer: County accordion --- */
.ft-counties{display:flex;flex-direction:column;gap:0}
.ft-county{border-bottom:1px solid rgba(255,255,255,.06)}
.ft-county:last-of-type{border-bottom:none}
.ft-county summary{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-size:14px;font-weight:600;color:rgba(255,255,255,.65);cursor:pointer;list-style:none;transition:color .2s}
.ft-county summary::-webkit-details-marker{display:none}
.ft-county summary::marker{display:none;content:""}
.ft-county summary:hover{color:var(--white)}
.ft-county-arrow{font-size:14px;color:rgba(255,255,255,.3);transition:transform .2s var(--ease)}
.ft-county[open] .ft-county-arrow{transform:rotate(90deg)}
.ft-county-list{list-style:none;padding:0 0 10px 0;display:flex;flex-direction:column;gap:6px}
.ft-county-list a{font-size:13px;color:rgba(255,255,255,.5);padding-left:12px;transition:color .2s,padding-left .2s}
.ft-county-list a:hover{color:var(--white);padding-left:16px}
.ft-all-cities{display:inline-flex;align-items:center;gap:4px;margin-top:14px;font-size:13px;font-weight:600;color:var(--red);transition:gap .2s}
.ft-all-cities:hover{gap:8px}

/* --- Footer: Certifications bar --- */
.footer-certs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.07)}

/* --- Stat grid --- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-radius:var(--r-card);overflow:hidden;background:var(--grey-light)}
.stat-block{padding:clamp(24px, 4vw, 40px) clamp(16px, 2.5vw, 28px);text-align:center;border-right:1px solid rgba(0,0,0,.06)}
.stat-block:last-child{border-right:none}
.stat-block-num{font-size:clamp(32px, 5vw, 48px);font-weight:800;letter-spacing:-.05em;color:var(--ink);line-height:1}
.stat-block-num span{color:var(--red)}
.stat-block-lbl{font-size:13px;color:var(--ink-3);margin-top:8px;font-weight:500;letter-spacing:.01em}

/* --- Service list (for inner pages) --- */
.svc-list{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-gap)}
.svc-list:has(> :nth-child(4)){grid-template-columns:repeat(2,1fr)}
.svc-item{background:var(--grey-light);border-radius:18px;padding:var(--sp-card);border:1.5px solid transparent;transition:border-color .2s,background .2s,transform .2s,box-shadow .2s}
.svc-item:hover{border-color:var(--red);background:var(--white);transform:translateY(-3px);box-shadow:var(--sh-card)}
.svc-item-icon{font-size:36px;margin-bottom:16px}
.svc-item-title{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:8px}
.svc-item-desc{font-size:14px;color:var(--ink-3);line-height:1.65}
.svc-link{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:13px;font-weight:600;color:var(--red);transition:gap .3s var(--ease)}
.svc-link:hover{gap:8px}

/* --- Review cards --- */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-gap)}
.rev-card{background:var(--white);border-radius:var(--r-card);padding:var(--sp-card);box-shadow:var(--sh-card);transition:transform .25s var(--ease),box-shadow .25s}
.rev-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px rgba(0,0,0,.08),0 20px 48px rgba(0,0,0,.07)}
/* First review emphasis */
.rev-grid>.rev-card:first-child{padding:44px;background:linear-gradient(135deg,rgba(213,22,12,.04) 0%,#fff 60%);border:1.5px solid rgba(213,22,12,.12)}
.rev-grid>.rev-card:first-child .rev-text{font-size:17px}
.rev-text{font-size:15px;line-height:1.7;color:var(--ink);font-style:italic;margin-top:12px}
.rev-author{display:flex;align-items:center;gap:11px;margin-top:22px;padding-top:18px;border-top:1px solid var(--grey-light)}
.avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:var(--white);flex-shrink:0}
.rev-name{font-size:14px;font-weight:700;color:var(--ink)}
.rev-city{font-size:12px;color:var(--ink-3);margin-top:1px}
.rev-src{margin-left:auto;font-size:11px;color:var(--ink-3)}

/* --- FAQ accordion --- */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:3px}
.faq-item{border-radius:16px;overflow:hidden;background:var(--grey-light);border:1px solid transparent;transition:background .2s,border-color .2s,box-shadow .2s}
.faq-item:hover{background:#efeff2;border-color:rgba(0,0,0,.04)}
.faq-item.open{background:var(--white);border-color:rgba(0,0,0,.06);box-shadow:0 2px 12px rgba(0,0,0,.04)}
.faq-q{width:100%;background:none;border:none;padding:clamp(16px, 2.5vw, 22px) clamp(20px, 3vw, 28px);text-align:left;font-size:clamp(15px, 1vw + 11px, 16px);font-weight:600;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .15s;min-height:44px}
.faq-q:hover{color:var(--red)}
.faq-arrow{font-size:18px;transition:transform .28s var(--ease);color:var(--grey);flex-shrink:0}
.faq-item.open .faq-arrow{transform:rotate(180deg);color:var(--red)}
/* Grid-rows animation — no layout thrash, no max-height guess */
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s var(--ease)}
.faq-a-inner{overflow:hidden;padding:0 clamp(20px, 3vw, 24px);font-size:clamp(14px, 0.8vw + 11px, 15px);color:var(--ink-3);line-height:1.7;transition:padding .28s var(--ease)}
.faq-item.open .faq-a{grid-template-rows:1fr}
.faq-item.open .faq-a-inner{padding:0 24px 20px}

/* --- Responsive --- */
@media(max-width:1000px){
  #nav{justify-content:center}
  .nav-logo{margin-right:0}
  .hamburger{display:flex;position:absolute;right:max(20px,4vw)}
  .nav-links{display:none}
  .dd{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .svc-list{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:repeat(2,1fr)}
  /* Collapse inline 2-col page layout grids (content + sticky sidebar) */
  div[style*="grid-template-columns:1fr 1fr"][style*="max-width:1100px"]{
    grid-template-columns:1fr!important;gap:48px!important
  }
}
@media(max-width:900px){
  /* Tablet landscape: collapse wide 2-col grids */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:72px"]{grid-template-columns:1fr!important;gap:40px!important}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  /* Hero: stack CTAs */
  .page-hero-acts{flex-direction:column;align-items:center}
  .page-hero-acts .btn{width:100%;justify-content:center;max-width:360px}
  .trust-strip{margin-top:24px}
  /* Grid collapses */
  .rev-grid{grid-template-columns:1fr}
  .svc-list{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .rev-grid>.rev-card:first-child{padding:var(--sp-card)}
  .rev-grid>.rev-card:first-child .rev-text{font-size:15px}
  /* CTA banner actions stack */
  .cta-acts{flex-direction:column;align-items:center}
  .cta-acts .btn{width:100%;justify-content:center;max-width:360px}
}
@media(max-width:640px){
  .form-row{grid-template-columns:1fr}
  .svc-list{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .stat-grid{grid-template-columns:1fr 1fr}
  .footer-badges{flex-wrap:wrap}
  .footer-ul[style*="columns:2"]{columns:1!important}
  /* Inline 2-col grids — collapse all variants */
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:80px"]{grid-template-columns:1fr!important;gap:40px!important}
  div[style*="grid-template-columns:1fr 1fr"][style*="gap:48px"]{grid-template-columns:1fr!important;gap:32px!important}
  div[style*="grid-template-columns:1fr 1."][style*="gap:"]{grid-template-columns:1fr!important;gap:40px!important}
  .mat-sticky{position:static}
}
@media(max-width:480px){
  :root{--nav-h:68px}
  .page-hero{padding:calc(var(--nav-h) + 40px) 16px 56px}
  .page-hero .b-lg{font-size:15px}
  .breadcrumb{font-size:12px;gap:6px}
  .stat-grid{grid-template-columns:1fr}
  .stat-block{border-right:none;border-bottom:1px solid rgba(0,0,0,.06)}
  .stat-block:last-child{border-bottom:none}
  .card,.rev-card,.svc-item{padding:clamp(20px, 5vw, 24px)}
  .faq-q{min-height:44px;padding:14px 16px;font-size:15px}
  .trust-strip{gap:6px}
  .trust-chip{padding:7px 14px;font-size:12px}
  .blog-cta-box{padding:24px 20px}
  .city-link-btn{padding:8px 14px;font-size:12px}
  .footer-phone{font-size:17px}
  .footer-desc{font-size:13px}
  .footer-ul[style*="columns:2"]{columns:1!important}
}

/* --- Internal link cards (related pages widget) --- */
.il-section{padding:clamp(56px, 8vw, 96px) var(--sp-side)}
.il-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--sp-gap);margin-top:0}
.il-grid>.il-card{flex:0 1 calc((100% - var(--sp-gap)*2)/3);min-width:0}
.il-card{display:flex;flex-direction:column;gap:10px;background:var(--grey-light);border-radius:var(--r-card);padding:var(--sp-card);border:1.5px solid transparent;text-decoration:none;color:var(--ink);transition:background .2s,transform .25s var(--ease),box-shadow .25s}
.il-card:hover{background:#e8e8ed;transform:translateY(-3px);box-shadow:0 4px 16px rgba(0,0,0,.08),0 16px 40px rgba(0,0,0,.06)}
/* First link card emphasis */
.il-grid>.il-card:first-child{padding:40px;background:linear-gradient(135deg,rgba(213,22,12,.04) 0%,var(--grey-light) 60%);border:1.5px solid rgba(213,22,12,.12)}
.il-grid>.il-card:first-child .il-icon{font-size:38px}
.il-grid>.il-card:first-child .il-label{font-size:19px}
.il-icon{font-size:32px;margin-bottom:4px}
.il-label{font-size:17px;font-weight:700;color:var(--ink)}
.il-desc{font-size:14px;color:var(--ink-3);line-height:1.58;flex:1}
.il-arrow{font-size:13px;font-weight:600;color:var(--red);margin-top:6px}

/* --- City link pills --- */
.city-link-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:0}
.city-link-btn{display:inline-flex;align-items:center;gap:6px;background:var(--grey-light);border:1.5px solid transparent;border-radius:var(--r-pill);padding:10px 20px;font-size:14px;font-weight:600;color:var(--ink-2);text-decoration:none;transition:border-color .2s,background .2s,color .2s,box-shadow .2s}
.city-link-btn:hover{border-color:var(--red);background:var(--white);color:var(--red);box-shadow:0 2px 8px rgba(213,22,12,.12)}

/* --- Contextual inline links --- */
.il-inline a{color:var(--red);text-decoration:underline;text-decoration-color:rgba(213,22,12,.25);text-underline-offset:3px;transition:text-decoration-color .2s}
.il-inline a:hover{text-decoration-color:var(--red)}

/* --- Responsive for internal link grids --- */
@media(max-width:1000px){.il-grid>.il-card{flex:0 1 calc((100% - var(--sp-gap))/2)}}
@media(max-width:640px){.il-grid>.il-card{flex:0 1 100%}.il-grid>.il-card:first-child{padding:var(--sp-card)}.il-grid>.il-card:first-child .il-icon{font-size:32px}.il-grid>.il-card:first-child .il-label{font-size:17px}.city-link-row{gap:8px}.city-link-btn{font-size:13px;padding:8px 15px}}

/* --- Nav phone (desktop) --- */
.nav-phone{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--ink-2);transition:color .15s;white-space:nowrap;letter-spacing:-.01em}
.nav-phone:hover{color:var(--red)}
.nav-phone svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;flex-shrink:0}
#nav.dark .nav-phone{color:rgba(255,255,255,.6)}
#nav.dark .nav-phone:hover{color:var(--white)}

/* --- Sticky mobile phone button --- */
.mobile-call{
  display:none;position:fixed;bottom:20px;right:20px;z-index:950;
  width:56px;height:56px;border-radius:50%;
  background:var(--red);color:var(--white);border:none;
  box-shadow:0 4px 20px rgba(213,22,12,.4),0 8px 32px rgba(0,0,0,.15);
  cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .2s;
  align-items:center;justify-content:center;
  text-decoration:none;
}
.mobile-call:hover,.mobile-call:active{transform:scale(1.1);box-shadow:0 6px 28px rgba(213,22,12,.55),0 12px 40px rgba(0,0,0,.2)}
.mobile-call svg{width:24px;height:24px;fill:var(--white)}

/* --- "Prefer to call?" strip near forms --- */
.call-alt{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:16px;padding:12px 20px;background:var(--grey-light);border-radius:var(--r-pill);font-size:14px;color:var(--ink-3);text-decoration:none;transition:background .2s,color .2s}
.call-alt:hover{background:#e8e8ed;color:var(--ink)}
.call-alt strong{color:var(--ink);font-weight:700}
.call-alt svg{width:16px;height:16px;fill:none;stroke:var(--red);stroke-width:2;flex-shrink:0}

/* --- Emergency urgency banner --- */
.urgency-banner{
  background:linear-gradient(90deg,#d5160c 0%,#a81009 100%);
  color:var(--white);text-align:center;
  padding:10px 20px;font-size:13px;font-weight:600;
  letter-spacing:.01em;
  display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;
  position:fixed;top:var(--nav-h);left:0;right:0;z-index:890;
}
.urgency-banner ~ .page-hero{padding-top:calc(var(--nav-h) + 120px)}
.urgency-banner a{color:var(--white);text-decoration:underline;text-underline-offset:2px;font-weight:700}
.urgency-banner .urgency-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;display:inline-block;animation:urgency-pulse 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes urgency-pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(74,222,128,.6)}50%{opacity:.8;box-shadow:0 0 0 6px rgba(74,222,128,0)}}

/* --- Blog inline CTA box --- */
.blog-cta-box{
  background:var(--grey-light);border-left:4px solid var(--red);border-radius:0 var(--r-card) var(--r-card) 0;
  padding:32px 36px;margin:40px 0;
}
.blog-cta-box-title{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:8px}
.blog-cta-box-desc{font-size:15px;color:var(--ink-3);line-height:1.6;margin-bottom:16px}
.blog-cta-box .btn{font-size:14px;padding:11px 22px}

/* --- Performance: off-screen rendering & containment --- */
.sec,.sec-sm,.il-section,.cta-banner{content-visibility:auto;contain-intrinsic-size:auto 500px}
.page-hero{content-visibility:visible}
.svc-item,.rev-card,.il-card,.card,.stat-block,.city-link-btn,.faq-item{contain:layout style}


/* --- Scale-in reveal variant --- */
.rv-scale{opacity:0;transform:scale(.94);filter:blur(4px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out),filter .7s var(--ease-out);will-change:opacity,transform}
.rv-scale.vis{opacity:1;transform:scale(1);filter:blur(0)}

/* --- Gradient text utility --- */
.grad-text{background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 50%,var(--red) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.grad-text-white{background:linear-gradient(180deg,#fff 20%,rgba(255,255,255,.6) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* --- Enhanced button glow on hover --- */
.btn-red{position:relative;overflow:hidden}
.btn-red::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 60%);opacity:0;transition:opacity .3s}
.btn-red:hover::before{opacity:1}
.btn:active{transform:scale(.96);transition-duration:.1s}

/* --- Enhanced card hover --- */
.card:hover,.svc-item:hover,.il-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px rgba(0,0,0,.08),0 24px 56px rgba(0,0,0,.1)}
.rev-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px rgba(0,0,0,.08),0 20px 48px rgba(0,0,0,.08)}

/* --- Section divider line --- */
.sec-divider{width:min(100px,20vw);height:1.5px;background:linear-gradient(90deg,transparent,var(--red),transparent);margin:0 auto;opacity:.35}

/* --- CTA banner shimmer --- */
.cta-banner::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.06) 50%,transparent 100%);animation:cta-shimmer 6s ease-in-out infinite;pointer-events:none}
@keyframes cta-shimmer{0%,100%{transform:translateX(-100%)}50%{transform:translateX(300%)}}

/* --- Footer hover glow on social icons --- */
.ft-social a:hover{box-shadow:0 0 16px rgba(213,22,12,.25)}

/* --- Smooth image loading --- */
img[loading="lazy"]{transition:opacity .4s var(--ease-out)}


/* --- Phase 2: Custom selection color --- */
::selection{background:rgba(213,22,12,.15);color:var(--ink)}

/* --- Phase 2: Focus-visible accessibility (Apple-like) --- */
:focus-visible{outline:3px solid rgba(213,22,12,.4);outline-offset:3px;border-radius:4px}
button:focus-visible,.btn:focus-visible{outline-offset:4px;border-radius:var(--r-pill)}

/* --- Phase 2: Animated link underline in body text --- */
.b-lg a,.b-md a,.b-sm a,.svc-item-desc a{text-decoration:none;background-image:linear-gradient(var(--red),var(--red));background-size:0% 1.5px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .3s var(--ease-out)}
.b-lg a:hover,.b-md a:hover,.b-sm a:hover,.svc-item-desc a:hover{background-size:100% 1.5px}

/* --- Phase 2: Stat number subtle glow on reveal --- */
.stat-block.vis .stat-block-num{text-shadow:0 0 40px rgba(213,22,12,.06)}


/* --- Phase 3: Smooth scroll --- */
html{scroll-behavior:smooth}

/* --- Phase 3: Tight headline tracking (Apple signature) --- */
.h-xl{letter-spacing:-.03em}
.h-lg{letter-spacing:-.02em}
.h-md{letter-spacing:-.015em}
.h-sm{letter-spacing:-.01em}

/* --- Phase 3: Scroll progress bar --- */
.scroll-progress{position:fixed;top:var(--nav-h);left:0;width:100%;height:2px;z-index:999;background:linear-gradient(90deg,var(--red),var(--red-deep));transform-origin:left;transform:scaleX(0);pointer-events:none;will-change:transform}

/* --- Phase 3: Eyebrow accent dot --- */
.eyebrow::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor;margin-right:8px;vertical-align:middle}

/* --- Phase 3: Trust chip hover --- */
.trust-chip{transition:border-color .2s,transform .2s var(--ease-out),box-shadow .2s}
.trust-chip:hover{border-color:rgba(213,22,12,.15);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.05)}

/* --- Phase 3: Review card quote decoration --- */
.rev-card{position:relative}
.rev-card::before{content:'\201C';position:absolute;top:12px;right:24px;font-size:64px;line-height:1;color:rgba(213,22,12,.06);font-family:Georgia,'Times New Roman',serif;pointer-events:none}

/* --- Phase 3: Hero headline text depth --- */
.page-hero .h-xl{text-shadow:0 2px 40px rgba(0,0,0,.12)}


/* --- Phase 4: Back-to-top button --- */
.back-top{position:fixed;bottom:100px;right:24px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(0,0,0,.1);background:rgba(255,255,255,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out),background .15s,box-shadow .15s;pointer-events:none;z-index:800;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.back-top.vis{opacity:1;transform:translateY(0);pointer-events:auto}
.back-top:hover{background:var(--white);box-shadow:0 4px 16px rgba(0,0,0,.1);border-color:rgba(0,0,0,.15)}
.back-top svg{width:18px;height:18px;stroke:var(--ink-2);stroke-width:2;fill:none}
@media(max-width:640px){.back-top{bottom:90px;right:16px;width:40px;height:40px}.back-top svg{width:16px;height:16px}}

/* --- Phase 4: Hero em/italic gradient text --- */
.page-hero em,.page-hero i{font-style:normal;background:linear-gradient(180deg,#fff 20%,rgba(255,255,255,.6) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* --- Phase 4: Print stylesheet --- */
@media print{
  #nav,.mob-nav,.hamburger,.scroll-progress,.back-top,.mobile-call,.urgency-banner,.roofle-trigger,.roofle-widget,iframe[src*="roofle"]{display:none!important}
  body{font-size:12pt;color:#000;background:#fff}
  body::before{display:none}
  .page-hero{min-height:auto;padding:24pt 0;background:#1d1d1f!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .page-hero *{color:#fff!important;-webkit-text-fill-color:#fff!important;text-shadow:none!important}
  a[href]::after{content:" (" attr(href) ")";font-size:9pt;color:#666}
  nav a::after,footer a::after,.btn::after,.nav-pill::after{content:""!important}
  .sec,.sec-sm{padding:18pt 0}
  .cta-banner{background:#1d1d1f!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .cta-banner *{color:#fff!important}
  .rv,.rv-scale{opacity:1!important;transform:none!important;filter:none!important}
}

/* --- Phase 5: Skip-to-content (a11y) --- */
.skip-link{position:absolute;top:-100%;left:16px;z-index:10000;padding:12px 24px;background:var(--red);color:#fff;font-weight:600;font-size:14px;border-radius:0 0 8px 8px;text-decoration:none;transition:top .2s}
.skip-link:focus{top:0}

/* --- prefers-reduced-motion --- */
@media(prefers-reduced-motion:reduce){
  .rv,.rv-scale{transition:none!important;opacity:1!important;transform:none!important;filter:none!important}
  .d1,.d2,.d3,.d4,.d5,.d6{transition-delay:0s!important}
  body::before{display:none}
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}

/* --- Responsive: mobile call + nav phone --- */
@media(max-width:1000px){
  .nav-phone{display:none}
  .mobile-call{display:flex}
}

/* --- Phase 6: Roofle widget mobile adjustments --- */
@media(max-width:768px){
  .quick-quote-drag-handle{transform:scale(.75)!important;transform-origin:right center!important}
  .quick-quote-callout{transform:scale(.5)!important;transform-origin:right bottom!important}
}
@media(max-width:480px){
  .quick-quote-drag-handle{transform:scale(.65)!important}
  .quick-quote-callout{transform:scale(.4)!important}
}

/* --- Shared JS init (inline) handled per page --- */

/* --- Blog author byline --- */
.blog-author{display:flex;gap:20px;align-items:flex-start;padding:32px 36px;margin:48px 0 0;background:var(--grey-light);border-radius:var(--r-card)}
.blog-author-avatar{width:56px;height:56px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-weight:700;font-size:20px}
.blog-author-name{font-weight:700;font-size:16px;margin-bottom:4px}
.blog-author-name a{color:var(--ink-1);text-decoration:none}
.blog-author-name a:hover{text-decoration:underline}
.blog-author-desc{font-size:14px;color:var(--ink-3);line-height:1.5}
@media(max-width:600px){.blog-author{flex-direction:column;align-items:center;text-align:center;padding:24px 20px}}