/* ============================================================
   NuShake Roofing — style.css
   Brand color: #febd17 (gold/yellow) — distinct from DeHart's #f25a24
   Based on DeHart/Econo family CSS structure
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --gold:#ffcd00;
  --gold-h:#e8a900;
  --gold-glow:rgba(254,189,23,.15);
  --black:#000;
  --white:#fff;
  --g50:#fafaf8;
  --g100:#f2f1ea;
  --g200:#e5e3d8;
  --g300:#ccc;
  --g400:#999;
  --g500:#6e6e6e;
  --g600:#505050;
  --g800:#161616;
  --ink:#090909;
  --gold-amber:#f5b400;
  --serif:'Archivo','Arial Black',Impact,sans-serif;
  --sans:'Archivo',system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.25,.1,.25,1);
  --ease-out:cubic-bezier(0,.55,.45,1);
  --shadow-sm:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.04);
  --shadow-warm:0 12px 40px rgba(254,189,23,.08),0 4px 12px rgba(254,189,23,.04);
  --shadow-card:0 1px 2px rgba(9,9,9,.06),0 4px 12px rgba(9,9,9,.07);
  --shadow-card-hover:0 2px 4px rgba(9,9,9,.07),0 14px 28px rgba(9,9,9,.12);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:17px;line-height:1.5;color:var(--g800);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Grain overlay */
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px}

/* — Type — */
.serif{font-family:var(--serif);font-weight:600}
.headline{font-family:var(--serif);font-weight:900;font-size:clamp(2.8rem,6.5vw,5rem);line-height:.98;letter-spacing:-.015em;text-transform:uppercase}
.subhead{font-family:var(--serif);font-weight:800;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.04;letter-spacing:-.01em;text-transform:uppercase}
.skip-link{position:absolute;left:8px;top:-48px;z-index:200;background:var(--gold);color:var(--g800);padding:12px 18px;border-radius:0 0 10px 10px;font-weight:700;font-size:.85rem;transition:top .2s}
.skip-link:focus{top:0}
/* Mobile sticky call bar (shared) */
.mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:rgba(255,255,255,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.08);padding:10px 16px}
.mob-bar-in{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:480px;margin:0 auto}
.mob-bar a{display:flex;align-items:center;justify-content:center;padding:13px;border-radius:0;font-weight:800;font-size:.82rem;text-align:center;text-decoration:none;text-transform:uppercase;letter-spacing:.02em}
.mob-bar .mb-call{color:var(--g800);border:1.5px solid var(--g200)}
.mob-bar .mb-form{background:var(--gold);color:var(--g800)}
@media(max-width:768px){.mob-bar{display:block}body{padding-bottom:70px}}
/* W3 — eyebrow rebuilt: black text + 2px yellow left bar (no yellow background). Cuts ~70% of the page-level yellow surface area. */
.eyebrow{font-family:var(--sans);font-weight:800;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);background:transparent;padding:0 0 0 12px;border-left:2px solid var(--gold);border-radius:0;display:inline-flex;align-items:center;gap:10px;margin-bottom:14px}
.eyebrow::before{display:none}
.eyebrow.on-dark{color:rgba(255,255,255,.85)}
.body-lg{font-size:clamp(1.05rem,1.5vw,1.2rem);line-height:1.65;color:var(--g500)}
.hazard-rule{height:4px;width:100%;background:var(--gold)}
.eyebrow.block{background:transparent;color:var(--ink);padding:0 0 0 12px;border-left:2px solid var(--gold);border-radius:0}
.eyebrow.block::before{display:none}

/* — Buttons — */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:800;font-size:.82rem;padding:17px 34px;border-radius:0;border:none;cursor:pointer;transition:all .25s var(--ease);text-decoration:none;letter-spacing:.04em;text-transform:uppercase}
.btn-primary{background:var(--gold);color:var(--ink);box-shadow:none}
.btn-primary:hover{background:var(--gold-h);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{background:var(--ink);color:var(--white)}
.btn-secondary:hover{background:var(--black);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--white)}
.btn-white{background:var(--white);color:var(--g800);box-shadow:var(--shadow-sm)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-light{background:rgba(255,255,255,.1);color:var(--white);border:1.5px solid rgba(255,255,255,.72);backdrop-filter:blur(8px)}
.btn-light:hover{background:rgba(255,255,255,.7);border-color:rgba(255,255,255,.4)}

/* — Layout — */
.wrap{max-width:1140px;margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.section{padding:clamp(88px,14vw,160px) 0}

/* ═══ NAV ═══ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--ink);transition:all .4s var(--ease)}
.nav.scrolled{background:var(--ink);border-bottom:2px solid var(--gold);box-shadow:0 2px 12px rgba(0,0,0,.5)}
.nav-in{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 clamp(20px,5vw,56px)}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1rem;letter-spacing:-.02em;color:var(--white)}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--white)}
.nav-cta{background:var(--gold)!important;color:var(--ink)!important;padding:11px 22px!important;border-radius:0!important;font-weight:800!important;font-size:.78rem!important;text-transform:uppercase!important;letter-spacing:.03em!important;transition:all .25s var(--ease)!important;box-shadow:none!important}
.nav-cta:hover{background:var(--gold-h)!important;transform:translateY(-1px)!important;box-shadow:0 4px 14px rgba(0,0,0,.3)!important}
.nav-phone{font-weight:700;letter-spacing:.02em;color:var(--white)!important}
.ham{display:none;background:none;border:none;cursor:pointer;padding:8px}
.ham span{display:block;width:20px;height:2px;background:var(--white);margin:4px 0;transition:.3s;border-radius:2px}
.mob-menu{position:fixed;inset:0;z-index:99;background:var(--white);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:opacity .3s}
.mob-menu.open{opacity:1;pointer-events:auto}
.mob-menu a{font-family:var(--serif);font-weight:600;font-size:1.8rem;color:var(--g800);text-transform:uppercase}
.mob-menu .mob-close{position:absolute;top:20px;right:24px;background:none;border:none;font-size:2rem;cursor:pointer;color:var(--g800)}
@media(max-width:768px){.nav-links{display:none}.ham{display:block}}

/* ═══ HERO ═══ (W2 rebuild: single-column full-bleed photo, form moved to its own section below with #quote anchor) */
.hero{min-height:88vh;max-width:none;display:grid;grid-template-columns:1fr;align-items:center;padding:140px max(clamp(24px,5vw,56px),calc((100% - 1280px)/2)) 100px;position:relative;overflow:hidden;background:var(--ink);isolation:isolate}
/* full-bleed jobsite photo with a deliberate gradient: dark-left for headline legibility, photo dominant right */
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(9,9,9,.78) 0%,rgba(9,9,9,.45) 35%,rgba(9,9,9,.18) 60%,rgba(9,9,9,.12) 100%),url('/assets/images/commercial-roofing.jpg') center/cover;z-index:-2}
/* soft top/bottom vignette for depth */
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,9,9,.25) 0%,transparent 18%,transparent 78%,rgba(9,9,9,.35) 100%);z-index:-1}
/* Lead form section: dedicated below the hero with #quote anchor — keeps form one-click accessible per chairman */
.lead-form-section{padding:clamp(56px,8vw,96px) 0;background:var(--ink);position:relative;border-top:4px solid var(--gold)}
.lead-form-section .wrap{display:grid;grid-template-columns:1fr;max-width:640px}
.lead-form-section h2{font-family:var(--serif);font-weight:900;color:var(--white);font-size:clamp(2rem,4vw,2.8rem);line-height:1;text-transform:uppercase;margin-bottom:8px}
.lead-form-section .lede{color:rgba(255,255,255,.65);font-size:1rem;margin-bottom:32px}
.lead-form-section .hero-form{margin:0}
.hero-content{padding-left:0;position:relative;z-index:1}
.hero .headline{margin-bottom:28px;color:var(--white);max-width:600px}
.hero .headline em{font-style:normal;color:var(--gold);position:relative}
.hero .headline em::after{content:'';position:absolute;bottom:1px;left:0;right:0;height:.16em;background:var(--gold);opacity:.85;border-radius:0;z-index:-1}
.hero-body{font-size:clamp(1rem,1.3vw,1.15rem);line-height:1.7;color:rgba(255,255,255,.82);max-width:520px;margin-bottom:40px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}
.hero-trust{display:flex;gap:28px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:8px;font-size:.76rem;font-weight:600;color:rgba(255,255,255,.72)}
.hero-trust-item .dot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex-shrink:0;box-shadow:0 0 8px rgba(254,189,23,.5)}
/* ghost CTA must read on the dark hero */
.hero .btn-ghost{border-color:rgba(255,255,255,.4);color:var(--white)}
.hero .btn-ghost:hover{background:var(--white);color:var(--ink);border-color:var(--white)}
.hero-form{background:#1b1b1b;border-radius:0;border:1px solid rgba(255,255,255,.1);border-top:4px solid var(--gold);padding:clamp(28px,3vw,40px);margin-right:0;position:relative;z-index:1;box-shadow:0 20px 60px rgba(0,0,0,.55)}
.hero-form::before{content:'';position:absolute;inset:-1.5px;border-radius:5px;background:linear-gradient(160deg,rgba(254,189,23,.3),transparent 50%,rgba(200,170,0,.15));z-index:-1}
.hero-form h2{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--white);margin-bottom:4px}
.hero-form .form-sub{font-size:.8rem;color:rgba(255,255,255,.4);margin-bottom:24px}
.ff{margin-bottom:14px}
.ff label{display:block;font-weight:600;font-size:.65rem;color:rgba(255,255,255,.4);letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px}
.ff input,.ff select,.ff textarea{width:100%;padding:13px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:4px;color:var(--white);font-family:var(--sans);font-size:.875rem;transition:all .25s}
.ff input::placeholder,.ff textarea::placeholder{color:rgba(255,255,255,.7)}
.ff input:focus,.ff select:focus,.ff textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.1);box-shadow:0 0 0 3px rgba(254,189,23,.55)}
.ff select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23fedc00' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.ff select option{background:var(--g800);color:var(--white)}
.ff-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-submit{width:100%;padding:15px;background:var(--gold);color:var(--ink);border:none;border-radius:0;font-family:var(--sans);font-weight:800;font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:all .3s;box-shadow:none}
.form-submit:hover{background:var(--gold-h);transform:translateY(-1px)}
.form-note{font-size:.7rem;color:rgba(255,255,255,.75);text-align:center;margin-top:10px}
.form-tel{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:14px;font-size:.8rem;color:rgba(255,255,255,.4)}
.form-tel strong{color:var(--white)}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto;padding:120px 0 60px}
  .hero::before{background:linear-gradient(rgba(9,9,9,.45),rgba(9,9,9,.48)),url('/assets/images/commercial-roofing.jpg') center/cover}
  .hero::after{background:linear-gradient(180deg,rgba(9,9,9,.28),transparent 32%,rgba(9,9,9,.5))}
  .hero-content{padding:0 clamp(20px,5vw,48px)}
  .hero-form{margin:0 clamp(20px,5vw,48px)}
  .hero .headline{font-size:clamp(2rem,8.5vw,3.1rem)}
}

