/* Lazy-load BG placeholder · navy placeholder until image loads · prevents layout shift */
.lazy-bg{background-color:#15233a;background-size:cover;background-position:center;background-repeat:no-repeat}

/* content-visibility:auto · skip render work for below-fold sections · improves INP + mobile perf */
.svc-grid,.ba-grid,.locations-grid,footer{content-visibility:auto;contain-intrinsic-size:auto 800px}

:root{
  --navy:#0e1a2c; --navy-2:#15233a; --navy-3:#1e2d42;
  --sky:#42aee9; --sky-deep:#2a8ec5; --sky-soft:#e8f4fc;
  --orange:#dd6c2d; --orange-dim:#b85b22; --orange-soft:#fce8db; --orange-text:#a14d1c;
  --green:#7cd653; --green-deep:#56a832; --green-text:#2d7a1f;
  --white:#ffffff; --bg:#f6f7f9; --bg-2:#eceff3;
  --line:rgba(14,26,44,0.10); --line-2:rgba(14,26,44,0.18); --line-dark:rgba(255,255,255,0.10);
  --text:#0e1a2c; --text-2:#3f4a5e; --text-3:#7a8294;
  --shadow-sm:0 2px 6px rgba(14,26,44,0.06);
  --shadow:0 8px 24px rgba(14,26,44,0.10);
  --shadow-lg:0 22px 60px rgba(14,26,44,0.22);
  --shadow-orange:0 12px 32px rgba(221,108,45,0.40);
  --shadow-orange-mega:0 16px 48px rgba(221,108,45,0.55);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Inter',system-ui,sans-serif;background:var(--white);color:var(--text);font-size:15.5px;line-height:1.55}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--sky);color:var(--navy)}
.container{max-width:1280px;margin:0 auto;padding:0 28px}
.mono{font-family:'JetBrains Mono',monospace}

/* SCROLL PROG */
.scroll-prog{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--sky),var(--orange));width:0%;z-index:200;transition:width 0.08s linear;box-shadow:0 0 12px var(--sky)}

/* TOP BAR — protocol bar */
.topbar{background:var(--navy);color:rgba(255,255,255,0.78);padding:8px 0;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.10em;border-bottom:1px solid var(--line-dark);position:relative}
.topbar .container{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;text-transform:uppercase}
.topbar .pulse{display:inline-flex;align-items:center;gap:7px;color:var(--green);font-weight:700}
.topbar .pulse::before{content:'';width:7px;height:7px;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(124,214,83,0.7)}50%{box-shadow:0 0 0 8px rgba(124,214,83,0)}}
.topbar strong{color:var(--white)}
.topbar .sep{color:rgba(255,255,255,0.30)}
.topbar a{color:var(--sky);font-weight:700}
.topbar .lic{color:var(--sky);font-weight:700}

/* NAV */
.topnav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,0.96);backdrop-filter:saturate(1.8) blur(12px);border-bottom:2px solid var(--navy);transition:box-shadow 0.3s}
.topnav.scrolled{box-shadow:0 6px 24px rgba(14,26,44,0.10)}
.topnav .container{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding-top:14px;padding-bottom:14px}
.brand{display:inline-flex;align-items:center;gap:11px;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:18px;letter-spacing:-0.02em;color:var(--navy);text-transform:uppercase;line-height:1}
.brand-mark{width:48px;height:48px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1)}
.brand-mark img{width:100%;height:100%;object-fit:contain;display:block}
.brand:hover .brand-mark{transform:rotate(8deg) scale(1.05)}
.footer-brand .brand-mark{width:54px;height:54px;background:var(--white);border-radius:50%;padding:3px}
.footer-brand .brand-mark img{filter:none}
.brand-name{display:flex;flex-direction:column;line-height:1}
.brand-name small{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:9.5px;letter-spacing:0.16em;color:var(--text-2);text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;gap:26px;justify-content:center}
.nav-links a{font-size:13.5px;font-weight:700;color:var(--text-2);transition:color 0.2s;text-transform:uppercase;letter-spacing:0.04em}
.nav-links a:hover{color:var(--orange)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;background:var(--orange);color:var(--white);font-family:'Inter Tight',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.02em;text-transform:uppercase;border:2px solid var(--orange);transition:all 0.2s}
.nav-cta:hover{transform:translateY(-1px);background:var(--navy);border-color:var(--navy);box-shadow:0 8px 22px rgba(14,26,44,0.30)}

/* BUTTONS — hard-edged industrial */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;font-family:'Inter Tight',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.04em;text-transform:uppercase;border:2px solid transparent;cursor:pointer;transition:all 0.2s;text-align:center;line-height:1.2}
.btn-orange{background:var(--orange);color:var(--white);border-color:var(--orange);box-shadow:0 8px 22px rgba(221,108,45,0.35)}
.btn-orange:hover{transform:translateY(-2px);background:var(--orange-dim);border-color:var(--orange-dim);box-shadow:0 14px 32px rgba(221,108,45,0.45)}
.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}
.btn-navy:hover{transform:translateY(-2px);background:var(--orange);border-color:var(--orange)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.45)}
.btn-ghost:hover{background:var(--white);color:var(--navy);border-color:var(--white)}
.btn-ghost-dark{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-ghost-dark:hover{background:var(--navy);color:var(--white)}

/* HERO — dark, brutalist refined */
.hero{position:relative;background:var(--navy);overflow:hidden;color:var(--white);border-bottom:3px solid var(--sky)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(0.9) brightness(0.36);z-index:0}
.hero-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.04) saturate(0.9) brightness(0.36);z-index:1}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,26,44,0.94) 0%,rgba(30,45,66,0.55) 45%,rgba(14,26,44,0.86) 100%)}
.hero-bg::before{content:'';position:absolute;top:-15%;right:-15%;width:75%;height:110%;background:radial-gradient(ellipse,rgba(66,174,233,0.20) 0%,transparent 60%);z-index:1}
.hero-grid-bg{position:absolute;inset:0;z-index:2;background-image:linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,0.03) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}
.hero-inner{position:relative;z-index:4;max-width:1280px;margin:0 auto;padding:88px 28px 88px;display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:center}

.hero-status{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;background:rgba(124,214,83,0.12);border:1px solid rgba(124,214,83,0.30);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;color:var(--green);margin-bottom:22px}
.hero-status::before{content:'';width:8px;height:8px;background:var(--green);border-radius:50%;box-shadow:0 0 0 0 rgba(124,214,83,0.7);animation:pulse 1.6s infinite}

.hero h1{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(36px,3.8vw,56px);line-height:0.96;letter-spacing:-0.035em;color:var(--white);margin-bottom:20px;text-transform:uppercase}
.hero h1 .strike{position:relative;display:inline-block}
.hero h1 .strike::after{content:'';position:absolute;top:50%;left:-2%;right:-2%;height:0.16em;background:var(--orange);transform:rotate(-3deg);transform-origin:left;animation:strikein 0.8s 0.5s both}
@keyframes strikein{0%{transform:rotate(-3deg) scaleX(0)}100%{transform:rotate(-3deg) scaleX(1)}}
.hero h1 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 0.10em;display:inline-block;line-height:1;box-shadow:0 6px 30px rgba(66,174,233,0.40)}

.hero-lede{font-size:18.5px;line-height:1.6;color:rgba(255,255,255,0.86);max-width:580px;margin-bottom:22px}
.hero-lede strong{color:var(--white);font-weight:700;background:rgba(66,174,233,0.18);padding:1px 5px}

.hero-trust{display:inline-flex;flex-wrap:wrap;gap:0;margin-bottom:24px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.14);padding:0;backdrop-filter:blur(8px)}
.hero-trust .tt{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.10em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,0.92);border-right:1px solid rgba(255,255,255,0.14)}
.hero-trust .tt:last-child{border-right:0}
.hero-trust .tt::before{content:'✓';color:var(--green);font-weight:900;font-size:12px}

.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:stretch;margin-bottom:18px}

/* MEGA CALL CTA — the dominant button */
.btn-call-mega{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;padding:22px 38px;background:var(--orange-text);color:var(--white);border:2px solid var(--orange-text);font-family:'Inter Tight',sans-serif;font-weight:900;text-transform:uppercase;cursor:pointer;transition:transform 0.2s,background 0.2s,border-color 0.2s;line-height:1;letter-spacing:-0.01em;position:relative;animation:callPulse 2.6s infinite;box-shadow:var(--shadow-orange)}
@keyframes callPulse{0%,100%{box-shadow:var(--shadow-orange),0 0 0 0 rgba(221,108,45,0.55)}50%{box-shadow:var(--shadow-orange-mega),0 0 0 18px rgba(221,108,45,0)}}
.btn-call-mega::before{content:'📞';font-size:26px;margin-bottom:8px;filter:grayscale(1) brightness(2)}
.btn-call-mega .call-label{font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:0.22em;color:rgba(255,255,255,0.90);font-weight:700;margin-bottom:5px}
.btn-call-mega .call-num{font-size:28px;letter-spacing:-0.01em}
.btn-call-mega:hover{transform:translateY(-3px);background:var(--orange-dim);border-color:var(--orange-dim)}

.btn-ghost-arrow{padding:18px 26px;font-size:14px;letter-spacing:0.04em;border-width:2px}
.btn-ghost-arrow::after{content:' →';margin-left:6px;transition:transform 0.2s;display:inline-block}
.btn-ghost-arrow:hover::after{transform:translateX(4px)}

.hero-meta{font-family:'JetBrains Mono',monospace;font-size:13.5px;color:rgba(255,255,255,0.70);letter-spacing:0.04em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hero-meta::before{content:'';width:18px;height:2px;background:var(--sky)}
.hero-meta strong{color:var(--white);font-weight:700}
.hero-meta .star{color:var(--orange)}

/* HERO FORM CARD — hard-edged premium */
.hero-form{background:var(--white);color:var(--navy);padding:28px;box-shadow:0 24px 70px rgba(0,0,0,0.55);position:relative;border:2px solid var(--navy)}
.hero-form::before{content:'';position:absolute;top:-2px;left:-2px;width:64px;height:6px;background:var(--orange)}
.hero-form::after{content:'';position:absolute;top:-2px;left:62px;width:36px;height:6px;background:var(--sky)}
.hf-tag{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;background:var(--orange-text);color:var(--white);font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px}
.hf-tag::before{content:'⚡';font-size:11px}
.hf-title{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:28px;line-height:1.0;letter-spacing:-0.025em;margin-bottom:6px;text-transform:uppercase}
.hf-title em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 5px}
.hf-sub{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-2);margin-bottom:18px;line-height:1.55;letter-spacing:0.02em;text-transform:uppercase}
.hf-form{display:flex;flex-direction:column;gap:9px}
.hf-form input,.hf-form select{width:100%;padding:13px 14px;background:var(--bg);border:1px solid var(--line-2);font:inherit;font-size:14.5px;color:var(--navy);outline:none;transition:border-color 0.2s,background 0.2s}
.hf-form input:focus,.hf-form select:focus{border-color:var(--orange);background:var(--white)}
.hf-form input::placeholder{color:var(--text-3)}
.hf-row{display:grid;grid-template-columns:1.4fr 1fr;gap:9px}
.hf-submit{margin-top:6px;padding:17px;background:var(--orange-text);color:var(--white);border:2px solid var(--orange-text);font-family:'Inter Tight',sans-serif;font-weight:900;font-size:15px;letter-spacing:0.04em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;box-shadow:var(--shadow-orange)}
.hf-submit:hover{background:var(--navy);border-color:var(--navy);transform:translateY(-1px)}
.hf-callback{margin-top:12px;padding:11px 13px;background:rgba(124,214,83,0.10);border-left:3px solid var(--green);font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text);font-weight:600;letter-spacing:0.02em;text-transform:uppercase;line-height:1.5}
.hf-callback strong{color:var(--green-deep);font-weight:800}
.hf-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 10px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-2);font-weight:700;letter-spacing:0.06em;text-transform:uppercase}
.hf-foot .star{color:var(--orange-text);font-weight:800}
.hf-foot .check{color:var(--green-text);font-weight:800}
.hf-foot .check::before{content:'✓ ';color:var(--green-text)}
.hf-foot .sep{color:var(--text-3)}

/* TRUST BAR — dark navy strip, single accent */
.trust-bar{background:var(--navy);border-bottom:1px solid var(--line-dark);color:var(--white);position:relative}
.trust-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--sky) 50%,transparent 100%);opacity:0.5}
.trust-bar-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(255,255,255,0.06);padding:0 28px}
.tb-cell{background:var(--navy);padding:30px 14px;text-align:center;display:flex;flex-direction:column;gap:6px;align-items:center;transition:background 0.2s}
.tb-cell:hover{background:var(--navy-2)}
.tb-num{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:32px;color:var(--sky);letter-spacing:-0.03em;line-height:1}
.tb-num .star{color:var(--orange);margin-right:3px}
.tb-num small{color:rgba(255,255,255,0.55);font-size:14px;font-weight:600}
.tb-lbl{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:rgba(255,255,255,0.68);font-weight:600;letter-spacing:0.10em;text-transform:uppercase}

/* SECTIONS */
.section{padding:104px 0;background:var(--white);position:relative}
.section.alt{background:var(--bg)}
.section.dark{background:var(--navy);color:var(--white)}
.section.dark::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--sky) 50%,transparent 100%);opacity:0.4}

.section-head{display:grid;grid-template-columns:1.1fr 1fr;gap:36px;align-items:end;margin-bottom:56px}
.section-head .kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--navy);color:var(--sky);font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:18px}
.section-head .kicker::before{content:'//';color:var(--orange);font-weight:800}
.section.dark .section-head .kicker{background:rgba(66,174,233,0.16);color:var(--sky)}
.section-head h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(34px,4.6vw,58px);line-height:0.94;letter-spacing:-0.04em;color:var(--navy);text-transform:uppercase}
.section.dark .section-head h2{color:var(--white)}
.section-head h2 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 0.08em;display:inline-block;line-height:1}
.section.dark .section-head h2 em{background:var(--sky);color:var(--navy)}
.section-head p{font-size:16.5px;color:var(--text-2);line-height:1.65;align-self:end;max-width:540px}
.section.dark .section-head p{color:rgba(255,255,255,0.78)}
.section-head p strong{color:var(--navy);font-weight:700}
.section.dark .section-head p strong{color:var(--white)}

/* WHY US — compact 6 bullets */
.why-layout{display:grid;grid-template-columns:1fr 1.25fr;gap:32px;align-items:stretch}
.team-photo{position:relative;overflow:hidden;border:2px solid var(--navy);background:var(--navy);margin:0;display:flex;flex-direction:column}
.team-photo img{width:100%;height:100%;object-fit:cover;flex:1;display:block}
.team-photo figcaption{padding:16px 20px;background:var(--navy);color:var(--white);display:flex;flex-direction:column;gap:4px;border-top:2px solid var(--orange)}
.team-photo .team-tag{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--sky);font-weight:700;letter-spacing:0.18em;text-transform:uppercase}
.team-photo .team-line{font-family:'Inter Tight',sans-serif;font-size:14px;color:var(--white);font-weight:700;line-height:1.35;letter-spacing:-0.005em}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:2px solid var(--navy);background:var(--navy)}
.why-cell{background:var(--white);padding:28px 24px;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;transition:background 0.25s}
.why-cell:hover{background:var(--bg)}
.why-cell::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--orange);transition:width 0.4s}
.why-cell:hover::before{width:100%}
.why-cell:nth-child(2n){border-right:0}
.why-cell:nth-last-child(-n+2){border-bottom:0}
.why-num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--orange-text);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;margin-bottom:4px}
.why-cell h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:21px;line-height:1.15;letter-spacing:-0.018em;color:var(--navy);text-transform:uppercase}
.why-cell p{font-size:15px;line-height:1.6;color:var(--text-2)}

/* SERVICES BENTO — hard edges, navy featured */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(200px,auto);gap:0;border:2px solid var(--navy);background:var(--navy)}
.svc{background:var(--white);padding:28px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:background 0.3s ease;text-decoration:none;color:inherit;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-photo{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 0.4s ease;z-index:0}
.svc-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,26,44,0.30) 0%,rgba(14,26,44,0.92) 100%)}
.svc:hover .svc-photo{opacity:1}
.svc.has-photo:hover{color:var(--white)}
.svc.has-photo:hover .svc-num,.svc.has-photo:hover h3,.svc.has-photo:hover p{color:var(--white)}
.svc.has-photo:hover .svc-num small{color:var(--sky)}
.svc-content{position:relative;z-index:2;display:flex;flex-direction:column;height:100%;gap:8px}
.svc-num{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:12px;letter-spacing:0.16em;color:var(--orange);text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}
.svc-num small{color:var(--text-3);font-weight:700}
.svc-arrow{width:34px;height:34px;background:var(--white);border:1.5px solid var(--navy);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all 0.25s}
.svc:hover .svc-arrow{background:var(--orange);border-color:var(--orange);color:var(--white);transform:rotate(-45deg)}
.svc h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:21px;line-height:1.12;letter-spacing:-0.02em;color:var(--navy);text-transform:uppercase;margin-top:auto}
.svc p{font-size:14.5px;line-height:1.55;color:var(--text-2)}
.svc.featured{grid-column:span 2;grid-row:span 2;background:var(--navy);color:var(--white);min-height:420px;border-right:1px solid var(--line-dark)}
.svc.featured h3{color:var(--white);font-size:42px;line-height:0.96;letter-spacing:-0.035em}
.svc.featured h3 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 0.06em}
.svc.featured p{color:rgba(255,255,255,0.84);font-size:16px;line-height:1.6;max-width:400px}
.svc.featured .svc-num{color:var(--sky)}
.svc.featured .svc-num small{color:rgba(255,255,255,0.5)}
.svc.featured .svc-arrow{background:var(--sky);border-color:var(--sky);color:var(--navy)}
.svc.featured:hover .svc-arrow{background:var(--orange);border-color:var(--orange);color:var(--white)}
.svc.featured .svc-photo{opacity:0.40}
.svc.featured:hover .svc-photo{opacity:0.55}
.svc.cta-tile{background:var(--orange);color:var(--white);grid-column:span 1}
.svc.cta-tile h3{color:var(--white);font-size:21px}
.svc.cta-tile p{color:rgba(255,255,255,0.92)}
.svc.cta-tile .svc-num{color:rgba(255,255,255,0.86)}
.svc.cta-tile .svc-arrow{background:var(--white);border-color:var(--white);color:var(--orange)}
.svc.cta-tile:hover{background:var(--orange-dim)}
.svc.cta-tile .pill{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;background:var(--white);color:var(--orange);font-family:'JetBrains Mono',monospace;font-weight:800;font-size:11px;letter-spacing:0.08em;align-self:flex-start;margin-top:6px}
.svc:nth-child(3n+0){border-right:1px solid var(--line)}
.svc:nth-child(4n){border-right:0}

/* CTA PROMPT (after sections) */
.cta-prompt{margin-top:48px;padding:28px 32px;background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative;overflow:hidden;border:2px solid var(--navy);border-left:6px solid var(--orange)}
.cta-prompt::before{content:'';position:absolute;top:0;right:0;bottom:0;width:280px;background:radial-gradient(circle at right,rgba(66,174,233,0.18) 0%,transparent 70%);pointer-events:none}
.cta-prompt-text{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:21px;letter-spacing:-0.01em;color:var(--white);position:relative;z-index:2;line-height:1.3;flex:1;min-width:240px;text-transform:uppercase}
.cta-prompt-text em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 5px}
.cta-prompt-ctas{display:inline-flex;gap:10px;flex-wrap:wrap;position:relative;z-index:2}
.cta-prompt .btn-ghost{color:var(--white);border-color:rgba(255,255,255,0.45)}
.cta-prompt .btn-ghost:hover{background:var(--white);color:var(--navy);border-color:var(--white)}

