/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --red:#d5160c; --red-deep:#a81009; --red-glow:rgba(213,22,12,.18);
  --ink:#1d1d1f; --ink-2:#424245; --ink-3:#595959;
  --bg:#fff; --bg-2:#f5f5f7; --bg-3:#e8e8ed;
  --line:rgba(0,0,0,.08);
  --nav-h:76px;
  --r:20px; --r-sm:12px; --r-pill:980px;
  --sp-sec:    clamp(48px, 6vw, 72px);
  --sp-sec-sm: clamp(32px, 4.5vw, 48px);
  --sp-side:   max(20px, 5vw);
  --sp-card:   clamp(24px, 4vw, 36px);
  --sp-gap:    clamp(12px, 2.5vw, 16px);
  --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:0 2px 16px rgba(0,0,0,.06),0 20px 48px rgba(0,0,0,.08);
  --sh-up:0 6px 28px rgba(0,0,0,.1),0 32px 72px rgba(0,0,0,.12);
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","Helvetica Neue",Arial,sans-serif;
}

/* ── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);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,svg{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}

/* ── TYPE ───────────────────────────────────────────────── */
.eyebrow{font-size:clamp(12px, 0.5vw + 9px, 13px);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red)}
.h1{font-size:clamp(52px,7vw,100px);font-weight:700;letter-spacing:-.04em;line-height:1.01;color:var(--ink)}
.h2{font-size:clamp(36px,4.8vw,64px);font-weight:700;letter-spacing:-.035em;line-height:1.04;color:var(--ink)}
.h3{font-size:clamp(22px,2.8vw,36px);font-weight:700;letter-spacing:-.025em;line-height:1.1;color:var(--ink)}
.h4{font-size:clamp(18px,2vw,24px);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.body-lg{font-size:clamp(16px, 1.2vw + 12px, 19px);line-height:1.65;color:var(--ink-3)}
.body-md{font-size:clamp(15px, 1vw + 11px, 16px);line-height:1.6;color:var(--ink-3)}
.body-sm{font-size:clamp(13px, 0.5vw + 11px, 14px);line-height:1.55;color:var(--ink-3)}
.white{color:#fff!important}
.red{color:var(--red)!important}
.accent{color:var(--red)}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:clamp(12px, 1.5vw, 14px) clamp(20px, 3vw, 28px);border-radius:var(--r-pill);font-size:clamp(14px, 1vw + 11px, 15px);font-weight:600;border:none;transition:transform .2s var(--ease),box-shadow .2s,background .2s;letter-spacing:-.01em;white-space:nowrap;min-height:48px}
.btn:hover{transform:scale(1.035)}
.btn:active{transform:scale(.97);transition-duration:.1s}
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 20px var(--red-glow)}
.btn-red:hover{background:var(--red-deep);box-shadow:0 8px 32px rgba(213,22,12,.35)}
.btn-outline{background:transparent;color:var(--red);border:1.5px solid var(--red)}
.btn-outline:hover{background:var(--red);color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#2d2d2f}
.btn-ghost{background:rgba(255,255,255,.13);color:#fff;border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(12px)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-white{background:#fff;color:var(--red)}
.btn-white:hover{background:#f0f0f0}

/* ── REVEAL ─────────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.rv.vis{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}
/* Scale-in reveal */
.rv-scale{opacity:0;transform:scale(.94);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.rv-scale.vis{opacity:1;transform:scale(1)}
/* rv-fb fallback handled via JS timeout */
/* Enhanced button glow */
.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}
/* Phase 2: selection + focus */
::selection{background:rgba(213,22,12,.15);color:var(--ink)}
: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 3: tight tracking + scroll progress */
html{scroll-behavior:smooth}
.h1{letter-spacing:-.03em}
.h2{letter-spacing:-.02em}
.h3{letter-spacing:-.015em}
.h4{letter-spacing:-.01em}
.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 5: skip-to-content */
.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}
/* Phase 4: back-to-top + print */
.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,transform .3s,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}}
@media print{#nav,.hamburger,.scroll-progress,.back-top,.mobile-call,.roofle-trigger,.roofle-widget,iframe[src*="roofle"]{display:none!important}body{font-size:12pt;color:#000;background:#fff}body::before{display:none}a[href]::after{content:" (" attr(href) ")";font-size:9pt;color:#666}nav a::after,footer a::after,.btn::after{content:""!important}.rv,.rv-scale{opacity:1!important;transform:none!important}}
@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}}