/* ═══ TRUST BAR ═══ */
.trust-bar{background:var(--gold);padding:20px 0;overflow:hidden;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.trust-bar-in{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:clamp(20px,3.5vw,40px);padding:0 24px;flex-wrap:wrap}
.trust-item{display:inline-flex;align-items:center;gap:9px;font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);white-space:nowrap}
.trust-item svg{width:15px;height:15px;flex-shrink:0}
.trust-item .gold{color:var(--ink);fill:var(--ink)}
.trust-sep{width:2px;height:16px;background:rgba(0,0,0,.28);flex-shrink:0}
@media(max-width:600px){.trust-sep{display:none}.trust-bar-in{gap:14px}.trust-item{font-size:.7rem}}

/* ═══ STATS ═══ */
.stats{padding:0;position:relative}
.stats::before{display:none}
.stats .wrap{max-width:none;padding:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-radius:0;overflow:hidden;background:var(--white);box-shadow:none;border:none;border-bottom:1px solid var(--g200)}
.stat{text-align:center;padding:clamp(36px,5vw,56px) 20px;position:relative;background:var(--white);transition:all .3s var(--ease)}
.stat::after{content:'';position:absolute;top:20%;right:0;bottom:20%;width:1px;background:var(--g200)}
.stat:last-child::after{display:none}
.stat:hover{background:var(--g50)}
.stat-val{font-family:var(--serif);font-weight:800;font-size:clamp(2.6rem,5.5vw,4rem);color:var(--ink);line-height:1;letter-spacing:-.02em;margin-bottom:10px}
.stat-val span{color:var(--ink)}
.stat-label{font-size:.8rem;font-weight:400;color:var(--g500);line-height:1.5}
.stat-label strong{display:block;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--ink);margin-bottom:5px}
@media(max-width:600px){.stats-grid{grid-template-columns:1fr 1fr}.stat::after{display:none}.stat{border-bottom:1px solid var(--g100)}.stat:nth-child(odd){border-right:1px solid var(--g100)}.stat:nth-child(n+3){border-bottom:none}}

/* ═══ CAREER ARC ═══ (W1-scoped yellow diet: was full-bleed yellow gradient, now white with yellow hazard-stripe bars top+bottom) */
.career{background:var(--white);color:var(--ink);position:relative;overflow:hidden;border-top:4px solid var(--gold);border-bottom:4px solid var(--gold)}
.career::before{content:'5';position:absolute;right:-1vw;bottom:-14vw;font-family:var(--serif);font-weight:800;font-size:46vw;line-height:.8;color:var(--g100);pointer-events:none}
.career::after{content:'';position:absolute;top:-200px;right:-200px;width:500px;height:500px;background:radial-gradient(circle,rgba(0,0,0,.06),transparent 70%);pointer-events:none}
.career-in{position:relative;z-index:1}
.career-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,80px);align-items:center}
.career-text .eyebrow{margin-bottom:20px}
.career-text .eyebrow::before{display:none}
.career-h{font-family:var(--serif);font-weight:900;font-size:clamp(2.2rem,4.6vw,3.3rem);line-height:1.02;letter-spacing:-.015em;color:var(--ink);margin-bottom:22px;text-transform:uppercase}
.career-body{font-size:1.02rem;line-height:1.75;color:rgba(0,0,0,.86);margin-bottom:28px}
.career blockquote{border-left:4px solid var(--ink);padding-left:22px;margin:0;font-family:var(--serif);font-style:normal;font-weight:600;font-size:1.18rem;line-height:1.42;letter-spacing:-.01em;color:var(--ink)}
.career-attr{margin-top:18px;font-size:.78rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:rgba(0,0,0,.82)}
/* connected milestone timeline: ink blocks climbing to a white "owner" summit */
.career-timeline{display:flex;flex-direction:column;gap:0;margin-bottom:28px}
.timeline-item{display:grid;grid-template-columns:54px 1fr;gap:20px;align-items:start;padding:0 0 26px;position:relative;border-bottom:none}
.timeline-item:last-child{padding-bottom:0}
.timeline-item:not(:last-child)::before{content:'';position:absolute;left:25.5px;top:54px;bottom:0;width:3px;background:rgba(0,0,0,.32)}
.timeline-age{width:54px;height:54px;display:grid;place-items:center;background:var(--ink);color:var(--gold);font-family:var(--serif);font-weight:800;font-size:1.4rem;line-height:1;border-radius:0;border-left:none;padding:0}
.timeline-item:last-child .timeline-age{background:var(--white);color:var(--ink);box-shadow:inset 0 0 0 3px var(--ink)}
.timeline-role{font-family:var(--sans);font-weight:800;font-size:.92rem;color:var(--ink);text-transform:uppercase;letter-spacing:.02em;margin-bottom:3px}
.timeline-year{font-size:.76rem;color:rgba(0,0,0,.66)}
.owner-card{transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.owner-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(0,0,0,.28)}
@media(max-width:768px){.career-grid{grid-template-columns:1fr}.career-text{text-align:left}}

