/* ============================================================
   Summit Leads V5  —  "Agency Energy"
   Complete makeover to the trades lead-gen agency formula
   (researched: One Base Media, Hook, SMC, SanXpert, KlientBoost)
   rendered in Summit's brand: light bright canvas, navy ink,
   GREEN pill CTAs used loudly, green benefit ticks, product
   mockups (SERP ad + landing-page phones + results cards) doing
   the talking. Focus of the whole site: Google Ads + landing
   pages for UK plumbing & heating firms. Honesty intact: no
   fabricated awards/logos/case numbers — coded example builds
   and the 14-day trial are the proof. Geist + Manrope.
   ============================================================ */

:root{
  /* --- colour system --- */
  --navy:#16245E;          /* Summit Navy — headings, ink, dark bands */
  --navy-deep:#0F1A40;     /* deep ink, hovers */
  --anchor:#0C1330;        /* darkest band (missed-call, footer) */
  --navy-wash:#EDEFF6;
  --navy-wash-2:#DCE2F0;
  --navy-mid:#5A6BA6;

  --accent:#15803D;        /* THE CTA green — loud pills, highlights (white text, AA 5.0) */
  --accent-hover:#116B33;
  --accent-bright:#43C97C; /* accent on dark surfaces (AA 7+ on navy) */
  --accent-deep:#136B34;   /* accent as small text on light washes (AA) */
  --green:#178A50;         /* benefit ticks, AA on white */
  --green-wash:#E4F3EA;
  --alert-wash:#FBECEC;    /* missed-call alert wash */
  --alert-text:#A03A3A;

  --carbon:#1B1F28;
  --graphite:#454B59;
  --slate:#5F6470;
  --canvas:#FFFFFF;        /* bright white base */
  --band:#F6F7F5;          /* soft alternating band */
  --paper:#FFFFFF;
  --fog:#F1F2F0;
  --hairline:#E5E6E2;
  --hairline-2:#CDCEC8;

  /* --- semantic --- */
  --text:#1B1F28;
  --text-2:#454B59;
  --text-strong:#16245E;
  --text-muted:#454B59;
  --on-navy:#E9EDF8;
  --on-navy-soft:#A7B2D2;
  --on-navy-line:rgba(255,255,255,.14);
  --danger:#C2293A;

  /* --- type --- */
  --display:"Geist", ui-sans-serif, system-ui, "Segoe UI", Roboto, Arial, sans-serif;
  --font:"Manrope", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --fs-eyebrow:.75rem;
  --fs-label:.875rem;
  --fs-small:.9375rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.1rem, 1rem + .5vw, 1.3rem);
  --fs-h3:clamp(1.2rem, 1.08rem + .45vw, 1.45rem);
  --fs-h2:clamp(2rem, 1.35rem + 2.5vw, 3.1rem);
  --fs-h1:clamp(2.7rem, 1.7rem + 3.6vw, 4.4rem);

  /* --- spacing --- */
  --container:1240px;
  --section:clamp(68px, 4.6vw + 40px, 130px);
  --section-tight:clamp(52px, 3.2vw + 34px, 92px);
  --card-pad:30px;
  --header-h:92px;

  /* --- shape: pill buttons · big friendly card radii --- */
  --r-xs:8px; --r-sm:12px; --r-md:16px; --r-lg:20px; --r-xl:24px; --r-pill:999px;

  /* --- lively but clean elevation --- */
  --sh-1:0 1px 2px rgba(12,19,48,.05);
  --sh-2:0 2px 4px rgba(12,19,48,.05), 0 18px 40px -18px rgba(12,19,48,.18);
  --sh-float:0 4px 10px rgba(12,19,48,.06), 0 34px 70px -26px rgba(12,19,48,.32);

  --ease:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:calc(var(--header-h) + 12px); }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--font); font-size:var(--fs-body); line-height:1.62; color:var(--text-2);
  background:var(--canvas); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1,"liga" 1; overflow-x:hidden;
}
img,svg,picture,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
ul,ol{ list-style:none; padding:0; }
::selection{ background:rgba(23,138,80,.22); }
:focus{ outline:none; }
:focus-visible{ outline:none; border-radius:var(--r-xs);
  box-shadow:0 0 0 2px var(--paper), 0 0 0 4px var(--navy); }
.surface-navy :focus-visible,.surface-anchor :focus-visible,.footer :focus-visible{
  box-shadow:0 0 0 2px var(--anchor), 0 0 0 4px var(--accent-bright); }

/* --- type --- */
h1,h2,h3,h4{ font-family:var(--display); color:var(--text-strong); text-wrap:balance; }
h1,h2{ font-weight:700; }
h1{ font-size:var(--fs-h1); line-height:1.02; letter-spacing:-.032em; }
h2{ font-size:var(--fs-h2); line-height:1.06; letter-spacing:-.025em; }
h3{ font-size:var(--fs-h3); font-weight:660; line-height:1.18; letter-spacing:-.015em; }
h4{ font-weight:660; line-height:1.2; letter-spacing:-.01em; }
p{ text-wrap:pretty; max-width:64ch; }
strong{ font-weight:700; color:var(--text); }

/* accent keyword devices */
.hl{ text-decoration:underline; text-decoration-color:var(--accent);
  text-decoration-thickness:.07em; text-underline-offset:.12em; text-decoration-skip-ink:none; }
.accent{ color:var(--accent); }
.surface-navy .accent,.surface-anchor .accent,.hero--page .accent{ color:var(--accent-bright); }

/* real Google "G" — inline beside every prominent Google mention */
.gmark{ display:inline-block; width:.95em; height:.95em; vertical-align:-.1em; }
h2 .gmark{ width:.88em; height:.88em; vertical-align:-.05em; margin-right:.02em; }
.eyebrow .gmark{ width:1.15em; height:1.15em; vertical-align:-.22em; }
.ticks .gmark{ width:1.05em; height:1.05em; vertical-align:-.18em; }
.g-line{ display:flex; align-items:center; gap:10px; margin-top:20px; padding-top:18px;
  border-top:1px solid var(--hairline); font-size:var(--fs-small); font-weight:800; color:var(--text-strong); }
.g-line .gmark{ width:20px; height:20px; flex:none; }

.skip-link{ position:absolute; left:-999px; top:0; z-index:200; background:var(--navy); color:#fff;
  padding:11px 18px; border-radius:var(--r-pill); font-size:var(--fs-label); font-weight:600; }
.skip-link:focus{ left:14px; top:14px; }