/* REVIEWS */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--navy);background:var(--navy)}
.rev{background:var(--white);padding:30px 28px;display:flex;flex-direction:column;gap:16px;transition:background 0.25s;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.rev:nth-child(3n){border-right:0}
.rev:nth-last-child(-n+3){border-bottom:0}
.rev:hover{background:var(--bg)}
.rev-top{display:flex;align-items:center;gap:10px}
.rev-stars{color:var(--orange);letter-spacing:2px;font-size:15px}
.rev-source{margin-left:auto;display:inline-flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-3);font-weight:700;letter-spacing:0.10em;text-transform:uppercase}
.rev-source .g{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--white);border:1px solid var(--line-2);font-family:'Inter Tight',sans-serif;font-weight:900;color:var(--sky-deep);font-size:12px}
.rev blockquote{font-size:16px;line-height:1.6;color:var(--text);flex:1}
.rev mark{background:rgba(124,214,83,0.30);color:var(--navy);padding:0 5px;font-weight:700}
.rev .meta{display:flex;align-items:center;gap:13px;padding-top:16px;border-top:1px solid var(--line)}
.rev .avatar{width:42px;height:42px;background:var(--navy);color:var(--sky);display:flex;align-items:center;justify-content:center;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:14px;flex-shrink:0;border:2px solid var(--navy)}
.rev .avatar.orange{background:var(--orange);color:var(--white);border-color:var(--orange)}
.rev .avatar.sky{background:var(--sky);color:var(--navy);border-color:var(--sky)}
.rev .avatar.green{background:var(--green);color:var(--navy);border-color:var(--green)}
.rev .meta strong{display:block;font-family:'Inter Tight',sans-serif;font-weight:800;font-size:14.5px;color:var(--navy);text-transform:uppercase;letter-spacing:0.01em}
.rev .meta span{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-2);letter-spacing:0.04em;margin-top:2px;display:inline-block}
.verified-pill{display:inline-flex;align-items:center;gap:3px;padding:1px 5px;background:var(--green);color:var(--navy);font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:800;letter-spacing:0.06em;text-transform:uppercase;margin-left:6px}
.verified-pill::before{content:'✓';font-weight:900}

/* BEFORE / AFTER */
.ba-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--navy);background:var(--navy)}
.ba{position:relative;overflow:hidden;aspect-ratio:5/4;cursor:pointer;background:var(--navy);transition:transform 0.3s;border-right:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.ba:nth-child(3n){border-right:0}
.ba:nth-last-child(-n+3){border-bottom:0}
.ba-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 0.6s ease,filter 0.4s ease}
.ba:hover .ba-img{transform:scale(1.06)}
.ba::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg,rgba(14,26,44,0.94) 0%,rgba(30,45,66,0.32) 55%,transparent 100%);z-index:1}
.ba-tag{position:absolute;top:14px;left:14px;z-index:2;padding:5px 11px;background:var(--white);color:var(--navy);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:800;letter-spacing:0.10em;text-transform:uppercase}
.ba-after{position:absolute;top:14px;right:14px;z-index:2;padding:5px 11px;background:var(--green);color:var(--navy);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:800;letter-spacing:0.10em;text-transform:uppercase}
.ba-after::before{content:'✓ ';font-weight:900}
.ba-cap{position:absolute;left:20px;right:20px;bottom:20px;z-index:2;color:var(--white)}
.ba-cap h4{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:20px;line-height:1.18;margin-bottom:10px;letter-spacing:-0.015em}
.ba-spec{display:flex;flex-direction:column;gap:4px;font-family:'JetBrains Mono',monospace;font-size:13px;color:rgba(255,255,255,0.94);font-weight:600;line-height:1.45}
.ba-spec-item b{display:inline-block;width:64px;color:var(--sky);font-weight:700;letter-spacing:0.10em;text-transform:uppercase;font-size:11px;margin-right:10px}

/* CTA BAND — sky strip */
.cta-band{background:var(--sky);color:var(--navy);padding:38px 0;position:relative;overflow:hidden;border-top:2px solid var(--navy);border-bottom:2px solid var(--navy)}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 50%,rgba(255,255,255,0.18),transparent 60%)}
.cta-band-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.cta-band h3{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(24px,3vw,36px);line-height:1.0;letter-spacing:-0.025em;color:var(--navy);text-transform:uppercase;flex:1;min-width:280px}
.cta-band h3 em{font-style:italic;color:var(--white)}
.cta-band-ctas{display:inline-flex;gap:10px;flex-wrap:wrap}

/* PROCESS — dark navy section */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:2px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.10)}
.pstep{background:var(--navy-2);padding:34px 28px;display:flex;flex-direction:column;gap:14px;position:relative;border-right:1px solid rgba(255,255,255,0.10);transition:background 0.3s}
.pstep:last-child{border-right:0}
.pstep:hover{background:var(--navy-3)}
.pstep::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--orange);transition:width 0.5s}
.pstep:hover::before{width:100%}
.pstep-num{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;background:var(--sky);color:var(--navy);font-family:'Inter Tight',sans-serif;font-weight:900;font-size:24px;letter-spacing:-0.02em;border:2px solid var(--sky)}
.pstep-meta{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--orange);font-weight:700;letter-spacing:0.18em;text-transform:uppercase}
.pstep-meta::before{content:'// ';color:var(--orange);font-weight:800}
.pstep h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:22px;line-height:1.12;color:var(--white);text-transform:uppercase;letter-spacing:-0.015em}
.pstep p{font-size:15px;line-height:1.65;color:rgba(255,255,255,0.82)}

/* PROOF / NUMBERS */
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:2px solid var(--navy);background:var(--navy)}
.num-cell{background:var(--white);padding:32px 28px;display:flex;flex-direction:column;gap:10px;transition:background 0.25s;border-right:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;min-height:200px}
.num-cell::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--sky);transition:width 0.5s}
.num-cell:hover::before{width:100%}
.num-cell:hover{background:var(--bg)}
.num-cell:nth-child(4n){border-right:0}
.num-cell:nth-last-child(-n+4){border-bottom:0}
.num-cell .lbl{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--text-3);font-weight:700;letter-spacing:0.16em;text-transform:uppercase}
.num-cell .lbl::before{content:'// ';color:var(--orange);font-weight:800}
.num-cell .val{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:54px;line-height:1;letter-spacing:-0.045em;color:var(--navy)}
.num-cell .val .star{color:var(--orange);margin-right:4px}
.num-cell .val small{color:var(--text-3);font-size:20px;font-weight:700}
.num-cell .desc{font-size:14.5px;color:var(--text-2);line-height:1.55;margin-top:auto}
.num-cell.accent{background:var(--navy);color:var(--white)}
.num-cell.accent .lbl{color:rgba(255,255,255,0.62)}
.num-cell.accent .val{color:var(--sky)}
.num-cell.accent .val small{color:rgba(255,255,255,0.55)}
.num-cell.accent .desc{color:rgba(255,255,255,0.78)}
.num-cell.accent::before{background:var(--orange)}

/* AREAS / COVERAGE — premium-compact v2 (WEB-059 redesign 2026-05-10): aggressive compaction for 10/10 premium look. Operator: "esta seccion aun se ve muy grande, nada estetico, debe lucir premiun, 10-10". 5-col city grid, thinner borders, tighter type, 360px map. */
.areas{padding:56px 0;background:var(--white)}
.areas-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:stretch}
.areas-left .kicker{display:inline-flex;align-items:center;gap:7px;padding:4px 9px;background:var(--navy);color:var(--sky);font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;margin-bottom:10px}
.areas-left .kicker::before{content:'//';color:var(--orange);font-weight:800}
.areas-left h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(22px,2.6vw,32px);line-height:1.02;letter-spacing:-0.025em;color:var(--navy);text-transform:uppercase;margin-bottom:8px}
.areas-left h2 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 5px}
.areas-left p{color:var(--text-2);font-size:13px;line-height:1.55;margin-bottom:14px;max-width:560px}
.areas-left p strong{color:var(--navy);font-weight:700}
.locations-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:10px;border:1.5px solid var(--navy);background:var(--navy)}
.loc-card{padding:12px 14px;background:var(--white);display:flex;flex-direction:column;gap:4px;transition:background 0.25s;border-right:1px solid var(--line);position:relative}
.loc-card:last-child{border-right:0}
.loc-card::before{content:'';position:absolute;top:0;left:0;width:0;height:2px;background:var(--orange);transition:width 0.4s}
.loc-card:hover::before{width:100%}
.loc-card.primary{background:linear-gradient(135deg,var(--sky-soft) 0%,var(--white) 100%)}
.loc-card .tag{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--orange);font-weight:800;letter-spacing:0.12em;text-transform:uppercase}
.loc-card.primary .tag{color:var(--sky-deep)}
.loc-card h4{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:12.5px;color:var(--navy);text-transform:uppercase;line-height:1.18}
.loc-card .info{font-size:11px;color:var(--text-2);line-height:1.45}
.dba-badge{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:3px 7px;background:rgba(124,214,83,0.14);color:var(--green-deep);font-family:'JetBrains Mono',monospace;font-size:8.5px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;border:1px solid rgba(124,214,83,0.30);align-self:flex-start}
.loc-card .info strong{color:var(--navy);font-weight:700}
.city-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:3px}
.city-cell{padding:7px 5px;background:var(--white);border:1px solid var(--line-2);font-family:'Inter',sans-serif;font-size:10.5px;color:var(--navy);font-weight:600;text-align:center;transition:all 0.2s;letter-spacing:-0.01em}
.city-cell:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.zip-cta{margin-top:10px;padding:9px 14px;background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;border-left:3px solid var(--orange)}
.zip-cta-text{font-size:11.5px;font-weight:600;line-height:1.45}
.zip-cta .btn{padding:8px 14px;font-size:12.5px;letter-spacing:0.02em;white-space:nowrap}
/* .map-frame v2: min-height:360px (WEB-059 — bajado de 420px). border 1.5px (refinado). align-items:stretch en .areas-inner + height:100% mantiene paridad con columna izquierda. Subtle box-shadow para profundidad premium. Mobile media queries resetean min-height. */
.map-frame{min-height:360px;height:100%;overflow:hidden;position:relative;border:1.5px solid var(--navy);box-shadow:0 6px 24px -10px rgba(14,26,44,0.18)}
.map-frame iframe{width:100%;height:100%;border:0}
.map-frame .pin{position:absolute;top:14px;left:14px;background:var(--navy);color:var(--sky);padding:7px 13px;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:800;letter-spacing:0.10em;text-transform:uppercase;z-index:2}
.map-frame .pin::before{content:'● ';color:var(--green);animation:pulse 1.6s infinite}

/* SPLIT (Res vs Com) */
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:2px solid var(--navy);background:var(--navy)}
.split{background:var(--white);padding:44px;display:flex;flex-direction:column;gap:16px;transition:background 0.25s;border-right:1px solid var(--line);position:relative}
.split:last-child{border-right:0}
.split::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--orange);transition:width 0.4s}
.split:hover::before{width:100%}
.split.com{background:var(--navy);color:var(--white)}
.split-icon{font-size:42px;line-height:1}
.split h3{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:28px;color:var(--navy);text-transform:uppercase;letter-spacing:-0.025em;line-height:1.0}
.split.com h3{color:var(--white)}
.split h3 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 5px}
.split.com h3 em{background:var(--sky);color:var(--navy)}
.split p{font-size:15.5px;color:var(--text-2);line-height:1.6}
.split.com p{color:rgba(255,255,255,0.82)}
.split ul{list-style:none;display:flex;flex-direction:column;gap:9px;margin-top:6px}
.split ul li{font-size:15px;color:var(--text-2);display:flex;gap:9px;align-items:baseline;line-height:1.5}
.split ul li::before{content:'✓';color:var(--green-deep);font-weight:900;font-size:13px}
.split.com ul li{color:rgba(255,255,255,0.86)}
.split.com ul li::before{color:var(--green)}

/* WATER DAMAGE */
.water{padding:104px 0;background:var(--white);position:relative;border-top:3px solid var(--orange)}
.water::before{content:'';position:absolute;top:0;left:0;right:0;height:200px;background:radial-gradient(ellipse at top,rgba(221,108,45,0.08) 0%,transparent 60%);pointer-events:none}
.water-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.water-content .kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--orange);color:var(--white);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px}
.water-content .kicker::before{content:'⚠';font-size:14px}
.water-content h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(32px,4vw,52px);line-height:0.96;letter-spacing:-0.04em;color:var(--navy);text-transform:uppercase;margin-bottom:16px}
.water-content h2 em{font-style:italic;background:var(--orange);color:var(--white);padding:0 6px}
.water-content p{font-size:16.5px;color:var(--text-2);line-height:1.65;margin-bottom:22px}
.water-content p strong{color:var(--navy);font-weight:700;background:var(--orange-soft);padding:1px 5px}
.water-badges{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-bottom:18px;border:2px solid var(--navy);background:var(--navy)}
.water-badge{padding:12px 14px;background:var(--white);font-family:'Inter Tight',sans-serif;font-size:13.5px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);text-transform:uppercase;letter-spacing:0.01em}
.water-badge:nth-child(2n){border-right:0}
.water-badge:nth-last-child(-n+2){border-bottom:0}
.water-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px}
.water-tag{padding:6px 11px;background:var(--bg);border:1.5px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--navy);font-weight:700;letter-spacing:0.06em;text-transform:uppercase}
.water-ctas{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.water-photo{position:relative;overflow:hidden;aspect-ratio:4/3;border:2px solid var(--navy)}
.water-photo img{width:100%;height:100%;object-fit:cover}
.water-photo .badge{position:absolute;top:14px;right:14px;padding:6px 12px;background:var(--orange);color:var(--white);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:800;letter-spacing:0.10em;text-transform:uppercase}
.doc-panel{position:absolute;bottom:14px;left:14px;right:14px;background:rgba(14,26,44,0.94);backdrop-filter:blur(8px);padding:14px;color:var(--white);border-left:3px solid var(--sky)}
.doc-panel .lbl{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--sky);font-weight:800;letter-spacing:0.16em;text-transform:uppercase;margin-bottom:8px}
.doc-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;font-family:'JetBrains Mono',monospace;font-size:11.5px;color:rgba(255,255,255,0.86)}

/* LOCAL GEO */
.local{padding:104px 0;background:var(--bg)}
.local-inner{max-width:1280px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center}
.local-photo{position:relative;overflow:hidden;aspect-ratio:4/3;border:2px solid var(--navy)}
.local-photo img{width:100%;height:100%;object-fit:cover}
.local-photo .humidity{position:absolute;bottom:14px;left:14px;right:14px;background:rgba(14,26,44,0.94);backdrop-filter:blur(8px);padding:14px 16px;color:var(--white);display:flex;justify-content:space-between;align-items:center;gap:14px;border-left:3px solid var(--sky)}
.local-photo .humidity .lbl{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--sky);font-weight:800;letter-spacing:0.14em;text-transform:uppercase}
.local-photo .humidity .val{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:34px;color:var(--white);line-height:1;letter-spacing:-0.03em}
.local-photo .humidity .val small{color:rgba(255,255,255,0.65);font-size:11.5px;font-weight:600;letter-spacing:0.04em;display:block;margin-top:3px;text-transform:uppercase}
.local-content .kicker{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;background:var(--navy);color:var(--sky);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px}
.local-content .kicker::before{content:'//';color:var(--orange);font-weight:800}
.local-content h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(32px,4vw,52px);line-height:0.96;letter-spacing:-0.04em;color:var(--navy);text-transform:uppercase;margin-bottom:14px}
.local-content h2 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 6px}
.local-content p{font-size:16.5px;color:var(--text-2);line-height:1.65;margin-bottom:22px}
.local-content p strong{color:var(--navy);font-weight:700}
.causes-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.cause{padding:14px 16px;background:var(--white);border:1.5px solid var(--line-2);font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--navy);font-weight:700;display:flex;align-items:center;gap:10px;text-transform:uppercase;letter-spacing:0.04em}
.cause::before{content:'⚠';color:var(--orange);font-size:15px}
.local-warning{margin-top:26px;padding:22px 24px;background:var(--navy);color:var(--white);border-left:4px solid var(--orange);display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.local-warning span{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:17px;line-height:1.4;text-transform:uppercase;letter-spacing:0.01em}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:0;border:2px solid var(--navy);background:var(--navy)}
.faq-item{background:var(--white);padding:26px 30px;cursor:pointer;transition:background 0.2s;border-bottom:1px solid var(--line);position:relative}
.faq-item:last-child{border-bottom:0}
.faq-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--orange);transition:width 0.3s}
.faq-item:hover::before{width:4px}
.faq-item.open{background:var(--bg)}
.faq-item.open::before{width:4px}
.faq-q{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:18px;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:14px;line-height:1.3;text-transform:uppercase;letter-spacing:-0.005em}
.faq-toggle{flex-shrink:0;width:36px;height:36px;background:var(--navy);color:var(--sky);display:flex;align-items:center;justify-content:center;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:20px;transition:all 0.25s;border:2px solid var(--navy)}
.faq-item.open .faq-toggle{background:var(--orange);color:var(--white);border-color:var(--orange);transform:rotate(45deg)}
.faq-a{display:none;margin-top:16px;font-size:15.5px;color:var(--text-2);line-height:1.7}
.faq-a strong{color:var(--navy);font-weight:700}
.faq-item.open .faq-a{display:block}

/* FINAL CTA */
.final-cta{background:var(--navy);color:var(--white);padding:108px 0;position:relative;overflow:hidden;border-top:3px solid var(--orange)}
.final-cta::before{content:'';position:absolute;top:-15%;right:-10%;width:65%;height:130%;background:radial-gradient(ellipse,rgba(66,174,233,0.20) 0%,transparent 65%)}
.final-cta-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center}
.final-cta .kicker{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(221,108,45,0.20);color:var(--orange);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:18px}
.final-cta .kicker::before{content:'⚡'}
.final-cta h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(38px,5.5vw,68px);line-height:0.94;letter-spacing:-0.045em;color:var(--white);text-transform:uppercase;margin-bottom:18px}
.final-cta h2 em{font-style:italic;background:var(--orange);color:var(--white);padding:0 0.06em;display:inline-block;line-height:1}
.final-cta p{font-size:17.5px;color:rgba(255,255,255,0.86);line-height:1.65;margin-bottom:24px;max-width:540px}
.final-cta p strong{color:var(--white);background:rgba(66,174,233,0.18);padding:1px 5px;font-weight:700}
.phone-line{display:inline-flex;align-items:center;gap:13px;padding:20px 28px;background:var(--orange);color:var(--white);font-family:'Inter Tight',sans-serif;font-weight:900;text-transform:uppercase;letter-spacing:0.01em;border:2px solid var(--orange);transition:all 0.2s;box-shadow:var(--shadow-orange);animation:callPulse 2.6s infinite;font-size:16px}
.phone-line strong{font-size:28px;letter-spacing:-0.01em}
.phone-line:hover{transform:translateY(-2px);background:var(--orange-dim);border-color:var(--orange-dim)}
.final-trust{margin-top:18px;padding:11px 14px;background:rgba(124,214,83,0.10);border-left:3px solid var(--green);font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:rgba(255,255,255,0.92);line-height:1.5;letter-spacing:0.04em;text-transform:uppercase}

.final-form{background:var(--white);color:var(--navy);padding:28px;border:2px solid var(--orange);position:relative}
.final-form::before{content:'';position:absolute;top:-2px;left:-2px;width:64px;height:6px;background:var(--orange)}
.final-form::after{content:'';position:absolute;top:-2px;left:62px;width:36px;height:6px;background:var(--sky)}
.final-form h3{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:24px;text-transform:uppercase;color:var(--navy);margin-bottom:6px;letter-spacing:-0.02em}
.final-form .sub{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--text-2);margin-bottom:18px;text-transform:uppercase;letter-spacing:0.04em;line-height:1.5}

/* FOOTER — premium v2 (WEB-061 2026-05-10): added Connect column + social icons + 57 Clicks agency link */
footer{background:linear-gradient(180deg,#000 0%,#050810 100%);color:rgba(255,255,255,0.78);padding:64px 0 24px;position:relative;border-top:1px solid var(--line-dark)}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(66,174,233,0.20) 50%,transparent 100%)}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr 1fr;gap:32px;margin-bottom:40px}
.footer-brand{display:flex;flex-direction:column;gap:14px}
.footer-brand .brand{color:var(--white)}
.footer-brand .brand-name small{color:rgba(255,255,255,0.55)}
.footer-brand p{font-size:13.5px;line-height:1.6;color:rgba(255,255,255,0.65);max-width:380px}
.footer-brand .lic{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:rgba(255,255,255,0.42);letter-spacing:0.06em;line-height:1.7}
.footer-col h5{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:12.5px;color:var(--white);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:16px;position:relative;padding-bottom:8px}
.footer-col h5::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:var(--orange)}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:13.5px;color:rgba(255,255,255,0.68);transition:color 0.2s,padding-left 0.2s;display:inline-flex;align-items:center}
.footer-col ul li a:hover{color:var(--orange);padding-left:3px}
.footer-col ul li a strong{color:var(--sky);font-weight:700}