/* ═══ SERVICES ═══ */
.services{background:var(--white);position:relative}
.services::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--g200) 30%,var(--g200) 70%,transparent)}
.svc-header{text-align:center;margin-bottom:clamp(52px,7vw,80px)}
.svc-header .eyebrow{margin-bottom:16px;justify-content:center;text-align:center}
.svc-header .subhead{margin-bottom:16px}
.svc-header .body-lg{max-width:520px;margin:0 auto}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.svc{background:var(--white);border-radius:0;border:1px solid var(--g100);border-top:4px solid var(--gold);box-shadow:var(--shadow-card);transition:all .3s var(--ease);position:relative;overflow:hidden}
.svc::before{content:'';position:absolute;top:0;left:0;width:0;height:4px;background:var(--ink);transition:width .4s var(--ease)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:var(--g100);border-top-color:var(--gold)}
.svc:hover::before{width:100%}
.svc-badge{display:inline-block;padding:4px 10px;background:var(--g50);border:1px solid var(--g100);border-radius:0;font-size:.6rem;font-weight:800;color:var(--ink);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.svc-link{font-size:.8rem;font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:6px;transition:gap .3s var(--ease)}
@media(max-width:700px){.svc-grid{grid-template-columns:1fr}}

/* ═══ SERVICE AREAS ═══ (W1-scoped: was full-bleed yellow, now white with yellow hazard-stripe at top) */
.areas{background:var(--white);position:relative}
.areas::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--gold)}
.areas .body-lg{color:var(--g500)}
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.area-group{background:var(--g50);border-radius:0;padding:28px 24px;border:1px solid var(--g100);border-top:3px solid var(--gold);box-shadow:var(--shadow-card);transition:all .25s var(--ease)}
.area-group h3{font-family:var(--serif);font-size:1rem;color:var(--g800);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--g200)}
.area-group ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.area-group li{font-size:.82rem;color:var(--g600);display:flex;align-items:center;gap:6px}
.area-group li::before{content:'';width:4px;height:4px;background:var(--ink);border-radius:50%;flex-shrink:0}
.area-group li a{color:inherit;text-decoration:none;transition:color .2s}
.area-group li a:hover{color:var(--ink)}
@media(max-width:768px){.areas-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.areas-grid{grid-template-columns:1fr}}

/* ═══ WHY ═══ */
.why{background:var(--g50);position:relative}
.why::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--g200) 30%,var(--g200) 70%,transparent)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;align-items:stretch}
.why-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--g200);border-top:4px solid var(--gold);border-radius:0;padding:clamp(28px,3vw,40px);box-shadow:var(--shadow-card);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease)}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover);border-color:var(--g100);border-top-color:var(--gold)}
.why-num{width:48px;height:48px;display:grid;place-items:center;background:var(--gold);color:var(--ink);border-radius:0;font-family:var(--serif);font-weight:800;font-size:1.25rem;line-height:1;margin-bottom:20px}
.why-title{font-family:var(--sans);font-weight:800;font-size:1.05rem;line-height:1.2;text-transform:uppercase;letter-spacing:.01em;color:var(--ink);margin-bottom:10px}
.why-desc{font-size:.94rem;line-height:1.62;color:var(--g600)}
.why-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--gold);margin-bottom:20px}
.why-icon svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.why-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:20px;margin-top:clamp(40px,6vw,60px)}
.why-cta-call{font-weight:800;color:var(--ink);text-decoration:underline;text-underline-offset:3px;transition:color .2s}
.why-cta-call:hover{color:var(--ink)}
@media(max-width:600px){.why-grid{grid-template-columns:1fr}}

/* ═══ REVIEWS ═══ */
.reviews-section{background:var(--gold);position:relative}
.reviews-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--ink)}
.reviews-section .eyebrow{background:var(--ink);color:var(--gold)}
.reviews-section .body-lg{color:rgba(0,0,0,.72)}
.reviews-section .btn-primary{background:var(--ink);color:var(--gold)}
.reviews-section .btn-primary:hover{background:#000}
.reviews-section .btn-primary::after{content:'→';margin-left:2px;transition:transform .25s var(--ease)}
.reviews-section .btn-primary:hover::after{transform:translateX(4px)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.review-card{background:var(--white);border:1px solid var(--g200);border-radius:0;padding:clamp(24px,3vw,36px);transition:all .3s var(--ease)}
.review-stars{color:var(--ink);font-size:1.1rem;margin-bottom:12px}
.review-body{font-size:.88rem;line-height:1.7;color:var(--g600);margin-bottom:20px;font-style:italic}
.review-author{font-weight:700;font-size:.82rem;color:var(--g800)}
.review-location{font-size:.75rem;color:var(--g400)}
@media(max-width:700px){.reviews-grid{grid-template-columns:1fr}}

/* ═══ ROOFLE WIDGET ═══ */
/* instant-quote = bold dark "tool console" band, split layout */
.roofle-section{background:var(--ink);padding:clamp(80px,10vw,120px) 0;position:relative}
.roofle-section::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent);opacity:.7}
.roofle-grid{display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);gap:clamp(40px,5vw,72px);align-items:center}
.roofle-aside .eyebrow{justify-content:flex-start;margin-bottom:18px}
.roofle-aside .subhead{text-align:left;color:var(--white);font-size:clamp(2rem,4.2vw,3rem);line-height:1.02;letter-spacing:-.02em}
.roofle-aside .subhead em{font-style:normal;color:var(--gold)}
.roofle-body{text-align:left;color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1.65;margin:16px 0 28px;max-width:46ch}
.roofle-steps{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:14px}
.roofle-steps li{display:flex;align-items:center;gap:14px;font-weight:600;color:rgba(255,255,255,.9);font-size:.95rem}
.roofle-steps b{flex:0 0 34px;height:34px;display:grid;place-items:center;background:var(--gold);color:var(--ink);font-family:var(--serif);font-weight:800;border-radius:0}
.roofle-trust{font-size:.82rem;color:rgba(255,255,255,.55);margin:0}
.roofle-section #roofle-widget{background:var(--white);border-radius:0;box-shadow:0 24px 48px rgba(0,0,0,.45);overflow:hidden;max-width:none;margin:0}
.rq-head{display:flex;align-items:center;gap:10px;background:var(--gold);color:var(--ink);padding:13px clamp(20px,3vw,28px);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em}
.rq-head svg{width:18px;height:18px;flex-shrink:0;stroke:var(--ink);fill:none}
#roofle-embed-iZ0x37irdCNYSNt9uR3h9{padding:clamp(18px,3vw,28px)}
.roofle-fallback{color:rgba(255,255,255,.72);font-size:.9rem;margin:18px 0 0;text-align:center}
.roofle-fallback a{color:var(--gold);font-weight:700}
.roofle-fallback a:hover{text-decoration:underline}
@media(max-width:980px){.roofle-grid{grid-template-columns:1fr;gap:36px}}