/* Hero entrance: blur-up reveal */
#hero .rv{transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
#hero .rv.vis{opacity:1;transform:none}

/* ── NAV ────────────────────────────────────────────────── */
#nav{
  position:fixed;inset:0 0 auto;z-index:900;height:var(--nav-h);
  background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 max(20px,4vw);transition:background .3s,border-color .3s;
}
#nav.scrolled{background:rgba(255,255,255,.96);box-shadow:0 1px 0 var(--line)}
#nav.on-dark{background:rgba(0,0,0,.75);border-bottom-color:rgba(255,255,255,.08)}
.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}
.nav-links a{font-size:13px;font-weight:500;color:var(--ink-2);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--red)}
#nav.on-dark .nav-links a{color:rgba(255,255,255,.6)}
#nav.on-dark .nav-links a:hover{color:#fff}
.nav-phone{display:inline-flex;align-items:center;gap:5px;font-size:13px!important;font-weight:600!important;white-space:nowrap;letter-spacing:-.01em}
.nav-phone svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2;flex-shrink:0}
.nav-cta{background:var(--red)!important;color:#fff!important;padding:8px 18px;border-radius:var(--r-pill);font-size:12px!important;font-weight:700!important;transition:background .2s,transform .15s!important}
.nav-cta:hover{background:var(--red-deep)!important;transform:scale(1.05)!important}
.ham{display:none;flex-direction:column;gap:5px;padding:4px;background:none;border:none}
.ham span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
#nav.on-dark .ham span{background:#fff}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE NAV ─────────────────────────────────────────── */
#mob{
  display:none;position:fixed;inset:var(--nav-h) 0 0;z-index:850;
  background:rgba(255,255,255,.97);backdrop-filter:blur(24px);
  padding:24px 24px 40px;flex-direction:column;gap:4px;
  transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:transform .3s var(--ease),opacity .3s;
}
#mob.open{display:flex;transform:none;opacity:1;pointer-events:all}
#mob a{font-size:clamp(17px, 2vw + 12px, 20px);font-weight:600;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--bg-2);transition:color .2s,padding-left .2s;display:flex;align-items:center;min-height:48px}
#mob a:hover{color:var(--red);padding-left:6px}
#mob .mob-cta{background:var(--red);color:#fff;text-align:center;border-radius:var(--r-pill);padding:16px!important;margin-top:12px;border:none!important}
/* 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(--bg-2);color:var(--red)}
.dd li a::after{display:none!important}
#nav.on-dark .dd{background:rgba(0,0,0,.88);border-color:rgba(255,255,255,.08)}
#nav.on-dark .dd li a{color:rgba(255,255,255,.7)}
#nav.on-dark .dd li a:hover{background:rgba(255,255,255,.08);color:#fff}
.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:rgba(245,245,247,.8);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.on-dark .dd-group{border-right-color:rgba(255,255,255,.08)}
#nav.on-dark .dd-group a{color:rgba(255,255,255,.6)}
#nav.on-dark .dd-group a:hover{background:rgba(255,255,255,.08);color:#fff}
#nav.on-dark .dd-county{color:rgba(255,255,255,.9)!important}
/* Mobile accordion */
.mob-section{border-bottom:1px solid var(--bg-2)}
.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,20px);font-weight:600;color:var(--ink);padding:14px 0;cursor:pointer;min-height:48px;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:12px;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}