/* Footer Connect column — horizontal icon row (5 platforms: IG · FB · YT · X · WA) + mini CTA */
.footer-connect ul.footer-social{display:flex;flex-direction:row;flex-wrap:nowrap;gap:5px;list-style:none;padding:0;margin:0}
.footer-social li{margin:0;padding:0;flex:0 0 auto}
.footer-social li a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(255,255,255,0.14);background:rgba(255,255,255,0.02);color:rgba(255,255,255,0.72);transition:all 0.25s;padding:0;text-decoration:none}
.footer-social li a:hover{color:var(--orange);border-color:var(--orange);background:rgba(221,108,45,0.10);transform:translateY(-2px)}
.footer-social li a svg{width:14px;height:14px;flex-shrink:0;display:block}
.footer-cta-mini{margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.08)}
.footer-call-mini{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:rgba(221,108,45,0.10);border:1px solid rgba(221,108,45,0.30);color:var(--orange);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;transition:all 0.2s}
.footer-call-mini:hover{background:var(--orange);color:var(--white);border-color:var(--orange);transform:translateY(-1px)}

.footer-bottom{max-width:1280px;margin:0 auto;padding:18px 28px 0;border-top:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:rgba(255,255,255,0.48);letter-spacing:0.06em;text-transform:uppercase}
.footer-agency-link{color:rgba(255,255,255,0.62);transition:color 0.2s;text-transform:uppercase}
.footer-agency-link:hover{color:var(--sky)}

/* Footer interlinking — brand-name links + address-block links (WEB-063) */
.footer-brand-link{color:var(--sky);text-decoration:none;transition:color 0.2s,text-decoration 0.2s}
.footer-brand-link:hover{color:var(--orange);text-decoration:underline;text-underline-offset:3px}
.footer-brand-link strong{color:inherit;font-weight:700}

/* Address block links — multi-line li that wraps street + city in single clickable block */
.footer-col ul li a.footer-addr-link{display:block;font-size:13px;line-height:1.55;color:rgba(255,255,255,0.68);transition:color 0.2s,padding-left 0.2s;padding:2px 0}
.footer-col ul li a.footer-addr-link:hover{color:var(--orange);padding-left:3px}
.footer-col ul li a.footer-addr-link br{display:block}
.footer-col ul li a.footer-addr-gbp{position:relative}
.addr-gbp-badge{display:inline-block;margin-top:4px;padding:2px 7px;background:rgba(124,214,83,0.12);border:1px solid rgba(124,214,83,0.30);color:var(--green);font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;line-height:1.4;border-radius:1px}
.footer-col ul li a.footer-addr-gbp:hover .addr-gbp-badge{background:rgba(124,214,83,0.25);border-color:rgba(124,214,83,0.55)}

/* MOBILE STICKY */
.mobile-sticky{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:var(--white);border-top:2px solid var(--navy);padding:11px;gap:9px;box-shadow:0 -6px 24px rgba(14,26,44,0.18)}
.mobile-sticky a{flex:1;padding:16px 10px;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:15px;display:flex;align-items:center;justify-content:center;gap:7px;text-align:center;line-height:1.2;text-transform:uppercase;letter-spacing:0.04em;border:2px solid transparent}
.mobile-sticky .ms-call{background:var(--orange);color:var(--white);border-color:var(--orange);box-shadow:0 4px 14px rgba(221,108,45,0.45);flex:1.4;animation:msPulse 2.4s infinite}
@keyframes msPulse{0%,100%{box-shadow:0 4px 14px rgba(221,108,45,0.45)}50%{box-shadow:0 6px 22px rgba(221,108,45,0.70)}}
.mobile-sticky .ms-form{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* REVEAL */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity 0.7s ease,transform 0.7s ease}
[data-reveal].in{opacity:1;transform:translateY(0)}

/* MOBILE */
@media(max-width:767px){
  .topnav .container{grid-template-columns:auto 1fr auto;gap:12px}
  .nav-links{display:none}
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:64px 22px 56px}
  .hero h1{font-size:54px}
  .trust-bar-inner{grid-template-columns:repeat(3,1fr)}
  .tb-cell:nth-child(4),.tb-cell:nth-child(5){grid-column:auto}
  /* SIMPLIFY mobile grids — go to 1-col immediately to reduce density */
  .why-layout{grid-template-columns:1fr;gap:24px}
  .team-photo img{aspect-ratio:16/10}
  .why-grid,.svc-grid,.reviews-grid,.ba-grid,.process-grid,.numbers-grid,.locations-grid,.split-grid{grid-template-columns:1fr}
  .why-cell,.svc,.rev,.ba,.pstep,.num-cell,.loc-card,.split{border-right:0;border-bottom:1px solid var(--line)}
  .pstep{border-bottom:1px solid rgba(255,255,255,0.10)}
  .ba{border-bottom:1px solid var(--line-dark)}
  .why-cell:last-child,.svc:last-child,.rev:last-child,.ba:last-child,.pstep:last-child,.num-cell:last-child,.loc-card:last-child,.split:last-child{border-bottom:0}
  .svc.featured{grid-column:auto;grid-row:auto;min-height:auto}
  .svc.featured h3{font-size:34px}
  .num-cell{min-height:auto;padding:28px 24px}
  .why-cell{padding:28px 24px}
  .svc{padding:24px}
  .rev{padding:26px 22px}
  .pstep{padding:28px 24px}
  .split{padding:32px 28px}
  .areas-inner,.water-inner,.local-inner,.final-cta-inner{grid-template-columns:1fr;gap:24px;align-items:stretch}
  .map-frame{min-height:auto;height:300px}
  .city-grid{grid-template-columns:repeat(3,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr;gap:28px}
  .section-head{grid-template-columns:1fr;gap:14px;margin-bottom:32px}
  .section-head p{max-width:none}
  .section{padding:64px 0}
  .areas,.water,.local{padding:64px 0}
  .final-cta{padding:64px 0}
  .mobile-sticky{display:flex}
  body{padding-bottom:84px}
  .topbar{font-size:10.5px}
  .topbar .container{gap:10px}
  .cta-prompt{flex-direction:column;align-items:flex-start;gap:16px;padding:24px}
  .cta-prompt-text{font-size:18px}
  .cta-prompt-ctas{width:100%;flex-direction:column}
  .cta-prompt-ctas .btn{width:100%}
  .btn-call-mega{width:100%}
  .btn-call-mega .call-num{font-size:24px}
  .water-badges{grid-template-columns:1fr}
  .water-ctas{flex-direction:column;align-items:stretch}
  .water-ctas .btn{width:100%}
  .local-warning{flex-direction:column;align-items:stretch;text-align:center;gap:14px}
  .zip-cta{flex-direction:column;align-items:stretch;text-align:center;gap:14px}
  .city-grid{grid-template-columns:1fr 1fr}
  .causes-grid{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{width:100%}
  .cta-band-inner{flex-direction:column;align-items:stretch;text-align:center;gap:16px}
  .cta-band-ctas{justify-content:center;flex-direction:column}
  .cta-band-ctas .btn{width:100%}
  .hf-row{grid-template-columns:1fr}
  .hero-trust .tt{padding:8px 12px;font-size:10.5px}
}
@media(max-width:560px){
  .hero h1{font-size:48px;line-height:0.9}
  .footer-inner{grid-template-columns:1fr}
  .trust-bar-inner{grid-template-columns:1fr 1fr}
  .city-grid{grid-template-columns:1fr 1fr}
  .tb-num{font-size:28px}
  .num-cell .val{font-size:46px}
  .svc.featured h3{font-size:30px}
}
/* H1 tighter fit on small phones — prevents 4-line wrap of long city/service H1s */
@media(max-width:430px){
  .hero h1,.page-hero h1{font-size:36px !important;line-height:0.95 !important;letter-spacing:-0.04em !important;margin-bottom:14px !important}
  .hero h1 em,.page-hero h1 em{padding:0 0.06em !important;line-height:1 !important;display:inline !important}
  .hero h1 br,.page-hero h1 br{display:none !important}
  .hero h1{margin-top:0}
}
@media(max-width:360px){
  .hero h1,.page-hero h1{font-size:32px !important}
}

/* ============================================================ */
/* ===== PAGE HEROES (sub-pages) — smaller than homepage ====== */
/* ============================================================ */
.page-hero{position:relative;background:var(--navy);overflow:hidden;color:var(--white);border-bottom:3px solid var(--sky);padding:62px 0 56px}
.page-hero::before{content:'';position:absolute;top:-15%;right:-10%;width:55%;height:120%;background:radial-gradient(ellipse,rgba(66,174,233,0.18) 0%,transparent 60%);z-index:0}
.page-hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--sky) 50%,transparent 100%);z-index:5}
.page-hero-grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,0.03) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}
.page-hero-inner{position:relative;z-index:3;max-width:1280px;margin:0 auto;padding:0 28px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:0.10em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,0.62);transition:color 0.2s}
.breadcrumb a:hover{color:var(--sky)}
.breadcrumb .sep{color:rgba(255,255,255,0.30)}
.breadcrumb .current{color:var(--sky);font-weight:700}
.page-hero-kicker{display:inline-flex;align-items:center;gap:10px;padding:6px 12px;background:rgba(124,214,83,0.14);border:1px solid rgba(124,214,83,0.30);font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;color:var(--green);margin-bottom:18px}
.page-hero-kicker::before{content:'';width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 1.6s infinite}
.page-hero h1{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(38px,5.5vw,72px);line-height:0.94;letter-spacing:-0.045em;color:var(--white);margin-bottom:18px;text-transform:uppercase;max-width:920px}
.page-hero h1 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 0.08em;display:inline-block;line-height:1}
.page-hero-lede{font-size:17.5px;line-height:1.6;color:rgba(255,255,255,0.84);max-width:660px;margin-bottom:24px}
.page-hero-lede strong{color:var(--white);font-weight:700;background:rgba(66,174,233,0.18);padding:1px 5px}
.page-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.page-hero-meta{margin-top:18px;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:rgba(255,255,255,0.62);letter-spacing:0.04em;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.page-hero-meta::before{content:'';width:18px;height:2px;background:var(--sky)}

/* PAGE PROSE */
.prose{max-width:760px;margin:0 auto;font-size:16.5px;line-height:1.75;color:var(--text-2)}
.prose h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(28px,3.6vw,40px);line-height:1.05;letter-spacing:-0.035em;color:var(--navy);text-transform:uppercase;margin:42px 0 18px}
.prose h2 em{font-style:italic;background:var(--sky);color:var(--navy);padding:0 0.08em}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:22px;line-height:1.2;color:var(--navy);text-transform:uppercase;margin:26px 0 12px;letter-spacing:-0.018em}
.prose p{margin-bottom:16px;color:var(--text-2)}
.prose p strong{color:var(--navy);font-weight:700}
.prose ul{margin:0 0 18px 0;padding-left:0;list-style:none}
.prose ul li{padding:7px 0 7px 28px;position:relative;color:var(--text-2)}
.prose ul li::before{content:'✓';position:absolute;left:0;top:7px;color:var(--green-deep);font-weight:900;font-size:15px}
.prose .callout{margin:24px 0;padding:20px 24px;background:var(--bg);border-left:4px solid var(--orange);font-size:15.5px;line-height:1.6}
.prose .callout strong{color:var(--navy);font-weight:800}
.prose a{color:var(--sky-deep);font-weight:700;border-bottom:2px solid rgba(66,174,233,0.30);transition:border-color 0.2s}
.prose a:hover{border-color:var(--sky-deep)}

/* RELATED LINKS GRID */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:44px}
.related-card{background:var(--white);border:1.5px solid var(--line-2);padding:22px;display:flex;flex-direction:column;gap:8px;transition:all 0.25s;text-decoration:none;color:inherit;position:relative}
.related-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--orange);transition:width 0.4s}
.related-card:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:var(--shadow)}
.related-card:hover::before{width:100%}
.related-card .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--orange);font-weight:700;letter-spacing:0.16em;text-transform:uppercase}
.related-card h4{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:17.5px;color:var(--navy);text-transform:uppercase;letter-spacing:-0.018em;line-height:1.15}
.related-card p{font-size:13.5px;color:var(--text-2);line-height:1.55}
.related-card .arrow{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--navy);font-weight:700;margin-top:auto;display:inline-flex;align-items:center;gap:6px}
.related-card:hover .arrow{color:var(--orange)}

/* MOBILE PAGE */
@media(max-width:767px){
  .page-hero{padding:48px 0 44px}
  .page-hero h1{font-size:38px;line-height:0.95}
  .page-hero-lede{font-size:16px}
  .related-grid{grid-template-columns:1fr;gap:12px}
  .prose h2{margin-top:32px}
  .breadcrumb{font-size:10.5px}
}

/* ============================================================ */
/* ===== NAV DROPDOWNS (Services + Locations) ================= */
/* ============================================================ */
.nav-links{align-items:center}
.nav-item-drop{position:relative}
.nav-item-drop > a{display:inline-flex;align-items:center;gap:5px}
.nav-item-drop > a::after{content:'▾';font-size:9px;color:var(--orange);transition:transform 0.2s;display:inline-block}
.nav-item-drop:hover > a::after,.nav-item-drop:focus-within > a::after{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px);background:var(--white);border:2px solid var(--navy);min-width:260px;padding:8px 0;opacity:0;visibility:hidden;transition:opacity 0.18s,transform 0.18s,visibility 0s 0.18s;z-index:120;box-shadow:0 14px 40px rgba(14,26,44,0.20)}
.nav-dropdown::before{content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);width:14px;height:14px;background:var(--white);border-top:2px solid var(--navy);border-left:2px solid var(--navy);transform:translateX(-50%) rotate(45deg)}
.nav-item-drop:hover .nav-dropdown,.nav-item-drop:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);transition:opacity 0.18s,transform 0.18s}
.nav-dropdown a{display:block;padding:11px 20px;font-size:13px;font-weight:600;color:var(--navy);text-transform:none;letter-spacing:0;white-space:nowrap;border:0;transition:background 0.15s,color 0.15s}
.nav-dropdown a:hover{background:var(--bg);color:var(--orange)}
.nav-dropdown a strong{color:var(--orange);font-weight:800;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.10em;text-transform:uppercase;margin-right:8px;display:inline-block;min-width:42px}
.nav-dropdown.dropdown-wide{min-width:320px}
.nav-dropdown.dropdown-2col{min-width:520px;display:grid;grid-template-columns:1fr 1fr;gap:0}
.nav-dropdown-divider{display:block;border-top:1px solid var(--line);margin:6px 0}
.nav-dropdown-section{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--orange);padding:8px 20px 4px;display:block}

/* ============================================================ */
/* ===== MOBILE NAV DRAWER (v9 — full rewrite) ================ */
/* Single source of truth. Desktop styles above are untouched.   */
/* ============================================================ */
.nav-toggle{display:none;background:transparent;border:0;width:44px;height:44px;padding:0;cursor:pointer;position:relative;flex-shrink:0;justify-content:center;align-items:center;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--navy);transition:transform 0.28s,opacity 0.18s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.nav-backdrop{position:fixed;inset:0;background:rgba(8,18,32,0.45);z-index:998;opacity:0;visibility:hidden;transition:opacity 0.25s,visibility 0s 0.25s;pointer-events:none}
.nav-backdrop.open{opacity:1;visibility:visible;transition:opacity 0.25s;pointer-events:auto}