/* ═══ FAMILY DISCLOSURE ═══ */
.family-strip{background:var(--white);padding:20px 0;text-align:center;border-top:1px solid var(--g200)}
.family-strip p{font-size:.8rem;color:var(--g500);display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.family-strip a{color:var(--ink);font-weight:700;transition:color .2s}
.family-strip a:hover{color:var(--ink)}
.family-strip .sep{width:4px;height:4px;background:var(--g300);border-radius:50%}

/* ═══ CTA STRIP ═══ */
.cta{background:linear-gradient(180deg,var(--gold) 0%,var(--gold-h) 100%);padding:clamp(88px,12vw,140px) 0;text-align:center;position:relative;overflow:hidden;border-bottom:5px solid var(--ink)}
.cta::before{content:'NU';position:absolute;top:50%;right:-2vw;transform:translateY(-50%);font-family:var(--serif);font-weight:900;font-size:clamp(220px,34vw,520px);line-height:.8;letter-spacing:-.04em;color:var(--ink);opacity:.05;z-index:0;pointer-events:none;white-space:nowrap}
.cta .subhead{color:var(--ink);font-size:clamp(2.4rem,5.5vw,4.2rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:18px;position:relative;z-index:1}
.cta-body{font-size:clamp(1.05rem,1.4vw,1.18rem);color:rgba(0,0,0,.82);max-width:540px;margin:0 auto 32px;position:relative;z-index:1}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.cta-proof{list-style:none;margin:26px auto 0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:8px 10px;max-width:700px;position:relative;z-index:1}
.cta-proof li{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;color:var(--ink);padding:6px 12px;border-radius:999px;background:rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.2)}
.cta-proof li::before{content:'✓';font-weight:900;font-size:.8em}
.cta-nap{margin-top:18px;font-size:.74rem;font-weight:600;line-height:1.6;color:rgba(0,0,0,.7);position:relative;z-index:1}

/* ═══ FOOTER ═══ */
.footer{background:var(--ink);padding:clamp(56px,9vw,90px) 0 0;border-top:3px solid var(--gold)}
.footer-grid{display:grid;gap:clamp(24px,2.5vw,44px);margin-bottom:48px;grid-template-columns:1.6fr 1fr 1.6fr 1.4fr 1fr}
@media(max-width:1100px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:700px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-logo{margin-bottom:20px}
.footer-logo img{height:56px;width:auto}
.footer-desc{font-size:.82rem;line-height:1.7;color:rgba(255,255,255,.6);margin-bottom:20px}
.footer-contact{display:flex;flex-direction:column;gap:8px}
.footer-contact a{display:flex;align-items:center;gap:10px;font-size:.82rem;color:rgba(255,255,255,.7);transition:color .2s}
.footer-contact a:hover{color:var(--gold)}
.footer-contact svg{width:14px;height:14px;stroke:rgba(255,255,255,.75);fill:none;stroke-width:2;flex-shrink:0}
.footer-col h4{font-weight:800;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col li a{font-size:.82rem;color:rgba(255,255,255,.7);transition:color .2s}
.footer-col li a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:32px 0;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}
.footer-bottom p,.footer-copyright{font-size:.72rem;color:rgba(255,255,255,.4);line-height:1.7;margin:0}
.footer-bottom a{color:rgba(255,255,255,.55);transition:color .2s}
.footer-bottom a:hover{color:var(--gold)}
.footer h4,.footer .footer-col-title{color:var(--gold);font-weight:800;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;margin-bottom:14px}
@media(max-width:900px){.footer-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column;text-align:center}.footer-social{justify-content:center}}
@media(max-width:420px){.footer-grid{grid-template-columns:1fr}}
/* DeWalt footer: social row, view-all links, trademark/identity bar */
.footer-social{display:flex;gap:10px;margin-top:24px}
.footer-social a{width:38px;height:38px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);border-radius:0;transition:all .2s var(--ease)}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink);transform:translateY(-2px)}
.footer-social svg{width:18px;height:18px;fill:currentColor}
.footer-viewall{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;color:var(--gold);transition:gap .2s var(--ease)}
.footer-viewall:hover{gap:10px;color:var(--white)}
.footer-trademark{font-size:.72rem;color:rgba(255,255,255,.42);line-height:1.7;max-width:none;margin-bottom:14px}
.footer-bottom-links{display:flex;gap:20px;align-items:center;justify-content:center;flex-wrap:wrap}
.footer-bottom-links a{font-size:.8rem;font-weight:600}
/* full-bleed footer: break out of the centered 1140px wrap */
.footer .wrap{max-width:none;padding-left:clamp(28px,6vw,80px);padding-right:clamp(28px,6vw,80px)}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links li a{font-size:.82rem;color:rgba(255,255,255,.72);transition:color .2s}
.footer-links li a:hover{color:var(--gold)}
.footer-links li a.hl{color:var(--gold)}

/* ═══ PAGE HEADER (inner pages) ═══ */
.page-hdr{padding:clamp(120px,16vh,150px) 0 clamp(44px,6vw,64px);text-align:left;position:relative}
.page-hdr::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--g200),var(--g200) 70%,transparent)}
.page-hdr .eyebrow{margin-bottom:16px;justify-content:flex-start;background:var(--gold);color:var(--ink);padding:6px 14px;border-radius:0}
.page-hdr h1{font-family:var(--serif);font-size:clamp(2.4rem,5.5vw,4rem);line-height:.98;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:20px}
.page-hdr h1::before{content:'';display:block;width:48px;height:5px;background:var(--gold);margin-bottom:20px}
.page-hdr .intro{font-size:clamp(1rem,1.3vw,1.12rem);line-height:1.7;color:var(--g500);max-width:640px;margin:0}
.breadcrumb{font-size:.75rem;color:var(--g400);margin-bottom:20px}
.breadcrumb a{color:var(--g500);text-decoration:none}
.breadcrumb a:hover{color:var(--ink)}

/* ═══ CONTENT LAYOUT (inner pages) ═══ */
.content{padding:0 0 clamp(88px,14vw,160px)}
.content-grid{display:grid;grid-template-columns:1fr 320px;gap:clamp(48px,7vw,96px);align-items:start}
.content-main h2{font-family:var(--serif);font-size:clamp(1.5rem,2.5vw,1.9rem);line-height:1.08;letter-spacing:-.01em;text-transform:uppercase;margin:clamp(44px,5vw,60px) 0 14px;padding-left:14px;border-left:4px solid var(--gold);color:var(--ink)}
.content-main h2:first-child{margin-top:0}
.content-main p{font-size:.95rem;line-height:1.8;color:var(--g600);margin-bottom:18px}
.content-main ul,.content-main ol{padding-left:20px;display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.content-main li{font-size:.95rem;line-height:1.7;color:var(--g600)}
@media(max-width:768px){.content-grid{grid-template-columns:1fr}}

/* ═══ SIDEBAR ═══ */
.sidebar-card{background:var(--white);border:1px solid var(--g200);border-radius:0;box-shadow:var(--shadow-card);padding:clamp(22px,2.5vw,32px);margin-bottom:20px}
.sidebar-card h3{font-family:var(--serif);font-size:1.1rem;margin-bottom:14px;color:var(--g800)}
.sidebar-card .btn{margin-bottom:10px;width:100%;justify-content:center;font-size:.82rem;padding:14px 20px}
.sidebar-card p{font-size:.8rem;color:var(--g500);margin-top:8px;line-height:1.5}
.sidebar-card ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.sidebar-card li a{font-size:.82rem;color:var(--g600);transition:color .2s}
.sidebar-card li a:hover{color:var(--ink)}

/* ═══ FAQ ═══ */
.faq-section{padding:clamp(72px,10vw,110px) 0}
/* split FAQ: sticky heading + help rail (left) · card accordion (right) */
.faq-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:clamp(36px,5vw,80px);align-items:start}
.faq-aside{position:sticky;top:110px}
.faq-aside .eyebrow{justify-content:flex-start;margin-bottom:18px}
.faq-aside .subhead{text-align:left;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.05;margin-bottom:16px}
.faq-intro{font-size:.95rem;line-height:1.6;color:var(--g600);margin-bottom:28px}
.faq-help-h{font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;color:var(--ink);margin-bottom:14px}
.faq-help .btn{width:100%;justify-content:center;margin-bottom:10px}
.faq-help-link{display:inline-block;margin-top:8px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:var(--ink)}
.faq-help-link:hover{color:var(--ink)}
.faq-list{display:flex;flex-direction:column;gap:10px;max-width:none;margin:0}
.faq-item{background:var(--white);border:1px solid var(--g200);border-left:3px solid var(--g200);border-radius:0;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.faq-item:hover{border-color:var(--g300);border-left-color:var(--gold)}
.faq-item.open{border-color:var(--ink);border-left-color:var(--gold)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--sans);font-weight:700;font-size:1.02rem;color:var(--ink);padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;transition:color .2s}
.faq-q:focus-visible{outline:3px solid var(--gold);outline-offset:-3px;border-radius:0}
.faq-q::after{content:'+';width:30px;height:30px;display:grid;place-items:center;background:var(--gold);color:var(--ink);border-radius:0;font-size:1.25rem;font-weight:800;line-height:1;flex-shrink:0;transition:background .2s,color .2s}
.faq-item.open .faq-q::after{content:'×';background:var(--ink);color:var(--gold)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:800px}
.faq-a-in{padding:0 22px 22px;font-size:.94rem;line-height:1.72;color:var(--g600)}
@media(max-width:860px){.faq-grid{grid-template-columns:1fr;gap:32px}.faq-aside{position:static}.faq-help .btn{width:auto}}
@media(prefers-reduced-motion:reduce){.faq-a,.faq-q::after{transition:none}}
.faq-cat-title{font-family:var(--serif);font-size:1.4rem;color:var(--g800);margin:48px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--g200)}
.faq-cat-title:first-of-type{margin-top:0}

