/* ============================================================
   Summit Leads V3.5  —  "Summit Blue, Operational"
   Firmer, serious, commercially-focused system. Translated from the
   Ventriloc analytics-console reference: neutral canvas, white operational
   cards, geometric type, controlled blue accent (orange -> Summit blue).
   Replaces the rejected soft "Light Editorial" pass (Fraunces, pale pastels).
   Space Grotesk (display) + Manrope (UI). Navy is action/headings; Action
   Blue is the single functional accent (icons, links, active, chart fills).
   ============================================================ */

:root{
  /* --- Summit colour system (Vince V3.5 brief) --- */
  --navy:#16245E;          /* Summit Navy — primary action, major headings, footer, strongest trust */
  --navy-deep:#0F1A40;     /* deeper navy — hover, deep panels */
  --blue:#2F63E9;          /* Action Blue — icons, links, active, selected, chart fills, small accents */
  --blue-700:#234FC4;      /* blue hover */
  --blue-wash:#E7EDFC;     /* faint blue chip/inset (icon squares, active wash) */
  --blue-wash-2:#D6E0FA;   /* slightly stronger blue inset */
  --carbon:#20242C;        /* main text, strong neutral UI */
  --graphite:#4D5563;      /* body + secondary text (AA 7.0 on paper) */
  --slate:#626C7B;         /* tertiary labels, captions, inactive (AA 5:1 on paper — darkened from brief #7A8495 to pass contrast) */
  --canvas:#EEF1F5;        /* page background */
  --paper:#FFFFFF;         /* operational cards + panels */
  --fog:#F6F7F9;           /* subtle inset surfaces */
  --hairline:#DCE1E8;      /* dividers + borders */
  --hairline-2:#CBD3DF;    /* stronger hairline (inputs, active rules) */

  /* --- semantic --- */
  --text:#20242C;          /* body strong */
  --text-2:#4D5563;        /* body */
  --text-strong:#16245E;   /* headings */
  --text-muted:#4D5563;    /* secondary */
  --on-navy:#E9EEFA;       /* text on navy */
  --on-navy-soft:#A8B6D8;  /* muted text on navy */
  --on-navy-line:rgba(255,255,255,.13);
  --danger:#C2293A;        /* form errors only */

  /* --- type --- */
  --display:"Space Grotesk", 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:.78125rem;       /* 12.5px */
  --fs-label:.875rem;           /* 14px */
  --fs-small:.9375rem;          /* 15px */
  --fs-body:1.0625rem;          /* 17px */
  --fs-lead:clamp(1.075rem, 1rem + .45vw, 1.225rem);     /* 17.2 → 19.6 */
  --fs-h3:clamp(1.15rem, 1.05rem + .4vw, 1.35rem);        /* card / UI titles */
  --fs-h2:clamp(2rem, 1.32rem + 2.3vw, 2.75rem);          /* section heading 32 → 44 */
  --fs-h1:clamp(2.7rem, 1.6rem + 3.2vw, 4rem);            /* hero display 43 → 64, compressed multi-line */

  /* --- spacing --- */
  --container:1240px;
  --section:clamp(64px, 4.5vw + 40px, 128px);    /* 64 mobile → ~96 tablet → 128 desktop */
  --section-tight:clamp(52px, 3vw + 32px, 92px);
  --card-pad:26px;
  --header-h:96px;

  /* --- shape lock: buttons pill · panels 12 · cards/inputs 8 · chips pill --- */
  --r-xs:6px; --r-sm:8px; --r-md:12px; --r-lg:16px; --r-pill:999px;

  /* --- restrained tinted elevation (white-on-canvas does most of the work) --- */
  --sh-1:0 1px 2px rgba(16,26,64,.05);
  --sh-2:0 1px 2px rgba(16,26,64,.04), 0 14px 30px -16px rgba(16,26,64,.16);
  --sh-float:0 2px 6px rgba(16,26,64,.06), 0 26px 50px -22px rgba(16,26,64,.30);

  --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; }