@media(max-width:767px){
  /* Hamburger visible · desktop call CTA hidden */
  .nav-toggle{display:inline-flex}
  .nav-cta{display:none}
  .topnav .container{grid-template-columns:auto 1fr auto;gap:10px}

  /* iOS Safari: kill .topnav stacking context when drawer is open
     (.topnav has backdrop-filter + z-index + sticky, would trap drawer) */
  body.nav-open .topnav{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;z-index:auto !important;position:static !important}
  body.nav-open{overflow:hidden}

  /* DRAWER — slide-in from right · z:999 above overlay
     No CSS transition — JS handles the animation via Element.animate() for reliability
     across iOS Safari and Chromium contexts where CSS transitions can stall */
  .nav-links{display:flex !important;flex-direction:column;align-items:stretch;justify-content:flex-start;position:fixed !important;top:0 !important;right:0 !important;left:auto !important;bottom:0 !important;width:min(88vw,420px) !important;height:100dvh;height:100vh;max-height:100vh;background:#ffffff !important;padding:0 !important;gap:0 !important;z-index:999 !important;transform:translateX(105%) !important;transition:none !important;box-shadow:-12px 0 40px rgba(14,26,44,0.30);overflow-y:auto !important;overflow-x:hidden !important;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
  .nav-links.open{transform:translateX(0) !important}

  /* Even more defensive — kill any leftover desktop dropdown positioning that could
     leak into mobile via specificity quirks. Applies to all .nav-dropdown
     descendants regardless of state. */
  .nav-links .nav-dropdown,
  .nav-links .nav-dropdown.dropdown-wide,
  .nav-links .nav-dropdown.dropdown-2col{
    position:static !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    transform:none !important;
    margin-left:0 !important;
    margin-right:0 !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
    overflow:visible !important;
  }
  .nav-links .nav-dropdown a{
    display:flex !important;
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:unset !important;
    margin:0 !important;
    text-align:left !important;
  }
}

/* Phones < 600px: drawer goes full-width for maximum readability */
@media(max-width:599px){
  .nav-links{width:100vw !important;max-width:100vw !important}
}

/* RE-WRAP — these rules MUST be inside @media(max-width:767px) — they were orphaned by a prior edit, breaking desktop nav */
@media(max-width:767px){
  /* Drawer header (sticky) — logo + brand + close X */
  .drawer-head{display:flex;align-items:center;gap:12px;padding:18px 18px 18px 20px;border-bottom:2px solid var(--navy);background:#ffffff;position:sticky;top:0;z-index:5;flex-shrink:0}
  .drawer-logo{width:44px;height:44px;flex-shrink:0;display:block}
  .drawer-brand{flex:1;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:14px;line-height:1;color:var(--navy);text-transform:uppercase;letter-spacing:-0.01em;display:flex;flex-direction:column;gap:3px;min-width:0;overflow:hidden}
  .drawer-brand small{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:8.5px;letter-spacing:0.10em;color:var(--text-2);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .drawer-x{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:transparent;border:1.5px solid var(--orange);color:var(--orange);font-size:18px;cursor:pointer;font-weight:800;line-height:1;touch-action:manipulation;-webkit-tap-highlight-color:rgba(221,108,45,0.20);padding:0}
  .drawer-x:active{background:var(--orange);color:#ffffff}

  /* Top-level items (Home / Services▾ / Locations▾ / Reviews / Contact▾) */
  .nav-links > a,.nav-item-drop > a{width:100%;padding:18px 22px;font-size:15px;border-bottom:1px solid var(--line);text-align:left;display:flex;align-items:center;gap:8px;color:var(--navy);text-transform:uppercase;letter-spacing:0.04em;font-weight:700;text-decoration:none;background:#ffffff;justify-content:flex-start}
  .nav-links > a:active,.nav-item-drop > a:active{background:var(--bg);color:var(--orange)}

  /* Dropdown parent — flatten desktop positioning */
  .nav-item-drop{position:static;display:block;width:100%}
  .nav-item-drop > a::after{content:'\25BE';display:inline-block !important;margin-left:auto;font-size:11px;color:var(--orange);transition:transform 0.22s;flex-shrink:0}
  /* Neutralize desktop hover-rotation; only .expanded rotates the arrow */
  .nav-item-drop:hover > a::after,.nav-item-drop:focus-within > a::after{transform:none}
  .nav-item-drop.expanded > a::after{transform:rotate(180deg)}
  .nav-item-drop.expanded:hover > a::after,.nav-item-drop.expanded:focus-within > a::after{transform:rotate(180deg)}

  /* Dropdown content — collapsed by default, shown only via .expanded class */
  .nav-dropdown{display:none !important;position:static !important;background:var(--bg) !important;border:0 !important;box-shadow:none !important;padding:0 !important;min-width:0 !important;width:100% !important;max-width:100% !important;opacity:1 !important;visibility:visible !important;transform:none !important;left:auto !important;top:auto !important;right:auto !important;grid-template-columns:1fr !important;gap:0 !important}
  .nav-dropdown::before{display:none !important}
  /* Neutralize desktop :hover/:focus-within — only .expanded reveals */
  .nav-item-drop:hover .nav-dropdown,.nav-item-drop:focus-within .nav-dropdown{display:none !important;transform:none !important;opacity:1 !important;visibility:visible !important}
  .nav-item-drop.expanded > .nav-dropdown{display:block !important}
  .nav-item-drop.expanded > .nav-dropdown.dropdown-2col{display:block !important}

  /* Sublinks inside dropdown — indented, full width, no truncation */
  .nav-dropdown a{display:flex;align-items:center;width:100%;padding:13px 22px 13px 38px;font-size:13.5px;border-bottom:1px solid var(--line);color:var(--navy);text-decoration:none;text-transform:none;letter-spacing:0;white-space:normal;background:transparent;box-sizing:border-box;gap:0}
  .nav-dropdown a:hover{background:transparent;color:var(--navy)}
  .nav-dropdown a:active{background:var(--sky-soft);color:var(--orange)}
  .nav-dropdown a:last-child{border-bottom:0}
  /* Number badges (01 / 02 / ...) — small, no width-blowup */
  .nav-dropdown a strong{color:var(--orange);font-weight:800;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.10em;text-transform:uppercase;margin-right:10px;display:inline-block;min-width:24px;flex-shrink:0}
  /* Group section labels (// HQ & Office, // Orlando Metro, ...) */
  .nav-dropdown-section{display:block;padding:14px 22px 6px 22px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--orange);background:var(--bg);border-bottom:1px solid var(--line)}
  .nav-dropdown-divider{display:none}

  /* Bottom phone CTA injected by JS */
  .drawer-cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:8px;padding:20px 22px;background:var(--orange);color:#ffffff;font-family:'Inter Tight',sans-serif;font-weight:900;font-size:17px;letter-spacing:0.02em;text-transform:uppercase;border:0;text-decoration:none;touch-action:manipulation;-webkit-tap-highlight-color:rgba(221,108,45,0.40);box-shadow:0 -4px 16px rgba(221,108,45,0.20);flex-shrink:0}
  .drawer-cta:active{background:var(--orange-dim)}

  /* Tap-friendly all interactive */
  .nav-links a,.nav-item-drop > a,.nav-dropdown a,.drawer-x,.drawer-cta{touch-action:manipulation !important;-webkit-tap-highlight-color:rgba(66,174,233,0.18);pointer-events:auto !important;cursor:pointer}
  .nav-links *{pointer-events:auto}
}

/* MOBILE EXTRA TIGHTENING (v8.2) */
@media(max-width:767px){
  /* Topbar: hide long license string, keep dispatch + phone */
  .topbar{padding:6px 0;font-size:10px}
  .topbar .container{gap:8px;justify-content:space-between;padding:0 14px}
  .topbar .lic{display:none}
  .topbar .sep{display:none}
  /* Trust signals reduced */
  .hero-trust{padding:0;gap:0}
  .hero-trust .tt{padding:7px 10px;font-size:10px;border-right:1px solid rgba(255,255,255,0.12)}
  /* Section paddings tighter on mobile */
  .section,.areas,.water,.local,.final-cta{padding:48px 0}
  .container{padding:0 18px}
  .hero-inner{padding:48px 18px 56px;gap:32px}
  /* Form padding tighter */
  .hero-form,.final-form{padding:22px 18px}
  .hf-form input,.hf-form select,.hf-submit{padding:13px 14px;font-size:14.5px}
  .hf-submit{padding:16px 14px;font-size:14px}
  /* Mobile sticky improvements */
  .mobile-sticky{padding:9px;gap:8px}
  .mobile-sticky a{padding:14px 8px;font-size:14px}
  /* Topnav tighter */
  .topnav .container{padding-top:11px;padding-bottom:11px}
  .brand-name{font-size:14.5px}
  .brand-name small{font-size:8.5px;margin-top:2px}
  .brand-mark{width:38px;height:38px}
  /* Trust bar */
  .trust-bar{padding:0}
  .trust-bar-inner{padding:18px 0}
  .tb-cell{padding:10px 6px}
  .tb-num{font-size:24px}
  .tb-lbl{font-size:9.5px}
  /* Section heads */
  .section-head h2{font-size:32px}
  .kicker{font-size:10.5px}
  /* Footer compact */
  .footer-inner{padding:42px 18px 28px;gap:24px}
  .footer-bottom{padding:18px;font-size:11px;flex-direction:column;align-items:center;text-align:center;gap:6px}
  /* Reviews/cards tighter */
  .rev{padding:22px 18px}
  .rev blockquote{font-size:14.5px;line-height:1.5}
  /* FAQ */
  .faq-q{font-size:15px;padding:16px 14px;line-height:1.35}
  .faq-a{font-size:14px;padding:0 14px 16px}
  /* Hero meta line */
  .hero-meta{font-size:12px}
}

/* Very narrow mobile — extra compact */
@media(max-width:430px){
  .hero h1{font-size:42px;line-height:0.92}
  .hero-lede{font-size:15.5px}
  .hf-title{font-size:24px}
  .btn-call-mega{padding:18px 24px}
  .btn-call-mega .call-num{font-size:22px}
  .btn-call-mega::before{font-size:22px;margin-bottom:6px}
  .hero-status{font-size:10px;padding:5px 10px;margin-bottom:16px}
  .section-head h2{font-size:28px}
  .topbar{font-size:9.5px}
  .brand-name{font-size:13.5px}
  .brand-name small{display:none}
  .nav-cta{padding:9px 10px;font-size:11.5px}
  .topnav .container{gap:6px}
  .num-cell .val{font-size:38px}
  .water-content h2,.local-content h2{font-size:30px}
  .footer-col h5{font-size:13px}
  .topbar .container{font-size:9.5px}
}

/* ============================================================ */
/* ===== v8.4 — TRUE MOBILE-FIRST OVERHAUL (≤768px) =========== */
/* User brief: clean, compact, conversion-focused mobile         */
/* ============================================================ */

/* Default desktop visibility for swap spans */
.lic-short{display:inline}
.lic-full{display:inline}
.cta-num{display:inline}
.cta-short{display:none}
.cta-icon{display:inline-flex;margin-right:6px}
.lede-full{display:inline}
.lede-short{display:none}

@media(max-width:768px){
  /* ============ TOPBAR — ultra-compact (≤36px) ============ */
  .topbar{padding:5px 0;font-size:9px;letter-spacing:0.05em;line-height:1.2}
  .topbar .container{gap:8px;padding:0 14px;flex-wrap:nowrap;justify-content:space-between;overflow:hidden}
  .topbar .pulse{flex-shrink:0;font-size:9.5px;gap:5px;letter-spacing:0.06em}
  .topbar .pulse::before{width:6px;height:6px}
  .topbar .lic{display:none}
  .topbar .lic-full{display:none}
  .topbar .lic-short{display:none}
  .topbar .sep{display:none}
  .topbar a{flex-shrink:0;font-size:10px;white-space:nowrap;font-weight:700;letter-spacing:0.04em}

  /* ============ HEADER — logo grande izq, hamburger derecha ============ */
  .topnav .container{grid-template-columns:auto 1fr auto;gap:12px;padding:10px 14px}
  .brand{gap:10px;font-size:13px;min-width:0;overflow:hidden;flex-shrink:1;line-height:1}
  .brand-mark{width:52px;height:52px;flex-shrink:0}
  .brand-name{display:flex;flex-direction:column;font-size:13px;line-height:1;letter-spacing:-0.01em;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
  .brand-name small{font-size:8px;margin-top:3px;letter-spacing:0.10em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;font-weight:600}
  .nav-toggle{width:42px;height:42px;flex-shrink:0;gap:5px;margin-left:auto}
  .nav-toggle span{width:26px;height:2.5px}
  .nav-cta{display:none}

  /* ============ HERO — taller, premium feel, form below the fold ============ */
  .hero-bg::after{background:linear-gradient(180deg,rgba(14,26,44,0.96) 0%,rgba(14,26,44,0.78) 60%,rgba(14,26,44,0.95) 100%)}
  .hero-grid-bg{background-size:48px 48px}
  .hero-inner{grid-template-columns:1fr;gap:0;padding:48px 16px 56px;align-items:start;min-height:78vh}
  .hero-status{font-size:9.5px;padding:5px 11px;margin-bottom:18px;letter-spacing:0.16em}
  .hero h1{font-size:clamp(48px,14vw,72px);line-height:0.9;letter-spacing:-0.045em;margin-bottom:18px;max-width:100%;word-break:keep-all;overflow-wrap:normal}
  .hero h1 .strike{display:inline-block;max-width:100%}
  .hero h1 em{padding:0 8px;display:inline-block;line-height:1.0;max-width:calc(100% - 16px);box-decoration-break:clone;-webkit-box-decoration-break:clone}
  .hero-lede{font-size:15.5px;line-height:1.55;margin-bottom:22px;max-width:none}
  .hero-lede .lede-full{display:none}
  .hero-lede .lede-short{display:inline}
  /* Trust badges visible (3 essential ones) for premium feel */
  .hero-trust{display:inline-flex;flex-wrap:wrap;margin-bottom:22px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);padding:0;gap:0;width:100%}
  .hero-trust .tt{padding:8px 10px;font-size:10px;letter-spacing:0.08em;color:rgba(255,255,255,0.92);border-right:1px solid rgba(255,255,255,0.10);flex:1;justify-content:center;text-align:center}
  .hero-trust .tt::before{font-size:11px}
  .hero-trust .tt:nth-child(4),.hero-trust .tt:nth-child(5){display:none}
  /* Hero meta line (★5.0 · 400+ verified · <2hr) restored */
  .hero-meta{display:flex;font-size:11.5px;letter-spacing:0.04em;margin-top:14px;flex-wrap:wrap;gap:8px;line-height:1.4}

  /* HERO CTAs — "Call Now" + "Free Inspection" simple, no number breaking */
  .hero-ctas{flex-direction:row;gap:8px;margin-bottom:12px;width:100%}
  .hero-ctas .btn-call-mega{flex:1;padding:0;height:54px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;font-size:0;letter-spacing:0;animation:none;box-shadow:0 6px 18px rgba(221,108,45,0.35);white-space:nowrap;text-transform:uppercase;font-weight:900;line-height:1}
  .hero-ctas .btn-call-mega::before{content:'\01F4DE';font-size:16px;margin-bottom:0;margin-right:0;filter:none}
  .hero-ctas .btn-call-mega .call-label{display:none}
  .hero-ctas .btn-call-mega .call-num{display:none}
  /* "Call Now" text injected via ::after */
  .hero-ctas .btn-call-mega::after{content:'Call Now';font-size:14.5px;letter-spacing:0.06em;font-weight:900;color:#fff;line-height:1;text-transform:uppercase}
  .hero-ctas .btn-ghost-arrow{flex:1;height:54px;padding:0 10px;font-size:12.5px;letter-spacing:0.04em;white-space:nowrap;display:flex;align-items:center;justify-content:center;border-width:1.5px}
  .hero-ctas .btn-ghost-arrow::after{margin-left:4px}

  /* HERO FORM — appears after scrolling past hero (separated with breathing space) */
  .hero-form{padding:18px 16px 20px;margin-top:24px;border-width:1.5px}
  .hero-form::before{height:3px;width:42px}
  .hero-form::after{height:3px;left:44px;width:24px}
  .hf-tag{font-size:8.5px;padding:3px 8px;margin-bottom:8px;letter-spacing:0.16em}
  .hf-title{font-size:20px;margin-bottom:3px;line-height:1.0;letter-spacing:-0.02em}
  .hf-sub{font-size:10px;margin-bottom:10px;letter-spacing:0.04em}
  .hf-form{gap:7px}
  .hf-form input,.hf-form select{padding:10px 12px;font-size:14.5px;height:42px;border-radius:0}
  .hf-row{grid-template-columns:1fr 1fr;gap:7px}
  .hf-submit{padding:12px 12px;font-size:12.5px;height:46px;letter-spacing:0.06em}
  .hf-callback{font-size:10px;padding:7px 9px}
  .hf-foot{font-size:9px;gap:4px;flex-wrap:wrap}

  /* TRUST BAR — show 3 cells main, hide 4-5 */
  .trust-bar{padding:0}
  .trust-bar-inner{grid-template-columns:repeat(3,1fr);padding:14px 0}
  .tb-cell:nth-child(4),.tb-cell:nth-child(5){display:none}
  .tb-cell{padding:6px 4px;border-right:1px solid var(--line-dark)}
  .tb-cell:last-child{border-right:0}
  .tb-num{font-size:22px;line-height:1}
  .tb-num small{font-size:12px}
  .tb-lbl{font-size:8.5px;margin-top:2px;letter-spacing:0.06em}

  /* SECTIONS — tighter padding */
  .section,.areas,.water,.local,.final-cta{padding:40px 0}
  .container{padding:0 16px}
  .section-head{margin-bottom:24px}
  .section-head h2{font-size:28px;line-height:0.98}
  .kicker{font-size:9.5px}

  /* CARDS — compact */
  .why-cell,.svc,.rev,.ba,.pstep,.num-cell,.loc-card,.split{padding:22px 18px}
  .rev blockquote{font-size:14px;line-height:1.5;margin:8px 0}
  .num-cell .val{font-size:42px}
  .num-cell .desc{font-size:12.5px;line-height:1.4}

  /* FAQ */
  .faq-q{font-size:14.5px;padding:14px 14px;line-height:1.3;gap:8px}
  .faq-a{font-size:13.5px;padding:0 14px 14px;line-height:1.55}
  .faq-toggle{font-size:18px}

  /* CTAs throughout site — compact */
  .btn{height:48px;padding:0 18px;font-size:13px}
  .btn-call-mega{padding:14px 18px;animation:none;box-shadow:0 6px 18px rgba(221,108,45,0.40)}

  /* PROSE */
  .prose{font-size:15.5px;line-height:1.65}
  .prose h2{font-size:26px}
  .prose h3{font-size:18px}

  /* PAGE HERO — sub-pages */
  .page-hero{padding:32px 0 28px}
  .page-hero h1{font-size:32px;line-height:0.96}
  .page-hero-lede{font-size:14.5px}
  .breadcrumb{font-size:9.5px}

  /* FOOTER */
  .footer-inner{grid-template-columns:1fr;gap:24px;padding:36px 16px 24px}
  .footer-col h5{font-size:12.5px}
  .footer-bottom{padding:14px 16px;font-size:10px;line-height:1.5;flex-direction:column;text-align:center;gap:6px}

  /* NUMBERS GRID */
  .numbers-grid{grid-template-columns:1fr 1fr}
  .num-cell{padding:18px 14px}

  /* AREAS / WATER / LOCAL */
  .areas-inner,.water-inner,.local-inner,.final-cta-inner{grid-template-columns:1fr;gap:20px;padding:0 16px;align-items:stretch}
  .map-frame{min-height:auto;height:260px}
  .city-grid{grid-template-columns:repeat(2,1fr)}
  .locations-grid{grid-template-columns:1fr}
  .loc-card{border-right:0;border-bottom:1px solid var(--line)}
  .loc-card:last-child{border-bottom:0}
  .water-content h2,.local-content h2{font-size:26px}
  .humidity{padding:14px;font-size:12px}

  /* MOBILE STICKY — compact (≤66px total), hidden until scroll>300px */
  body{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}
  .mobile-sticky{padding:6px 8px calc(6px + env(safe-area-inset-bottom,0px));gap:6px;border-top-width:1.5px;transform:translateY(110%);transition:transform 0.32s cubic-bezier(0.34,1.2,0.64,1)}
  .mobile-sticky.show{transform:translateY(0)}
  .mobile-sticky a{padding:0;height:50px;font-size:13px;letter-spacing:0.06em;border-width:1.5px;line-height:1;font-weight:900}

  /* SCROLL-PROG bar thinner on mobile */
  .scroll-prog{height:2px}

  /* DRAWER (already at 980px breakpoint, nothing to change here) */
}

/* Very narrow phones (≤400px iPhone X/12 mini) */
@media(max-width:400px){
  .hero h1{font-size:44px;line-height:0.88}
  .hero h1 em{padding:0 6px}
  .hero-lede{font-size:14px;line-height:1.4}
  .hf-title{font-size:18px}
  .hf-tag{font-size:8px}
  .hero-ctas{gap:7px}
  .hero-ctas .btn-call-mega::after{font-size:13.5px}
  .hero-ctas .btn-ghost-arrow{font-size:11.5px;padding:0 8px}
  .topbar{padding:4px 0}
  .topbar .pulse{font-size:9px}
  .topbar a{font-size:9.5px}
  .brand-mark{width:46px;height:46px}
  .brand-name{font-size:12px;max-width:160px}
  .brand-name small{font-size:7.5px}
  .nav-toggle{width:40px;height:40px}
  .topnav .container{gap:10px;padding:8px 12px}
  .section-head h2{font-size:24px}
  .container,.hero-inner{padding-left:14px;padding-right:14px}
  .mobile-sticky a{font-size:12.5px;height:48px;letter-spacing:0.04em}
}

/* ============================================================ */
/* TABLET COMPACT DESKTOP NAV (768-1023px) — iPad portrait/landscape */
/* Desktop nav now applies from 768px+. At iPad widths, tighten so the nav fits. */
/* ============================================================ */
@media(min-width:768px) and (max-width:1023px){
  /* Smaller nav-link font + tighter gap so 5 items + dropdowns fit */
  .nav-links{gap:14px}
  .nav-links a{font-size:12px;letter-spacing:0.02em}
  .nav-item-drop > a::after{font-size:8px;margin-left:3px}
  /* Brand text smaller on tablet to free nav room */
  .brand-name{font-size:14px}
  .brand-name small{font-size:8.5px}
  .brand-mark{width:42px;height:42px}
  /* Topnav padding tighter */
  .topnav .container{gap:14px;padding-top:12px;padding-bottom:12px}
  /* Phone CTA tighter (icon + short num only) */
  .nav-cta{padding:9px 12px;font-size:12px}
  .nav-cta .cta-num{display:none}
  .nav-cta .cta-short{display:inline}
  /* Hero — single column on tablet to give H1 full width (avoids 4-line wrap) */
  .hero-inner{gap:36px;padding:56px 22px 48px;grid-template-columns:1fr}
  .hero h1{font-size:clamp(42px,6vw,60px) !important;line-height:0.95;max-width:760px}
  .hero-lede{font-size:16px;max-width:680px}
  .hero-form{max-width:580px;margin-top:8px}
  /* Trust bar 5 columns at iPad */
  .trust-bar-inner{grid-template-columns:repeat(5,1fr)}
  /* Why grid 2col instead of 3 */
  .why-grid,.svc-grid{grid-template-columns:1fr 1fr}
  /* Section padding tighter */
  .section,.areas,.water,.local,.final-cta{padding:64px 0}
  /* Page-hero (city/service pages) tighter H1 */
  .page-hero h1{font-size:clamp(36px,5vw,52px);max-width:760px}
}

/* ============================================================ */
/* H1 sizing refinement — reduce desktop max so it doesn't billboard */
/* the form column (city pages especially)                            */
/* ============================================================ */
.hero h1{font-size:clamp(36px,3.8vw,56px) !important}
.page-hero h1{font-size:clamp(36px,4vw,60px) !important;max-width:680px}

/* ============================================================ */
/* PREMIUM CITY HERO — Editorial 3-line H1 (refined, NOT billboard) */
/* MOLD / REMEDIATION / in [City], FL                              */
/* ============================================================ */
.city-hero-h1{
  display:block;
  font-family:'Inter Tight',sans-serif;
  margin:0 0 24px 0;
  color:var(--white);
}
.city-hero-h1-line{
  display:block;
  font-size:clamp(48px,4.6vw,72px);
  font-weight:900;
  letter-spacing:-0.04em;
  text-transform:uppercase;
  line-height:0.94;
}
.city-hero-h1-loc{
  display:block;
  margin-top:14px;
  font-size:clamp(20px,1.6vw,28px);
  line-height:1.1;
  font-weight:500;
  letter-spacing:-0.015em;
  text-transform:none;
  color:rgba(255,255,255,0.78);
}
.hero h1.city-hero-h1 .city-hero-h1-loc em,
.page-hero h1.city-hero-h1 .city-hero-h1-loc em{
  color:var(--sky) !important;
  font-style:italic !important;
  font-weight:700 !important;
  background:transparent !important;
  padding:0 !important;
  box-shadow:none !important;
  display:inline !important;
  line-height:inherit !important;
}
@media(max-width:1023px){
  .city-hero-h1-line{font-size:clamp(44px,5.5vw,60px)}
  .city-hero-h1-loc{font-size:clamp(18px,2.2vw,24px);margin-top:10px}
}
@media(max-width:767px){
  .city-hero-h1{margin-bottom:18px}
  .city-hero-h1-line{font-size:clamp(38px,10vw,56px) !important;line-height:0.92}
  .city-hero-h1-loc{font-size:clamp(16px,4.4vw,22px) !important;margin-top:10px;line-height:1.15}
}
/* override any global .hero h1 / .page-hero h1 sizing on .city-hero-h1 */
.hero h1.city-hero-h1,.page-hero h1.city-hero-h1{
  font-size:inherit !important;
  line-height:inherit !important;
  letter-spacing:0 !important;
  max-width:none !important;
  margin-bottom:24px !important;
  text-transform:none !important;
}

/* ============================================================ */
/* PREMIUM LOCAL INTRO — 2-col with Quick Facts card               */
/* ============================================================ */
.local-intro-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start;padding:24px 0}
.local-intro-copy h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(28px,2.6vw,40px);line-height:1.05;letter-spacing:-0.03em;color:var(--navy);text-transform:uppercase;margin:0 0 16px}
.local-intro-copy h2 em{font-style:italic;color:var(--sky-deep);background:none;padding:0}
.local-intro-copy p{font-size:16.5px;line-height:1.65;color:var(--text-2);margin:0 0 14px}
.local-intro-copy p strong{color:var(--navy);font-weight:700}
.quick-facts{background:var(--navy);color:var(--white);padding:28px 26px;border:1px solid rgba(66,174,233,0.18);border-radius:0;position:relative}
.quick-facts::before{content:'';position:absolute;top:0;left:0;width:6px;height:48px;background:var(--orange)}
.quick-facts h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;color:var(--sky);margin:0 0 18px}
.quick-facts dl{margin:0;display:grid;grid-template-columns:1fr;gap:10px}
.quick-facts dt{font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:2px}
.quick-facts dd{margin:0 0 10px 0;font-size:14.5px;line-height:1.4;font-weight:600;color:var(--white)}
.quick-facts dd:last-child{margin-bottom:0}
.quick-facts dd a{color:var(--sky);text-decoration:none;font-weight:700}
@media(max-width:980px){
  .local-intro-grid{grid-template-columns:1fr;gap:28px}
  .quick-facts{padding:22px 20px}
}

/* ============================================================ */
/* PREMIUM NEIGHBORHOODS — chips/cards instead of paragraph        */
/* ============================================================ */
.neighborhoods-chips{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 32px}
.neighborhoods-chips .chip{display:inline-flex;align-items:center;gap:8px;padding:11px 16px;background:var(--white);border:1.5px solid var(--line-2);font-family:'Inter Tight',sans-serif;font-weight:700;font-size:13.5px;color:var(--navy);transition:all 0.2s;letter-spacing:-0.005em}
.neighborhoods-chips .chip:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:0 8px 20px rgba(14,26,44,0.12)}
.neighborhoods-chips .chip.zip{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--sky-deep);font-size:13px;letter-spacing:0.04em}
.neighborhoods-chips .chip.nearby{background:var(--bg);border-style:dashed;color:var(--text-2);font-size:13px}
.neighborhoods-chips .chip.nearby::before{content:'•';color:var(--orange);margin-right:2px}
.neighborhoods-cta{display:flex;align-items:center;gap:18px;padding:20px 24px;background:var(--bg);border-left:4px solid var(--orange);margin-top:24px;flex-wrap:wrap}
.neighborhoods-cta-text{flex:1;min-width:240px;font-size:15px;color:var(--navy)}
.neighborhoods-cta-text strong{font-weight:800}