/* ── HERO ───────────────────────────────────────────────── */
#hero{
  min-height:100svh;background:#0a0a0a;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  padding:calc(var(--nav-h) + 60px) 0 80px;
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  pointer-events:none;z-index:0;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.65) 0%,rgba(0,0,0,.55) 40%,rgba(0,0,0,.75) 100%);
}
.hero-grid{
  position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 75% 75% at 50% 40%,#000 30%,transparent 100%);
  pointer-events:none;
}
.hero-glow{
  position:absolute;top:-120px;left:50%;transform:translateX(-50%);z-index:1;
  width:min(900px, 200vw);height:min(700px, 150vw);
  background:radial-gradient(ellipse,rgba(213,22,12,.18) 0%,transparent 65%);
  pointer-events:none;
}
.hero-glow::after{content:'';position:absolute;top:40%;left:60%;width:50%;height:50%;background:radial-gradient(ellipse,rgba(255,140,50,.06) 0%,transparent 65%);pointer-events:none}
.hero-body{
  position:relative;z-index:2;max-width:1040px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:0;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-pill);padding:6px 16px;
  font-size:12px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.55);
  margin-bottom:28px;
}
.hero-eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red)}
.hero-h1{font-size:clamp(56px,8vw,108px);font-weight:700;letter-spacing:-.05em;line-height:.97;color:#fff;margin-bottom:28px;background:linear-gradient(180deg,#fff 20%,rgba(255,255,255,.75) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-h1 em{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}
.hero-sub{font-size:clamp(16px, 1.5vw + 12px, 21px);line-height:1.6;color:rgba(255,255,255,.6);max-width:980px;margin:0 auto clamp(28px, 4vw, 40px)}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:56px}
.hero-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.trust-chip{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-pill);padding:8px 16px;
  font-size:13px;font-weight:500;color:rgba(255,255,255,.55);
  transition:background .2s,border-color .2s;
}
.trust-chip:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.2)}
.trust-chip svg{flex-shrink:0;opacity:.7}

/* manufacturer badges (inside hero) */
.mfg-inner{display:flex;align-items:center;justify-content:center;gap:clamp(10px,2vw,24px);flex-wrap:nowrap;padding:32px 0 0;margin-top:16px;width:100%}
.mfg-inner img{flex:0 1 auto;height:auto;max-height:70px;width:auto;max-width:28%;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));opacity:1}
@media(min-width:1061px){.mfg-inner img{max-height:120px;max-width:none}.mfg-inner img:last-child{max-height:none;max-width:240px}}
@media(max-width:600px){.mfg-inner{padding:20px 0 0;gap:12px}.mfg-inner img{max-height:40px}}

/* scroll cue */
.scroll-cue{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.25);
}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:scroll-pulse 2.5s ease-in-out infinite}
@keyframes scroll-pulse{0%{opacity:.2;transform:scaleY(1)}40%{opacity:.9;transform:scaleY(1.05)}100%{opacity:.2;transform:scaleY(1)}}

/* ── STATS BAR ──────────────────────────────────────────── */
.stats-bar{
  background:#fff;border-bottom:1px solid var(--line);
  overflow:hidden;padding:0;position:relative;
}
.stats-bar::before,.stats-bar::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.stats-bar::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.stats-bar::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.stats-track{
  display:flex;gap:0;
  animation:marquee 30s linear infinite;
  width:max-content;
}
.stats-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.stat-item{
  display:flex;align-items:center;gap:12px;
  padding:20px 40px;border-right:1px solid var(--line);
  flex-shrink:0;
}
.stat-num{font-size:24px;font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1}
.stat-num sup{font-size:14px;color:var(--red);font-weight:700;vertical-align:super}
.stat-lbl{font-size:12px;color:var(--ink-3);font-weight:500;white-space:nowrap}

/* ── SECTION SHELL ──────────────────────────────────────── */
.sec{padding:var(--sp-sec) var(--sp-side)}
.sec-sm{padding:var(--sp-sec-sm) var(--sp-side)}
.sec-hdr{max-width:680px}
.sec-hdr.ctr{margin:0 auto;text-align:center}
.sec-hdr .eyebrow{margin-bottom:14px}
.sec-hdr .body-lg{margin-top:18px}
.sec-hdr.ctr .body-lg{margin:18px auto 0;max-width:500px}