/* ═══ CONTACT FORM ═══ */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(48px,7vw,96px);align-items:start}
.contact-form-wrap{background:var(--white);border:1px solid var(--g200);border-radius:0;padding:clamp(32px,4vw,48px)}
.contact-form-wrap h2{font-family:var(--serif);font-size:1.6rem;margin-bottom:8px}
.contact-form-wrap .form-desc{font-size:.88rem;color:var(--g500);margin-bottom:28px;line-height:1.6}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-info-card{background:var(--white);border:1px solid var(--g100);border-radius:0;padding:24px}
.contact-info-card h3{font-family:var(--serif);font-size:1rem;margin-bottom:12px;color:var(--g800)}
.contact-info-card a{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--g600);margin-bottom:8px;transition:color .2s}
.contact-info-card a:hover{color:var(--ink)}
.contact-info-card svg{width:16px;height:16px;stroke:var(--ink);fill:none;stroke-width:2;flex-shrink:0}
.light-form input,.light-form select,.light-form textarea{width:100%;padding:13px 16px;background:var(--g50);border:1px solid var(--g200);border-radius:4px;color:var(--g800);font-family:var(--sans);font-size:.875rem;transition:all .25s;margin-bottom:14px}
.light-form input:focus,.light-form select:focus,.light-form textarea:focus{outline:none;border-color:var(--ink);background:var(--white);box-shadow:0 0 0 3px rgba(201,172,0,.5)}
.light-form label{display:block;font-weight:600;font-size:.65rem;color:var(--g400);letter-spacing:.08em;text-transform:uppercase;margin-bottom:5px}
.light-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9ac00' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer}
.light-form-submit{width:100%;padding:15px;background:var(--gold);color:var(--g800);border:none;border-radius:0;font-family:var(--sans);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .3s;box-shadow:0 2px 12px rgba(254,189,23,.3)}
.light-form-submit:hover{background:var(--gold-h);transform:translateY(-1px);box-shadow:0 6px 20px rgba(254,189,23,.4)}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* ═══ OWNERSHIP CALLOUT ═══ */
.ownership-callout{background:var(--white);border:1px solid var(--g200);border-left:3px solid var(--ink);border-radius:0;padding:20px 24px;font-size:.92rem;line-height:1.7;color:var(--g600);margin:24px 0 32px}
.ownership-callout strong{color:var(--g800);display:block;margin-bottom:8px}
.ownership-callout a{color:var(--ink);font-weight:600}

/* ═══ MAP EMBED ═══ */
.map-embed{border-radius:0;overflow:hidden;border:1px solid var(--g200);margin-top:24px}
.map-embed iframe{display:block;width:100%;height:260px;border:none}

/* ═══ CERTS STRIP ═══ */
.certs-strip{background:var(--g50);border-top:1px solid var(--g100);border-bottom:1px solid var(--g100);padding:20px 0}
.certs-strip-in{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:clamp(20px,4vw,48px);padding:0 24px;flex-wrap:wrap}
.cert-item{font-size:.72rem;font-weight:700;color:var(--g500);display:flex;align-items:center;gap:8px}
.cert-item::before{content:'✓';width:18px;height:18px;background:var(--gold);color:var(--g800);border-radius:50%;display:grid;place-items:center;font-size:.65rem;font-weight:900;flex-shrink:0}

/* ═══ MISC ═══ */
.section-hdr{text-align:center;margin-bottom:clamp(52px,7vw,80px)}
.section-hdr .eyebrow{margin-bottom:16px;justify-content:center;background:var(--gold);color:var(--ink);padding:6px 14px;border-radius:0}
.section-hdr .subhead{margin-bottom:16px}
.section-hdr .body-lg{max-width:560px;margin:0 auto}

/* — DeWalt micro-interactions & polish — */
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--gold);transition:width .25s var(--ease)}
.nav-links a:hover::after{width:100%}
.btn:active{transform:translateY(0) scale(.98)}
.area-group:hover{border-color:rgba(0,0,0,.12);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}
.review-card:hover{transform:translateY(-2px);border-color:var(--g200);box-shadow:var(--shadow-card-hover)}
.faq-q:hover::after{transform:scale(1.08)}
@media(max-width:600px){.hero{padding-top:110px}.hero-form{margin:0}.btn{width:100%;justify-content:center}.faq-q{font-size:.92rem}}