/* ============================================================ */
/* PREMIUM MAP + OFFICE — large embed + side card                  */
/* ============================================================ */
.map-premium{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;align-items:stretch;margin:32px 0}
.map-premium .map-frame-large{position:relative;min-height:480px;border:1px solid var(--line-dark);background:var(--navy);overflow:hidden}
.map-premium .map-frame-large iframe{width:100%;height:100%;border:0;display:block;min-height:480px}
.map-premium .map-frame-large .pin{position:absolute;bottom:14px;left:14px;background:var(--navy);color:var(--white);padding:8px 14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;border-left:3px solid var(--orange);z-index:2}
.office-card{background:var(--white);border:2px solid var(--navy);padding:28px 26px;display:flex;flex-direction:column;gap:18px;position:relative}
.office-card .office-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.office-card .badge{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;border:1px solid}
.office-card .badge.primary{background:var(--orange);color:var(--white);border-color:var(--orange)}
.office-card .badge.secondary{background:transparent;color:var(--navy);border-color:var(--navy)}
.office-card .badge.success{background:rgba(124,214,83,0.12);color:var(--green-deep);border-color:rgba(124,214,83,0.40)}
.office-card h3{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:22px;line-height:1.05;color:var(--navy);text-transform:uppercase;letter-spacing:-0.025em;margin:0}
.office-card .office-addr{font-size:15px;line-height:1.55;color:var(--text-2);margin:0}
.office-card .office-addr strong{color:var(--navy);font-weight:700;display:block;margin-top:6px;font-size:17px}
.office-card .office-cta{display:flex;flex-direction:column;gap:10px;margin-top:auto}
.office-card .office-cta a{padding:14px 16px;font-family:'Inter Tight',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.02em;text-transform:uppercase;text-decoration:none;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:all 0.2s}
.office-card .office-cta a.primary{background:var(--orange);color:var(--white);border:0}
.office-card .office-cta a.primary:hover{background:var(--orange-dim);transform:translateY(-2px)}
.office-card .office-cta a.outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.office-card .office-cta a.outline:hover{background:var(--navy);color:var(--white)}
@media(max-width:980px){
  .map-premium{grid-template-columns:1fr;gap:18px}
  .map-premium .map-frame-large{min-height:340px}
  .map-premium .map-frame-large iframe{min-height:340px}
}

/* ============================================================ */
/* LOCAL RISK CARDS — Visual risk grid                              */
/* ============================================================ */
.risk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.risk-card{background:var(--white);border:1.5px solid var(--line-2);padding:22px 20px;display:flex;flex-direction:column;gap:10px;transition:all 0.25s;position:relative;overflow:hidden}
.risk-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--orange);transition:width 0.4s}
.risk-card:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:0 12px 28px rgba(14,26,44,0.10)}
.risk-card:hover::before{width:100%}
.risk-card .risk-num{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;color:var(--orange);letter-spacing:0.14em;text-transform:uppercase}
.risk-card h4{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:17px;line-height:1.15;color:var(--navy);text-transform:uppercase;letter-spacing:-0.02em;margin:0}
.risk-card p{font-size:13.5px;line-height:1.55;color:var(--text-2);margin:0}
@media(max-width:768px){.risk-grid{grid-template-columns:1fr 1fr;gap:10px}}
@media(max-width:480px){.risk-grid{grid-template-columns:1fr}}

/* ============================================================ */
/* HERO ZIP FIELD — fits inline with other inputs                  */
/* ============================================================ */
.hf-form .hf-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hf-form .hf-row input{width:100%}
@media(max-width:480px){.hf-form .hf-row{grid-template-columns:1fr}}

/* ============================================================ */
/* H1 MAX 3 LINES — clamp font + line-height across mobile sizes */
/* ============================================================ */
@media(max-width:767px){
  .hero h1,.page-hero h1{
    font-size:clamp(28px,8vw,48px) !important;
    line-height:0.95 !important;
    letter-spacing:-0.035em !important;
    margin-bottom:18px !important;
    max-height:calc(0.95em * 3) !important;
    overflow:hidden !important;
    word-break:keep-all !important;
    overflow-wrap:break-word !important;
  }
  .hero h1 em,.page-hero h1 em{
    padding:0 0.08em !important;
    line-height:1 !important;
    display:inline !important;
    box-shadow:none !important;
  }
  /* Strip aggressive <br/> on mobile */
  .hero h1 br,.page-hero h1 br{display:none !important}
}

/* ============================================================ */
/* PHASE 4 — SEO IMAGE SUPPORT                                   */
/* Allow <img> inside .svc-photo and .ba-img while preserving    */
/* identical visual design (background-image fallback gone — img */
/* is now the actual element rendering the visual). Google can   */
/* now crawl + index these images per city page.                 */
/* ============================================================ */
.svc-photo img,
.ba-img img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.svc-photo img{z-index:0}
.ba-img img{transition:transform 0.6s ease,filter 0.4s ease}
.ba:hover .ba-img img{transform:scale(1.05);filter:brightness(0.85)}

/* Visually-hidden description for screen readers + alt fallback  */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================================================ */
/* PHASE 5 — PREMIUM LOCAL INTRO + NEARBY AREAS                  */
/* Operator brief: "no más muros de texto" → local intro must be */
/* heading + 1 short copy + 6 visual bullets + real image +      */
/* compact quick-facts + CTA. Nearby areas adds internal link    */
/* equity at bottom of every city page.                           */
/* ============================================================ */

/* ===== Premium local intro 2-col grid ====================== */
.local-intro-premium{display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:start;padding:8px 0}
.local-intro-left{display:flex;flex-direction:column}
.local-intro-left h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(30px,2.8vw,44px);line-height:1.02;letter-spacing:-0.03em;color:var(--navy);text-transform:uppercase;margin:0 0 8px}
.local-intro-left h2 em{font-style:italic;color:var(--sky-deep);background:none;padding:0}
.local-intro-left .lead-sub{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--orange);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;margin:0 0 18px}
.local-intro-left .lead-copy{font-size:16px;line-height:1.65;color:var(--text-2);margin:0 0 24px;max-width:560px}
.local-intro-left .lead-copy strong{color:var(--navy);font-weight:700}

/* ===== 6 visual scannable bullets ========================== */
.local-bullets{display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;margin:0 0 28px;padding:0;list-style:none}
.local-bullets li{display:flex;align-items:flex-start;gap:11px;font-family:'Inter Tight',sans-serif;font-size:15px;font-weight:600;color:var(--navy);line-height:1.35;letter-spacing:-0.005em}
.local-bullets li::before{content:'✓';display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--green);color:var(--navy);border-radius:0;font-weight:900;font-size:13px;flex-shrink:0;margin-top:1px}

/* ===== Local intro CTA bar ================================= */
.local-intro-cta{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap}
.local-intro-cta .btn-primary{display:inline-flex;align-items:center;gap:10px;padding:16px 24px;background:var(--orange);color:var(--white);font-family:'Inter Tight',sans-serif;font-weight:800;font-size:14px;letter-spacing:0.04em;text-transform:uppercase;text-decoration:none;border:2px solid var(--orange);box-shadow:var(--shadow-orange);transition:all 0.2s}
.local-intro-cta .btn-primary:hover{background:var(--orange-dim);transform:translateY(-2px)}
.local-intro-cta .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 22px;background:transparent;color:var(--navy);border:2px solid var(--navy);font-family:'Inter Tight',sans-serif;font-weight:800;font-size:13.5px;letter-spacing:0.04em;text-transform:uppercase;text-decoration:none;transition:all 0.2s}
.local-intro-cta .btn-secondary:hover{background:var(--navy);color:var(--white)}

/* ===== Right column: image stacked over compact quick-facts  */
.local-intro-right{display:flex;flex-direction:column;gap:18px}
.local-intro-photo{position:relative;aspect-ratio:5/4;overflow:hidden;border:2px solid var(--navy);background:var(--navy)}
.local-intro-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.6s ease}
.local-intro-photo:hover img{transform:scale(1.04)}
.local-intro-photo::after{content:'';position:absolute;left:0;right:0;bottom:0;height:50%;background:linear-gradient(180deg,transparent 0%,rgba(14,26,44,0.65) 100%);pointer-events:none;z-index:1}
.local-intro-photo .photo-caption{position:absolute;left:18px;bottom:14px;right:18px;z-index:2;color:var(--white);font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;line-height:1.4}
.local-intro-photo .photo-caption .city{display:block;font-family:'Inter Tight',sans-serif;font-size:18px;font-weight:900;letter-spacing:-0.02em;text-transform:uppercase;color:var(--sky);margin-bottom:2px}

/* ===== Compact quick-facts card (smaller than Phase 2) ===== */
.quick-facts-compact{background:var(--navy);color:var(--white);padding:22px 24px;border:1px solid rgba(66,174,233,0.18);position:relative}
.quick-facts-compact::before{content:'';position:absolute;top:0;left:0;width:5px;height:36px;background:var(--orange)}
.quick-facts-compact h3{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--sky);margin:0 0 14px}
.quick-facts-compact dl{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}
.quick-facts-compact .qf-item{display:flex;flex-direction:column;gap:2px}
.quick-facts-compact dt{font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:700;letter-spacing:0.10em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin:0}
.quick-facts-compact dd{margin:0;font-size:13px;line-height:1.35;font-weight:700;color:var(--white)}
.quick-facts-compact dd a{color:var(--sky);text-decoration:none}

@media(max-width:980px){
  .local-intro-premium{grid-template-columns:1fr;gap:32px}
  .local-bullets{grid-template-columns:1fr 1fr}
  .local-intro-photo{aspect-ratio:16/10}
  .quick-facts-compact dl{grid-template-columns:1fr 1fr;gap:10px 16px}
}
@media(max-width:480px){
  .local-bullets{grid-template-columns:1fr;gap:10px}
  .quick-facts-compact dl{grid-template-columns:1fr}
}

/* ============================================================ */
/* NEARBY AREAS WE SERVE — internal-link card grid               */
/* ============================================================ */
.nearby-areas{padding:80px 0;background:var(--bg);border-top:1px solid var(--line)}
.nearby-areas-head{text-align:center;margin-bottom:36px}
.nearby-areas-head .kicker{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;background:var(--navy);color:var(--sky);font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px}
.nearby-areas-head h2{font-family:'Inter Tight',sans-serif;font-weight:900;font-size:clamp(28px,3vw,40px);line-height:1.0;letter-spacing:-0.025em;color:var(--navy);text-transform:uppercase;margin:0 0 10px}
.nearby-areas-head h2 em{font-style:italic;color:var(--sky-deep)}
.nearby-areas-head p{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--text-2);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;max-width:680px;margin:0 auto}
.nearby-areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;max-width:1100px;margin:0 auto}
.nearby-area-card{display:flex;align-items:center;gap:14px;padding:18px 22px;background:var(--white);border:1.5px solid var(--line-2);text-decoration:none;color:var(--navy);transition:all 0.25s;position:relative;overflow:hidden}
.nearby-area-card::before{content:'';position:absolute;left:0;top:0;height:100%;width:0;background:var(--orange);transition:width 0.3s}
.nearby-area-card:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:0 12px 28px rgba(14,26,44,0.10)}
.nearby-area-card:hover::before{width:4px}
.nearby-area-card .area-name{font-family:'Inter Tight',sans-serif;font-weight:800;font-size:16px;letter-spacing:-0.01em;text-transform:uppercase}
.nearby-area-card .area-zip{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-3);font-weight:600;letter-spacing:0.06em;margin-top:2px;text-transform:none}
.nearby-area-card .area-arrow{margin-left:auto;color:var(--orange);font-weight:900;font-size:18px;transition:transform 0.25s}
.nearby-area-card:hover .area-arrow{transform:translateX(4px)}

/* ============================================================ */
/* PHASE 14 — MOBILE VISUAL RICHNESS                              */
/* Operator brief: 10/10 ratio imagen/video on mobile             */
/* ============================================================ */

/* === Hero mobile fallback: hide video on mobile, use poster bg === */
@media(max-width:767px){
  .hero-bg video{display:none}
  .hero-bg{
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
  }
  .hero-bg::after{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(14,26,44,0.55) 0%,rgba(14,26,44,0.85) 100%);
    z-index:1;
  }
}

/* === Reviews: enhanced avatar (Google-profile-style polish) === */
.rev .avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:'Inter Tight',sans-serif;
  font-weight:800;
  font-size:14px;
  color:var(--white);
  letter-spacing:-0.02em;
  flex-shrink:0;
  box-shadow:0 2px 8px rgba(14,26,44,0.18),inset 0 0 0 2px rgba(255,255,255,0.95);
  position:relative;
}
.rev .avatar::after{
  content:'';
  position:absolute;
  bottom:-2px;
  right:-2px;
  width:14px;
  height:14px;
  background:#4285F4;
  border:2px solid var(--white);
  border-radius:50%;
  background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="white"%3E%3Cpath d="M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z"/%3E%3C/svg%3E');
  background-size:8px;
  background-position:center;
  background-repeat:no-repeat;
}
.rev .avatar.orange{background:linear-gradient(135deg,#dd6c2d 0%,#b8551c 100%)}
.rev .avatar.sky{background:linear-gradient(135deg,#42aee9 0%,#1e88c4 100%)}
.rev .avatar.green{background:linear-gradient(135deg,#7cd653 0%,#4ea832 100%)}

/* === Process steps: SVG icons === */
.pstep-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;
  height:48px;
  background:rgba(66,174,233,0.15);
  border:1.5px solid rgba(66,174,233,0.30);
  border-radius:0;
  margin-bottom:14px;
  color:var(--sky);
}
.pstep-icon svg{width:26px;height:26px;stroke-width:1.8}

/* === Proof Numbers icons === */
.num-cell .num-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  margin-bottom:8px;
  color:var(--orange);
  opacity:0.85;
}
.num-cell .num-icon svg{width:24px;height:24px;stroke-width:1.8}

/* === RES vs COM real photo === */
.split{position:relative;overflow:hidden}
.split-photo{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  margin-bottom:18px;
  border:1px solid var(--line-2);
}
.split-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 0.5s ease;
}
.split:hover .split-photo img{transform:scale(1.03)}
.split-photo::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(14,26,44,0.45) 100%);
  pointer-events:none;
}
.split-photo .split-photo-tag{
  position:absolute;
  bottom:10px;
  left:14px;
  z-index:2;
  font-family:'JetBrains Mono',monospace;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--white);
}
/* Hide old emoji icon when split-photo present */
.split.has-photo .split-icon{display:none}

/* === FAQ icons === */
.faq-q .faq-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  margin-right:10px;
  color:var(--orange);
  flex-shrink:0;
  vertical-align:middle;
}
.faq-q .faq-icon svg{width:18px;height:18px;stroke-width:2}

/* === Neighborhoods header visual === */
.nh-header-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:56px;
  height:56px;
  margin-bottom:12px;
  background:rgba(221,108,45,0.10);
  border:1.5px solid rgba(221,108,45,0.30);
  color:var(--orange);
}
.nh-header-icon svg{width:30px;height:30px;stroke-width:1.8}

/* === Phase 1: process-full alternating timeline === */
.process-full {
  background: var(--navy);
  color: #fff;
  padding: 96px 0;
}
.process-full .container {
  max-width: 1180px;
}
.process-full .section-head {
  margin-bottom: 64px;
}
.process-full .section-head .kicker {
  color: var(--sky);
}
.process-full .section-head h2 {
  color: #fff;
}
.process-full .section-head p {
  color: rgba(255,255,255,0.78);
}

.process-full-legal {
  max-width: 880px;
  margin: 0 0 48px;
  padding: 22px 26px;
  background: var(--navy-2);
  border-left: 4px solid var(--sky);
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.7;
  color: rgba(255,255,255,0.82);
}

.pstep-full {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  padding: 64px 0;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.pstep-full:first-of-type { border-top: none; padding-top: 16px; }
.pstep-full:last-of-type { padding-bottom: 16px; }

.pstep-full-content { display: flex; flex-direction: column; }
.pstep-full-number {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--sky);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.pstep-full h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(26px, 3.2vw, 36px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin: 0 0 18px;
  color: #fff;
}
.pstep-full-body {
  font-family: 'Inter', sans-serif;
  font-size: 16.5px;
  line-height: 1.7;
  color: rgba(255,255,255,0.84);
  margin: 0 0 16px;
}
.pstep-full-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
}
.pstep-full-photo {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--navy-2);
  border: 2px solid rgba(255,255,255,0.10);
  overflow: hidden;
}
.pstep-full-photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.pstep-full-photo::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(14,26,44,0.30));
  pointer-events: none;
}

/* Alternating swap on desktop */
.pstep-full:nth-of-type(even) .pstep-full-content { order: 2; }
.pstep-full:nth-of-type(even) .pstep-full-photo   { order: 1; }

/* Mobile */
@media (max-width: 767px) {
  .process-full { padding: 64px 0; }
  .pstep-full {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 40px 0;
  }
  .pstep-full:nth-of-type(even) .pstep-full-content { order: 0; }
  .pstep-full:nth-of-type(even) .pstep-full-photo   { order: 0; }
  .pstep-full h3 { font-size: clamp(22px, 6vw, 28px); }
  .process-full-legal { padding: 20px; font-size: 14px; }
}
@media (max-width: 430px) {
  .process-full { padding: 48px 0; }
  .pstep-full { padding: 32px 0; gap: 18px; }
}

/* Final notice block (warranty + lab verification) */
.process-final-notice {
  margin-top: 32px;
  padding: 32px;
  background: var(--navy-2);
  border-left: 4px solid var(--orange);
  border-top: 1px solid rgba(255,255,255,0.10);
  border-right: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.process-final-notice + .process-final-notice { margin-top: 16px; }
.process-final-notice:first-of-type { margin-top: 56px; }
.process-final-notice h4 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 8px;
}
.process-final-notice p {
  font-family: 'Inter', sans-serif;
  font-size: 15.5px;
  line-height: 1.7;
  color: rgba(255,255,255,0.84);
  margin: 0;
}
.process-final-notice .pfn-tag {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--orange);
  text-transform: uppercase;
  margin-bottom: 12px;
}
@media (max-width: 430px) {
  .process-final-notice { padding: 24px 20px; }
}