/* ── SERVICES BENTO ─────────────────────────────────────── */
#services{background:#fff}
.bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:auto;
  gap:var(--sp-gap);
  margin-top:56px;
}
.bc{
  border-radius:var(--r);padding:var(--sp-card);
  transition:transform .25s var(--ease),box-shadow .25s;
  position:relative;overflow:hidden;
}
.bc:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08),0 16px 40px rgba(0,0,0,.1)}
.bc-light{background:var(--bg-2);color:var(--ink)}
.bc-dark{background:#111;color:#fff}
.bc-red{background:var(--red);color:#fff}
.bc-black{background:#000;color:#fff}
/* Ambient glow on dark bento cards */
.bc-dark::after,.bc-black::after{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 70%,rgba(213,22,12,.06) 0%,transparent 60%);pointer-events:none;transition:opacity .3s}
.bc-dark:hover::after,.bc-black:hover::after{opacity:1.5}
.bc .tag{
  display:inline-flex;align-items:center;
  border-radius:var(--r-pill);padding:4px 12px;
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:16px;
}
.tag-w{background:rgba(255,255,255,.12);color:#fff}
.tag-r{background:rgba(213,22,12,.15);color:#b01209}
.tag-g{background:var(--bg-3);color:#555}
.bc .icon{font-size:36px;margin-bottom:14px;display:block}
.bc .bc-title{font-size:clamp(22px,2.4vw,30px);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-top:0;margin-bottom:12px}
.bc .bc-desc{font-size:14px;line-height:1.65;opacity:.65}
.bc .bc-link{
  display:inline-flex;align-items:center;gap:5px;
  margin-top:20px;font-size:13px;font-weight:700;
  transition:gap .2s;
}
.bc-dark .bc-link,.bc-black .bc-link,.bc-red .bc-link{color:#fff}
.bc-dark .bc-link:hover,.bc-black .bc-link:hover,.bc-red .bc-link:hover{color:#fff;gap:10px}
.bc-light .bc-link{color:var(--red)}
.bc-light .bc-link:hover{gap:10px}
.bc[data-n]::after{
  content:attr(data-n);
  position:absolute;bottom:-16px;right:16px;
  font-size:100px;font-weight:900;letter-spacing:-.06em;line-height:1;
  opacity:.06;pointer-events:none;color:inherit;
}

/* Bento grid placement */
.g-span-5{grid-column:span 5}
.g-span-4{grid-column:span 4}
.g-span-3{grid-column:span 3}
.g-span-7{grid-column:span 7}
.g-span-6{grid-column:span 6}
.g-span-8{grid-column:span 8}
.g-row-2{grid-row:span 2}

/* ── WHY US ─────────────────────────────────────────────── */
#trust{background:var(--bg-2)}
.trust-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px, 7vw, 80px);align-items:center;
}
.cred-list{display:flex;flex-direction:column;gap:6px;margin-top:48px}
.cred-row{
  display:flex;align-items:center;gap:18px;
  background:#fff;border-radius:16px;padding:20px 24px;
  border:1px solid transparent;
  transition:border-color .2s,transform .2s;
}
.cred-row:hover{border-color:var(--red);transform:translateX(4px)}
.cred-ic{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-size:20px;
}
.cred-title{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:2px}
.cred-sub{font-size:13px;color:var(--ink-3)}
.cred-badge{
  margin-left:auto;flex-shrink:0;
  background:rgba(213,22,12,.1);color:var(--red);
  font-size:12px;font-weight:800;padding:4px 10px;border-radius:var(--r-pill);
}

/* Stats ring visual */
.ring-wrap{display:flex;flex-direction:column;align-items:center;gap:32px}
.ring{
  position:relative;width:260px;height:260px;
  border-radius:50%;border:1.5px solid var(--bg-3);
  display:flex;align-items:center;justify-content:center;
}
.ring::before{
  content:'';position:absolute;inset:-16px;border-radius:50%;
  border:1px solid var(--bg-3);
}
.ring-dot{
  position:absolute;top:-8px;left:50%;transform:translateX(-50%);
  width:16px;height:16px;border-radius:50%;background:var(--red);
  box-shadow:0 0 16px var(--red);
}
.ring-center{text-align:center}
.ring-num{font-size:64px;font-weight:800;letter-spacing:-.05em;color:var(--ink);line-height:1}
.ring-lbl{font-size:14px;color:var(--ink-3);margin-top:4px}
.ring-stats{display:flex;gap:32px}
.ring-stat{text-align:center}
.ring-stat-n{font-size:32px;font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1}
.ring-stat-n span{font-size:18px;color:var(--red)}
.ring-stat-l{font-size:12px;color:var(--ink-3);margin-top:4px}
/* Ring shimmer */
.ring::after{content:'';position:absolute;inset:-1px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0%,rgba(213,22,12,.12) 10%,transparent 20%);animation:ring-spin 8s linear infinite}
@keyframes ring-spin{to{transform:rotate(360deg)}}

/* ── PROCESS ────────────────────────────────────────────── */
#process{background:#fff}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-gap);margin-top:64px;position:relative}
.steps::before{
  content:'';position:absolute;top:32px;left:calc(12.5% + 16px);right:calc(12.5% + 16px);
  height:1px;background:linear-gradient(to right,transparent,var(--bg-3) 20%,var(--bg-3) 80%,transparent);
  z-index:0;
}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:1}
.step-num{
  width:64px;height:64px;border-radius:50%;
  background:var(--bg-2);border:1.5px solid var(--bg-3);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:var(--ink-3);letter-spacing:.04em;
  transition:background .3s,border-color .3s,color .3s;
  margin-bottom:20px;
}
.step:hover .step-num{background:var(--red);border-color:var(--red);color:#fff}
.step-title{font-size:17px;font-weight:700;color:var(--ink);margin-top:0;margin-bottom:8px}
.step-desc{font-size:14px;color:var(--ink-3);line-height:1.6;max-width:200px}

/* ── MATERIALS ──────────────────────────────────────────── */
#materials{background:var(--bg-2)}
.mat-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px, 7vw, 80px);align-items:start}
.mat-sticky{position:sticky;top:calc(var(--nav-h) + 24px)}
.mat-list{display:flex;flex-direction:column;gap:4px;margin-top:56px}
.mat-row{
  display:flex;align-items:center;gap:18px;padding:20px 24px;
  border-radius:14px;border:1.5px solid transparent;background:#fff;
  transition:border-color .2s,transform .2s,box-shadow .2s;cursor:pointer;
}
.mat-row:hover,.mat-row.active{border-color:var(--red);transform:translateX(4px);box-shadow:0 4px 16px var(--red-glow)}
.mat-icon{font-size:28px;flex-shrink:0;width:44px;text-align:center}
.mat-name{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:3px}
.mat-life{font-size:13px;color:var(--ink-3)}
.mat-arrow{margin-left:auto;font-size:18px;color:var(--bg-3);transition:color .2s,transform .2s}
.mat-row:hover .mat-arrow,.mat-row.active .mat-arrow{color:var(--red);transform:translateX(4px)}

/* ── REVIEWS ────────────────────────────────────────────── */
#reviews{background:#fff}
.reviews-hdr{text-align:center;margin-bottom:56px}
.rev-rating{font-size:72px;font-weight:800;letter-spacing:-.06em;color:var(--ink);line-height:1;margin:12px 0 8px}
.rev-rating span{color:var(--red)}
.rev-meta{font-size:14px;color:var(--ink-3)}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-gap)}
.rev-card{
  background:var(--bg-2);border-radius:var(--r);padding:var(--sp-card);
  transition:transform .25s var(--ease),box-shadow .25s;border:1px solid transparent;
}
.rev-card:hover{transform:translateY(-5px);box-shadow:var(--sh-up);border-color:var(--line);background:#fff}
/* Featured first review — bento span */
.rev-featured{
  grid-column:span 2;grid-row:span 2;
  padding:0;display:flex;flex-direction:column;
  border:1.5px solid rgba(213,22,12,.12);position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(213,22,12,.03) 0%,var(--bg-2) 40%);
}
/* Project photo area */
.rev-featured-img{
  width:100%;height:220px;overflow:hidden;position:relative;
  background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);
}
.rev-featured-img img{width:100%;height:100%;object-fit:cover;display:block}
.rev-featured-img-label{
  position:absolute;bottom:12px;left:16px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#fff;font-size:12px;font-weight:600;letter-spacing:.03em;
  padding:6px 14px;border-radius:var(--r-pill);
}
/* Text area below image */
.rev-featured-body{padding:32px 40px 40px;display:flex;flex-direction:column;flex:1}
.rev-featured .rev-stars{font-size:16px;letter-spacing:3px;margin-bottom:16px}
.rev-featured .rev-text{font-size:18px;line-height:1.75}
.rev-featured .rev-author{margin-top:auto;padding-top:24px}
.rev-featured .avatar{width:48px;height:48px;font-size:17px}
.rev-featured .rev-name{font-size:16px}
.rev-stars{color:var(--red);font-size:14px;letter-spacing:2px;margin-bottom:14px}
.rev-text{font-size:15px;line-height:1.7;color:var(--ink);font-style:italic}
.rev-author{
  display:flex;align-items:center;gap:12px;
  margin-top:24px;padding-top:18px;border-top:1px solid var(--bg-3);
}
.avatar{
  width:40px;height:40px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:800;color:#fff;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);font-weight:600;letter-spacing:.03em}

/* ── COVERAGE ───────────────────────────────────────────── */
#coverage{background:var(--bg-2)}
.cov-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px, 7vw, 80px);align-items:center}
.city-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.city-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:#fff;border:1px solid var(--bg-3);border-radius:var(--r-pill);
  padding:8px 16px;font-size:13px;font-weight:500;color:var(--ink-2);
  transition:border-color .2s,color .2s,transform .15s;
}
.city-pill:hover{border-color:var(--red);color:var(--red);transform:scale(1.04)}
.city-dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex-shrink:0}