: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(--blue); }
.surface-navy :focus-visible,.footer :focus-visible{
  box-shadow:0 0 0 2px var(--navy), 0 0 0 4px #9FB6F2; }

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

.skip-link{ position:absolute; left:-999px; top:0; z-index:200; background:var(--navy); color:#fff;
  padding:11px 18px; border-radius:var(--r-sm); 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:36ch; margin-bottom:clamp(34px,4vw,52px); }
.section-head.center{ margin-inline:auto; text-align:center; max-width:44ch; }
.section-head h2 + p{ margin-top:18px; }
.section-head p{ color:var(--text-muted); font-size:var(--fs-lead); line-height:1.5; max-width:58ch; }
.section-head.center p{ margin-inline:auto; }

/* eyebrow / kicker — rationed (max ~1 per 3 sections) */
.eyebrow{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font);
  font-size:var(--fs-eyebrow); font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  color:var(--blue); margin-bottom:16px; }
.eyebrow::before{ content:""; width:18px; height:2px; background:var(--blue); border-radius:2px; }
.eyebrow.on-navy{ color:#9FB6F2; }
.eyebrow.on-navy::before{ background:#9FB6F2; }

/* --- surfaces (hierarchy via tint, restrained elevation) --- */
.surface-canvas{ background:var(--canvas); }
.surface-paper{ background:var(--paper); }
.surface-fog{ background:var(--fog); }
.surface-navy{ background:var(--navy); color:var(--on-navy); }
.surface-navy h1,.surface-navy h2,.surface-navy h3,.surface-navy h4{ color:#fff; }
.section + .section.surface-paper,.section + .section.surface-canvas{ border-top:1px solid var(--hairline); }

/* ============================================================
   BUTTONS  (Navy primary · quiet secondary · text link)
   ============================================================ */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font); font-size:.9375rem; font-weight:600; line-height:1; white-space:nowrap;
  padding:14px 22px; border-radius:var(--r-pill); border:1.5px solid transparent;
  transition:background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease), transform .12s var(--ease); }
.btn svg{ width:17px; height:17px; flex:none; }
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--navy); color:#fff; }
.btn-primary:hover{ background:var(--navy-deep); }
.btn-secondary{ background:var(--paper); color:var(--navy); border-color:var(--hairline-2); }
.btn-secondary:hover{ border-color:var(--navy); background:var(--fog); }
.btn-lg{ padding:16px 26px; font-size:1rem; }
.btn-block{ width:100%; }
/* on navy surfaces invert */
.surface-navy .btn-primary{ background:#fff; color:var(--navy); }
.surface-navy .btn-primary:hover{ background:var(--blue-wash); }
.surface-navy .btn-secondary{ background:transparent; color:#fff; border-color:var(--on-navy-line); }
.surface-navy .btn-secondary:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.45); }

/* quiet text link */
.link-quiet{ display:inline-flex; align-items:center; gap:8px; font-size:.9375rem; font-weight:600;
  color:var(--blue); 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; }

/* ============================================================
   HEADER + HAMBURGER TRIGGER  (clean: logo left, actions right)
   ============================================================ */
.site-header{ position:sticky; top:0; z-index:80; background:var(--paper);
  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(10px); box-shadow:0 4px 16px rgba(22,36,94,.06); }
.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:84px; }
.nav__actions{ display:flex; align-items:center; gap:12px; margin-left:auto; }
.nav__phone{ display:inline-flex; align-items:center; gap:8px; font-size:.9375rem; font-weight:700;
  color:var(--navy); padding:8px 10px; border-radius:var(--r-sm); white-space:nowrap; }
.nav__phone svg{ width:16px; height:16px; color:var(--blue); }
.nav__phone:hover{ background:rgba(22,36,94,.05); }
.nav__toggle{ display:inline-flex; align-items:center; gap:9px; height:44px; padding:0 16px;
  border-radius:var(--r-pill); border:1.5px solid var(--hairline-2); background:var(--paper);
  color:var(--navy); font-family:var(--font); font-size:.9375rem; font-weight:700;
  transition:border-color .15s var(--ease), background .15s var(--ease); }