/* Inline CTA band inside process-full (dark variant of cta-band pattern) */
.process-full .process-cta {
  margin-top: 56px;
  padding: 32px 36px;
  background: var(--navy-2);
  border-left: 6px solid var(--orange);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  flex-wrap: wrap;
}
.process-full .process-cta-text { flex: 1; min-width: 240px; }
.process-full .process-cta-text .kicker {
  color: var(--sky);
  display: block;
  margin-bottom: 8px;
}
.process-full .process-cta-text h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(22px, 2.6vw, 28px);
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 6px;
  line-height: 1.1;
}
.process-full .process-cta-text p {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.process-full .process-cta-ctas {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
}
.process-full .process-cta .btn-ghost-dark {
  color: #fff;
  border-color: rgba(255,255,255,0.45);
  background: transparent;
}
.process-full .process-cta .btn-ghost-dark:hover {
  background: #fff;
  color: var(--navy);
  border-color: #fff;
}
@media (max-width: 430px) {
  .process-full .process-cta { padding: 24px 20px; }
}

/* === Phase 2: FAQ premium redesign === */

/* Search bar */
.faq-search {
  position: sticky;
  top: 64px;
  z-index: 40;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.faq-search-inner {
  display: block;
  position: relative;
}
.faq-search-input {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 500;
  padding: 14px 18px 14px 48px;
  border: 2px solid var(--navy);
  background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230e1a2c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat 16px center;
  background-size: 20px;
  color: var(--navy);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.faq-search-input:focus {
  border-color: var(--sky);
  box-shadow: 0 0 0 3px rgba(66,174,233,0.18);
}
.faq-search-input::placeholder { color: var(--text-3); }
.faq-search-empty {
  display: none;
  text-align: center;
  padding: 60px 20px;
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: -0.01em;
}
.faq-search-empty.show { display: block; }
.faq-search-empty .kicker { display: block; margin-bottom: 12px; color: var(--orange-text); }

/* Category tabs */
.faq-cat-tabs-wrap {
  position: sticky;
  top: 128px;
  z-index: 35;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.faq-cat-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 16px 0;
  justify-content: center;
  max-width: 920px;
  margin: 0 auto;
}
.faq-cat-tab {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-2);
  background: #fff;
  border: 2px solid var(--line-2);
  padding: 9px 16px;
  cursor: pointer;
  transition: all 0.15s;
}
.faq-cat-tab:hover {
  border-color: var(--navy);
  color: var(--navy);
}
.faq-cat-tab.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}
.faq-cat-tab.active.cat-pricing {
  background: var(--orange-text);
  border-color: var(--orange-text);
}
.faq-cat-tab .count {
  display: inline-block;
  margin-left: 6px;
  font-size: 10px;
  opacity: 0.75;
}

/* 2-col layout: ToC + content */
.faq-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 56px;
  align-items: start;
  padding-top: 32px;
}

/* In-page ToC sticky sidebar */
.faq-toc-sticky {
  position: sticky;
  top: 200px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.faq-toc-sticky h5 {
  margin: 0 0 14px;
  color: var(--text-3);
  font-size: 11px;
  letter-spacing: 0.16em;
  font-weight: 700;
}
.faq-toc-sticky ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.faq-toc-sticky li {
  border-left: 2px solid var(--line);
  padding: 8px 0 8px 14px;
  margin-bottom: 2px;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.faq-toc-sticky li:hover {
  border-left-color: var(--navy);
  background: var(--sky-soft);
}
.faq-toc-sticky a {
  color: var(--text-2);
  text-decoration: none;
  display: block;
  transition: color 0.15s;
}
.faq-toc-sticky a:hover { color: var(--navy); }
.faq-toc-sticky li.active {
  border-left-color: var(--orange);
  background: var(--orange-soft);
}
.faq-toc-sticky li.active a { color: var(--navy); font-weight: 800; }

/* FAQ content column */
.faq-content { min-width: 0; }

/* Category group */
.faq-group {
  padding: 56px 0 16px;
  border-top: 1px solid var(--line);
  scroll-margin-top: 220px;
}
.faq-group:first-of-type {
  border-top: none;
  padding-top: 8px;
}
.faq-group-head {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 28px;
}
.faq-group-head .kicker {
  color: var(--sky-deep);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.faq-group-head h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.faq-group-head h2 em {
  font-style: italic;
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.16em;
  display: inline-block;
}
.faq-group-head p {
  font-family: 'Inter', sans-serif;
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--text-2);
  margin: 4px 0 0;
  max-width: 620px;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}

/* Pricing tier table */
.pricing-tiers {
  margin: 32px 0;
  border: 2px solid var(--navy);
  background: #fff;
}
.pricing-tier {
  display: grid;
  grid-template-columns: 88px 1fr 220px 180px;
  gap: 18px;
  align-items: center;
  padding: 22px 24px;
  border-bottom: 1px solid var(--line);
  transition: background 0.15s;
}
.pricing-tier:last-child { border-bottom: none; }
.pricing-tier:hover { background: var(--sky-soft); }
.pricing-tier-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sky-deep);
}
.pricing-tier-name {
  font-family: 'Inter Tight', sans-serif;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--navy);
  line-height: 1.2;
}
.pricing-tier-range {
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 900;
  color: var(--navy);
  letter-spacing: -0.02em;
}
.pricing-tier-range.custom {
  color: var(--orange-text);
  font-size: 16px;
}
.pricing-tier-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: right;
  line-height: 1.4;
}
.pricing-footnote {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--text-3);
  margin: 12px 0 0;
  text-align: center;
  line-height: 1.55;
}

/* Inline mini-CTA between groups */
.faq-mini-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  background: var(--sky-soft);
  border-left: 4px solid var(--sky);
  margin: 32px 0 8px;
}
.faq-mini-cta-text {
  font-family: 'Inter Tight', sans-serif;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--navy);
  line-height: 1.25;
  margin: 0;
  flex: 1;
}
.faq-mini-cta-text small {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--sky-deep);
  margin-top: 4px;
  text-transform: uppercase;
}
.faq-mini-cta .btn { flex-shrink: 0; }
.faq-mini-cta.orange {
  background: var(--orange-soft);
  border-left-color: var(--orange);
}
.faq-mini-cta.orange .faq-mini-cta-text small { color: var(--orange-text); }

/* Hidden by search/filter */
.faq-item[hidden],
.faq-group[hidden] { display: none !important; }

/* FAQ item scroll-margin for anchor jumps */
.faq-item {
  scroll-margin-top: 220px;
}

/* Tablet */
@media (max-width: 1023px) {
  .faq-layout {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .faq-toc-sticky {
    position: static;
    margin-bottom: 24px;
    padding: 20px;
    background: var(--sky-soft);
    border-left: 4px solid var(--sky);
  }
  .faq-toc-sticky ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px 20px;
  }
  .faq-cat-tabs-wrap { top: 124px; }
  .pricing-tier {
    grid-template-columns: 80px 1fr 180px;
    gap: 14px;
  }
  .pricing-tier-meta {
    grid-column: 1 / -1;
    text-align: left;
    padding-top: 6px;
    border-top: 1px dashed var(--line);
  }
}

/* Mobile */
@media (max-width: 767px) {
  .faq-search { top: 56px; padding: 12px 0; }
  .faq-search-input {
    font-size: 15px;
    padding: 12px 14px 12px 42px;
    background-size: 18px;
    background-position: 12px center;
  }
  .faq-cat-tabs-wrap { top: 112px; }
  .faq-cat-tabs {
    gap: 6px;
    padding: 12px 0;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-left: 4px;
    padding-right: 4px;
  }
  .faq-cat-tabs::-webkit-scrollbar { display: none; }
  .faq-cat-tab {
    font-size: 11px;
    padding: 7px 12px;
    letter-spacing: 0.10em;
    flex-shrink: 0;
  }
  .faq-toc-sticky ul { grid-template-columns: 1fr; }
  .pricing-tier {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 18px 18px;
  }
  .pricing-tier-num { font-size: 10px; }
  .pricing-tier-meta {
    text-align: left;
    grid-column: auto;
    padding-top: 4px;
    border-top: none;
  }
  .pricing-tier-range { font-size: 17px; }
  .faq-mini-cta {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 18px;
  }
  .faq-mini-cta-text { font-size: 14.5px; }
  .faq-group {
    padding: 40px 0 12px;
    scroll-margin-top: 180px;
  }
  .faq-item { scroll-margin-top: 180px; }
}

/* === Phase 3: Reviews premium redesign === */

/* Aggregate stat panel */
.review-stats {
  background: var(--navy);
  color: #fff;
  padding: 64px 0;
  position: relative;
  overflow: hidden;
  border-bottom: 3px solid var(--sky);
}
.review-stats::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 55%;
  height: 140%;
  background: radial-gradient(ellipse, rgba(66,174,233,0.20) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
}
.review-stats::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px), linear-gradient(0deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 80px 80px;
  z-index: 0;
  pointer-events: none;
}
.review-stats-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
  position: relative;
  z-index: 2;
}
.review-stats-big {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.review-stats-big .kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 12px;
  background: rgba(66,174,233,0.14);
  border: 1px solid rgba(66,174,233,0.32);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--sky);
  align-self: flex-start;
  margin-bottom: 8px;
}
.review-stats-big-num {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(72px, 8vw, 120px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.05em;
  color: #fff;
  display: inline-flex;
  align-items: flex-end;
  gap: 8px;
}
.review-stats-big-num em {
  display: inline-block;
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  font-style: italic;
  margin-right: 4px;
  box-shadow: 0 6px 30px rgba(66,174,233,0.40);
}
.review-stars {
  font-size: 28px;
  color: var(--sky);
  letter-spacing: 0.10em;
  line-height: 1;
}
.review-stats-sub {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.4;
  color: rgba(255,255,255,0.84);
  max-width: 380px;
}
.review-stats-zero {
  display: inline-block;
  background: var(--orange);
  color: var(--white);
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  padding: 7px 14px;
  margin-top: 6px;
  align-self: flex-start;
  box-shadow: 0 6px 18px rgba(221,108,45,0.35);
}
.review-stats-source {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.review-stats-source-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--sky);
  text-transform: uppercase;
}
.review-stats-source-num {
  font-family: 'Inter Tight', sans-serif;
  font-size: 52px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: #fff;
}
.review-stats-source-label {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: rgba(255,255,255,0.65);
  line-height: 1.4;
}
.review-stats-source-dist {
  margin-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.review-stats-source-bar {
  position: relative;
  height: 8px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  overflow: hidden;
}
.review-stats-source-bar-fill {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--sky), var(--green));
  width: 100%;
}
.review-stats-source-anno {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.60);
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
}
.review-stats-source-anno strong {
  color: var(--green);
  font-weight: 800;
}
.review-stats-meta {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.review-stats-meta-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.review-stats-meta-row span:last-child {
  color: #fff;
  font-weight: 700;
}
.review-stats-meta-row.live span:last-child::before {
  content: '';
  display: inline-block;
  width: 7px;
  height: 7px;
  background: var(--green);
  border-radius: 50%;
  margin-right: 7px;
  box-shadow: 0 0 0 0 rgba(124,214,83,0.7);
  animation: pulse 1.6s infinite;
}

/* Trust badges row */
.trust-badges-section {
  background: var(--white);
  padding: 56px 0 32px;
  border-bottom: 1px solid var(--line);
}
.trust-badges-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  border: 2px solid var(--navy);
  background: #fff;
}
.trust-badge {
  padding: 28px 18px;
  text-align: center;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.trust-badge:last-child { border-right: none; }
.trust-badge:hover { background: var(--bg); }
.trust-badge-icon {
  width: 36px;
  height: 36px;
  color: var(--navy);
  flex-shrink: 0;
  margin-bottom: 4px;
}
.trust-badge-icon svg { width: 100%; height: 100%; display: block; }
.trust-badge-label {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--navy);
  line-height: 1.2;
}
.trust-badge-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--text-3);
  text-transform: uppercase;
  line-height: 1.3;
}

/* Reviews section wrapper */
.reviews-section-head {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0 0 28px;
}
.reviews-section-head .kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sky-deep);
  align-self: flex-start;
}
.reviews-section-head h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.reviews-section-head h2 em {
  font-style: italic;
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  display: inline-block;
}
.reviews-section-head p {
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 720px;
  margin: 0;
}

/* Filter chips */
.review-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 0 32px;
  justify-content: flex-start;
}
.review-filter-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-2);
  background: #fff;
  border: 2px solid var(--line-2);
  padding: 9px 16px;
  cursor: pointer;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  line-height: 1;
}
.review-filter-chip:hover {
  border-color: var(--navy);
  color: var(--navy);
  transform: translateY(-1px);
}
.review-filter-chip.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}
.review-filter-chip .count {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-3);
  letter-spacing: 0.04em;
}
.review-filter-chip.active .count { color: var(--sky); }

/* Hide cards filtered out */
.rev.is-hidden {
  display: none !important;
}

/* Empty state */
.review-filter-empty {
  display: none;
  text-align: center;
  padding: 56px 28px;
  border: 2px dashed var(--line-2);
  background: var(--bg);
}
.review-filter-empty.show { display: block; }
.review-filter-empty p {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin: 0 0 6px;
}
.review-filter-empty small {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--text-3);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Review CTA blocks (Google · Leave) */
.review-cta-block {
  background: var(--sky-soft);
  border: 2px solid var(--sky);
  padding: 48px 40px;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  align-items: center;
  margin: 56px 0 28px;
  position: relative;
}
.review-cta-block-text {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.review-cta-block-text .kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky-deep);
  align-self: flex-start;
  margin-bottom: 4px;
}
.review-cta-block-text h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(24px, 3vw, 34px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.review-cta-block-text h3 em {
  font-style: italic;
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  display: inline-block;
}
.review-cta-block-text p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
  max-width: 520px;
}
.review-cta-block-action {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 10px;
}
.review-cta-block-action .btn-mega {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 22px 30px;
  background: var(--navy);
  color: var(--white);
  border: 2px solid var(--navy);
  font-family: 'Inter Tight', sans-serif;
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  transition: all 0.2s;
  box-shadow: 0 12px 32px rgba(14,26,44,0.25);
  width: 100%;
  text-align: center;
}
.review-cta-block-action .btn-mega:hover {
  background: var(--orange);
  border-color: var(--orange);
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(221,108,45,0.40);
}
.review-cta-block-action .btn-mega svg {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}
.review-cta-block-action .btn-mega-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--text-3);
  text-transform: uppercase;
  text-align: right;
}

/* Leave-review variant */
.review-leave-cta {
  background: var(--orange-soft);
  border-color: var(--orange);
}
.review-leave-cta .review-cta-block-text .kicker { color: var(--orange-text); }
.review-leave-cta .review-cta-block-text h3 em {
  background: var(--orange);
  color: var(--white);
  font-style: italic;
}
.review-leave-cta .review-cta-block-action .btn-mega {
  background: var(--orange);
  border-color: var(--orange);
  box-shadow: 0 12px 32px rgba(221,108,45,0.35);
}
.review-leave-cta .review-cta-block-action .btn-mega:hover {
  background: var(--navy);
  border-color: var(--navy);
  box-shadow: 0 16px 40px rgba(14,26,44,0.40);
}

/* Mobile */
@media (max-width: 900px) {
  .review-stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }
  .review-stats-big { grid-column: 1 / -1; }
  .trust-badges-row {
    grid-template-columns: repeat(5, 1fr);
  }
}
@media (max-width: 767px) {
  .review-stats { padding: 48px 0; }
  .review-stats-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .review-stats-big { grid-column: auto; }
  .trust-badges-section { padding: 40px 0 24px; }
  .trust-badges-row {
    grid-template-columns: repeat(2, 1fr);
  }
  .trust-badge {
    padding: 22px 14px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .trust-badge:nth-child(2n) { border-right: none; }
  .trust-badge:nth-child(5) {
    grid-column: 1 / -1;
    border-right: none;
    border-bottom: none;
  }
  .trust-badge:nth-child(3),
  .trust-badge:nth-child(4) { border-bottom: 1px solid var(--line); }
  .review-filter-chips {
    padding: 0 0 24px;
    gap: 6px;
  }
  .review-filter-chip {
    font-size: 11px;
    padding: 7px 12px;
    letter-spacing: 0.10em;
  }
  .review-cta-block {
    grid-template-columns: 1fr;
    padding: 32px 24px;
    gap: 24px;
    margin: 40px 0 20px;
  }
  .review-cta-block-action {
    align-items: stretch;
  }
  .review-cta-block-action .btn-mega-meta {
    text-align: center;
  }
  .reviews-section-head { margin-bottom: 22px; }
}
@media (max-width: 430px) {
  .review-stats-big-num { font-size: clamp(56px, 14vw, 80px); }
  .review-stats-source-num { font-size: 38px; }
  .review-stars { font-size: 22px; }
  .trust-badges-row { grid-template-columns: 1fr 1fr; }
  .trust-badge { padding: 18px 10px; }
  .trust-badge-label { font-size: 12px; }
  .trust-badge-icon { width: 30px; height: 30px; }
}

/* === Phase 4: Contact premium redesign === */

/* Contact methods grid */
.contact-methods {
  background: var(--bg);
  padding: 80px 0;
}
.contact-methods-head {
  max-width: 1180px;
  margin: 0 auto 32px;
  padding: 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-methods-head .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky-deep);
}
.contact-methods-head h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(32px, 4.2vw, 52px);
  font-weight: 900;
  line-height: 0.98;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.contact-methods-head h2 em {
  font-style: italic;
  color: var(--orange-text);
}
.contact-methods-head p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 6px 0 0;
  max-width: 720px;
}
.contact-methods-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 2px solid var(--navy);
  background: #fff;
  max-width: 1180px;
  margin: 0 auto;
}
.contact-method {
  padding: 40px 32px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: background 0.15s;
  position: relative;
  text-decoration: none;
  color: inherit;
  min-height: 220px;
}
.contact-method:last-child { border-right: none; }
.contact-method:hover { background: var(--sky-soft); }
.contact-method-icon {
  width: 32px;
  height: 32px;
  color: var(--navy);
  flex-shrink: 0;
}
.contact-method-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.contact-method-primary {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--navy);
  text-decoration: none;
}
.contact-method:hover .contact-method-primary { color: var(--orange-text); }
.contact-method-meta {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-2);
  margin-top: auto;
}
.contact-method-pulse {
  position: absolute;
  top: 28px;
  right: 24px;
  width: 10px;
  height: 10px;
  background: var(--green, #7cd653);
  border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(124, 214, 83, 0.6);
  animation: cm-pulse 1.8s infinite;
}
@keyframes cm-pulse {
  0% { box-shadow: 0 0 0 0 rgba(124,214,83,0.6); }
  70% { box-shadow: 0 0 0 14px rgba(124,214,83,0); }
  100% { box-shadow: 0 0 0 0 rgba(124,214,83,0); }
}

/* What-to-expect timeline */
.contact-timeline {
  padding: 80px 0;
  background: #fff;
}
.contact-timeline-head {
  max-width: 1180px;
  margin: 0 auto 36px;
  padding: 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-timeline-head .kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky-deep);
}
.contact-timeline-head h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(32px, 4.2vw, 52px);
  font-weight: 900;
  line-height: 0.98;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.contact-timeline-head h2 em {
  font-style: italic;
  color: var(--orange-text);
}
.contact-timeline-head p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 6px 0 0;
  max-width: 720px;
}
.contact-timeline-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  max-width: 1180px;
  margin: 0 auto;
  position: relative;
  border: 2px solid var(--navy);
  background: #fff;
}
.contact-timeline-step {
  padding: 36px 32px;
  border-right: 1px solid var(--line);
  position: relative;
}
.contact-timeline-step:last-child { border-right: none; }
.contact-timeline-step::before {
  content: '';
  position: absolute;
  top: 50%;
  right: -11px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: var(--navy);
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  display: block;
  z-index: 2;
}
.contact-timeline-step:last-child::before { display: none; }
.contact-timeline-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky-deep);
  margin-bottom: 14px;
}
.contact-timeline-step h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 14px;
}
.contact-timeline-step p {
  font-family: 'Inter', sans-serif;
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0 0 16px;
}
.contact-timeline-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--orange-text);
  text-transform: uppercase;
}