/* Interactive Map */
.cov-map{
  background:#fff;border-radius:var(--r);
  box-shadow:var(--sh);position:relative;overflow:hidden;
  aspect-ratio:4/5;
}
#service-map{width:100%;height:100%}
.cov-map-badge{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:600;background:rgba(213,22,12,.92);color:#fff;font-size:12px;font-weight:700;letter-spacing:.04em;padding:8px 20px;border-radius:var(--r-pill);backdrop-filter:blur(8px);pointer-events:none;white-space:nowrap}
/* Override Leaflet controls for clean look */
.cov-map .leaflet-control-attribution{font-size:9px;opacity:.5}
.cov-map .leaflet-control-zoom a{width:30px;height:30px;line-height:30px;font-size:16px;border-radius:8px;color:var(--ink)}
.city-tip{font-family:var(--ff);font-size:12px;font-weight:600;padding:4px 10px;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.city-marker{background:none!important;border:none!important}

/* ── INTERNAL LINK CARDS (blog / related) ───────────────── */
.il-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--sp-gap)}
.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(--bg-2);border-radius:var(--r);padding:var(--sp-card);text-decoration:none;color:var(--ink);transition:background .2s,transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s}
.il-card:hover{background:#e8e8ed;transform:translateY(-4px);box-shadow:0 4px 20px rgba(0,0,0,.1),0 32px 80px rgba(0,0,0,.13)}
.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}
@media(max-width:900px){.il-grid>.il-card{flex:0 1 calc((100% - var(--sp-gap))/2)}}
@media(max-width:600px){.il-grid>.il-card{flex:0 1 100%}}