.nav__toggle:hover{ border-color:var(--navy); }
.nav__toggle-ic{ position:relative; width:20px; height:20px; flex:none; }
.nav__toggle-ic svg{ position:absolute; inset:0; width:20px; height:20px; color:var(--navy); 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; }

/* ============================================================
   MOBILE DRAWER
   ============================================================ */
.drawer{ position:fixed; inset:0; z-index:95; visibility:hidden; }
.drawer__backdrop{ position:absolute; inset:0; background:rgba(16,26,64,.42); 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:44px; height:44px; flex:none; display:grid; place-items:center; border-radius:var(--r-sm);
  color:var(--navy); border:1px 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:600; letter-spacing:-.01em; color:var(--text-strong);
  transition:background .14s var(--ease); }
.drawer__link:hover{ background:var(--paper); }
.drawer__link .ic{ width:38px; height:38px; flex:none; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--blue-wash); color:var(--blue); 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); }
.drawer__link:hover .drawer__go{ transform:translateX(3px); color:var(--navy); }
.drawer__link[aria-current="page"]{ background:var(--paper); }
.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:50px;
  font-weight:700; color:var(--navy); border:1.5px solid var(--hairline-2); border-radius:var(--r-pill); }
.drawer__call svg{ width:18px; height:18px; color:var(--blue); }

/* ============================================================
   HERO  (full-bleed tradesman photo + navy directional scrim)
   ============================================================ */
.hero{ position:relative; isolation:isolate; min-height:clamp(560px,76vh,760px); display:flex; align-items:center;
  padding-block:clamp(40px,6vw,88px); overflow:hidden; background:#1a2440; }
.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(13,22,52,.92) 0%, rgba(13,22,52,.78) 38%, rgba(13,22,52,.30) 66%, rgba(13,22,52,.12) 100%),
    linear-gradient(0deg, rgba(13,22,52,.55) 0%, rgba(13,22,52,0) 42%); }