/* DBA card v2 */
.dba-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  margin: 32px 0;
}
.dba-card {
  background: #fff;
  border: 2px solid var(--navy);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.dba-card.primary {
  background: var(--sky-soft);
}
.dba-card-photo {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--navy-2, var(--navy));
  overflow: hidden;
}
.dba-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.dba-card-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(14,26,44,0.20));
  pointer-events: none;
}
.dba-card-label {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--navy);
  color: #fff;
  padding: 6px 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  z-index: 2;
}
.dba-card.primary .dba-card-label { background: var(--orange-text); }
.dba-card-body {
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
}
.dba-card-body h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
  line-height: 1.05;
}
.dba-card-addr {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-2);
  margin: 0;
}
.dba-card-stat {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--orange-text);
  text-transform: uppercase;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.dba-card-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: auto;
}
.dba-card-phone {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  color: var(--navy);
  text-decoration: none;
  letter-spacing: -0.02em;
}
.dba-card-phone:hover { color: var(--orange-text); }
.dba-card-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-3);
  text-transform: uppercase;
}
.dba-card-map-link {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sky-deep);
  text-decoration: none;
  margin-top: 4px;
  display: inline-block;
}
.dba-card-map-link:hover {
  color: var(--navy);
  text-decoration: underline;
}

/* Business hours block */
.business-hours {
  background: var(--navy);
  color: #fff;
  padding: 64px 0;
}
.business-hours-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  align-items: start;
}
.business-hours-primary {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.business-hours-primary-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green, #7cd653);
}
.business-hours-primary-h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(64px, 8vw, 120px);
  font-weight: 900;
  line-height: 0.92;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.business-hours-primary-sub {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.84);
  max-width: 460px;
}
.business-hours-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.business-hours-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,0.10);
  align-items: baseline;
}
.business-hours-row:first-child { padding-top: 0; }
.business-hours-row:last-child { border-bottom: none; }
.business-hours-row-label {
  font-family: 'Inter Tight', sans-serif;
  font-size: 14.5px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: #fff;
}
.business-hours-row-value {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--sky);
  text-align: right;
}
.business-hours-creds {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.15);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  line-height: 1.6;
}

/* Mobile */
@media (max-width: 1023px) {
  .contact-methods-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-method:nth-child(odd) { border-right: 1px solid var(--line); }
  .contact-method:nth-child(2n) { border-right: none; }
  .contact-method:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .contact-timeline-grid { grid-template-columns: 1fr; }
  .contact-timeline-step {
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 28px 28px;
  }
  .contact-timeline-step:last-child { border-bottom: none; }
  .contact-timeline-step::before {
    top: auto;
    bottom: -11px;
    right: 50%;
    transform: translateX(50%);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
  }
  .dba-cards { grid-template-columns: 1fr; gap: 20px; }
  .business-hours-grid { grid-template-columns: 1fr; gap: 36px; }
}
@media (max-width: 767px) {
  .contact-methods { padding: 56px 0; }
  .contact-methods-head { padding: 0 20px; }
  .contact-methods-grid { grid-template-columns: 1fr; }
  .contact-method {
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: 32px 28px;
    min-height: 0;
  }
  .contact-method:last-child { border-bottom: none; }
  .contact-method-pulse { top: 24px; right: 20px; }
  .contact-timeline { padding: 56px 0; }
  .contact-timeline-head { padding: 0 20px; }
  .business-hours { padding: 48px 0; }
  .business-hours-grid { padding: 0 20px; }
  .dba-card-body { padding: 24px 22px; }
  .dba-card-photo { aspect-ratio: 4 / 3; }
}
@media (max-width: 430px) {
  .contact-methods-head h2 { font-size: clamp(28px, 9vw, 36px); }
  .contact-timeline-head h2 { font-size: clamp(28px, 9vw, 36px); }
  .business-hours-primary-h2 { font-size: clamp(56px, 18vw, 80px); }
  .dba-card-phone { font-size: 20px; }
}

/* === Phase 5: Locations index redesign === */

/* Hero photo anchor (subtle accent) */
.page-hero.locations-hero {
  position: relative;
  overflow: hidden;
}
.locations-hero-photo {
  position: absolute;
  top: 0; right: 0;
  width: 40%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0.18;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(to left, black 30%, transparent 100%);
  mask-image: linear-gradient(to left, black 30%, transparent 100%);
  z-index: 1;
}
.page-hero.locations-hero .page-hero-inner { position: relative; z-index: 2; }

/* Coverage trust bar */
.coverage-trust-bar {
  background: var(--navy);
  color: #fff;
  border-top: 2px solid var(--sky);
  border-bottom: 2px solid var(--sky);
  padding: 0;
}
.coverage-trust-bar-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  max-width: 1280px;
  margin: 0 auto;
}
.coverage-trust-cell {
  padding: 32px 24px;
  border-right: 1px solid rgba(255,255,255,0.10);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.coverage-trust-cell:last-child { border-right: none; }
.coverage-trust-cell-num {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--sky);
}
.coverage-trust-cell-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.75);
}

/* County grouping */
.county-groups {
  padding: 88px 0 56px;
}
.county-group {
  margin-bottom: 56px;
  padding: 36px 36px;
  background: #fff;
  border: 2px solid var(--navy);
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 36px;
  align-items: start;
}
.county-group:last-child { margin-bottom: 0; }
.county-group.featured {
  background: var(--sky-soft);
}
.county-group-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border-right: 1px solid var(--line);
  padding-right: 32px;
}
.county-group-header .kicker { color: var(--sky-deep); }
.county-group-header h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.county-group-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--orange-text);
  margin-top: 6px;
}
.county-group-dispatch {
  margin-top: 14px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-2);
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.county-group-cities {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  align-self: stretch;
}
.county-city-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
  border-right: 1px solid var(--line);
  text-decoration: none;
  transition: background 0.15s;
  position: relative;
}
.county-city-card:nth-child(2n) { border-right: none; }
.county-city-card:hover { background: var(--bg); }
.county-city-card:hover::after { color: var(--orange-text); }
.county-city-card::after {
  content: '→';
  position: absolute;
  top: 18px;
  right: 22px;
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 900;
  color: var(--text-3);
  transition: color 0.15s;
}
.county-city-card.primary {
  background: var(--sky-soft);
}
.county-city-card.primary::after { color: var(--sky-deep); }
.county-city-name {
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--navy);
}
.county-city-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
}
.county-city-card.primary .county-city-meta { color: var(--sky-deep); }

/* Locations proof numbers grid */
.locations-proof {
  background: var(--bg);
  padding: 64px 0;
}
.locations-proof-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 2px solid var(--navy);
  background: #fff;
  max-width: 1180px;
  margin: 32px auto 0;
}
.locations-proof-cell {
  padding: 36px 28px;
  border-right: 1px solid var(--line);
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.locations-proof-cell:last-child { border-right: none; }
.locations-proof-cell.accent { background: var(--navy); color: #fff; border-right-color: rgba(255,255,255,0.10); }
.locations-proof-num {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(40px, 4.5vw, 56px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--navy);
}
.locations-proof-cell.accent .locations-proof-num { color: var(--sky); }
.locations-proof-label {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--text-2);
}
.locations-proof-cell.accent .locations-proof-label { color: rgba(255,255,255,0.84); }

/* Phase 5 Mobile */
@media (max-width: 1023px) {
  .locations-hero-photo { width: 50%; opacity: 0.14; }
  .coverage-trust-bar-grid { grid-template-columns: repeat(3, 1fr); }
  .coverage-trust-cell:nth-child(n+4) { border-top: 1px solid rgba(255,255,255,0.10); }
  .coverage-trust-cell:nth-child(3) { border-right: none; }
  .county-group {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 28px 28px;
  }
  .county-group-header {
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding-right: 0;
    padding-bottom: 20px;
  }
  .county-group-cities { grid-template-columns: repeat(2, 1fr); }
  .locations-proof-grid { grid-template-columns: repeat(2, 1fr); }
  .locations-proof-cell:nth-child(2n) { border-right: none; }
  .locations-proof-cell:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .locations-proof-cell.accent:nth-child(-n+2) { border-bottom-color: rgba(255,255,255,0.10); }
}
@media (max-width: 767px) {
  .locations-hero-photo { display: none; }
  .coverage-trust-bar-grid { grid-template-columns: repeat(2, 1fr); }
  .coverage-trust-cell { padding: 24px 18px; }
  .coverage-trust-cell:nth-child(2n) { border-right: none; }
  .coverage-trust-cell:nth-child(-n+4) { border-bottom: 1px solid rgba(255,255,255,0.10); }
  .coverage-trust-cell:nth-child(5) { grid-column: span 2; border-bottom: none; }
  .county-groups { padding: 56px 0 32px; }
  .county-group { padding: 24px 22px; margin-bottom: 24px; }
  .county-group-cities { grid-template-columns: 1fr; }
  .county-city-card { padding: 16px 18px; border-right: none; }
  .locations-proof { padding: 48px 0; }
}
@media (max-width: 430px) {
  .coverage-trust-cell-num { font-size: clamp(28px, 7vw, 36px); }
  .county-group-header h3 { font-size: 24px; }
}

/* === Phase 6: Blog index redesign === */

/* Featured post hero */
.blog-featured {
  background: var(--sky-soft);
  border-top: 2px solid var(--navy);
  border-bottom: 2px solid var(--navy);
  padding: 0;
}
.blog-featured-inner {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 56px 28px;
}
.blog-featured-photo {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--navy-2);
  border: 2px solid var(--navy);
  overflow: hidden;
}
.blog-featured-photo img {
  width: 100%; height: 100%; object-fit: cover;
}
.blog-featured-photo::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, transparent 60%, rgba(14,26,44,0.30));
  pointer-events: none;
}
.blog-featured-content {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.blog-featured-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange-text);
}
.blog-featured-content h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.blog-featured-excerpt {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
}
.blog-featured-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
}
.blog-featured-cta {
  align-self: flex-start;
  margin-top: 8px;
}

/* Category chips */
.blog-cat-chips-wrap {
  position: sticky;
  top: 64px;
  z-index: 40;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.blog-cat-chips {
  padding: 16px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  max-width: 1280px;
  margin: 0 auto;
  padding-left: 28px;
  padding-right: 28px;
}
.blog-cat-chip {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-2);
  background: #fff;
  border: 2px solid var(--line-2);
  padding: 9px 16px;
  cursor: pointer;
  transition: all 0.15s;
  font: inherit;
  font-family: 'JetBrains Mono', monospace;
}
.blog-cat-chip:hover { border-color: var(--navy); color: var(--navy); }
.blog-cat-chip.active {
  background: var(--navy);
  border-color: var(--navy);
  color: #fff;
}
.blog-cat-chip .count {
  margin-left: 6px;
  font-size: 10px;
  opacity: 0.75;
}

/* Blog cards grid v2 */
.blog-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 56px;
  align-items: start;
  padding: 56px 0;
}
.blog-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
.blog-card-v2 {
  background: #fff;
  border: 2px solid var(--navy);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  transition: transform 0.18s, box-shadow 0.18s;
}
.blog-card-v2:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}
.blog-card-v2-photo {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--navy-2);
  overflow: hidden;
  border-bottom: 2px solid var(--navy);
}
.blog-card-v2-photo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s;
}
.blog-card-v2:hover .blog-card-v2-photo img { transform: scale(1.04); }
.blog-card-v2-cat {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--navy);
  color: #fff;
  padding: 6px 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.blog-card-v2[data-category="mold-inspection"] .blog-card-v2-cat { background: var(--sky-deep); }
.blog-card-v2[data-category="mold-remediation"] .blog-card-v2-cat { background: var(--orange-text); }
.blog-card-v2[data-category="indoor-air-quality"] .blog-card-v2-cat { background: #2d7a8a; }
.blog-card-v2[data-category="water-damage"] .blog-card-v2-cat { background: #5a4cd6; }
.blog-card-v2[data-category="prevention"] .blog-card-v2-cat { background: #2d7a1f; }

.blog-card-v2-body {
  padding: 24px 26px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.blog-card-v2-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.blog-card-v2-body h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.blog-card-v2-excerpt {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
  flex: 1;
}
.blog-card-v2-cta {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--orange-text);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
}
.blog-card-v2-cta::after {
  content: '→';
  transition: transform 0.15s;
}
.blog-card-v2:hover .blog-card-v2-cta::after { transform: translateX(4px); }

/* Editorial sidebar */
.blog-sidebar {
  position: sticky;
  top: 140px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.blog-sidebar-block {
  background: #fff;
  border: 2px solid var(--navy);
  padding: 24px;
}
.blog-sidebar-block h5 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sky-deep);
  margin: 0 0 14px;
}
.blog-sidebar-block h6 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 6px;
}
.blog-sidebar-block p {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-2);
  margin: 0;
}
.blog-sidebar-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.blog-sidebar-list li {
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.blog-sidebar-list li:last-child { border-bottom: none; }
.blog-sidebar-list a {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  color: var(--text);
  text-decoration: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.blog-sidebar-list a:hover { color: var(--orange-text); }
.blog-sidebar-count {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--text-3);
}

/* Newsletter signup */
.blog-newsletter {
  background: var(--navy);
  color: #fff;
  padding: 64px 0;
  border-top: 2px solid var(--sky);
}
.blog-newsletter-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  align-items: center;
}
.blog-newsletter-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.blog-newsletter-content .kicker { color: var(--sky); }
.blog-newsletter-content h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.blog-newsletter-content p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.blog-newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.blog-newsletter-input {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  padding: 16px 18px;
  border: 2px solid var(--sky);
  background: rgba(255,255,255,0.06);
  color: #fff;
}
.blog-newsletter-input::placeholder { color: rgba(255,255,255,0.55); }
.blog-newsletter-input:focus { outline: 2px solid var(--orange); }
.blog-newsletter-btn {
  font-family: 'Inter Tight', sans-serif;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--orange);
  color: #fff;
  border: 2px solid var(--orange);
  padding: 14px 22px;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
}
.blog-newsletter-btn:hover { background: var(--orange-dim); border-color: var(--orange-dim); transform: translateY(-1px); }
.blog-newsletter-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

/* Mobile */
@media (max-width: 1023px) {
  .blog-layout { grid-template-columns: 1fr; gap: 32px; padding: 40px 0; }
  .blog-sidebar { position: static; }
  .blog-cards-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .blog-featured-inner { grid-template-columns: 1fr; gap: 32px; padding: 40px 24px; }
  .blog-newsletter-inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 767px) {
  .blog-cards-grid { grid-template-columns: 1fr; gap: 18px; }
  .blog-featured { padding: 0; }
  .blog-featured-inner { padding: 32px 22px; }
  .blog-cat-chips { padding: 12px 16px; }
  .blog-cat-chip { font-size: 11px; padding: 7px 12px; letter-spacing: 0.10em; }
  .blog-newsletter { padding: 48px 0; }
  .blog-cat-chips-wrap { top: 56px; }
}

/* === Phase 7: Blog post premium template === */

/* Featured image hero (post-level) */
.post-featured-img {
  background: var(--bg);
  padding: 32px 0 0;
}
.post-featured-img-frame {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  position: relative;
}
.post-featured-img-photo {
  aspect-ratio: 16 / 9;
  background: var(--navy-2);
  border: 2px solid var(--navy);
  overflow: hidden;
  position: relative;
}
.post-featured-img-photo img {
  width: 100%; height: 100%; object-fit: cover;
}
.post-featured-img-cat {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--navy);
  color: #fff;
  padding: 6px 14px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.post-featured-img-caption {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: 10px;
  text-align: right;
}

/* Article meta block */
.post-meta-block {
  background: var(--bg);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 20px 0;
  margin: 32px 0 0;
}
.post-meta-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 24px;
  align-items: center;
}
.post-author {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.post-author-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
}
.post-author-name {
  font-family: 'Inter Tight', sans-serif;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.005em;
  color: var(--navy);
}
.post-dates {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: center;
}
.post-dates span:first-child { color: var(--navy); }
.share-row {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
}
.share-btn {
  width: 36px;
  height: 36px;
  background: #fff;
  border: 1.5px solid var(--line-2);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.15s;
}
.share-btn:hover {
  background: var(--navy);
  border-color: var(--navy);
}
.share-btn svg { width: 16px; height: 16px; color: var(--navy); }
.share-btn:hover svg { color: #fff; }
.share-btn-copy.copied {
  background: var(--green-deep);
  border-color: var(--green-deep);
}
.share-btn-copy.copied svg { color: #fff; }

/* Article 2-col layout */
.post-layout {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 56px;
  align-items: start;
  padding: 56px 0;
  max-width: 1280px;
  margin: 0 auto;
}
.post-layout > .prose-wrap {
  min-width: 0;
}

/* Sticky ToC sidebar */
.toc-sticky {
  position: sticky;
  top: 140px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.toc-sticky-block {
  background: #fff;
  border: 2px solid var(--navy);
  padding: 24px;
}
.toc-sticky-block h5 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sky-deep);
  margin: 0 0 12px;
}
.toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.toc-list li {
  border-left: 2px solid var(--line);
  padding: 8px 0 8px 14px;
  margin-bottom: 2px;
  transition: border-color 0.15s;
}
.toc-list li.h3-item { padding-left: 26px; font-size: 12px; }
.toc-list li:hover { border-left-color: var(--navy); }
.toc-list li.active { border-left-color: var(--orange); }
.toc-list a {
  color: var(--text-2);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  text-decoration: none;
  display: block;
  line-height: 1.4;
}
.toc-list li.active a { color: var(--navy); font-weight: 600; }

/* Sticky side-rail CTA */
.side-rail-cta {
  background: var(--navy);
  color: #fff;
  border: 2px solid var(--navy);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.side-rail-cta-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--orange);
}
.side-rail-cta h6 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.side-rail-cta p {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.side-rail-cta-phone {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--orange);
  text-decoration: none;
  display: block;
  margin-top: 6px;
}
.side-rail-cta-phone:hover { color: #fff; }
.side-rail-cta-trust {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.15);
}

/* Pull quote */
.prose-pullquote {
  margin: 32px 0;
  padding: 28px 32px;
  background: var(--sky-soft);
  border-left: 4px solid var(--sky);
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.02em;
  color: var(--navy);
}
.prose-pullquote::before {
  content: '"';
  display: inline-block;
  font-size: 1.3em;
  font-weight: 900;
  color: var(--sky-deep);
  margin-right: 6px;
  vertical-align: -0.1em;
}

/* Citation list */
.citation-list {
  margin: 56px 0 0;
  padding: 28px 32px;
  background: var(--bg);
  border-left: 4px solid var(--navy);
}
.citation-list h5 {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-3);
  margin: 0 0 16px;
}
.citation-list ol {
  list-style: none;
  counter-reset: ref;
  padding: 0;
  margin: 0;
}
.citation-list ol li {
  counter-increment: ref;
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--text-2);
  padding: 10px 0 10px 32px;
  position: relative;
  border-bottom: 1px solid var(--line);
}
.citation-list ol li::before {
  content: '[' counter(ref) ']';
  position: absolute;
  left: 0;
  top: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  color: var(--orange-text);
}
.citation-list ol li:last-child { border-bottom: none; }
.citation-list a {
  color: var(--sky-deep);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.citation-list a:hover { color: var(--navy); }

/* Related grid v2 (image-led) */
.related-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 32px 0 0;
}

/* Prev/Next nav */
.prev-next-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 2px solid var(--navy);
  margin: 56px 0 0;
}
.prev-next-cell {
  padding: 24px 28px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: background 0.15s;
  position: relative;
}
.prev-next-cell:hover { background: var(--bg); }
.prev-next-cell.prev { border-right: 1px solid var(--line); }
.prev-next-cell.next { text-align: right; align-items: flex-end; }
.prev-next-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-3);
}
.prev-next-title {
  font-family: 'Inter Tight', sans-serif;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--navy);
  line-height: 1.2;
}
.prev-next-cell:hover .prev-next-title { color: var(--orange-text); }

/* Mobile */
@media (max-width: 1023px) {
  .post-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .toc-sticky { position: static; flex-direction: row; flex-wrap: wrap; gap: 16px; }
  .toc-sticky-block { flex: 1 1 280px; }
  .post-meta-inner { grid-template-columns: 1fr; gap: 12px; }
  .share-row { justify-content: flex-start; }
  .related-grid-v2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .post-featured-img { padding: 24px 0 0; }
  .post-featured-img-photo { aspect-ratio: 3 / 2; }
  .post-layout { padding: 40px 0; gap: 24px; }
  .toc-sticky { flex-direction: column; }
  .related-grid-v2 { grid-template-columns: 1fr; gap: 18px; }
  .prev-next-nav { grid-template-columns: 1fr; }
  .prev-next-cell.prev { border-right: none; border-bottom: 1px solid var(--line); }
  .prev-next-cell.next { text-align: left; align-items: flex-start; }
  .citation-list { padding: 22px 22px; }
}

/* === Phase 8 corrections === */
.trust-badge-meta-verified {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--green-deep);
  margin-top: 4px;
}

/* === Phase 11: /services/ index redesign === */