/* Blog bento — homepage magazine layout */
.blog-bento{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:var(--sp-gap)}
.blog-bento>.il-card:first-child{
  grid-row:span 2;padding:40px;background:linear-gradient(135deg,rgba(213,22,12,.04) 0%,var(--bg-2) 60%);border:1.5px solid rgba(213,22,12,.12);
}
.blog-bento>.il-card:first-child .il-icon{font-size:40px;margin-bottom:8px}
.blog-bento>.il-card:first-child .il-label{font-size:20px}
.blog-bento>.il-card:first-child .il-desc{font-size:16px;line-height:1.65}
.blog-bento>.il-card:first-child .il-arrow{font-size:14px;margin-top:12px}
@media(max-width:900px){.blog-bento{grid-template-columns:1fr;grid-template-rows:auto}.blog-bento>.il-card:first-child{grid-row:auto;padding:32px}.blog-bento>.il-card:first-child .il-label{font-size:17px}.blog-bento>.il-card:first-child .il-desc{font-size:14px}}

/* ── CTA BAND ───────────────────────────────────────────── */
#cta{background:linear-gradient(135deg,#d5160c 0%,#b5120a 40%,#a81009 100%);padding:var(--sp-sec) var(--sp-side);text-align:center;position:relative;overflow:hidden}
#cta::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 .h2{color:#fff;position:relative;z-index:1}
#cta .body-lg{color:rgba(255,255,255,.65);margin:16px auto 0;max-width:480px;position:relative;z-index:1}
/* CTA shimmer (matches inner-page .cta-banner shimmer) */
#cta::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%)}}

.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:40px;position:relative;z-index:1}