/* --- layout --- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.section{ padding-block:var(--section); position:relative; }
.section--tight{ padding-block:var(--section-tight); }

.section-head{ max-width:46ch; margin-bottom:clamp(36px,4.2vw,58px); }
.section-head.center{ margin-inline:auto; text-align:center; max-width:48ch; }
.section-head h2 + p{ margin-top:18px; }
.section-head p{ color:var(--text-muted); font-size:var(--fs-lead); line-height:1.52; max-width:56ch; }
.section-head.center p{ margin-inline:auto; }

/* eyebrow */
.eyebrow{ display:inline-flex; align-items:center; gap:10px; font-family:var(--font);
  font-size:var(--fs-eyebrow); font-weight:800; letter-spacing:.13em; text-transform:uppercase;
  color:var(--accent); margin-bottom:16px; }
.eyebrow::before{ content:""; width:20px; height:3px; border-radius:3px; background:var(--accent); flex:none; }
.eyebrow.on-navy{ color:var(--accent-bright); }
.eyebrow.on-navy::before{ background:var(--accent-bright); }

/* --- surfaces --- */
.surface-canvas{ background:var(--canvas); }
.surface-band{ background:var(--band); }
.surface-paper{ background:var(--paper); }
.surface-fog{ background:var(--fog); }
.surface-navy{ background:var(--navy); color:var(--on-navy); }
.surface-anchor{ background:var(--anchor); color:var(--on-navy); }
.surface-navy h1,.surface-navy h2,.surface-navy h3,.surface-navy h4,
.surface-anchor h1,.surface-anchor h2,.surface-anchor h3,.surface-anchor h4{ color:#fff; }
.surface-navy .section-head p,.surface-navy p,
.surface-anchor .section-head p,.surface-anchor p{ color:var(--on-navy-soft); }
.section + .section.surface-canvas,.section + .section.surface-band{ border-top:1px solid var(--hairline); }

/* ============================================================
   BUTTONS — green PILL is the primary CTA everywhere (agency
   energy) · navy outline secondary
   ============================================================ */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font); font-size:.9375rem; font-weight:800; line-height:1; white-space:nowrap;
  padding:16px 27px; border-radius:var(--r-pill); border:2px solid transparent; letter-spacing:.005em;
  transition:background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease), transform .12s var(--ease), box-shadow .18s var(--ease); }
.btn svg{ width:17px; height:17px; flex:none; }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--accent); color:#fff;
  box-shadow:0 2px 8px rgba(21,128,61,.28), 0 14px 30px -12px rgba(12,19,48,.3); }