/* Hero photo anchor (subtle accent · reuse Phase 5 pattern) */
.page-hero.services-hero {
  position: relative;
  overflow: hidden;
}
.services-hero-photo {
  position: absolute;
  top: 0; right: 0;
  width: 40%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0.18;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(to left, black 30%, transparent 100%);
  mask-image: linear-gradient(to left, black 30%, transparent 100%);
  z-index: 1;
}
.page-hero.services-hero .page-hero-inner { position: relative; z-index: 2; }

/* Process overview 3-card */
.svc-process-overview {
  background: var(--bg);
  padding: 80px 0;
}
.svc-process-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 2px solid var(--navy);
  background: #fff;
  max-width: 1280px;
  margin: 40px auto 0;
}
.svc-process-card {
  padding: 36px 32px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 14px;
  text-decoration: none;
  transition: background 0.15s;
  position: relative;
}
.svc-process-card:last-child { border-right: none; }
.svc-process-card:hover { background: var(--bg-2); }
.svc-process-card-photo {
  aspect-ratio: 4 / 3;
  background: var(--navy-2);
  overflow: hidden;
  margin-bottom: 8px;
  border: 1px solid var(--line);
}
.svc-process-card-photo img { width: 100%; height: 100%; object-fit: cover; }
.svc-process-card-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky-deep);
}
.svc-process-card h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.svc-process-card p {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
  flex: 1;
}
.svc-process-card-cta {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--orange-text);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
}
.svc-process-card-cta::after { content: '→'; transition: transform 0.15s; }
.svc-process-card:hover .svc-process-card-cta::after { transform: translateX(4px); }

/* Service tiles v2 */
.svc-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 2px solid var(--navy);
  background: #fff;
  margin-top: 40px;
}
.svc-tile {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: background 0.15s;
  position: relative;
}
.svc-tile:nth-child(3n) { border-right: none; }
.svc-tile:nth-last-child(-n+3) { border-bottom: none; }
.svc-tile:hover { background: var(--bg); }
.svc-tile.featured {
  background: var(--sky-soft);
}
.svc-tile.featured:hover { background: var(--sky-soft); }
.svc-tile-photo {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--navy-2);
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.svc-tile-photo img { width: 100%; height: 100%; object-fit: cover; }
.svc-tile-cat {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--navy);
  color: #fff;
  padding: 6px 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.svc-tile.featured .svc-tile-cat { background: var(--orange-text); }
.svc-tile-featured-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  background: var(--orange);
  color: var(--navy);
  padding: 5px 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.svc-tile-body {
  padding: 26px 26px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.svc-tile-body h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.svc-tile-body p {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  margin: 0;
}
.svc-tile-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.svc-tile-features li {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-2);
  padding-left: 18px;
  position: relative;
}
.svc-tile-features li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--green-text);
  font-weight: 900;
}
.svc-tile-price {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--orange-text);
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.svc-tile-cta {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--navy);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
}
.svc-tile-cta::after { content: '→'; transition: transform 0.15s; }
.svc-tile:hover .svc-tile-cta::after { transform: translateX(4px); }

/* Pricing tier preview block */
.svc-pricing-preview {
  background: var(--navy);
  color: #fff;
  padding: 64px 0;
}
.svc-pricing-preview-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.svc-pricing-preview-content { display: flex; flex-direction: column; gap: 14px; }
.svc-pricing-preview-content .kicker { color: var(--sky); }
.svc-pricing-preview-content h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(28px, 3.4vw, 40px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.svc-pricing-preview-content p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.svc-pricing-tiers-mini {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.svc-pricing-tier-mini {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.svc-pricing-tier-mini:last-child { border-bottom: none; }
.svc-pricing-tier-mini-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--sky);
}
.svc-pricing-tier-mini-name {
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: #fff;
}
.svc-pricing-tier-mini-range {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.78);
}

/* Mobile */
@media (max-width: 1023px) {
  .svc-process-cards { grid-template-columns: 1fr; }
  .svc-process-card { border-right: none; border-bottom: 1px solid var(--line); }
  .svc-process-card:last-child { border-bottom: none; }
  .svc-grid-v2 { grid-template-columns: repeat(2, 1fr); }
  .svc-tile { border-right: 1px solid var(--line) !important; }
  .svc-tile:nth-child(2n) { border-right: none !important; }
  .svc-pricing-preview-inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 767px) {
  .svc-process-overview { padding: 56px 0; }
  .svc-grid-v2 { grid-template-columns: 1fr; }
  .svc-tile { border-right: none !important; border-bottom: 1px solid var(--line) !important; }
  .svc-tile:last-child { border-bottom: none !important; }
  .svc-pricing-preview { padding: 48px 0; }
}

/* === Phase 13-18: Internal page elevation === */

/* Pulse keyframe alias for internal-hero status pill (matches homepage hero-status) */
@keyframes cm-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(124, 214, 83, 0.7); }
  50% { box-shadow: 0 0 0 8px rgba(124, 214, 83, 0); }
}

/* 2a · Premium internal hero — upgrade from .page-hero */
.internal-hero {
  position: relative;
  background: var(--navy);
  color: #fff;
  overflow: hidden;
  padding: 88px 0 96px;
  border-bottom: 2px solid var(--sky);
}
.internal-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(14,26,44,0) 0%, rgba(14,26,44,0.45) 70%, rgba(14,26,44,1) 100%),
    radial-gradient(60% 80% at 80% 30%, rgba(66,174,233,0.16), transparent 70%),
    repeating-linear-gradient(0deg, transparent 0 79px, rgba(255,255,255,0.04) 79px 80px),
    repeating-linear-gradient(90deg, transparent 0 79px, rgba(255,255,255,0.04) 79px 80px);
  pointer-events: none;
  z-index: 1;
}
.internal-hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 56px;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
}
.internal-hero-content {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.internal-hero-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--green);
  align-self: flex-start;
}
.internal-hero-status::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--green);
  border-radius: 50%;
  box-shadow: 0 0 0 0 var(--green);
  animation: cm-pulse 1.8s infinite;
  flex-shrink: 0;
}
.internal-hero-breadcrumb {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.internal-hero-breadcrumb a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  transition: color 0.15s;
}
.internal-hero-breadcrumb a:hover { color: var(--sky); }
.internal-hero-breadcrumb .sep { margin: 0 8px; opacity: 0.4; }
.internal-hero-kicker {
  display: inline-flex;
  align-self: flex-start;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky);
}
.internal-hero h1 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(40px, 5.2vw, 72px);
  font-weight: 900;
  line-height: 0.94;
  letter-spacing: -0.04em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.internal-hero h1 em {
  display: inline-block;
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  font-style: normal;
  line-height: 1;
}
.internal-hero h1.urgent em { background: var(--orange); color: #fff; }
.internal-hero-lede {
  font-family: 'Inter', sans-serif;
  font-size: clamp(16px, 1.6vw, 19px);
  line-height: 1.55;
  color: rgba(255,255,255,0.85);
  max-width: 580px;
  margin: 0;
}
.internal-hero-lede strong {
  color: #fff;
  font-weight: 700;
  background: rgba(66,174,233,0.18);
  padding: 1px 5px;
}
.internal-hero-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}
.internal-hero-trust-strip .tt {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.78);
  padding: 7px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
}
.internal-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 14px;
  align-items: center;
}
.internal-hero-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-top: 8px;
}
.internal-hero-aside {
  position: relative;
  background: rgba(14,26,44,0.65);
  border: 2px solid rgba(255,255,255,0.10);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  backdrop-filter: blur(8px);
}
.internal-hero-aside-tag {
  position: absolute;
  top: -12px;
  left: 24px;
  background: var(--sky);
  color: var(--navy);
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 10px;
}
.internal-hero-aside-num {
  font-family: 'Inter Tight', sans-serif;
  font-size: 64px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
  color: #fff;
}
.internal-hero-aside-num em {
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  font-style: normal;
}
.internal-hero-aside-label {
  font-family: 'Inter Tight', sans-serif;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.005em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.1;
}
.internal-hero-aside-rows {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.10);
}
.internal-hero-aside-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.internal-hero-aside-row span:last-child { color: var(--sky); font-weight: 700; }
@media (max-width: 1023px) {
  .internal-hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .internal-hero { padding: 64px 0 72px; }
}
@media (max-width: 767px) {
  .internal-hero { padding: 48px 0 56px; }
  .internal-hero h1 { font-size: clamp(32px, 8vw, 48px); }
  .internal-hero-aside { padding: 24px; }
  .internal-hero-aside-num { font-size: 48px; }
}

/* 2b · Location card v3 — risk + response + availability */
.location-card-v3 {
  background: #fff;
  border: 2px solid var(--navy);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: all 0.18s;
  position: relative;
  overflow: hidden;
  color: inherit;
}
.location-card-v3:hover {
  background: var(--bg);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.location-card-v3.primary {
  background: var(--sky-soft);
  border-color: var(--sky-deep);
}
.location-card-v3-header {
  padding: 22px 24px 16px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  border-bottom: 1px solid var(--line);
}
.location-card-v3-name {
  font-family: 'Inter Tight', sans-serif;
  font-size: 20px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.location-card-v3-availability {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green-text);
  background: rgba(124,214,83,0.10);
  border: 1px solid var(--green);
  padding: 4px 8px;
  white-space: nowrap;
}
.location-card-v3-rows {
  padding: 14px 24px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.location-card-v3-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.location-card-v3-row-label { color: var(--text-3); }
.location-card-v3-row-value { color: var(--navy); font-weight: 700; text-align: right; }
.location-card-v3-cta {
  padding: 14px 24px;
  background: var(--navy);
  color: #fff;
  font-family: 'Inter Tight', sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  transition: background 0.15s;
}
.location-card-v3:hover .location-card-v3-cta {
  background: var(--orange-text);
}
.location-card-v3.primary .location-card-v3-cta { background: var(--orange-text); }
.location-card-v3-cta::after {
  content: '→';
  transition: transform 0.15s;
}
.location-card-v3:hover .location-card-v3-cta::after { transform: translateX(4px); }

/* 2c · CTA band v2 — stronger conversion band */
.cta-band-v2 {
  background: var(--navy);
  color: #fff;
  padding: 64px 0;
  border-top: 2px solid var(--sky);
  border-bottom: 2px solid var(--sky);
  position: relative;
  overflow: hidden;
}
.cta-band-v2::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(60% 100% at 70% 50%, rgba(221,108,45,0.18), transparent 70%);
  pointer-events: none;
}
.cta-band-v2-inner {
  position: relative;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 56px;
  align-items: center;
}
.cta-band-v2-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cta-band-v2-kicker {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sky);
}
.cta-band-v2-content h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(28px, 3.4vw, 42px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}
.cta-band-v2-content h2 em {
  background: var(--orange);
  color: var(--navy);
  padding: 0 0.08em;
  font-style: normal;
  display: inline-block;
  line-height: 1;
}
.cta-band-v2-content p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  margin: 0;
}
.cta-band-v2-actions {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: stretch;
}
.cta-band-v2-actions .btn { text-align: center; justify-content: center; }
.cta-band-v2-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  text-align: center;
  margin-top: 8px;
}
@media (max-width: 1023px) {
  .cta-band-v2-inner { grid-template-columns: 1fr; gap: 28px; }
  .cta-band-v2 { padding: 48px 0; }
}

/* 2d · Contact hero form — premium form aside */
.contact-hero-form {
  background: #fff;
  border: 2px solid var(--navy);
  padding: 28px 28px 24px;
  position: relative;
  color: var(--navy);
}
.contact-hero-form::before {
  content: '';
  position: absolute;
  top: -2px; left: -2px; right: -2px;
  height: 6px;
  background: linear-gradient(90deg, var(--sky) 0%, var(--sky) 50%, var(--orange) 50%, var(--orange) 100%);
}
.contact-hero-form-tag {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange-text);
  margin-bottom: 6px;
}
.contact-hero-form h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 8px;
  line-height: 1.05;
}
.contact-hero-form h3 em {
  background: var(--sky);
  color: var(--navy);
  padding: 0 0.08em;
  font-style: normal;
  display: inline-block;
}
.contact-hero-form-sub {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-2);
  margin: 0 0 18px;
}
.contact-hero-form-fields {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.contact-hero-form-fields input,
.contact-hero-form-fields select,
.contact-hero-form-fields textarea {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  padding: 12px 14px;
  border: 1.5px solid var(--line-2);
  background: #fff;
  color: var(--navy);
  outline: none;
  transition: border-color 0.15s;
  width: 100%;
  box-sizing: border-box;
}
.contact-hero-form-fields input:focus,
.contact-hero-form-fields select:focus,
.contact-hero-form-fields textarea:focus { border-color: var(--sky); }
.contact-hero-form-fields input::placeholder { color: var(--text-3); }
.contact-hero-form-submit {
  margin-top: 6px;
  padding: 16px;
  background: var(--orange-text);
  color: #fff;
  border: none;
  font-family: 'Inter Tight', sans-serif;
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background 0.15s;
  width: 100%;
}
.contact-hero-form-submit:hover { background: var(--orange-dim); }
.contact-hero-form-trust {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.contact-hero-form-trust-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-2);
}
.contact-hero-form-trust-row::before {
  content: '✓';
  color: var(--green-deep);
  font-weight: 900;
}

/* 2e · Article callout emergency — premium in-article CTA */
.article-callout-emergency {
  margin: 32px 0;
  padding: 28px 32px;
  background: var(--navy);
  color: #fff;
  border-left: 5px solid var(--orange);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
}
.article-callout-emergency-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.article-callout-emergency-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange);
}
.article-callout-emergency h4 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
  line-height: 1.1;
}
.article-callout-emergency p {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.78);
  margin: 4px 0 0;
}
.article-callout-emergency .btn-call-mega { white-space: nowrap; }
@media (max-width: 767px) {
  .article-callout-emergency {
    grid-template-columns: 1fr;
    padding: 22px 22px;
    gap: 14px;
  }
}

/* 2f · When to call — decision-guide conversion block */
.when-to-call {
  margin: 40px 0;
  background: var(--bg);
  border: 2px solid var(--navy);
  padding: 32px;
}
.when-to-call-tag {
  display: inline-block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--orange-text);
  background: var(--orange-soft);
  padding: 5px 10px;
  margin-bottom: 14px;
}
.when-to-call h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 900;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0 0 14px;
  line-height: 1.05;
}
.when-to-call ul {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
.when-to-call ul li {
  font-family: 'Inter', sans-serif;
  font-size: 14.5px;
  line-height: 1.45;
  color: var(--text);
  padding-left: 24px;
  position: relative;
}
.when-to-call ul li::before {
  content: '⚠';
  position: absolute;
  left: 0;
  color: var(--orange-text);
  font-weight: 900;
}
.when-to-call-cta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
@media (max-width: 767px) {
  .when-to-call { padding: 24px; margin: 28px 0; }
  .when-to-call ul { grid-template-columns: 1fr; }
}

/* 2g · Blog cards v2 hover polish — additive layer to existing Phase 6 cards */
.blog-card-v2 { position: relative; }
.blog-card-v2::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid transparent;
  pointer-events: none;
  transition: border-color 0.18s;
}
.blog-card-v2:hover::after { border-color: var(--orange); }
.blog-card-v2 .blog-card-v2-photo img {
  transition: transform 0.4s ease;
}
.blog-card-v2:hover .blog-card-v2-photo img { transform: scale(1.04); }

/* 2h · Related grid v2 — image-led OVERRIDE of Phase 7 text-only stub */
.related-grid-v2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 0;
}
.related-card-v2 {
  background: #fff;
  border: 2px solid var(--navy);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform 0.18s, box-shadow 0.18s;
  position: relative;
  color: inherit;
}
.related-card-v2:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow);
}
.related-card-v2-photo {
  position: relative;
  aspect-ratio: 16 / 9;
  background: var(--navy-2);
  overflow: hidden;
  border-bottom: 2px solid var(--navy);
}
.related-card-v2-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.related-card-v2:hover .related-card-v2-photo img { transform: scale(1.04); }
.related-card-v2-cat {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--navy);
  color: #fff;
  padding: 5px 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.related-card-v2-body {
  padding: 18px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.related-card-v2-body h4 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 17px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.015em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 0;
}
.related-card-v2-meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-top: auto;
  padding-top: 4px;
}
@media (max-width: 1023px) {
  .related-grid-v2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .related-grid-v2 { grid-template-columns: 1fr; gap: 16px; }
}

/* === Phase 23: Privacy Policy page === */

.privacy-container {
  max-width: 920px;
}
.privacy-prose {
  font-family: 'Inter', sans-serif;
  color: var(--text);
}
.privacy-prose h2 {
  font-family: 'Inter Tight', sans-serif;
  font-size: clamp(24px, 2.8vw, 32px);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 48px 0 16px;
  padding-top: 36px;
  border-top: 2px solid var(--navy);
  display: flex;
  align-items: baseline;
  gap: 16px;
}
.privacy-prose h2:first-of-type {
  padding-top: 0;
  border-top: none;
  margin-top: 0;
}
.privacy-prose h2 .sec-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px;
  font-weight: 700;
  color: var(--sky-deep);
  letter-spacing: 0.18em;
  white-space: nowrap;
}
.privacy-prose h3 {
  font-family: 'Inter Tight', sans-serif;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--navy);
  margin: 32px 0 12px;
}
.privacy-prose p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--text-2);
  margin: 0 0 14px;
}
.privacy-prose p strong {
  color: var(--navy);
  font-weight: 700;
}
.privacy-prose ul,
.privacy-prose ol {
  margin: 0 0 18px 22px;
  padding: 0;
}
.privacy-prose li {
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--text-2);
  margin: 0 0 8px;
}
.privacy-prose li strong {
  color: var(--navy);
}
.privacy-prose a {
  color: var(--sky-deep);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.privacy-prose a:hover {
  color: var(--orange-text);
}
.privacy-callout {
  margin: 24px 0;
  padding: 22px 26px;
  background: var(--sky-soft);
  border-left: 4px solid var(--sky);
  font-size: 15px;
  line-height: 1.6;
  color: var(--text);
}
.privacy-callout strong {
  color: var(--navy);
  font-weight: 700;
}
.privacy-callout p:last-child {
  margin-bottom: 0;
}
.privacy-table-wrap {
  overflow-x: auto;
  margin: 18px 0 28px;
  border: 2px solid var(--navy);
}
.privacy-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14.5px;
  background: #fff;
}
.privacy-table th {
  background: var(--navy);
  color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: left;
  padding: 12px 14px;
  white-space: nowrap;
}
.privacy-table td {
  padding: 14px 14px;
  border-top: 1px solid var(--line);
  vertical-align: top;
  color: var(--text);
  line-height: 1.55;
}
.privacy-table td strong {
  color: var(--navy);
  font-weight: 700;
}
.privacy-table tr:nth-child(even) td {
  background: var(--bg);
}
.privacy-contact-box {
  margin: 36px 0 16px;
  padding: 28px 32px;
  background: var(--navy);
  color: #fff;
  border-left: 5px solid var(--orange);
}
.privacy-contact-box h3 {
  color: #fff;
  font-family: 'Inter Tight', sans-serif;
  font-size: 22px;
  font-weight: 900;
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}
.privacy-contact-box p {
  color: rgba(255,255,255,0.85);
  margin: 0 0 8px;
  font-size: 15.5px;
  line-height: 1.55;
}
.privacy-contact-box a {
  color: var(--sky);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.privacy-contact-box a:hover {
  color: var(--orange);
}
.privacy-contact-box strong {
  color: #fff;
}
.privacy-toc {
  margin: 8px 0 40px;
  padding: 24px 28px;
  background: var(--bg);
  border: 1px solid var(--line);
}
.privacy-toc-tag {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sky-deep);
  margin-bottom: 12px;
}
.privacy-toc ol {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 24px;
  counter-reset: toc;
}
.privacy-toc ol li {
  counter-increment: toc;
  margin: 0;
  padding: 4px 0;
  font-family: 'Inter Tight', sans-serif;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.privacy-toc ol li::before {
  content: counter(toc, decimal-leading-zero);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--orange-text);
  margin-right: 10px;
}
.privacy-toc ol li a {
  color: var(--navy);
  text-decoration: none;
  transition: color 0.15s;
}
.privacy-toc ol li a:hover {
  color: var(--orange-text);
}
.privacy-last-updated {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 32px;
  padding: 10px 16px;
  background: var(--orange-soft);
  border-left: 3px solid var(--orange);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--orange-text);
}

@media (max-width: 767px) {
  .privacy-prose h2 {
    flex-direction: column;
    gap: 6px;
    align-items: flex-start;
  }
  .privacy-toc ol {
    grid-template-columns: 1fr;
  }
  .privacy-contact-box {
    padding: 22px 22px;
  }
  .privacy-callout {
    padding: 18px 20px;
  }
}