/* ── CONTACT ────────────────────────────────────────────── */
#contact{background:#fff}
.contact-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px, 7vw, 80px);align-items:start}
.contact-ways{display:flex;flex-direction:column;gap:12px;margin-top:40px}
.way{
  display:flex;align-items:center;gap:16px;
  background:var(--bg-2);border-radius:14px;padding:18px 22px;
  border:1.5px solid transparent;transition:border-color .2s,transform .2s;
}
.way:hover{border-color:var(--red);transform:translateX(4px)}
.way-ic{font-size:22px;width:44px;text-align:center;flex-shrink:0}
.way-label{font-size:12px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.way-val{font-size:16px;font-weight:700;color:var(--ink)}

/* Form */
.form-card{background:var(--bg-2);border-radius:var(--r);padding:var(--sp-card);border:1px solid var(--line)}
.form-title{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.03em;margin-bottom:28px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fg label{font-size:clamp(12px, 0.5vw + 11px, 13px);font-weight:600;color:var(--ink-2)}
.fg input,.fg textarea,.fg select{
  background:#fff;border:1.5px solid var(--bg-3);border-radius:10px;
  padding:clamp(11px, 1.5vw, 13px) 16px;font-size:16px;color:var(--ink);outline:none;
  transition:border-color .2s,box-shadow .2s;font-family:var(--font);
  -webkit-appearance:none;
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--bg-3);color:var(--ink-3)}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--red);box-shadow:0 0 0 2px rgba(213,22,12,.12)}
.fg textarea{resize:none;height:108px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-submit{
  width:100%;background:var(--red);color:#fff;border:none;
  padding:16px;border-radius:var(--r-pill);font-size:17px;font-weight:700;
  cursor:pointer;margin-top:8px;
  transition:background .2s,transform .2s,box-shadow .2s;letter-spacing:-.01em;
}
.form-submit:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 8px 28px var(--red-glow)}
.form-note{font-size:12px;color:var(--ink-3);text-align:center;margin-top:12px}

/* ── FOOTER ─────────────────────────────────────────────── */
#footer{background:linear-gradient(180deg,#050505 0%,#000 100%);padding:clamp(40px, 6vw, 60px) var(--sp-side) clamp(20px, 3vw, 28px)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px, 4vw, 36px);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}
.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:#fff;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:#fff}
.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)}
.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:#fff;transform:scale(1.1)}
.ft-social a svg{width:18px;height:18px}
.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:#fff}
.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:#fff}
.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:#fff;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-certs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.f-badge{background:#110f0f;border:1px solid rgba(255,255,255,.09);border-radius:var(--r-pill);padding:4px 11px;font-size:12px;color:rgba(255,255,255,.45);font-weight:600}
.f-badge-gold{background:#240806;border-color:#3d1210;color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:12.5px;color:rgba(255,255,255,.6)}
.footer-parent-line{text-align:center;padding:14px 0 0;font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.01em}
.footer-parent-line strong{font-weight:600;color:rgba(255,255,255,.7)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.2);transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.55)}