/* DeWalt amber-box labels + amber CTA band */
.svc-header .eyebrow::before,.page-hdr .eyebrow::before,.section-hdr .eyebrow::before{display:none}
.cta .btn{min-height:48px}
.cta .btn-primary{background:var(--ink)!important;color:var(--white)!important;border:2px solid var(--ink)!important}
.cta .btn-primary::after{content:'→';margin-left:2px;font-weight:800;transition:transform .25s var(--ease)}
.cta .btn-primary:hover{background:#000!important;transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.28)}
.cta .btn-primary:hover::after{transform:translateX(4px)}
.cta .btn-light{background:transparent!important;color:var(--ink)!important;border:2px solid var(--ink)!important;backdrop-filter:none!important}
.cta .btn-light:hover{background:var(--ink)!important;color:var(--white)!important;transform:translateY(-2px)}
.cta .btn:focus-visible{outline:3px solid var(--ink);outline-offset:3px}
@media(prefers-reduced-motion:reduce){.cta .btn,.cta .btn-primary::after{transition:none!important;transform:none!important}}

/* eyebrow context overrides */
.hero .eyebrow{background:transparent;color:var(--gold);padding:0}
.hero .eyebrow::before{display:inline-block;content:'';width:30px;height:3px;background:var(--gold)}
.cta .eyebrow{background:var(--ink);color:var(--gold)}

/* ═══ PROJECT GALLERY ═══ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery-item{position:relative;margin:0;overflow:hidden;border-radius:0;border:1px solid var(--g200);background:var(--g100);aspect-ratio:3/2;box-shadow:var(--shadow-card);transition:box-shadow .3s var(--ease)}
.gallery-wide{grid-column:span 1}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(9,9,9,.5));opacity:0;transition:opacity .3s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item:hover{box-shadow:inset 0 -4px 0 var(--gold),var(--shadow-card-hover)}
.gallery-item:hover::after{opacity:1}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* service-page photo band */
.svc-photo{margin:0;border-radius:0;overflow:hidden;box-shadow:var(--shadow-card-hover);aspect-ratio:16/9;background:var(--g100)}
.svc-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* manufacturer cert badges */
.cert-badge{margin-left:auto;flex-shrink:0;width:72px;height:72px;object-fit:contain;background:#fff;border-radius:0;padding:6px}
@media(max-width:520px){.cert-badge{width:56px;height:56px}}

/* ════════════════════════════════════════════════════════════
   15-AGENT PANEL REDESIGN — Reviews · Services · Areas · Why · Gallery
   (overrides appended last so same-specificity rules win by order)
   ════════════════════════════════════════════════════════════ */

/* ─── REVIEWS: split + dark proof tile + ★ watermark ─── */
.reviews-section{overflow:hidden}
.reviews-section::after{content:'★';position:absolute;left:-2vw;bottom:-12vw;font-size:40vw;line-height:.8;color:rgba(9,9,9,.05);pointer-events:none;z-index:0}
.reviews-section .wrap{position:relative;z-index:1}
.rv-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,72px);align-items:center}
.rv-lead{text-align:left}
.rv-lead .eyebrow{justify-content:flex-start}
.rv-lead .subhead{text-align:left}
.rv-lead .body-lg{max-width:48ch;margin-top:16px;color:rgba(0,0,0,.74)}
.rv-lead-cta{margin-top:28px}
.rv-lead-cta .btn-primary{background:var(--ink);color:var(--gold)}
.rv-lead-cta .btn-primary:hover{background:#000}
.rv-tile{background:var(--ink);color:var(--white);border-radius:0;padding:clamp(28px,3vw,40px);box-shadow:var(--shadow-card-hover);position:relative}
.rv-tile::before{content:'';position:absolute;top:0;left:0;width:48px;height:4px;background:var(--gold)}
.rv-tile h3{font-family:var(--serif);font-weight:800;text-transform:uppercase;font-size:1.05rem;letter-spacing:.01em;color:#fff;margin-bottom:18px}
.rv-tile ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:24px}
.rv-tile li{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;line-height:1.5;color:rgba(253,253,245,.84)}
.rv-tile li::before{content:'→';color:var(--gold);font-weight:900;flex-shrink:0}
.rv-tile li strong{color:#fff;font-weight:800}
.g-review{display:inline-flex;align-items:center;gap:12px;background:var(--white);color:var(--ink);padding:11px 22px 11px 11px;border-radius:0;font-family:var(--sans);font-weight:800;font-size:.8rem;letter-spacing:.03em;text-transform:uppercase;box-shadow:var(--shadow-card);transition:all .25s var(--ease)}
.g-review .g-mark{display:grid;place-items:center;width:34px;height:34px;background:#fff;border-radius:0;flex-shrink:0}
.g-review .g-mark svg{width:20px;height:20px;display:block}
.g-review::after{content:'→';color:var(--ink);transition:transform .25s var(--ease)}
.g-review:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}
.g-review:hover::after{transform:translateX(4px)}
@media(max-width:820px){.rv-split{grid-template-columns:1fr;gap:32px}.rv-lead,.rv-lead .subhead{text-align:center}.rv-lead .eyebrow{justify-content:center}.rv-lead .body-lg{margin-inline:auto}.rv-lead-cta{display:flex;justify-content:center}.reviews-section::after{font-size:62vw;bottom:-20vw}}

/* ─── SERVICES: icon + bold-name scan layer, demoted number ─── */
.svc{display:flex;flex-direction:column;padding:clamp(24px,3vw,34px)}
.svc-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.svc-ico{flex:0 0 30px;width:30px;height:30px;stroke:var(--ink);stroke-width:1.7;fill:none;transition:stroke .3s var(--ease)}
.svc:hover .svc-ico{stroke:var(--ink)}
.svc-name{font-family:var(--serif);font-weight:800;font-size:1.08rem;line-height:1.08;text-transform:uppercase;letter-spacing:-.005em;color:var(--ink);margin:0}
.svc-desc{font-size:.82rem;line-height:1.6;color:var(--g500);margin:0 0 16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.svc-num{position:absolute;top:14px;right:16px;font-size:.62rem;font-weight:800;color:var(--g500);letter-spacing:.1em;opacity:.4;margin:0}
.svc-link{margin-top:auto;font-size:.78rem;font-weight:800;color:var(--ink);text-transform:uppercase;letter-spacing:.03em;display:inline-flex;align-items:center;gap:7px}
.svc-link::after{content:'→';transition:transform .3s var(--ease-out)}
.svc-link:hover{gap:7px}
.svc-link:hover::after{transform:translateX(4px)}
.svc--emergency{background:var(--ink);border-top-color:var(--gold)}
.svc--emergency .svc-name{color:#fff}
.svc--emergency .svc-ico,.svc--emergency:hover .svc-ico{stroke:var(--gold)}
.svc--emergency .svc-desc{color:rgba(255,255,255,.7)}
.svc--emergency .svc-link{color:var(--gold)}
.svc--emergency .svc-num{color:rgba(255,255,255,.55)}
.svc--specialty{border-color:var(--gold);background:linear-gradient(180deg,rgba(254,189,23,.06),var(--white) 44%)}
.svc--specialty .svc-badge{background:var(--gold);color:var(--ink);border:none}

/* ─── AREAS: count chips, 2-col city lists, CA watermark, hover rails ─── */
.areas{overflow:hidden}
.areas::after{content:'CA';position:absolute;right:-2vw;bottom:-13vw;font-family:var(--serif);font-weight:800;font-size:34vw;line-height:.8;color:rgba(0,0,0,.05);pointer-events:none;z-index:0}
.areas .wrap{position:relative;z-index:1}
.areas-grid{align-items:stretch}
.area-group{display:flex;flex-direction:column;position:relative;overflow:hidden}
.area-group::before{content:'';position:absolute;top:0;left:0;width:0;height:4px;background:var(--gold);transition:width .4s var(--ease);z-index:2}
.area-group:hover::before{width:100%}
.area-group h3{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:none;padding-bottom:14px;position:relative;text-transform:uppercase;letter-spacing:.01em;font-weight:800;color:var(--ink)}
.area-group h3::after{content:'';position:absolute;left:0;bottom:0;width:28px;height:3px;background:var(--ink);transition:background .25s var(--ease)}
.area-group:hover h3::after{background:var(--ink)}
.area-count{font-family:var(--sans);font-size:.6rem;font-weight:800;letter-spacing:.04em;line-height:1;background:var(--ink);color:var(--gold);padding:4px 7px;border-radius:0;flex-shrink:0}
.area-group ul{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:7px 16px;align-content:start}
.area-group li::before{border-radius:0;width:5px;height:5px;transition:transform .2s var(--ease)}
.area-group li:hover::before{transform:rotate(45deg)}
.area-group li a{border-bottom:1px solid transparent;transition:color .2s,border-color .2s}
.area-group li a:hover{color:var(--ink);border-bottom-color:var(--ink)}
.area-hq{font-size:.58rem;font-weight:800;color:var(--ink);letter-spacing:.05em;background:rgba(0,0,0,.12);padding:2px 5px;border-radius:0;margin-left:4px}
@media(max-width:420px){.area-group ul{grid-template-columns:1fr}}

/* ─── WHY: proof-tag chips + ghost numeral watermark ─── */
.why-card{position:relative;overflow:hidden;isolation:isolate}
.why-card>*{position:relative;z-index:1}
.why-ghost{position:absolute;top:-.3em;right:-.04em;z-index:0;font-family:var(--serif);font-weight:800;font-size:clamp(120px,11vw,168px);line-height:.8;letter-spacing:-.04em;color:var(--ink);opacity:.04;pointer-events:none;user-select:none;transition:transform .35s var(--ease),opacity .35s var(--ease)}
.why-card:hover .why-ghost{transform:translate(-3px,3px);opacity:.06}
.why-tag{display:inline-flex;align-items:center;gap:6px;margin:0 0 14px;padding:5px 11px;border-radius:999px;font-family:var(--sans);font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:rgba(254,189,23,.14);border:1px solid rgba(168,127,0,.35)}
.why-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--ink)}

/* ─── GALLERY: slide-up service tags, L-bracket, quote CTA ─── */
.gallery-item{border:1px solid var(--g200);transition:box-shadow .25s var(--ease),border-color .25s var(--ease)}
.gallery-item:hover{border-color:var(--g800);box-shadow:var(--shadow-card-hover)}
.gallery-item::after{background:linear-gradient(to top,rgba(9,9,9,.78) 0%,rgba(9,9,9,0) 52%);opacity:1}
.gallery-item::before{content:'';position:absolute;top:9px;left:9px;width:14px;height:14px;border-top:2px solid var(--gold);border-left:2px solid var(--gold);opacity:.7;transition:opacity .25s var(--ease);z-index:2;pointer-events:none}
.gallery-item:hover::before{opacity:1}
.gallery-tag{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;padding:12px 14px;font-family:var(--serif);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.55);border-bottom:3px solid var(--gold);z-index:3;pointer-events:none}
.gallery-tag .arrow{color:var(--gold);transition:transform .28s var(--ease)}
.gallery-item:hover .gallery-tag .arrow{transform:translateX(4px)}
@media(prefers-reduced-motion:reduce){.gallery-item,.gallery-item *{transition:none!important}.why-ghost,.reviews-section::after{transition:none}}

/* ════════════════════════════════════════════════════════════
   HOMEPAGE: full-bleed sections + 5-up services grid
   (scoped to body.home so the 60+ inner/location pages stay boxed)
   ════════════════════════════════════════════════════════════ */
/* lift the 1140px cap — sections fill the viewport (keeps existing
   .wrap side-padding; only sets max-width, so .stats/.footer padding survive) */
.home .wrap{max-width:none}
/* a touch more breathing room on the open sections at wide viewports */
.home .services .wrap,.home .areas .wrap,.home .reviews-section .wrap,
.home #recent-work .wrap,.home #about .wrap,.home .faq-section .wrap,
.home .roofle-section .wrap,.home .why .wrap,.home .section>.wrap{padding-left:clamp(24px,5vw,80px);padding-right:clamp(24px,5vw,80px)}
.home .stats .wrap{padding:0}

/* 15 services as 5 columns × 3 rows (zero orphans) */
.home .svc-grid{grid-template-columns:repeat(5,1fr);gap:14px}
.home .svc{padding:clamp(20px,1.9vw,28px)}
.home .svc-name{font-size:1rem}
.home .svc-desc{font-size:.8rem}
@media(max-width:1180px){.home .svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.home .svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:424px){.home .svc-grid{grid-template-columns:1fr}}

/* intro/body text scales with the full-bleed width instead of staying narrow */
.home .svc-header .body-lg,.home .cta-body{max-width:clamp(560px,56vw,880px)}
.home .rv-lead .body-lg,.home .roofle-body{max-width:none}

/* ════════════════════════════════════════════════════════════
   REVIEWS TRUST TILE v2 — credential ladder (7-agent redesign)
   ════════════════════════════════════════════════════════════ */
/* DeWalt "spec plate": molded surface, milled edge, full-width gold rail, ghost ✓ */
.rv-tile{background:linear-gradient(180deg,#151515 0%,var(--ink) 60%);border:1px solid rgba(168,127,0,.28);overflow:hidden;padding:clamp(30px,3vw,42px)}
.rv-tile::before{width:100%;height:6px}
.rv-tile::after{content:'\2713';position:absolute;right:-.3rem;bottom:-1.6rem;font-family:var(--serif);font-weight:800;font-size:11rem;line-height:1;color:var(--gold);opacity:.05;pointer-events:none}
.rv-tile h3{margin-bottom:6px;letter-spacing:.05em}
/* credential ladder */
.rv-tile .rv-creds{list-style:none;display:flex;flex-direction:column;gap:0;margin:0 0 4px}
.rv-tile .rv-creds li{position:relative;display:flex;align-items:flex-start;gap:13px;padding:15px 0;border-top:1px solid rgba(168,127,0,.16);color:inherit;font-size:inherit;line-height:inherit}
.rv-tile .rv-creds li::before{content:none}
.rv-tile .rv-creds li::after{content:'';position:absolute;left:-12px;top:14px;bottom:14px;width:2px;background:var(--gold);opacity:0;transition:opacity .25s var(--ease)}
.rv-tile .rv-creds li:hover::after{opacity:.7}
/* amber square icon chip — echoes .why-num */
.cred-ico{flex:0 0 auto;width:28px;height:28px;display:grid;place-items:center;background:var(--gold);color:var(--ink);border-radius:0;margin-top:1px}
.cred-ico svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
/* two-line stacked label/detail */
.cred-txt{display:flex;flex-direction:column;gap:3px;min-width:0}
.cred-label{font-family:var(--serif);font-weight:800;text-transform:uppercase;font-size:.82rem;letter-spacing:.04em;color:#fff;line-height:1.2;transition:color .2s var(--ease)}
.cred-detail{font-family:var(--sans);font-size:.82rem;line-height:1.45;color:rgba(253,253,245,.72)}
.cred-detail a{color:var(--gold);text-decoration:underline;text-underline-offset:2px;transition:color .2s var(--ease)}
.cred-detail a:hover{color:var(--gold-h)}
.rv-tile .rv-creds li:hover .cred-label{color:var(--gold)}
.rv-tile .g-review{margin-top:22px}
@media(prefers-reduced-motion:reduce){.rv-tile .rv-creds li::after{transition:none}.cred-label{transition:none}}

/* hero text was feeling compacted: looser headline leading, wider measure, more rhythm */
.hero .headline{max-width:760px;line-height:1.05;margin-bottom:32px}
.hero-body{max-width:620px;line-height:1.75;margin-bottom:44px}
.hero .eyebrow{margin-bottom:26px}

/* full-bleed nav sitewide — taller bar for the bigger gold logo, content-aligned gutters */
.nav-in{max-width:none;padding-left:clamp(24px,5vw,80px);padding-right:clamp(24px,5vw,80px);height:72px}

/* ── FAMILY-OF-COMPANIES band (homepage) — structured 3-up, not a thin gray line ── */
.home .family-strip{background:var(--white);padding:clamp(30px,4vw,46px) 0;border-top:1px solid var(--g200)}
.home .family-in{max-width:920px;margin:0 auto;padding:0 clamp(20px,5vw,40px);text-align:center}
.home .family-label{font-family:var(--sans);font-weight:800;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--g500);margin:0 0 20px;display:flex;align-items:center;justify-content:center;gap:14px}
.home .family-label::before,.home .family-label::after{content:'';height:1px;width:40px;background:var(--g200)}
.home .family-brands{list-style:none;display:flex;justify-content:center;align-items:stretch;flex-wrap:wrap;gap:0;margin:0;padding:0}
.home .fam-brand{flex:1 1 0;min-width:180px;padding:6px 26px;display:flex}
.home .fam-brand + .fam-brand{border-left:1px solid var(--g200)}
.home .fam-brand>a,.home .fam-brand{position:relative}
.home .fam-brand>a{display:flex;flex-direction:column;align-items:center;gap:3px;width:100%}
.home .fam-name{font-family:var(--serif);font-weight:800;text-transform:uppercase;font-size:1rem;letter-spacing:.01em;color:var(--ink);transition:color .2s var(--ease)}
.home .fam-area{font-size:.78rem;color:var(--g500)}
.home .fam-go{margin-top:5px;font-size:.66rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);transition:gap .2s var(--ease)}
.home .fam-brand>a:hover .fam-name{color:var(--ink)}
.home .fam-brand--current{flex-direction:column;align-items:center;gap:3px}
.home .fam-brand--current .fam-name{color:var(--ink)}
.home .fam-here{margin-top:6px;font-size:.6rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:2px 8px;border-radius:0}
@media(max-width:620px){.home .family-brands{flex-direction:column;gap:18px}.home .fam-brand{padding:0}.home .fam-brand + .fam-brand{border-left:none;border-top:1px solid var(--g200);padding-top:18px}}

/* ════════════════════════════════════════════════════════════
   MOBILE-SCROLL & TAP-TARGET UX (SEO audit P0: scroll with ease)
   ════════════════════════════════════════════════════════════ */
/* anchor jumps no longer land under the 72px fixed nav */
html{scroll-padding-top:84px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
/* tap targets ≥44px (hamburger) / ≥48px (sticky call bar) */
.ham{padding:12px;min-width:44px;min-height:44px}
.mob-bar a{min-height:48px}
/* stop iOS auto-zoom: mobile form inputs ≥16px */
@media(max-width:768px){
  .ff input,.ff select,.ff textarea,.light-form input,.light-form select,.light-form textarea,.contact-form-wrap input,.contact-form-wrap select,.contact-form-wrap textarea{font-size:16px}
  /* tighten inter-section whitespace so the long page scrolls faster on phones */
  .section{padding:clamp(52px,11vw,84px) 0}
  /* sticky call bar shouldn't collide with the open mobile menu */
  .mob-menu.open ~ .mob-bar{display:none}
}
/* floating back-to-top button (sits above the sticky call bar) */
.to-top{position:fixed;right:16px;bottom:84px;z-index:88;width:46px;height:46px;display:grid;place-items:center;background:var(--ink);color:var(--gold);border:2px solid var(--gold);border-radius:6px;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s var(--ease),transform .25s var(--ease);box-shadow:0 6px 18px rgba(0,0,0,.3)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top svg{width:20px;height:20px;stroke:currentColor;stroke-width:2.5;fill:none}
.to-top:hover{background:#000}
@media(min-width:769px){.to-top{bottom:24px}}
@media(prefers-reduced-motion:reduce){.to-top{transition:none}}

/* ── footer rebalanced: 4 columns + wide all-24-cities block (SEO P0: PageRank distribution) ── */
.footer-grid{grid-template-columns:2fr 1fr 2.4fr 1fr}
.footer-areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px 18px}
@media(max-width:900px){.footer-grid{grid-template-columns:repeat(2,1fr)}.footer-areas{grid-column:1/-1}.footer-areas-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.footer-grid{grid-template-columns:1fr 1fr}.footer-areas-grid{grid-template-columns:1fr 1fr}}

/* ── A11Y: visible keyboard focus on all interactive elements (audit P1) ── */
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:2px}
.btn:focus-visible,.form-submit:focus-visible,.light-form-submit:focus-visible,.to-top:focus-visible,.ham:focus-visible,.mob-close:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.nav-links a:focus-visible,.footer a:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:2px}
/* don't double-up native focus rings on form inputs that already get one */
input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--gold);outline-offset:1px}