.btn-primary:hover{ background:var(--accent-hover); color:#fff; }
.btn-secondary{ background:transparent; color:var(--navy); border-color:var(--navy); }
.btn-secondary:hover{ background:var(--navy); color:#fff; }
.btn-lg{ padding:19px 32px; font-size:1.02rem; }
.btn-block{ width:100%; }
.surface-navy .btn-secondary,.surface-anchor .btn-secondary{
  background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.surface-navy .btn-secondary:hover,.surface-anchor .btn-secondary:hover{
  background:rgba(255,255,255,.1); border-color:#fff; color:#fff; }

/* quiet text link */
.link-quiet{ display:inline-flex; align-items:center; gap:8px; font-size:.9375rem; font-weight:800;
  color:var(--navy); padding:8px 2px; }
.link-quiet svg{ width:16px; height:16px; transition:transform .2s var(--ease); }
.link-quiet:hover svg{ transform:translateX(3px); }
.link-quiet.on-photo{ color:#fff; }

/* green benefit ticks */
.ticks{ display:grid; gap:13px; }
.ticks li{ display:flex; gap:12px; align-items:flex-start; font-size:1rem; line-height:1.5; color:var(--graphite); }
.ticks li b,.ticks li strong{ color:var(--carbon); }
.ticks .tick{ width:22px; height:22px; flex:none; margin-top:1px; display:grid; place-items:center;
  border-radius:50%; background:var(--green-wash); color:var(--green); }
.ticks .tick svg{ width:13px; height:13px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{ position:sticky; top:0; z-index:80; background:var(--canvas);
  border-bottom:1px solid var(--hairline);
  transition:box-shadow .2s var(--ease), background .2s var(--ease); }
.site-header.is-stuck{ background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(12px); box-shadow:0 4px 18px rgba(12,19,48,.07); }
.nav{ display:flex; align-items:center; gap:22px; min-height:var(--header-h); }
.nav__logo{ display:flex; align-items:center; flex:none; }
.nav__logo img{ width:auto; height:78px; }
.nav__actions{ display:flex; align-items:center; gap:14px; margin-left:auto; }
.nav__phone{ display:inline-flex; align-items:center; gap:8px; font-size:.95rem; font-weight:800;
  color:var(--navy); padding:8px 10px; border-radius:var(--r-pill); white-space:nowrap; }
.nav__phone svg{ width:16px; height:16px; color:var(--accent); }
.nav__phone:hover{ background:rgba(22,36,94,.05); }
.nav__cta{ padding:13px 22px; font-size:.9rem; }
.nav__toggle{ display:inline-flex; align-items:center; gap:9px; height:46px; padding:0 18px;
  border-radius:var(--r-pill); border:2px solid var(--navy); background:var(--paper);
  color:var(--navy); font-family:var(--font); font-size:.9375rem; font-weight:800;
  transition:background .15s var(--ease), color .15s var(--ease); }
.nav__toggle:hover{ background:var(--navy); color:#fff; }
.nav__toggle:hover .nav__toggle-ic svg{ color:#fff; }
.nav__toggle-ic{ position:relative; width:20px; height:20px; flex:none; }
.nav__toggle-ic svg{ position:absolute; inset:0; width:20px; height:20px; color:currentColor; transition:opacity .2s var(--ease); }
.nav__toggle .ic-close{ opacity:0; }
.nav__toggle[aria-expanded="true"] .ic-open{ opacity:0; }
.nav__toggle[aria-expanded="true"] .ic-close{ opacity:1; }

/* ============================================================
   DRAWER
   ============================================================ */
.drawer{ position:fixed; inset:0; z-index:95; visibility:hidden; }
.drawer__backdrop{ position:absolute; inset:0; background:rgba(12,19,48,.5); opacity:0;
  transition:opacity .25s var(--ease); }
.drawer__panel{ position:absolute; inset:0 0 0 auto; width:min(420px,100%); background:var(--canvas);
  display:flex; flex-direction:column; transform:translateX(100%); transition:transform .28s var(--ease); }
.drawer.is-open{ visibility:visible; }
.drawer.is-open .drawer__backdrop{ opacity:1; }
.drawer.is-open .drawer__panel{ transform:translateX(0); }
.drawer__top{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 20px; border-bottom:1px solid var(--hairline); min-height:var(--header-h); }
.drawer__top img{ height:48px; width:auto; }
.drawer__close{ width:46px; height:46px; flex:none; display:grid; place-items:center; border-radius:50%;
  color:var(--navy); border:2px solid var(--hairline-2); background:var(--paper); }
.drawer__close svg{ width:22px; height:22px; }
.drawer__scroll{ flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch; padding:14px 16px 16px;
  display:grid; gap:4px; align-content:start; }
.drawer__link{ display:flex; gap:14px; align-items:center; min-height:56px; padding:10px 14px; border-radius:var(--r-md);
  font-family:var(--display); font-size:1.0625rem; font-weight:640; letter-spacing:-.01em; color:var(--text-strong);
  transition:background .14s var(--ease); }
.drawer__link:hover{ background:var(--band); }
.drawer__link .ic{ width:40px; height:40px; flex:none; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--navy-wash); color:var(--navy); transition:background .14s var(--ease), color .14s var(--ease); }
.drawer__link .ic svg{ width:19px; height:19px; }
.drawer__label{ flex:1; }
.drawer__go{ width:18px; height:18px; color:var(--slate); transition:transform .2s var(--ease), color .2s var(--ease); }
.drawer__link:hover .drawer__go{ transform:translateX(3px); color:var(--accent); }
.drawer__link[aria-current="page"]{ background:var(--band); box-shadow:inset 3px 0 0 var(--accent); }
.drawer__link[aria-current="page"] .ic{ background:var(--navy); color:#fff; }
.drawer__actions{ display:grid; gap:12px; padding:16px 20px calc(16px + env(safe-area-inset-bottom));
  border-top:1px solid var(--hairline); background:var(--paper); }
.drawer__call{ display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:52px;
  font-weight:800; color:var(--navy); border:2px solid var(--navy); border-radius:var(--r-pill); }
.drawer__call svg{ width:18px; height:18px; color:var(--accent); }

/* ============================================================
   V5 HERO — light, punchy, mockup collage (the agency formula)
   ============================================================ */
.hero5{ position:relative; overflow:hidden; background:
    radial-gradient(1100px 520px at 88% -10%, rgba(23,138,80,.08), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(22,36,94,.07), transparent 55%),
    var(--canvas);
  padding-block:clamp(52px,5.6vw,96px); border-bottom:1px solid var(--hairline); }
.hero5__grid{ display:grid; grid-template-columns:minmax(0,1.04fr) minmax(0,.96fr); gap:clamp(36px,4.5vw,76px); align-items:center; }
.hero5__copy .eyebrow{ margin-bottom:22px; }
.hero5 h1{ margin-bottom:24px; max-width:15ch; font-size:clamp(2.9rem, 1.8rem + 3.9vw, 4.8rem); }
.hero5__sub{ font-size:var(--fs-lead); line-height:1.55; color:var(--graphite); max-width:44ch; margin-bottom:34px; }
.hero5__cta{ display:flex; align-items:center; gap:20px; flex-wrap:wrap; }

/* hero photography (V5.2 — stock imagery, not coded diagrams) */
.hero-photo{ position:relative; }
.photo-card--hero img{ aspect-ratio:10/9; object-position:62% 42%; }
.photo-chip{ position:absolute; z-index:3; display:inline-flex; align-items:center; gap:8px;
  background:var(--paper); border:1px solid var(--hairline); box-shadow:var(--sh-2);
  border-radius:var(--r-pill); padding:10px 15px; font-size:12.5px; font-weight:800; color:var(--carbon); white-space:nowrap; }
.photo-chip svg{ width:16px; height:16px; flex:none; }
.photo-chip .tick-ic{ display:inline-flex; color:var(--green); }
.photo-chip .tick-ic svg{ width:16px; height:16px; }
.photo-chip--tl{ top:20px; left:-16px; }
.photo-chip--br{ bottom:24px; right:-12px; }

/* ---- phone landing-page mockup ---- */
.phone-mock{ width:min(270px,74vw); background:var(--carbon); border-radius:34px; padding:10px;
  box-shadow:var(--sh-float); }
.phone-mock__screen{ background:#fff; border-radius:26px; overflow:hidden; }
.pm-top{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:11px 13px; border-bottom:1px solid var(--hairline); }
.pm-top__brand{ display:flex; align-items:center; gap:7px; font-family:var(--display); font-weight:800; font-size:11.5px; color:var(--navy); }
.pm-top__brand .dot{ width:20px; height:20px; border-radius:6px; background:var(--navy); color:#fff; display:grid; place-items:center; font-size:9px; }
.pm-top__call{ display:inline-flex; align-items:center; gap:5px; background:var(--accent); color:#fff;
  font-size:10.5px; font-weight:800; border-radius:var(--r-pill); padding:6px 10px; }
.pm-top__call svg{ width:11px; height:11px; }
.pm-hero{ position:relative; }
.pm-hero img{ width:100%; height:104px; object-fit:cover; }
.pm-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(12,19,48,.66), rgba(12,19,48,.12)); }
.pm-hero__t{ position:absolute; left:12px; right:12px; bottom:9px; z-index:2; color:#fff;
  font-family:var(--display); font-weight:700; font-size:13.5px; line-height:1.25; letter-spacing:-.01em; }
.pm-chips{ display:flex; gap:6px; padding:10px 12px 2px; flex-wrap:wrap; }
.pm-chip{ display:inline-flex; align-items:center; gap:5px; font-size:9.5px; font-weight:800; color:var(--graphite);
  background:var(--band); border:1px solid var(--hairline); border-radius:var(--r-pill); padding:4px 8px; }
.pm-chip svg{ width:10px; height:10px; color:var(--green); }
.pm-form{ padding:10px 12px 13px; display:grid; gap:7px; }
.pm-form .f{ height:30px; border:1.5px solid var(--hairline-2); border-radius:9px; display:flex; align-items:center;
  padding:0 10px; font-size:10.5px; color:var(--slate); }
.pm-form .b{ height:34px; border-radius:var(--r-pill); background:var(--accent); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; }
.pm-tag{ display:block; text-align:center; font-size:9.5px; color:var(--slate); padding:0 10px 10px; font-weight:600; }

/* ============================================================
   TRUST STRIP (honest chips — replaces award walls)
   ============================================================ */
.trust{ background:var(--band); border-bottom:1px solid var(--hairline); }
.trust__row{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; padding-block:22px; }
.trust__item{ display:flex; align-items:center; gap:11px; font-size:13.5px; font-weight:700; color:var(--carbon); line-height:1.35; }
.trust__item svg{ width:20px; height:20px; flex:none; color:var(--accent); }

/* ============================================================
   SERVICES — three big cards (the offer, agency-style)
   ============================================================ */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc-card{ position:relative; display:flex; flex-direction:column; background:var(--paper); border:1px solid var(--hairline);
  border-radius:var(--r-xl); padding:var(--card-pad); box-shadow:var(--sh-1);
  transition:box-shadow .2s var(--ease), transform .2s var(--ease), border-color .2s var(--ease); }
.svc-card:hover{ box-shadow:var(--sh-2); transform:translateY(-4px); border-color:var(--navy-wash-2); }
.svc-card__photo{ margin:calc(var(--card-pad) * -1) calc(var(--card-pad) * -1) 22px;
  border-radius:var(--r-xl) var(--r-xl) 0 0; overflow:hidden; border-bottom:1px solid var(--hairline); }
.svc-card__photo img{ width:100%; height:176px; object-fit:cover; }
.svc-card h3{ font-size:1.35rem; margin-bottom:10px; display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.svc-card h3 .gmark{ width:22px; height:22px; }
.svc-card p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.6; margin-bottom:18px; }
.svc-card .ticks{ gap:9px; margin-bottom:22px; }
.svc-card .ticks li{ font-size:.9rem; }
.svc-card .link-quiet{ margin-top:auto; }

/* ============================================================
   WORK BAND (navy) — "the pages your ads deserve" phone trio
   ============================================================ */
.work{ }
.work__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.6vw,34px); justify-items:center;
  margin-bottom:26px; }
.work .phone-mock{ position:static; width:min(258px,100%); }
.work .phone-mock:nth-child(2){ transform:translateY(18px); }
.work__note{ display:flex; align-items:center; justify-content:center; gap:9px; font-size:12.5px; font-weight:700;
  color:var(--on-navy-soft); text-align:center; }
.work__note svg{ width:15px; height:15px; color:var(--accent-bright); flex:none; }
.work__points{ display:flex; justify-content:center; gap:clamp(16px,3vw,42px); flex-wrap:wrap; margin-top:30px; }
.work__points span{ display:inline-flex; align-items:center; gap:9px; font-size:var(--fs-small); font-weight:700; color:#EAF0FC; }
.work__points svg{ width:17px; height:17px; color:var(--accent-bright); flex:none; }

/* ============================================================
   PROCESS — giant numerals 1·2·3 (agency staple)
   ============================================================ */
.process{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(22px,3vw,40px); }
.process__step{ position:relative; padding-top:8px; }
.process__n{ font-family:var(--display); font-weight:750; font-size:clamp(4.4rem, 3rem + 4.5vw, 7rem); line-height:.9;
  letter-spacing:-.04em; color:var(--accent); opacity:.92; margin-bottom:14px; }
.process__step h3{ font-size:1.3rem; margin-bottom:9px; }
.process__step p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.6; }
.process__step .mini{ display:inline-flex; align-items:center; gap:7px; margin-top:12px; font-size:12.5px; font-weight:800;
  color:var(--green); }
.process__step .mini svg{ width:14px; height:14px; }

/* ============================================================
   OPERATIONAL UI (kept — results/dashboard cards, all tagged)
   ============================================================ */
.opcard{ background:var(--paper); border:1px solid var(--hairline); border-radius:var(--r-lg);
  box-shadow:var(--sh-float); overflow:hidden; }
.opcard--flat{ box-shadow:var(--sh-1); }
.opcard__head{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:14px 16px; border-bottom:1px solid var(--hairline); background:#FBFBF9; }
.opcard__title{ display:flex; align-items:center; gap:9px; font-size:var(--fs-label); font-weight:800;
  color:var(--text-strong); }
.opcard__title .live{ width:8px; height:8px; border-radius:50%; background:var(--green); flex:none;
  box-shadow:0 0 0 3px var(--green-wash); }
.tag-ex{ font-size:12px; font-weight:600; color:var(--slate); white-space:nowrap; }
.opcard__body{ padding:16px; }
.tl{ display:grid; gap:0; }
.tl-item{ position:relative; display:grid; grid-template-columns:34px 1fr auto; gap:12px; padding:9px 0; }
.tl-item:not(:last-child)::before{ content:""; position:absolute; left:16px; top:34px; bottom:-1px; width:2px;
  background:var(--hairline); }
.tl-ic{ width:34px; height:34px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:var(--navy-wash); color:var(--navy); position:relative; z-index:1; }
.tl-ic svg{ width:17px; height:17px; }
.tl-ic.is-done{ background:var(--green); color:#fff; }
.tl-ic.is-alert{ background:var(--alert-wash); color:var(--alert-text); }
.tl-b{ min-width:0; align-self:center; }
.tl-b strong{ display:block; font-size:var(--fs-label); font-weight:700; color:var(--text-strong); line-height:1.25; }
.tl-b span{ display:block; font-size:12px; color:var(--text-muted); line-height:1.35; }
.tl-time{ font-size:11.5px; color:var(--slate); font-variant-numeric:tabular-nums; align-self:center; white-space:nowrap; }
.opcard__foot{ display:flex; align-items:center; gap:9px; padding:12px 16px; border-top:1px solid var(--hairline);
  background:var(--green-wash); font-size:var(--fs-label); font-weight:700; color:#0F5B33; }
.opcard__foot svg{ width:17px; height:17px; color:var(--green); flex:none; }
.statusrow{ display:grid; grid-template-columns:34px 1fr auto; gap:13px; align-items:center; padding:13px 0;
  border-top:1px solid var(--hairline); }
.statusrow:first-child{ border-top:none; }
.statusrow .ic{ width:34px; height:34px; flex:none; display:grid; place-items:center; border-radius:var(--r-xs);
  background:var(--navy-wash); color:var(--navy); }
.statusrow .ic svg{ width:17px; height:17px; }
.statusrow .b strong{ display:block; font-size:var(--fs-label); font-weight:700; color:var(--text-strong); }
.statusrow .b span{ font-size:12px; color:var(--text-muted); }
.pill{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:800; padding:5px 11px;
  border-radius:var(--r-pill); white-space:nowrap; }
.pill svg{ width:12px; height:12px; }
.pill--new{ background:var(--navy-wash); color:var(--navy); }
.pill--won{ background:var(--green); color:#fff; }
.pill--booked{ background:var(--navy); color:#fff; }
.pill--followup{ background:var(--green-wash); color:var(--accent-deep); }
.srcrow{ display:grid; gap:7px; margin-bottom:13px; }
.srcrow:last-child{ margin-bottom:0; }
.srcrow .lab{ display:flex; justify-content:space-between; font-size:12px; }
.srcrow .lab span{ color:var(--text-muted); } .srcrow .lab b{ color:var(--text-strong); font-weight:700; }
.srcrow .track{ height:8px; background:var(--fog); border-radius:var(--r-pill); overflow:hidden; }
.srcrow .fill{ display:block; height:100%; border-radius:var(--r-pill); background:var(--navy); }
.srcrow .fill.b{ background:var(--navy-mid); } .srcrow .fill.c{ background:var(--navy-wash-2); }
.bars{ display:flex; align-items:flex-end; gap:8px; height:92px; padding-bottom:2px;
  border-bottom:1px solid var(--hairline); margin-bottom:16px; }
.bars .bar{ flex:1; background:var(--navy-wash-2); border-radius:4px 4px 0 0; min-height:8px; }
.bars .bar.hi{ background:var(--accent); }
.bars .bar.mid{ background:var(--navy-mid); }

/* ============================================================
   SIGNATURE MISSED-CALL (kept — full-bleed anchor)
   ============================================================ */
.surface-anchor .mcq-step__b strong{ color:#fff; }
.surface-anchor .mcq-step__b span{ color:var(--on-navy-soft); }
.mcq{ display:grid; grid-template-columns:1fr 1.02fr; gap:clamp(40px,5vw,84px); align-items:center; }
.mcq__steps{ display:grid; gap:0; }
.mcq-step{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:24px 0; }
.mcq-step + .mcq-step{ border-top:1px solid var(--on-navy-line); }
.mcq-step__dot{ width:48px; height:48px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:rgba(255,255,255,.05); border:1px solid var(--on-navy-line); color:var(--on-navy-soft);
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease); }
.mcq-step__dot svg{ width:21px; height:21px; }
.mcq-step.is-active .mcq-step__dot{ background:var(--accent-bright); border-color:var(--accent-bright); color:var(--navy-deep); }
.mcq-step__b strong{ display:block; font-size:1.08rem; font-weight:660; color:var(--text-strong); margin-bottom:4px;
  font-family:var(--display); letter-spacing:-.01em; }
.mcq-step__b span{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.5; }
.mcq__phone{ display:grid; place-items:center; }
.phone{ width:100%; max-width:344px; background:var(--paper); border:1px solid var(--hairline);
  border-radius:var(--r-xl); box-shadow:var(--sh-float); padding:16px 16px 18px; }
.phone__head{ display:flex; align-items:center; gap:11px; padding-bottom:13px; border-bottom:1px solid var(--hairline); margin-bottom:13px; }
.phone__avatar{ width:40px; height:40px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:var(--navy); color:#fff; }
.phone__avatar svg{ width:20px; height:20px; }
.phone__head strong{ font-size:var(--fs-label); font-weight:700; color:var(--text-strong); display:block; }
.phone__head > div > span{ display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-muted); }
.phone__head .live{ width:7px; height:7px; border-radius:50%; background:var(--green); display:inline-block; }
.bubbles{ display:grid; gap:9px; }
.bubble{ max-width:88%; padding:10px 13px; border-radius:14px; font-size:var(--fs-label); line-height:1.45;
  opacity:0; transform:translateY(10px) scale(.97); transition:opacity .45s var(--ease), transform .45s var(--ease); }
.bubble.show{ opacity:1; transform:none; }
.bubble .meta{ display:block; font-size:11px; color:var(--slate); margin-bottom:3px; font-weight:700; }
.bubble .time{ display:block; font-size:10.5px; margin-top:4px; }
.bubble.missed{ background:var(--alert-wash); border:1px solid #F0D4D4; color:var(--alert-text); justify-self:start; }
.bubble.missed .meta,.bubble.missed .time{ color:var(--alert-text); }
.bubble.auto{ background:var(--navy); color:var(--on-navy); justify-self:start; }
.bubble.auto .time{ color:var(--on-navy-soft); }
.bubble.reply{ background:var(--fog); border:1px solid var(--hairline); color:var(--carbon); justify-self:end; }
.bubble.reply .time{ color:var(--slate); }
.bubble.typing{ display:inline-flex; gap:4px; background:var(--fog); border:1px solid var(--hairline);
  justify-self:start; padding:12px 14px; }
.bubble.typing i{ width:6px; height:6px; border-radius:50%; background:var(--slate); animation:typing 1.2s infinite; }
.bubble.typing i:nth-child(2){ animation-delay:.2s; } .bubble.typing i:nth-child(3){ animation-delay:.4s; }
@keyframes typing{ 0%,60%,100%{ opacity:.3; transform:translateY(0); } 30%{ opacity:1; transform:translateY(-3px); } }
.phone__booked{ display:flex; align-items:center; gap:9px; margin-top:13px; padding:11px 13px;
  background:var(--green-wash); border:1px solid #CBE7D6; border-radius:var(--r-sm); font-size:12.5px; font-weight:800; color:#0F5B33;
  opacity:0; transform:translateY(10px); transition:opacity .45s var(--ease), transform .45s var(--ease); }
.phone__booked.show{ opacity:1; transform:none; }
.phone__booked svg{ width:16px; height:16px; color:var(--green); flex:none; }
@media (prefers-reduced-motion: reduce){
  .bubble,.phone__booked{ opacity:1; transform:none; transition:none; }
  .bubble.typing{ display:none; }
  .mcq-step__dot{ transition:none; }
}

/* ============================================================
   SEE EVERY ENQUIRY
   ============================================================ */
.seegrid{ display:grid; grid-template-columns:1.25fr 1fr; gap:20px; align-items:start; }
.seegrid__side{ display:grid; gap:20px; }

/* ============================================================
   COMPARISON
   ============================================================ */
.compare{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.ccol{ border-radius:var(--r-xl); padding:clamp(26px,3vw,40px); }
.ccol--them{ background:var(--paper); border:1px solid var(--hairline); }
.ccol--us{ background:var(--navy); color:var(--on-navy); box-shadow:var(--sh-2); }
.ccol h3{ margin-bottom:5px; font-size:1.3rem; }
.ccol--us h3{ color:#fff; }
.ccol__sub{ font-size:12.5px; color:var(--text-muted); margin-bottom:20px; }
.ccol--us .ccol__sub{ color:var(--on-navy-soft); }
.clist{ display:grid; gap:14px; }
.clist li{ display:flex; gap:11px; align-items:flex-start; font-size:var(--fs-small); line-height:1.5; }
.clist svg{ width:18px; height:18px; flex:none; margin-top:1px; }
.ccol--them .clist li{ color:var(--graphite); }
.ccol--them .clist svg{ color:var(--slate); }
.ccol--us .clist li{ color:#EAF0FC; }
.ccol--us .clist svg{ color:var(--accent-bright); }

/* ============================================================
   QUALIFIER
   ============================================================ */
.qualify{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.qcard{ border-radius:var(--r-xl); padding:clamp(26px,3vw,40px); }
.qcard--yes{ background:var(--paper); border:1px solid var(--hairline); box-shadow:var(--sh-1); }
.qcard--no{ background:var(--fog); border:1px solid var(--hairline); }
.qcard h3{ display:flex; align-items:center; gap:10px; margin-bottom:18px; font-size:1.25rem; }
.qcard h3 svg{ width:21px; height:21px; }
.qcard--yes h3 svg{ color:var(--green); } .qcard--no h3 svg{ color:var(--slate); }
.qlist{ display:grid; gap:13px; }
.qlist li{ display:flex; gap:11px; align-items:flex-start; font-size:var(--fs-small); line-height:1.5; color:var(--graphite); }
.qlist svg{ width:18px; height:18px; flex:none; margin-top:1px; }
.qcard--yes .qlist svg{ color:var(--green); } .qcard--no .qlist svg{ color:var(--slate); }

/* ============================================================
   OFFER / TRIAL — pricing-panel style
   ============================================================ */
.offer{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(30px,4vw,56px); align-items:start; }
.offer-card{ background:var(--navy); color:var(--on-navy); border-radius:var(--r-xl); padding:clamp(30px,3.4vw,46px);
  box-shadow:var(--sh-float); position:relative; overflow:hidden; }
.offer-card::before{ content:""; position:absolute; right:-70px; top:-70px; width:230px; height:230px; border-radius:50%;
  background:radial-gradient(circle, rgba(67,201,124,.2), transparent 65%); }
.offer-card__badge{ display:inline-flex; font-size:11.5px; font-weight:800; color:#fff; letter-spacing:.1em;
  text-transform:uppercase; background:var(--accent); padding:7px 14px; border-radius:var(--r-pill); margin-bottom:20px; }
.offer-card h3{ color:#fff; font-size:1.7rem; margin-bottom:8px; letter-spacing:-.02em; }
.offer-card__line{ font-size:var(--fs-small); color:var(--on-navy-soft); margin-bottom:24px; }
.offer-list{ display:grid; gap:14px; margin-bottom:28px; }
.offer-list li{ display:flex; gap:11px; align-items:flex-start; font-size:var(--fs-small); line-height:1.5; color:#EAF0FC; }
.offer-list strong{ color:#fff; }
.offer-list svg{ width:18px; height:18px; flex:none; margin-top:1px; color:var(--accent-bright); }
.offer-note{ font-size:12px; color:var(--on-navy-soft); margin-top:14px; line-height:1.5; }
.offer-side{ padding-top:4px; }
.offer-side .photo-card{ margin-bottom:26px; }
.offer-side h3{ font-size:1.3rem; margin-bottom:6px; }
.offer-side > p{ color:var(--text-muted); margin-bottom:10px; font-size:var(--fs-small); }
.honesty-item{ display:flex; gap:14px; align-items:flex-start; padding:18px 0; border-top:1px solid var(--hairline); }
.honesty-item:first-of-type{ border-top:none; }
.honesty-item > svg{ width:24px; height:24px; flex:none; color:var(--navy); }
.honesty-item strong{ display:block; font-size:1rem; color:var(--text-strong); margin-bottom:3px; }
.honesty-item p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.5; }

/* photo card (kept for accents) */
.photo-card{ position:relative; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--sh-2);
  background:var(--anchor); }
.photo-card img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.photo-card--wide img{ aspect-ratio:3/2; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:780px; margin-inline:auto; }
.faq-item{ border:1px solid var(--hairline); border-radius:var(--r-md); background:var(--paper); margin-bottom:12px; }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:20px 22px; font-family:var(--display); font-size:1.08rem; font-weight:660; color:var(--text-strong);
  letter-spacing:-.01em; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-ic{ width:32px; height:32px; flex:none; display:grid; place-items:center; border-radius:50%;
  background:var(--fog); color:var(--navy); transition:background .2s var(--ease), color .2s var(--ease); }
.faq-ic svg{ width:16px; height:16px; transition:transform .2s var(--ease); }
.faq-item[open] .faq-ic{ background:var(--accent); color:#fff; }
.faq-item[open] .faq-ic svg{ transform:rotate(45deg); }
.faq-answer{ padding:0 22px 22px; }
.faq-answer p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.6; max-width:68ch; }

/* ============================================================
   FINAL CTA + LEAD FORM (navy)
   ============================================================ */
.cta-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,4.5vw,64px); align-items:center; }
.cta-points{ display:grid; gap:14px; margin-top:26px; }
.cta-points li{ display:flex; gap:12px; align-items:flex-start; font-size:var(--fs-small); line-height:1.5; color:#EAF0FC; }
.cta-points svg{ width:19px; height:19px; flex:none; margin-top:1px; color:var(--accent-bright); }
.cta-call{ margin-top:30px; padding-top:24px; border-top:1px solid var(--on-navy-line); }
.cta-call span{ display:block; font-size:12.5px; color:var(--on-navy-soft); margin-bottom:7px; }
.cta-call a{ display:inline-flex; align-items:center; gap:10px; font-family:var(--display); font-size:1.55rem; font-weight:700; color:#fff; letter-spacing:-.015em; white-space:nowrap; }
.cta-call svg{ width:22px; height:22px; color:var(--accent-bright); flex:none; }

.form-card{ background:var(--paper); border-radius:var(--r-xl); box-shadow:var(--sh-float); padding:clamp(26px,2.8vw,36px); }
.form-card > h3{ font-size:1.4rem; margin-bottom:6px; }
.form-card__sub{ font-size:var(--fs-small); color:var(--text-muted); margin-bottom:20px; }
.form-alert{ display:none; align-items:center; gap:10px; padding:12px 14px; border-radius:var(--r-sm);
  font-size:var(--fs-label); font-weight:600; margin-bottom:16px; }
.form-alert.show{ display:flex; }
.form-alert svg{ width:18px; height:18px; flex:none; }
.form-alert--ok{ background:var(--green-wash); color:#0F5B33; }
.form-alert--ok svg{ color:var(--green); }
.form-alert--err{ background:#FCECEE; color:#B42334; }
.form-alert--err svg{ color:#B42334; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field{ margin-bottom:14px; display:flex; flex-direction:column; }
.field label{ font-size:var(--fs-eyebrow); font-weight:800; color:var(--text-strong); margin-bottom:7px; letter-spacing:.02em; }
.field .req{ color:var(--accent); }
.field input,.field textarea{ font:inherit; font-size:var(--fs-label); color:var(--text);
  background:var(--paper); border:1.5px solid var(--hairline-2); border-radius:var(--r-sm);
  padding:12px 14px; width:100%; transition:border-color .15s var(--ease), box-shadow .15s var(--ease); min-height:48px; }
.field textarea{ min-height:auto; resize:vertical; line-height:1.5; }
.field input::placeholder,.field textarea::placeholder{ color:var(--slate); }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--navy);
  box-shadow:0 0 0 3px rgba(22,36,94,.14); }
.field--error input,.field--error textarea{ border-color:var(--danger); }
.field__error{ display:none; align-items:center; gap:6px; margin-top:6px; font-size:11.5px; color:var(--danger); }
.field__error svg{ width:13px; height:13px; flex:none; }
.field--error .field__error{ display:flex; }
.field--turnstile{ margin-bottom:14px; min-height:65px; }
.field--turnstile .cf-turnstile{ max-width:100%; }
.btn-submit{ margin-top:8px; position:relative; }
.btn-submit .spin{ display:none; width:18px; height:18px; animation:spin .8s linear infinite; }
.btn-submit.is-loading .label{ opacity:.6; } .btn-submit.is-loading .spin{ display:block; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.form-privacy{ font-size:12px; color:var(--slate); margin-top:14px; line-height:1.5; }
.form-privacy a{ color:var(--navy); text-decoration:underline; }
.surface-navy .form-card h3,.surface-navy .form-card h4,
.surface-anchor .form-card h3,.surface-anchor .form-card h4{ color:var(--text-strong); }
.surface-navy .form-card p,.surface-navy .form-card .form-card__sub,
.surface-anchor .form-card p,.surface-anchor .form-card .form-card__sub{ color:var(--text-muted); }
.surface-navy .form-card label,.surface-anchor .form-card label{ color:var(--text-strong); }
.surface-navy .form-card .form-privacy,.surface-anchor .form-card .form-privacy{ color:var(--slate); }

/* ============================================================
   FOOTER (anchor)
   ============================================================ */
.footer{ background:var(--anchor); color:var(--on-navy-soft); padding-block:72px 40px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:40px; }
.footer-brand .wordmark{ display:inline-flex; align-items:center; gap:10px; margin-bottom:16px; }
.footer-brand .mark{ width:30px; height:30px; }
.footer-brand .s1,.footer-brand .s2{ font-family:var(--display); font-size:1.15rem; font-weight:700; letter-spacing:.01em; }
.footer-brand .s1{ color:#fff; } .footer-brand .s2{ color:var(--accent-bright); }
.footer-brand p{ font-size:var(--fs-small); color:var(--on-navy-soft); line-height:1.6; max-width:34ch; }
.footer-col h4{ font-family:var(--font); font-size:var(--fs-eyebrow); font-weight:800; color:#fff;
  letter-spacing:.12em; text-transform:uppercase; margin-bottom:14px; }
.footer-col ul{ display:grid; gap:10px; }
.footer-col a,.footer-contact span{ font-size:var(--fs-small); color:var(--on-navy-soft); transition:color .15s var(--ease); }
.footer-col a .gmark{ width:14px; height:14px; vertical-align:-.13em; margin-right:2px; }
.footer-col a:hover{ color:#fff; }
.footer-contact li{ display:flex; align-items:center; gap:10px; margin-bottom:10px; font-size:var(--fs-small); color:var(--on-navy-soft); }
.footer-contact svg{ width:16px; height:16px; flex:none; color:var(--accent-bright); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  margin-top:52px; padding-top:28px; border-top:1px solid var(--on-navy-line); }
.footer-bottom p{ font-size:12px; color:var(--on-navy-soft); max-width:none; }
.footer-legal{ display:flex; gap:18px; }
.footer-legal a{ font-size:12px; color:var(--on-navy-soft); }
.footer-legal a:hover{ color:#fff; }

/* ============================================================
   STICKY MOBILE CALLBAR
   ============================================================ */
.callbar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:70; gap:10px;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom)); background:var(--paper); border-top:1px solid var(--hairline); }
.callbar a{ flex:1; }
.callbar .btn{ width:100%; padding:14px 18px; }
.callbar .btn-call{ background:var(--paper); color:var(--navy); border:2px solid var(--navy); }
.callbar .btn-call svg{ color:var(--accent); }

/* ============================================================
   PHOTO PAGE HERO (kept for Who-we-help)
   ============================================================ */
.hero{ position:relative; isolation:isolate; display:flex; align-items:center;
  padding-block:clamp(48px,6vw,96px); overflow:hidden; background:var(--anchor); }
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; object-position:72% 50%; }
.hero__scrim{ position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(90deg, rgba(12,19,48,.92) 0%, rgba(12,19,48,.78) 34%, rgba(12,19,48,.22) 66%, rgba(12,19,48,.02) 100%),
    linear-gradient(0deg, rgba(12,19,48,.5) 0%, rgba(12,19,48,0) 40%); }
.hero__copy{ max-width:700px; }
.hero__tag{ display:inline-flex; align-items:center; gap:9px; font-size:var(--fs-eyebrow); font-weight:800;
  letter-spacing:.13em; text-transform:uppercase; color:#C9D3EC; margin-bottom:22px; }
.hero__tag svg{ width:15px; height:15px; color:var(--accent-bright); }
.hero h1{ color:#fff; }
.hero__sub{ margin-top:24px; font-size:var(--fs-lead); line-height:1.5; color:#D7DEF2; max-width:46ch; }
.hero__cta{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:34px; }
.hero--page{ min-height:clamp(400px,50vh,540px); padding-block:clamp(56px,7vw,100px); }
.hero--page > .container{ width:100%; }
.hero--page h1{ font-size:clamp(2.5rem, 1.6rem + 3.2vw, 3.9rem); max-width:16ch; }

/* light sub-page hero (V5 default) */
.page-head{ position:relative; overflow:hidden; border-bottom:1px solid var(--hairline);
  background:
    radial-gradient(900px 420px at 92% -20%, rgba(23,138,80,.07), transparent 60%),
    var(--canvas);
  padding-block:clamp(46px,5vw,84px); }
.page-head__grid{ display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); gap:clamp(34px,4.5vw,68px); align-items:center; }
.page-head__grid.is-solo{ grid-template-columns:1fr; max-width:800px; }
.page-head h1{ margin-bottom:18px; max-width:17ch; font-size:clamp(2.4rem, 1.6rem + 2.9vw, 3.9rem); }
.page-head__sub{ font-size:var(--fs-lead); line-height:1.55; color:var(--graphite); max-width:50ch; margin-bottom:24px; }
.page-head .ticks{ margin-bottom:26px; }
.page-head__cta{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.page-head__visual{ position:relative; }

/* steps rows (how-it-works detail) */
.steps{ max-width:880px; }
.step-row{ display:grid; grid-template-columns:84px 1fr; gap:22px; padding:28px 0; border-top:1px solid var(--hairline); align-items:start; }
.step-row:last-child{ border-bottom:1px solid var(--hairline); }
.step-row__n{ font-family:var(--display); font-size:clamp(1.7rem, 1.3rem + 1.4vw, 2.3rem); font-weight:750;
  color:var(--accent); letter-spacing:-.02em; line-height:1.1; font-variant-numeric:tabular-nums; }
.step-row h3{ display:flex; align-items:center; gap:10px; margin-bottom:7px; font-size:1.25rem; }
.step-row h3 svg{ width:20px; height:20px; color:var(--navy); flex:none; }
.step-row p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.6; max-width:56ch; }

/* generic card grid */
.grid-cards{ display:grid; grid-template-columns:repeat(12,1fr); gap:22px; }
.card{ grid-column:span 4; background:var(--paper); border:1px solid var(--hairline); border-radius:var(--r-lg);
  padding:var(--card-pad); box-shadow:var(--sh-1); transition:border-color .18s var(--ease), box-shadow .18s var(--ease), transform .18s var(--ease); display:block; }
.card:hover{ box-shadow:var(--sh-2); transform:translateY(-3px); }
.card--span6{ grid-column:span 6; } .card--span4{ grid-column:span 4; }
.card__ic{ width:46px; height:46px; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--navy-wash); color:var(--navy); margin-bottom:18px; }
.card__ic svg{ width:22px; height:22px; }
.card h3{ margin-bottom:7px; }
.card p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.55; }

/* two-column content */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(34px,4.5vw,72px); align-items:center; }
.split .stack{ display:grid; gap:20px; }
.split .cta-points li{ color:var(--graphite); }
.split .cta-points svg{ color:var(--green); }
.split__phone{ display:grid; place-items:center; }

/* ============================================================
   REVEAL MOTION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }
html:not(.js) .reveal{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .footer-brand{ grid-column:1 / -1; }
  .trust__row{ grid-template-columns:1fr 1fr; gap:10px 24px; padding-block:18px; }
}
@media (max-width:980px){
  /* full-bleed photo heroes with overlaid text on mobile — the client boiler-LP
     treatment (GasMaster benchmark): photo behind, navy scrim, white copy on top */
  .hero5,.page-head{ position:relative; isolation:isolate; background:var(--anchor); border-bottom:none;
    padding-block:clamp(60px,11vw,88px); min-height:72vh; display:flex; align-items:center; }
  .hero5 > .container,.page-head > .container{ width:100%; }
  .hero5__grid,.page-head__grid{ grid-template-columns:1fr; gap:0; }
  .hero-photo,.page-head__visual{ position:absolute; inset:0; z-index:-2; margin:0; max-width:none;
    opacity:1 !important; transform:none !important; transition:none !important; }
  .hero-photo::after,.page-head__visual::after{ content:""; position:absolute; inset:0; z-index:2;
    background:linear-gradient(0deg, rgba(12,19,48,.9) 0%, rgba(12,19,48,.7) 48%, rgba(12,19,48,.22) 100%); }
  .hero-photo .photo-card,.page-head__visual .photo-card{ position:absolute; inset:0; border-radius:0; box-shadow:none; }
  .hero-photo .photo-card picture,.page-head__visual .photo-card picture{ height:100%; }
  .hero-photo .photo-card img,.page-head__visual .photo-card img{ width:100%; height:100%; aspect-ratio:auto; object-fit:cover; object-position:50% 28%; }
  .photo-chip{ display:none; }
  .hero5 h1,.page-head h1{ color:#fff; max-width:none; text-shadow:0 1px 14px rgba(12,19,48,.45); }
  .hero5 .eyebrow,.page-head .eyebrow{ text-shadow:0 1px 10px rgba(12,19,48,.55); }
  .hero5__sub,.page-head__sub{ color:#D7DEF2; }
  .hero5 .eyebrow,.page-head .eyebrow{ color:var(--accent-bright); }
  .hero5 .accent,.page-head .accent{ color:var(--accent-bright); }
  .hero5 .hl,.page-head .hl{ text-decoration-color:var(--accent-bright); }
  .hero5 .link-quiet,.page-head .link-quiet{ color:#fff; }
  .page-head .ticks li{ color:#E9EDF8; }
  .page-head .ticks li b,.page-head .ticks li strong{ color:#fff; }
  .page-head .ticks .tick{ background:rgba(255,255,255,.14); color:var(--accent-bright); }
  .svc-grid{ grid-template-columns:1fr; }
  .process{ grid-template-columns:1fr; gap:36px; }
  .work__grid{ grid-template-columns:1fr; gap:26px; }
  .work .phone-mock:nth-child(2){ transform:none; }
  .mcq,.offer,.cta-grid,.seegrid,.split{ grid-template-columns:1fr; gap:34px; }
  .mcq__phone{ order:-1; }
  .seegrid__side{ grid-template-columns:1fr; }
  .callbar{ display:flex; }
  body{ padding-bottom:74px; }
}
@media (max-width:760px){
  .compare,.qualify{ grid-template-columns:1fr; }
  .grid-cards{ grid-template-columns:repeat(6,1fr); }
  .card,.card--span6,.card--span4{ grid-column:span 6; }
  .field-row{ grid-template-columns:1fr; gap:0; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:12px; }
  .step-row{ grid-template-columns:52px 1fr; gap:16px; padding:24px 0; }
  .trust__row{ grid-template-columns:1fr; gap:12px; }
}
@media (max-width:767px){
  .nav__phone,.nav__cta{ display:none; }
  .nav__toggle-label{ display:none; }
  .nav__toggle{ width:46px; padding:0; justify-content:center; }
}
@media (max-width:520px){
  .container{ padding-inline:18px; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero5__cta .btn,.page-head__cta .btn{ width:100%; }
}

/* ============================================================
   LEGACY VAR ALIASES (start.mjs + inline styles)
   ============================================================ */
:root{
  --blue:var(--navy); --blue-700:var(--navy-deep);
  --blue-wash:var(--navy-wash); --blue-wash-2:var(--navy-wash-2);
  --ink:var(--navy); --ink-700:var(--navy-deep); --ink-text:var(--text-strong);
  --wash:var(--navy-wash-2); --mist:var(--navy-wash); --pale:var(--fog); --linen:var(--paper);
  --charcoal:var(--carbon);
  --body:var(--text-2); --muted:var(--text-muted);
  --blue-text:var(--navy); --blue-soft:var(--navy-wash); --blue-soft-2:var(--navy-wash-2);
  --line:var(--hairline); --r-nav:var(--r-sm); --r-card:var(--r-md);
  --cyan:var(--navy); --surface-2:var(--fog);
  --steel:var(--graphite); --on-ink:var(--on-navy); --on-ink-soft:var(--on-navy-soft);
  --canvas-legacy:var(--band);
}
.surface-soft{ background:var(--fog); }
.surface-ink{ background:var(--navy); color:var(--on-navy); }
.surface-mist{ background:var(--navy-wash); }