/* ── ULTRA-WIDE CONTAINMENT ─────────────────────────────── */
.sec > *,.sec-sm > *{max-width:1200px;margin-left:auto;margin-right:auto}
.bento,.rev-grid,.il-grid,.blog-bento,.steps,.trust-inner,.mat-inner,.cov-inner,.contact-inner{max-width:1200px;margin-left:auto;margin-right:auto}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1060px){
  .nav-links{display:none}
  .ham{display:flex}
  .trust-inner,.mat-inner,.cov-inner,.contact-inner{grid-template-columns:1fr;gap:48px}
  .mat-sticky{position:static}
  .rev-grid{grid-template-columns:repeat(2,1fr)}
  .rev-featured{grid-column:span 2;grid-row:auto}
  .rev-featured-img{height:180px}
  .rev-featured-body{padding:28px 32px 32px}
  .rev-featured .rev-text{font-size:16px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .steps::before{display:none}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
  .bento{grid-template-columns:repeat(6,1fr)}
  .g-span-5,.g-span-7,.g-span-8{grid-column:span 6}
  .g-span-4,.g-span-6{grid-column:span 3}
  .g-span-3{grid-column:span 3}
  .g-row-2{grid-row:auto}
}
@media(max-width:640px){
  /* Hero */
  .hero-eyebrow{font-size:11px;padding:5px 12px;max-width:90vw;text-align:center}
  .hero-h1{font-size:clamp(44px,12vw,64px);letter-spacing:-.045em}
  .hero-btns{flex-direction:column;align-items:stretch;width:100%;max-width:360px;margin-left:auto;margin-right:auto}
  .hero-btns .btn{width:100%;justify-content:center}
  .hero-trust{gap:6px}
  /* Services bento */
  .bento{grid-template-columns:1fr;gap:12px}
  .g-span-5,.g-span-4,.g-span-3,.g-span-7,.g-span-6,.g-span-8{grid-column:span 1}
  /* Reviews */
  .rev-grid{grid-template-columns:1fr}
  .rev-featured{grid-column:span 1;grid-row:auto}
  .rev-featured-img{height:200px}
  .rev-featured-body{padding:24px 28px 28px}
  .rev-featured .rev-text{font-size:16px}
  .rev-featured .avatar{width:40px;height:40px;font-size:15px}
  /* Process */
  .steps{grid-template-columns:1fr 1fr}
  /* Form */
  .fg-row{grid-template-columns:1fr}
  /* Contact section 2-col */
  .contact-inner{grid-template-columns:1fr!important;gap:40px!important}
  /* CTA */
  .cta-btns{flex-direction:column;align-items:stretch;width:100%;max-width:360px;margin-left:auto;margin-right:auto}
  .cta-btns .btn{justify-content:center}
  /* Footer */
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-certs{flex-wrap:wrap}
}
@media(max-width:480px){
  :root{--nav-h:68px}
  .hero-eyebrow{font-size:10px;padding:4px 10px}
  .hero-trust .trust-chip{padding:6px 12px;font-size:12px}
  .scroll-cue{display:none}
  .stat-item{padding:14px 24px}
  .stat-num{font-size:20px}
  .stat-lbl{font-size:11px}
  .steps{grid-template-columns:1fr!important}
  .cred-row{padding:14px 16px;gap:12px}
  .cred-ic{width:38px;height:38px;border-radius:10px;font-size:16px}
  .ring{width:200px;height:200px}
  .ring-num{font-size:48px}
  .form-card{padding:24px}
  .rev-featured-body{padding:20px 22px 24px}
  .ft-phone{font-size:18px}
  .ft-desc{font-size:13px}
  .bc{padding:clamp(20px, 5vw, 24px)}
  .il-card{padding:clamp(20px, 5vw, 24px)}
}

/* Sticky mobile call 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:#fff;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)}
.mobile-call svg{width:24px;height:24px;fill:#fff}
@media(max-width:1000px){#nav{justify-content:center}.nav-logo{margin-right:0}.ham,.hamburger{position:absolute;right:max(20px,4vw)}.nav-phone{display:none!important}.mobile-call{display:flex}.dd{display:none}}

/* Call-instead strip */
.call-alt{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:16px;padding:12px 20px;background:var(--bg-2);border-radius:var(--r-pill);font-size:14px;color:var(--ink-3);text-decoration:none;transition:background .2s,color .2s}
.call-alt:hover{background:var(--bg-3);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}

/* Performance: off-screen rendering & containment */
#services,#trust,#process,#materials,#reviews,#coverage,#blog,#cta,#contact,#footer{content-visibility:auto;contain-intrinsic-size:auto 600px}
.bc,.rev-card,.il-card,.step,.cred-row,.mat-row,.city-pill,.way,.fg{contain:layout style}
.stats-track{will-change:transform}
.rv{will-change:opacity,transform}

/* prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
  .rv{transition:none!important;opacity:1!important;transform:none!important}
  .d1,.d2,.d3,.d4,.d5,.d6{transition-delay:0s!important}
  html{scroll-behavior:auto}
  body::before{display:none}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
/* === MOBILE READABILITY (audit 2026-05) === */
@media(max-width:768px){
  body{font-size:17px;line-height:1.65}
  .hero-sub{font-size:17px!important;line-height:1.55!important}
  /* Section padding breathable */
  section.sec{padding-top:48px;padding-bottom:48px}
  /* Form inputs sized for older eyes + 48px tap target */
  input[type=text],input[type=email],input[type=tel],textarea,select{padding:14px 16px;min-height:48px;font-size:16px}
  /* Cap line-length on body content */
  section p,section li{max-width:65ch}
}