/* ── PRINT — quotes/inspection-report-friendly output (audit layer-4) ── */
@media print {
  /* Hide site chrome and floating UI */
  .nav, .nav-cta, footer, .to-top, .mob-bar, .mob-menu, .sticky-cta,
  [class*="cookie"], [class*="modal"], .hazard-rule, .family-strip { display: none !important; }
  /* Reset backgrounds + colors for ink-friendly print */
  html, body { background: #fff !important; color: #000 !important; font-size: 11pt; }
  section, .hero, .section, .cta, [style*="background:var(--ink)"], [style*="background:#"] {
    background: #fff !important; color: #000 !important;
  }
  /* Make links visible + print the URL */
  a { color: #000 !important; text-decoration: underline; }
  a[href^="http"]:after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  a[href^="tel:"]:after, a[href^="mailto:"]:after { content: " (" attr(href) ")"; font-size: 9pt; color: #555; }
  /* Don't split key content blocks across pages */
  h1, h2, h3, .card, .testimonial, .stat-card, .faq-item, .review-card,
  .post-cta, .why-card { page-break-inside: avoid; }
  h2, h3 { page-break-after: avoid; }
  img { max-width: 100% !important; height: auto !important; page-break-inside: avoid; }
  /* Show the brand trust line at top of every printed page */
  body:before {
    content: "NuShake Roofing · CSLB #1142280 · (209) 253-0506 · nushake.com";
    display: block; font-size: 9pt; color: #555;
    padding: 8px 0; border-bottom: 1px solid #ccc; margin-bottom: 16px;
  }
}

/* Active nav link styling (audit layer-6) */
.nav-links a[aria-current="page"]{color:var(--gold)}
.mob-menu a[aria-current="page"]{color:var(--gold)}

/* ── Testimonials grid (P0 CRO, audit Opus-grade) ── */
.rv-testimonials{margin-top:clamp(40px,5vw,72px);padding-top:clamp(32px,4vw,48px);border-top:1px solid var(--g100)}
.rv-testimonials-head{grid-column:1/-1;text-align:center;margin:0 0 clamp(8px,1vw,16px)}
.rv-testimonials-head h3{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,1.8rem);margin:0 0 8px;color:var(--g800);letter-spacing:-.01em}
.rv-testimonials-head p{font-size:.95rem;color:var(--g500);margin:0}
.rv-testimonials-head p a{color:var(--ink);font-weight:700;text-decoration:none;border-bottom:1.5px solid currentColor}
.rv-testimonials-head p a:hover{color:var(--ink)}
.rv-testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(16px,2vw,24px)}
@media(min-width:900px){.rv-testimonials{grid-template-columns:repeat(3,1fr)}}
.rv-card{background:var(--white);border:1px solid var(--g100);border-radius:0;padding:clamp(22px,2.5vw,28px);display:flex;flex-direction:column;gap:14px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.rv-card:hover{border-color:var(--g200);box-shadow:0 4px 12px rgba(0,0,0,.04)}
.rv-stars{color:var(--gold);font-size:1rem;letter-spacing:1px;line-height:1}
.rv-quote{font-size:.95rem;line-height:1.65;color:var(--g800);margin:0;font-style:normal;quotes:"\201C""\201D""\2018""\2019"}
.rv-quote:before{content:open-quote;color:var(--gold);font-weight:700;margin-right:1px}
.rv-quote:after{content:close-quote;color:var(--gold);font-weight:700;margin-left:1px}
.rv-attr{display:flex;flex-direction:column;gap:2px;margin-top:auto;padding-top:12px;border-top:1px solid var(--g100);font-size:.82rem}
.rv-attr strong{color:var(--g800);font-weight:700}
.rv-attr span{color:var(--g500)}


/* Mobile menu tap targets (audit v2 P1: WCAG 2.5.5 — ensure 48x48 minimum) */
.mob-menu a{min-height:48px;display:flex;align-items:center;padding:0 24px}
.mob-menu .mob-close{min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center}


/* ════════════════════════════════════════════════════════════════════
   MOBILE SCROLL-EASE COMPACTION (audit v2 P1 — safe subset)
   ════════════════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .hero{padding-top:clamp(80px,12vw,120px);padding-bottom:clamp(40px,8vw,72px)}
  .hero .headline{font-size:clamp(2rem,9vw,3.2rem);line-height:1.02;margin-bottom:14px}
  .hero-body{font-size:.92rem;line-height:1.55;margin-bottom:18px}
  .hero-btns{gap:8px;margin-bottom:14px}
  .hero-btns .btn{padding:14px 18px;font-size:.85rem}
  .hero-trust{flex-direction:column;gap:8px;margin-bottom:14px;font-size:.78rem}
  .hero-price{font-size:.85rem!important;margin-top:12px!important;padding:10px 12px;background:rgba(254,189,23,.08);border-left:2px solid var(--gold);border-radius:0 3px 3px 0}
  .section{padding:clamp(40px,9vw,72px) 0}
  .svc,.svc-card,.why-card,.area-group{padding:clamp(18px,3vw,28px)}
}



/* Responsive comparison tables (smoke test caught .price-table overflowing on mobile) */
@media(max-width:768px){
  .price-table,.materials-table,table.comparison{
    display:block;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:100%;
    font-size:.85rem;
  }
}


/* ════════════════════════════════════════════════════════════════════
   W6 — Manufacturer cert strip (DeWalt-style credibility band below hero)
   ════════════════════════════════════════════════════════════════════ */
.cert-strip{padding:32px 0;background:var(--white);border-bottom:1px solid var(--g100)}
.cert-strip-label{text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500);margin-bottom:16px}
.cert-strip-logos{display:flex;justify-content:center;align-items:center;gap:48px;flex-wrap:wrap}
.cert-strip-logos img{height:56px;width:auto;opacity:.75;transition:opacity .2s,filter .2s;filter:grayscale(.3)}
.cert-strip-logos img:hover{opacity:1;filter:grayscale(0)}
@media(max-width:640px){.cert-strip-logos{gap:24px}.cert-strip-logos img{height:42px}}


/* ════════════════════════════════════════════════════════════════════
   City photo band — DeWalt-style atmospheric photo with caption (city pages)
   ════════════════════════════════════════════════════════════════════ */
.city-band{position:relative;min-height:clamp(360px,42vw,520px);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden;margin:clamp(40px,5vw,72px) 0;border-top:4px solid var(--gold);border-bottom:4px solid var(--gold)}
.city-band::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(9,9,9,.78) 0%,rgba(9,9,9,.25) 45%,rgba(9,9,9,.15) 100%);pointer-events:none}
.city-band-caption{position:absolute;left:0;right:0;bottom:0;padding:clamp(24px,4vw,40px) clamp(20px,5vw,56px);z-index:1;color:var(--white);max-width:1280px;margin:0 auto}
.city-band-caption .eyebrow{color:rgba(255,255,255,.85);margin-bottom:8px}
.city-band-caption h3{font-family:var(--serif);font-weight:900;font-size:clamp(1.4rem,3vw,2.2rem);line-height:1.05;text-transform:uppercase;margin:0 0 6px;color:var(--white);letter-spacing:-.01em}
.city-band-caption p{font-size:.95rem;color:rgba(255,255,255,.78);max-width:560px;line-height:1.5;margin:0}

/* ════════════════════════════════════════════════════════════════════
   D0.8 — Defensive contrast: primary CTA on yellow sections inverts to black-on-yellow
   ════════════════════════════════════════════════════════════════════ */
.gold-bg .btn-primary,
[style*="background:var(--gold)"] .btn-primary,
[style*="background:#ffcd"] .btn-primary,
[style*="background:#FFCD"] .btn-primary{background:var(--ink);color:var(--gold)}
.gold-bg .btn-primary:hover,
[style*="background:var(--gold)"] .btn-primary:hover{background:var(--g800);color:var(--gold)}