.hero__grid{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,360px); gap:48px; align-items:center; width:100%; }
.hero__copy{ max-width:660px; }
.hero__tag{ display:inline-flex; align-items:center; gap:8px; font-size:var(--fs-eyebrow); font-weight:700;
  letter-spacing:.04em; text-transform:uppercase; color:#BFD0FF; margin-bottom:20px; }
.hero__tag svg{ width:15px; height:15px; }
.hero h1{ color:#fff; }
.hero__sub{ margin-top:22px; font-size:var(--fs-lead); line-height:1.5; color:#D5DEF4; max-width:44ch; }
.hero__cta{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-top:30px; }
.hero__reassure{ display:flex; align-items:center; gap:9px; margin-top:24px; font-size:var(--fs-label);
  font-weight:500; color:#C3CFE9; }
.hero__reassure svg{ width:17px; height:17px; color:#7FE6C0; flex:none; }
.hero__reassure b{ color:#fff; font-weight:700; }

/* hero floating operational card (selected concept: enquiry -> booking timeline) */
.hero__panel{ justify-self:end; width:100%; max-width:360px; }

/* full-bleed background hero for sub-pages (single column, shorter) */
.hero--page{ min-height:clamp(400px,50vh,540px); padding-block:clamp(48px,7vw,92px); }
.hero--page > .container{ width:100%; }

/* ============================================================
   OPERATIONAL UI  (white "product screen" cards — the imagery)
   ============================================================ */
.opcard{ background:var(--paper); border:1px solid var(--hairline); border-radius:var(--r-md);
  box-shadow:var(--sh-float); overflow:hidden; }
.opcard--flat{ box-shadow:none; }
.opcard__head{ display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:14px 16px; border-bottom:1px solid var(--hairline); background:var(--fog); }
.opcard__title{ display:flex; align-items:center; gap:9px; font-size:var(--fs-label); font-weight:700;
  color:var(--text-strong); }
.opcard__title .live{ width:8px; height:8px; border-radius:50%; background:var(--blue); flex:none;
  box-shadow:0 0 0 3px var(--blue-wash); }
.tag-ex{ font-size:12px; font-weight:600; color:var(--slate); white-space:nowrap; }
.opcard__body{ padding:16px; }

/* vertical timeline (enquiry -> booking) */
.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(--blue-wash); color:var(--blue); position:relative; z-index:1; }
.tl-ic svg{ width:17px; height:17px; }
.tl-ic.is-done{ background:var(--navy); color:#fff; }
.tl-ic.is-alert{ background:#FBE9D6; color:#B5701B; }
.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(--blue-wash); font-size:var(--fs-label); font-weight:700; color:var(--navy); }
.opcard__foot svg{ width:17px; height:17px; color:var(--blue); flex:none; }

/* status rows (see-every-enquiry list) */
.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-sm);
  background:var(--blue-wash); color:var(--blue); }
.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:700; padding:5px 11px;
  border-radius:var(--r-pill); white-space:nowrap; }
.pill svg{ width:12px; height:12px; }
.pill--new{ background:var(--blue-wash); color:var(--blue); }
.pill--won{ background:#DEF3E7; color:#1F7A4D; }
.pill--booked{ background:var(--navy); color:#fff; }
.pill--followup{ background:#FBE9D6; color:#9A5A12; }

/* source / result mini-bars */
.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(--blue); }
.srcrow .fill.b{ background:var(--navy); } .srcrow .fill.c{ background:var(--blue-wash-2); }

/* weekly bars */
.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(--blue-wash-2); border-radius:4px 4px 0 0; min-height:8px; }
.bars .bar.hi{ background:var(--navy); }
.bars .bar.mid{ background:var(--blue); }

/* ============================================================
   PROOF STRIP
   ============================================================ */
.proof{ background:var(--paper); border-top:1px solid var(--hairline); border-bottom:1px solid var(--hairline); }
.proof__row{ display:grid; grid-template-columns:repeat(3,1fr); }
.pitem{ display:flex; gap:14px; align-items:flex-start; padding:26px 0; }
.proof__row .pitem + .pitem{ padding-left:36px; border-left:1px solid var(--hairline); }
.proof__row .pitem:not(:first-child){ padding-left:36px; }
.pic{ width:38px; height:38px; flex:none; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--blue-wash); color:var(--blue); }
.pic svg{ width:20px; height:20px; }
.pitem strong{ display:block; font-size:var(--fs-label); font-weight:700; color:var(--text-strong); margin-bottom:3px; }
.pitem span{ font-size:13.5px; color:var(--text-muted); line-height:1.5; }

/* ============================================================
   CONNECTED OFFER  (numbered editorial list + one visual)
   ============================================================ */
.connect{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(36px,5vw,72px); align-items:start; }
.connect__lead{ position:sticky; top:calc(var(--header-h) + 24px); }
.connect__visual{ margin-top:28px; }
.offerlist{ display:grid; gap:0; }
.orow{ display:grid; grid-template-columns:auto 1fr; gap:20px; padding:24px 0; border-top:1px solid var(--hairline); }
.orow:last-child{ border-bottom:1px solid var(--hairline); }
.orow__n{ font-family:var(--display); font-size:1.05rem; font-weight:600; color:var(--blue);
  font-variant-numeric:tabular-nums; line-height:1.7; }
.orow__b h3{ display:flex; align-items:center; gap:11px; margin-bottom:8px; }
.orow__b h3 svg{ width:20px; height:20px; color:var(--blue); flex:none; }
.orow__b p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.55; margin-bottom:12px; }
.orow__tags{ display:flex; flex-wrap:wrap; gap:7px; }
.chip{ display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; color:var(--carbon);
  background:var(--fog); border:1px solid var(--hairline); padding:5px 11px; border-radius:var(--r-pill); }
.chip svg{ width:13px; height:13px; color:var(--blue); }

/* ============================================================
   SIGNATURE MISSED-CALL
   ============================================================ */
.mcq{ display:grid; grid-template-columns:1fr 1.02fr; gap:clamp(36px,5vw,72px); align-items:center; }
.mcq__steps{ display:grid; gap:0; }
.mcq-step{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:22px 0; }
.mcq-step + .mcq-step{ border-top:1px solid var(--hairline); }
.mcq-step__dot{ width:46px; height:46px; flex:none; display:grid; place-items:center; border-radius:var(--r-md);
  background:var(--paper); border:1px solid var(--hairline); color:var(--blue);
  font-family:var(--display); font-weight:600; transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease); }
.mcq-step.is-active .mcq-step__dot{ background:var(--navy); border-color:var(--navy); color:#fff; }
.mcq-step__b strong{ display:block; font-size:1.05rem; font-weight:700; 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:340px; background:var(--paper); border:1px solid var(--hairline);
  border-radius:var(--r-lg); box-shadow:var(--sh-2); 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(--blue); display:inline-block; }
.bubbles{ display:grid; gap:9px; }
.bubble{ max-width:88%; padding:10px 13px; border-radius:13px; font-size:var(--fs-label); line-height:1.45;
  opacity:0; transform:translateY(8px); transition:opacity .4s var(--ease), transform .4s 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(--fog); border:1px solid var(--hairline); color:var(--graphite); justify-self:start; }
.bubble.missed .time{ color:var(--slate); }
.bubble.auto{ background:var(--navy); color:var(--on-navy); justify-self:start; }
.bubble.auto .time{ color:var(--on-navy-soft); }
.bubble.reply{ background:var(--blue); color:#fff; justify-self:end; }
.bubble.reply .time{ color:#D6E0FA; }
.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(--blue-wash); border-radius:var(--r-sm); font-size:12.5px; font-weight:700; color:var(--navy);
  opacity:0; transform:translateY(8px); transition:opacity .4s var(--ease), transform .4s var(--ease); }
.phone__booked.show{ opacity:1; transform:none; }
.phone__booked svg{ width:16px; height:16px; color:var(--blue); 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  (full-width operational view)
   ============================================================ */
.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:18px; }
.ccol{ border-radius:var(--r-md); padding:var(--card-pad); }
.ccol--them{ background:var(--paper); border:1px solid var(--hairline); }
.ccol--us{ background:var(--navy); color:var(--on-navy); }
.ccol h3{ margin-bottom:5px; }
.ccol--us h3{ color:#fff; }
.ccol__sub{ font-size:12.5px; color:var(--text-muted); margin-bottom:18px; }
.ccol--us .ccol__sub{ color:var(--on-navy-soft); }
.clist{ display:grid; gap:13px; }
.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:#7FE6C0; }

/* ============================================================
   QUALIFIER  (who it's for — yes/no)
   ============================================================ */
.qualify{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.qcard{ border-radius:var(--r-md); padding:var(--card-pad); }
.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:16px; }
.qcard h3 svg{ width:20px; height:20px; }
.qcard--yes h3 svg{ color:var(--blue); } .qcard--no h3 svg{ color:var(--slate); }
.qlist{ display:grid; gap:12px; }
.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(--blue); } .qcard--no .qlist svg{ color:var(--slate); }

/* ============================================================
   OFFER / TRIAL  (split panel)
   ============================================================ */
.offer{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(28px,4vw,52px); align-items:start; }
.offer-card{ background:var(--navy); color:var(--on-navy); border-radius:var(--r-md); padding:clamp(28px,3vw,40px); }
.offer-card__badge{ display:inline-flex; font-size:11.5px; font-weight:700; color:#fff; letter-spacing:.03em;
  text-transform:uppercase; background:rgba(255,255,255,.12); padding:6px 13px; border-radius:var(--r-pill); margin-bottom:18px; }
.offer-card h3{ color:#fff; font-size:1.5rem; margin-bottom:8px; }
.offer-card__line{ font-size:var(--fs-small); color:var(--on-navy-soft); margin-bottom:22px; }
.offer-list{ display:grid; gap:14px; margin-bottom:26px; }
.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:#7FE6C0; }
.offer-note{ font-size:12px; color:var(--on-navy-soft); margin-top:14px; line-height:1.5; }
.offer-side{ padding-top:4px; }
.offer-side h3{ font-size:1.25rem; 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(--blue); }
.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; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:780px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid var(--hairline); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:22px 2px; font-family:var(--display); font-size:1.075rem; font-weight:600; color:var(--text-strong);
  letter-spacing:-.01em; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-ic{ width:30px; height:30px; flex:none; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--blue-wash); color:var(--blue); 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(--navy); color:#fff; }
.faq-item[open] .faq-ic svg{ transform:rotate(45deg); }
.faq-answer{ padding:0 2px 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(28px,4vw,56px); align-items:center; }
.cta-copy .eyebrow{ color:#9FB6F2; }
.cta-copy .eyebrow::before{ background:#9FB6F2; }
.cta-points{ display:grid; gap:14px; margin-top:24px; }
.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:#7FE6C0; }
.cta-call{ margin-top:28px; padding-top:22px; 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.5rem; font-weight:600; color:#fff; letter-spacing:-.01em; }
.cta-call svg{ width:22px; height:22px; color:#9FB6F2; }
.surface-navy .section-head p,.surface-navy p{ color:var(--on-navy-soft); }

.form-card{ background:var(--paper); border-radius:var(--r-md); box-shadow:var(--sh-2); padding:clamp(24px,2.6vw,32px); }
.form-card > h3{ font-size:1.3rem; 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(--blue-wash); color:var(--navy); }
.form-alert--ok svg{ color:var(--blue); }
.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:700; color:var(--text-strong); margin-bottom:7px; }
.field .req{ color:var(--blue); }
.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 13px; 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(--blue);
  box-shadow:0 0 0 3px rgba(47,99,233,.16); }
.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(--blue); text-decoration:underline; }
/* the form-card is always a white surface — insulate it from .surface-navy inversion */
.surface-navy .form-card h3,.surface-navy .form-card h4{ color:var(--text-strong); }
.surface-navy .form-card p,.surface-navy .form-card .form-card__sub{ color:var(--text-muted); }
.surface-navy .form-card label{ color:var(--text-strong); }
.surface-navy .form-card .form-privacy{ color:var(--slate); }
.surface-navy .form-card .form-alert--ok{ background:var(--blue-wash); color:var(--navy); }
.surface-navy .form-card .btn-primary{ background:var(--navy); color:#fff; }
.surface-navy .form-card .btn-primary:hover{ background:var(--navy-deep); }

/* ============================================================
   FOOTER  (navy)
   ============================================================ */
.footer{ background:var(--navy); color:var(--on-navy-soft); padding-block:64px 36px; }
.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:600; letter-spacing:.01em; }
.footer-brand .s1{ color:#fff; } .footer-brand .s2{ color:#9FB6F2; }
.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:700; color:#fff;
  letter-spacing:.04em; 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: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:#9FB6F2; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:18px; flex-wrap:wrap;
  margin-top:48px; padding-top:26px; 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%; }
.callbar .btn-call{ background:var(--paper); color:var(--navy); border:1.5px solid var(--hairline-2); }
.callbar .btn-call svg{ color:var(--blue); }

/* ============================================================
   SUB-PAGE HERO (kept for the not-yet-elevated sub-pages)
   ============================================================ */
.page-hero{ background:var(--paper); border-bottom:1px solid var(--hairline); padding-block:clamp(44px,5vw,76px); }
.page-hero__grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(32px,4vw,52px); align-items:center; }
.page-hero__grid.is-solo{ grid-template-columns:1fr; max-width:760px; }
.page-hero h1{ color:var(--text-strong); margin-bottom:18px; font-size:clamp(2.2rem,1.4rem+3vw,3.4rem); }
.page-hero__copy p{ font-size:var(--fs-lead); color:var(--text-muted); line-height:1.5; max-width:48ch; }
.page-hero__photo{ border-radius:var(--r-md); overflow:hidden; box-shadow:var(--sh-2); }
.page-hero__photo img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.accent{ color:var(--blue); }

/* generic card grid (sub-pages) */
.grid-cards{ display:grid; grid-template-columns:repeat(12,1fr); gap:18px; }
.card{ grid-column:span 4; background:var(--paper); border:1px solid var(--hairline); border-radius:var(--r-md);
  padding:var(--card-pad); transition:border-color .18s var(--ease), box-shadow .18s var(--ease); display:block; }
a.card:hover{ border-color:var(--blue); box-shadow:var(--sh-2); }
.card--span6{ grid-column:span 6; } .card--span4{ grid-column:span 4; }
.card__ic{ width:42px; height:42px; display:grid; place-items:center; border-radius:var(--r-sm);
  background:var(--blue-wash); color:var(--blue); margin-bottom:16px; }
.card__ic svg{ width:21px; height:21px; }
.card h3{ margin-bottom:7px; }
.card p{ font-size:var(--fs-small); color:var(--text-muted); line-height:1.55; }
.cta-grid .cta-points li{ color:#EAF0FC; }

/* two-column content (sub-pages) */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,4vw,64px); align-items:center; }

/* ============================================================
   REVEAL MOTION  (intensity 4, reduced-motion safe)
   ============================================================ */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .55s var(--ease), transform .55s 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; }
  .mega__inner{ grid-template-columns:1fr 1fr; }
  .mega__aside{ grid-column:1 / -1; flex-direction:row; align-items:center; justify-content:space-between; }
  .mega__aside .btn{ margin-top:0; white-space:nowrap; }
}
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; gap:32px; }
  .hero__panel{ display:none; }      /* keep hero clean on mobile; operational UI lives in dedicated sections */
  .connect{ grid-template-columns:1fr; gap:36px; }
  .connect__lead{ position:static; }
  .mcq,.offer,.cta-grid,.seegrid,.split{ grid-template-columns:1fr; gap:32px; }
  .mcq__phone{ order:-1; }
  .seegrid__side{ grid-template-columns:1fr; }
  .callbar{ display:flex; }
  body{ padding-bottom:74px; }
}
@media (max-width:760px){
  .proof__row{ grid-template-columns:1fr; }
  .proof__row .pitem + .pitem{ border-left:none; border-top:1px solid var(--hairline); padding-left:0; }
  .proof__row .pitem:not(:first-child){ padding-left:0; }
  .pitem{ padding:22px 0; }
  .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; }
  .page-hero__grid{ grid-template-columns:1fr; gap:28px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:12px; }
}
@media (max-width:767px){
  .nav__phone,.nav__cta{ display:none; }
  .nav__toggle-label{ display:none; }
  .nav__toggle{ width:44px; padding:0; justify-content:center; }
}
@media (max-width:520px){
  .container{ padding-inline:18px; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero__cta{ gap:12px; }
  .hero__cta .btn{ width:100%; }
}

/* ============================================================
   LEGACY VAR ALIASES (sub-page inline styles reference old names;
   map them onto the new palette so sub-pages stay consistent,
   pending their own elevation pass)
   ============================================================ */
:root{
  --ink:var(--navy); --ink-700:var(--navy-deep); --ink-text:var(--text-strong);
  --wash:var(--blue-wash-2); --mist:var(--blue-wash); --pale:var(--fog); --linen:var(--paper);
  --charcoal:var(--carbon);
  --body:var(--text-2); --muted:var(--text-muted);
  --blue-text:var(--blue); --blue-soft:var(--blue-wash); --blue-soft-2:var(--blue-wash-2);
  --line:var(--hairline); --r-nav:var(--r-sm); --r-card:var(--r-md);
  --cyan:var(--blue); --surface-2:var(--fog);
  --steel:var(--graphite); --on-ink:var(--on-navy); --on-ink-soft:var(--on-navy-soft);
}
.surface-soft{ background:var(--fog); }
.surface-ink{ background:var(--navy); color:var(--on-navy); }
.surface-mist{ background:var(--blue-wash); }
.section-head .eyebrow{ }
