/* ============================================================
   CLICKATE PUBLIC STYLESHEET
   Design system: tokens.css → components → utilities → layout
   No utility framework. BEM-ish naming. WCAG AA throughout.
   ============================================================ */

:root{
  --ink:#16222C;
  --ink-soft:#3C4B58;
  --muted:#64727E;
  --primary:#1E3D5C;
  --primary-soft:#EAF0F6;
  --accent:#E89B1C;
  --accent-ink:#7A4E03;
  --accent-soft:#FBF1DD;
  --surface:#FFFFFF;
  --surface-alt:#F7F5F0;
  --line:#E4E0D6;
  --line-strong:#C9C3B4;
  --success:#1E7B4D;
  --danger:#B23A3A;
  --wa:#1FAF5E;
  --radius:10px;
  --radius-sm:6px;
  --container:1400px;
  --gutter:clamp(14px, 4vw, 44px);
  --font-display:"Bricolage Grotesque", Georgia, serif;
  --font-body:"Instrument Sans", "Segoe UI", Tahoma, sans-serif;
  --shadow-1:0 1px 2px rgba(22,34,44,.06), 0 4px 14px rgba(22,34,44,.06);
  --shadow-2:0 2px 4px rgba(22,34,44,.08), 0 14px 34px rgba(22,34,44,.10);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001s !important;transition-duration:.001s !important}
}
body{
  font-family:var(--font-body);
  font-size:clamp(15px, 1.5vw, 17px);
  line-height:1.6;
  color:var(--ink);
  background:var(--surface);
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--accent-ink)}
ul{list-style:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container-narrow{max-width:980px;margin-inline:auto;padding-inline:var(--gutter)}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200}
.skip-link:focus{left:8px;top:8px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;letter-spacing:-.015em;color:var(--ink);font-weight:700}
.h-display{font-size:clamp(26px, 3.4vw, 44px);font-weight:800}
.h-section{font-size:clamp(23px, 2.8vw, 36px)}
.h-card{font-size:clamp(17px, 1.6vw, 20px)}
.lead{font-size:clamp(16px, 1.7vw, 19px);color:var(--ink-soft)}
.small{font-size:13.5px}
.mark{background:linear-gradient(transparent 62%, var(--accent-soft) 62%)}
.kicker{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
.kicker::before{content:"";width:26px;height:2px;background:var(--accent)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:clamp(22px,3vw,36px)}
.section-head .h-section{max-width:24ch}
.section-num{font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--muted);letter-spacing:.1em}
.rule-top{border-top:1px solid var(--line)}
section{padding-block:clamp(40px, 6vw, 84px)}
.band-alt{background:var(--surface-alt)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:48px;padding:11px 22px;border-radius:999px;
  font-weight:600;font-size:15px;line-height:1.2;border:1.5px solid transparent;
  transition:background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease;
  white-space:nowrap;cursor:pointer;
}
.btn svg{flex:none}
.btn-primary{background:var(--accent);color:#231603;border-color:var(--accent)}
.btn-primary:hover{background:#D68C0F;border-color:#D68C0F;color:#231603;transform:translateY(-1px)}
.btn-outline{border-color:var(--primary);color:var(--primary);background:var(--surface)}
.btn-outline:hover{background:var(--primary-soft);color:var(--primary)}
.btn-ghost{color:var(--primary);padding-inline:10px}
.btn-ghost:hover{color:var(--accent-ink)}
.btn-wa{background:var(--surface);border-color:var(--wa);color:#11713C}
.btn-wa:hover{background:#EDFAF2;color:#11713C}
.btn[disabled]{opacity:.6;cursor:not-allowed}
.arrow{transition:transform .15s ease}
a:hover .arrow,.btn:hover .arrow{transform:translateX(3px)}

/* ============================================================
   HEADER
   ============================================================ */
.utility{background:var(--surface-alt);border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
.utility-in{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:36px}
.utility-in ul{display:flex;gap:18px;flex-wrap:wrap}
.utility a{color:var(--ink-soft);font-weight:500}
.utility a:hover{color:var(--primary)}
.utility .dot{color:var(--line-strong)}
header.site{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
header.site.is-stuck{box-shadow:var(--shadow-1)}
/* 3-column grid: brand | flexible nav | CTA cluster.
   Robust replacement for the old flex + margin-auto trick, which let
   nav.primary's `margin-inline:auto` and .nav-cta's `margin-left:auto`
   share the free space and pin the CTA halfway between the menu and
   the right edge on desktop. Grid gives us deterministic columns:
   brand stays left, nav.primary sits in the flexible middle column,
   .nav-cta always lands flush right - on every page, every viewport. */
.nav-in{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;min-height:72px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:800;font-size:23px;letter-spacing:-.02em;color:var(--ink)}
.brand:hover{color:var(--ink)}
.brand .spark{width:10px;height:10px;border-radius:50%;background:var(--accent);flex:none}
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:10px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;margin-top:1px}
nav.primary{display:flex;align-items:center;gap:2px;justify-self:start}
nav.primary > ul{display:flex;align-items:center;gap:2px}
.nav-link{display:inline-flex;align-items:center;gap:6px;padding:10px 13px;border-radius:8px;font-weight:600;font-size:15px;color:var(--ink-soft)}
.nav-link:hover,.nav-link[aria-expanded="true"]{color:var(--primary);background:var(--primary-soft)}
.nav-link .chev{transition:transform .18s ease}
.nav-link[aria-expanded="true"] .chev{transform:rotate(180deg)}
.nav-cta{display:flex;align-items:center;justify-content:flex-end;gap:10px}
/* Tablet + mobile: tighten the header gutter so the CTA cluster sits flush
   to the right edge without the desktop-sized 4vw container padding leaving
   awkward whitespace. Brand also shifts left for visual balance. */
@media (max-width:1180px){header.site .nav-in{padding-inline:14px}}
@media (max-width:540px){header.site .nav-in{padding-inline:10px}}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--line-strong);color:var(--primary);background:var(--surface)}
.icon-btn:hover{border-color:var(--wa);color:#11713C;background:#EDFAF2}
.burger{display:none;width:46px;height:46px;border:1.5px solid var(--line-strong);border-radius:10px;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2px;background:var(--ink);position:relative;transition:background .15s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink);transition:transform .2s ease, top .2s ease}
.burger span::before{top:-6px}.burger span::after{top:6px}
.burger[aria-expanded="true"] span{background:transparent}
.burger[aria-expanded="true"] span::before{top:0;transform:rotate(45deg)}
.burger[aria-expanded="true"] span::after{top:0;transform:rotate(-45deg)}

/* ---------- mega menu ---------- */
.mega{position:absolute;left:0;right:0;top:100%;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:var(--shadow-2);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease, transform .18s ease, visibility .18s}
.mega.open{opacity:1;visibility:visible;transform:translateY(0)}
.mega-in{display:grid;grid-template-columns:280px 1fr;gap:0;padding-block:26px}
.mega-feature{border:1.5px solid var(--accent);background:var(--accent-soft);border-radius:var(--radius);padding:20px;margin-right:28px;display:flex;flex-direction:column;gap:9px;align-self:start}
.tag-new{display:inline-block;align-self:flex-start;background:var(--accent);color:#231603;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 9px;border-radius:999px}
.mega-feature h4{font-size:17px}
.mega-feature p{font-size:13.5px;color:var(--ink-soft)}
.mega-cols{display:grid;grid-template-columns:repeat(5,1fr);gap:8px 22px}
.mega-col h5{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid var(--line)}
.mega-col h5 em{color:var(--accent-ink);font-style:normal}
.mega-col a.pillar{display:block;font-weight:600;font-size:14.5px;color:var(--ink);padding:5px 0}
.mega-col a.pillar:hover{color:var(--primary)}
.mega-col a.sub{display:block;font-size:13px;color:var(--muted);padding:2.5px 0}
.mega-col a.sub:hover{color:var(--accent-ink)}
.mega-foot{display:flex;justify-content:space-between;align-items:center;gap:14px;border-top:1px solid var(--line);padding-block:12px;font-size:13.5px;color:var(--muted);flex-wrap:wrap}
.dropdown{position:absolute;top:100%;min-width:280px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-2);padding:10px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease, transform .18s ease, visibility .18s}
.dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:8px 10px;border-radius:7px;font-size:14px;font-weight:500;color:var(--ink-soft)}
.dropdown a:hover{background:var(--primary-soft);color:var(--primary)}
.has-menu{position:relative}
.nav-item-static{position:relative}

/* ---------- mobile drawer ---------- */
.drawer{position:fixed;inset:0;z-index:99;background:var(--surface);transform:translateX(100%);transition:transform .25s ease;overflow-y:auto;padding:90px var(--gutter) 40px}
.drawer.open{transform:translateX(0)}
.drawer .acc{border-bottom:1px solid var(--line)}
.drawer .acc > button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:15px 2px;font-family:var(--font-display);font-weight:700;font-size:19px}
.drawer .acc > button .chev{transition:transform .2s ease}
.drawer .acc > button[aria-expanded="true"] .chev{transform:rotate(180deg)}
.drawer .acc-panel{display:none;padding:0 2px 16px}
.drawer .acc-panel.open{display:block}
.drawer .acc-panel h6{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:12px 0 4px}
.drawer .acc-panel a{display:block;padding:6px 0;font-size:15px;color:var(--ink-soft);font-weight:500}
.drawer .plain-link{display:block;padding:15px 2px;border-bottom:1px solid var(--line);font-family:var(--font-display);font-weight:700;font-size:19px;color:var(--ink)}
.drawer-cta{display:grid;gap:10px;margin-top:22px}
.drawer-meta{margin-top:22px;font-size:13.5px;color:var(--muted);line-height:1.9}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding-block:clamp(38px,6vw,80px) clamp(34px,5vw,64px);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-60px;top:-60px;width:420px;height:420px;background-image:radial-gradient(var(--line) 1.5px, transparent 1.5px);background-size:18px 18px;opacity:.55;pointer-events:none}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:clamp(26px,4vw,60px);align-items:center;position:relative;z-index:1}
.hero h1{margin:14px 0 16px}
.hero .lead{margin-bottom:24px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.trustline{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--muted);flex-wrap:wrap}
.trustline svg{color:var(--success)}
.hero-stats{display:flex;gap:0;margin-top:30px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-stat{padding:16px 26px 2px 0;margin-right:26px;border-right:1px solid var(--line)}
.hero-stat:last-child{border-right:0;margin-right:0}
.hero-stat b{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(22px,2.4vw,30px);font-variant-numeric:tabular-nums;color:var(--primary)}
.hero-stat span{font-size:12.5px;color:var(--muted);letter-spacing:.04em}

/* generic page hero */
.page-hero{padding-block:clamp(36px,5vw,72px) clamp(28px,4vw,56px)}
.page-hero h1{margin:14px 0 16px}
.breadcrumbs{display:flex;gap:6px;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:12px}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--primary)}
.breadcrumbs span[aria-current]{color:var(--ink-soft);font-weight:500}
.breadcrumbs .sep{color:var(--line-strong)}

/* report card */
.report{position:relative}
.report-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-2);padding:22px;max-width:480px;margin-left:auto}
.report-card .rc-head{display:flex;justify-content:space-between;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding-bottom:13px;margin-bottom:6px}
.rc-title{font-weight:700;font-family:var(--font-display);font-size:16px}
.rc-title small{display:block;font-family:var(--font-body);font-weight:500;font-size:12px;color:var(--muted)}
.rc-badge{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border:1px solid var(--accent);padding:4px 10px;border-radius:999px;white-space:nowrap}
.rc-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 0;border-bottom:1px dashed var(--line)}
.rc-row:last-of-type{border-bottom:0}
.rc-engine{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14.5px}
.rc-engine i{width:8px;height:8px;border-radius:50%;background:var(--primary);flex:none}
.rc-cited{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--success)}
.rc-pending{color:var(--muted);font-size:13px;font-weight:500}
.rc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:13px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.report-note{position:absolute;left:-8px;bottom:-18px;background:var(--ink);color:#fff;border-radius:10px;padding:11px 16px;font-size:13px;font-weight:500;box-shadow:var(--shadow-2);display:flex;align-items:center;gap:9px}
.report-note b{color:var(--accent)}

/* ============================================================
   PROMISE VERBS
   ============================================================ */
.verbs{padding-block:0}
.verbs-grid{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.verb{padding:22px 20px;border-right:1px solid var(--line);position:relative;display:block;color:var(--ink);transition:background .15s ease}
.verb:last-child{border-right:0}
.verb:hover{background:var(--surface-alt);color:var(--ink)}
.verb i{font-style:normal;font-family:var(--font-display);font-weight:800;font-size:12px;color:var(--accent-ink);letter-spacing:.12em}
.verb h3{font-size:clamp(17px,1.6vw,21px);margin:7px 0 5px}
.verb p{font-size:13px;color:var(--muted);line-height:1.5}
.verb::after{content:"\2192";position:absolute;right:16px;top:20px;color:var(--line-strong);transition:color .15s, transform .15s}
.verb:hover::after{color:var(--accent-ink);transform:translateX(2px)}

/* ============================================================
   WEDGE PANEL
   ============================================================ */
.wedge-card{border:1.5px solid var(--accent);border-radius:14px;background:var(--accent-soft);display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);gap:clamp(20px,3vw,46px);padding:clamp(24px,3.5vw,46px);align-items:center;position:relative;overflow:hidden}
.wedge-card::before{content:"AI";position:absolute;right:-20px;bottom:-66px;font-family:var(--font-display);font-weight:800;font-size:240px;line-height:1;color:rgba(232,155,28,.14);pointer-events:none}
.wedge-card h2{font-size:clamp(22px,2.6vw,34px);max-width:22ch;margin:10px 0 12px}
.wedge-points{display:grid;gap:9px;margin-bottom:20px}
.wedge-points li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:var(--ink-soft)}
.wedge-points svg{flex:none;margin-top:3px;color:var(--accent-ink)}
.wedge-side{position:relative;z-index:1;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:22px;box-shadow:var(--shadow-1)}
.wedge-side .price{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--primary)}
.wedge-side .price small{font-size:13px;color:var(--muted);font-weight:500;font-family:var(--font-body)}
.wedge-side ul{margin:13px 0 17px;display:grid;gap:7px}
.wedge-side li{font-size:13.5px;color:var(--ink-soft);display:flex;gap:8px}
.wedge-side li::before{content:"\2014";color:var(--accent-ink)}

/* ============================================================
   PILLARS
   ============================================================ */
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.pillar-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:22px;position:relative;display:flex;flex-direction:column;gap:9px;transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease}
.pillar-card:hover{border-color:var(--primary);box-shadow:var(--shadow-1);transform:translateY(-2px)}
.pillar-num{position:absolute;right:16px;top:8px;font-family:var(--font-display);font-weight:800;font-size:42px;color:var(--surface-alt);-webkit-text-stroke:1px var(--line-strong);pointer-events:none}
.pillar-card h3 a{color:var(--ink)}
.pillar-card h3 a:hover{color:var(--primary)}
.pillar-card > p{font-size:13.5px;color:var(--muted);min-height:2.6em}
.pillar-links{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:8px}
.chip{font-size:12px;font-weight:600;color:var(--ink-soft);background:var(--surface-alt);border:1px solid var(--line);border-radius:999px;padding:4px 11px}
a.chip:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}
.pillar-more{font-size:13px;font-weight:600;color:var(--primary);display:inline-flex;gap:6px;align-items:center;margin-top:4px}

/* ============================================================
   PROCESS / STEPS
   ============================================================ */
/* Process section: numbered cards with hover lift. Driven by CSS counter so
   it works on <ol class="process-grid"><li class="step">, <div>...</div> in
   block-renderer and the home page (no markup changes required there). */
.lp-section-head{margin:42px 0 18px}
.lp-section-head .kicker{display:block;margin-bottom:4px}
.lp-section-head h2.h-section{margin:0}
.lp-section-head__sub{color:var(--ink-soft);font-size:15px;line-height:1.55;margin:8px 0 0;max-width:62ch}

.process-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;counter-reset:step;list-style:none;padding:0;margin:0}
.step{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:60px 22px 22px;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.step:hover{transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(15,23,42,.14);border-color:var(--line-strong)}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:20px;left:20px;width:38px;height:38px;border-radius:10px;background:var(--accent-soft);color:var(--accent-ink);font-family:var(--font-display);font-weight:800;font-size:14px;letter-spacing:.02em;display:flex;align-items:center;justify-content:center}
.step h3{font-size:17px;line-height:1.3;margin:0 0 6px;color:var(--ink)}
.step p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0}

/* Responsive column counts for .process-grid live in the global RESPONSIVE
   block lower in this file (1024px -> 2 cols, 640px -> 1 col). Only the
   step card's internal padding shrinks on narrow screens. */
@media (max-width:540px){.step{padding:54px 20px 20px}.step::before{width:34px;height:34px;font-size:13px;top:18px;left:18px}}

/* Long-form reading area: typography rhythm for content_blocks rendered by
   x-block-renderer. Applies to .rich-text paragraphs/lists, the bare h2/h3
   emitted by the block-renderer's heading branch, and the in-flow blocks
   (final-card, stats_band, quote). The reading container is capped to a
   comfortable measure for body copy. */
.lp-content{margin-top:48px;font-size:16px;line-height:1.7;color:var(--ink)}
.lp-content > * + *{margin-top:22px}
.lp-content > h2{font-size:clamp(22px,2.4vw,30px);font-family:var(--font-display);font-weight:700;line-height:1.22;margin:48px 0 14px;color:var(--ink);letter-spacing:-.01em;max-width:30ch}
.lp-content > h2:first-child{margin-top:0}
.lp-content > h2::before{content:"";display:block;width:42px;height:3px;background:var(--accent-ink);border-radius:2px;margin-bottom:14px}
.lp-content > h3{font-size:clamp(18px,1.7vw,22px);font-family:var(--font-display);font-weight:700;line-height:1.3;margin:32px 0 10px;color:var(--ink)}
.lp-content > h4{font-size:17px;font-weight:700;margin:24px 0 8px;color:var(--ink)}
.lp-content .rich-text{font-size:16.5px;line-height:1.72;color:var(--ink-soft);max-width:68ch}
.lp-content .rich-text p{margin:0 0 16px}
.lp-content .rich-text p:last-child{margin-bottom:0}
.lp-content .rich-text p + p{margin-top:0}
.lp-content .rich-text strong{color:var(--ink);font-weight:700}
.lp-content .rich-text a{color:var(--accent-ink);font-weight:600;border-bottom:1px solid color-mix(in srgb,var(--accent-ink) 35%,transparent);transition:border-color .15s}
.lp-content .rich-text a:hover{border-bottom-color:var(--accent-ink)}
.lp-content .rich-text ul,.lp-content .rich-text ol{margin:14px 0 18px;padding-left:22px;max-width:64ch}
.lp-content .rich-text ul li,.lp-content .rich-text ol li{margin:6px 0;line-height:1.6}
.lp-content .rich-text ul li::marker{color:var(--accent-ink)}
.lp-content .rich-text blockquote{margin:22px 0;padding:14px 20px;border-left:3px solid var(--accent);background:var(--surface-alt);border-radius:0 8px 8px 0;font-style:italic;color:var(--ink)}
.lp-content .rich-text code{font-family:ui-monospace,monospace;font-size:.92em;background:var(--surface-alt);padding:1px 6px;border-radius:4px;border:1px solid var(--line)}
.lp-content .t-quote{font-size:19px;line-height:1.5;color:var(--ink);padding:18px 22px;background:var(--surface-alt);border-radius:0 12px 12px 0;margin:28px 0}
.lp-content .final-card{margin:32px 0}
.lp-content .hero-stats{margin:24px 0}
.lp-content .deliverable-list{margin-top:14px}
.lp-content .block-image{margin:24px 0}
.lp-content .block-image img{width:100%;height:auto;border-radius:12px;border:1px solid var(--line)}
.lp-content .block-image figcaption{font-size:13px;color:var(--muted);text-align:center;margin-top:8px}
.lp-content .cost-table{margin:24px 0}
/* Nested .process-grid inside content_blocks (steps block type) inherits the
   upgraded styles automatically via the rules above. */

/* ============================================================
   WORK
   ============================================================ */
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.case{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);display:flex;flex-direction:column;transition:border-color .15s, box-shadow .15s, transform .15s}
.case:hover{border-color:var(--primary);box-shadow:var(--shadow-1);transform:translateY(-2px)}
.case-visual{height:150px;position:relative;border-bottom:1px solid var(--line);background:var(--surface-alt);overflow:hidden}
.case-visual .pattern{position:absolute;inset:0;opacity:.6}
.case-visual .metric{position:absolute;left:14px;bottom:14px;background:var(--ink);color:#fff;border-radius:8px;padding:7px 12px;font-family:var(--font-display);font-weight:800;font-size:18px;line-height:1}
.case-visual .metric small{display:block;font-family:var(--font-body);font-weight:500;font-size:10.5px;color:#CBD5DD;margin-top:3px;letter-spacing:.05em}
.case-body{padding:17px 18px 19px;display:flex;flex-direction:column;gap:7px;flex:1}
.case-tags{display:flex;gap:6px;flex-wrap:wrap}
.case h3{font-size:16.5px;line-height:1.3}
.case h3 a{color:var(--ink)}
.case h3 a:hover{color:var(--primary)}
.case p{font-size:13.5px;color:var(--muted)}

/* ============================================================
   MARQUEE PROOF
   ============================================================ */
.proof{padding-block:26px;border-block:1px solid var(--line);overflow:hidden}
.proof .small{text-align:center;color:var(--muted);margin-bottom:14px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;font-size:11.5px}
.marquee{display:flex;gap:0;overflow:hidden;mask-image:linear-gradient(to right, transparent, #000 8%, #000 92%, transparent)}
.marquee-track{display:flex;align-items:center;gap:clamp(28px,5vw,64px);padding-right:clamp(28px,5vw,64px);animation:scroll 36s linear infinite;flex:none}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-100%)}}
.logo-mark{font-family:var(--font-display);font-weight:700;font-size:19px;color:var(--muted);white-space:nowrap;letter-spacing:.01em}
.logo-mark span{color:var(--line-strong);font-weight:600}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.t-rail{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.t-rail::-webkit-scrollbar{display:none}
.t-card{flex:0 0 min(480px, 88%);scroll-snap-align:start;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:24px;display:flex;flex-direction:column;gap:14px}
.t-quote{font-size:16px;line-height:1.65;color:var(--ink-soft)}
.t-quote::before{content:"\201C";font-family:var(--font-display);font-weight:800;font-size:42px;line-height:0;display:block;color:var(--accent);margin:18px 0 2px}
.t-person{display:flex;align-items:center;gap:12px;margin-top:auto}
.avatar{width:46px;height:46px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:16px;flex:none}
.avatar.alt{background:var(--accent);color:#231603}
.t-person b{display:block;font-size:14.5px}
.t-person span{font-size:12.5px;color:var(--muted)}
.t-controls{display:flex;gap:8px}
.t-btn{width:44px;height:44px;border:1.5px solid var(--line-strong);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--primary)}
.t-btn:hover{border-color:var(--primary);background:var(--primary-soft)}

/* ============================================================
   INDUSTRIES + PRICING SPLIT
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:14px}
.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:clamp(20px,2.6vw,32px)}
.panel h3{font-size:clamp(19px,2vw,24px);margin:8px 0 10px}
.panel > p{font-size:14.5px;color:var(--muted);margin-bottom:16px;max-width:52ch}
.ind-wrap{display:flex;flex-wrap:wrap;gap:8px}
.price-list{display:grid;gap:0;border-top:1px solid var(--line)}
.price-list a{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 2px;border-bottom:1px solid var(--line);font-weight:600;font-size:14.5px;color:var(--ink)}
.price-list a:hover{color:var(--primary)}
.price-list .rng{font-variant-numeric:tabular-nums;color:var(--accent-ink);font-size:13.5px;white-space:nowrap}

/* ============================================================
   INSIGHTS
   ============================================================ */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.post{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:20px;display:flex;flex-direction:column;gap:9px;transition:border-color .15s, box-shadow .15s}
.post:hover{border-color:var(--primary);box-shadow:var(--shadow-1)}
.post .meta{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--muted)}
.post .meta b{color:var(--accent-ink);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:11px}
.post h3{font-size:16.5px;line-height:1.35}
.post h3 a{color:var(--ink)}
.post h3 a:hover{color:var(--primary)}
.post p{font-size:13.5px;color:var(--muted)}
.post .read{margin-top:auto;font-size:13px;font-weight:600;color:var(--primary);display:inline-flex;gap:6px;align-items:center}

/* ============================================================
   ARTICLE
   ============================================================ */
.article-grid{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:48px;align-items:start}
.article-body{max-width:70ch}
.article-body p,.article-body ul,.article-body ol,.article-body blockquote{margin-bottom:18px;font-size:16.5px;line-height:1.75;color:var(--ink-soft)}
.article-body h2{font-size:clamp(22px,2.4vw,30px);margin:28px 0 14px;color:var(--ink)}
.article-body h3{font-size:20px;margin:22px 0 10px;color:var(--ink)}
.article-body ul,.article-body ol{padding-left:24px}
.article-body ul li{list-style:disc}
.article-body ol li{list-style:decimal}
.article-body blockquote{border-left:3px solid var(--accent);padding-left:20px;font-style:italic;color:var(--ink)}
.article-toc{position:sticky;top:96px;font-size:14px;border-left:2px solid var(--line);padding-left:18px}
.article-toc h6{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.article-toc a{display:block;padding:5px 0;color:var(--ink-soft);font-weight:500}
.article-toc a:hover{color:var(--primary)}
.article-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--muted);margin-bottom:24px}

/* ============================================================
   COST TABLE (pricing guides)
   ============================================================ */
.answer-box{border:1.5px solid var(--accent);background:var(--accent-soft);border-radius:14px;padding:20px 24px;margin:18px 0 24px;font-size:16.5px;line-height:1.65;color:var(--ink)}
.answer-box b{color:var(--accent-ink)}
.reviewed-badge{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:var(--success);background:#EDFAF2;border:1px solid #B8E2C9;border-radius:999px;padding:4px 12px;margin-bottom:8px}
.cost-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.cost-table caption{caption-side:bottom;text-align:left;font-size:12.5px;color:var(--muted);margin-top:8px}
.cost-table th,.cost-table td{padding:13px 16px;border-bottom:1px solid var(--line);text-align:left;font-size:14.5px;vertical-align:top}
.cost-table thead th{background:var(--surface-alt);font-weight:700;color:var(--ink);font-family:var(--font-display)}
.cost-table tbody tr:nth-child(even){background:#FBFAF6}
.cost-table .num{white-space:nowrap;color:var(--accent-ink);font-weight:600}
.factor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}
.factor{border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:var(--surface)}
.factor h4{font-size:16px;margin-bottom:6px}
.factor p{font-size:13.5px;color:var(--muted)}

/* ============================================================
   FORMS
   ============================================================ */
.lead-form{display:grid;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:clamp(20px,2.6vw,30px);box-shadow:var(--shadow-1)}
.lead-form.compact{padding:clamp(18px,2vw,22px)}
.lead-form h3{font-size:20px;margin-bottom:6px}
.lead-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.lead-form label{font-size:13px;font-weight:600;color:var(--ink);display:block;margin-bottom:4px}
.lead-form input,.lead-form textarea,.lead-form select{width:100%;font:inherit;color:var(--ink);background:var(--surface);border:1.5px solid var(--line-strong);border-radius:8px;padding:11px 14px;font-size:15px;transition:border-color .15s, box-shadow .15s}
.lead-form input:focus,.lead-form textarea:focus,.lead-form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.lead-form textarea{min-height:120px;resize:vertical}
.lead-form .field-error{color:var(--danger);font-size:12.5px;margin-top:4px}
.lead-form input[aria-invalid="true"],.lead-form textarea[aria-invalid="true"],.lead-form select[aria-invalid="true"]{border-color:var(--danger)}
.lead-form .submit-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.lead-form .helper{font-size:12.5px;color:var(--muted)}
.lead-form .honeypot{position:absolute;left:-9999px;height:0;width:0;overflow:hidden}
.lead-form.success{background:#EDFAF2;border-color:#B8E2C9;padding:30px}
.lead-form.success h3{color:var(--success)}
.lead-form.success p{color:var(--ink-soft);font-size:15px;line-height:1.55}

.alert{padding:12px 16px;border-radius:8px;font-size:14.5px;margin-bottom:14px}
.alert-error{background:#FDECEC;border:1px solid #F4BBBB;color:#7A1F1F}
.alert-success{background:#EDFAF2;border:1px solid #B8E2C9;color:#11713C}

/* ============================================================
   QUOTE FLOW
   ============================================================ */
.quote-card{max-width:760px;margin-inline:auto;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:clamp(24px,3vw,38px);box-shadow:var(--shadow-1)}
.steps{display:flex;justify-content:center;gap:10px;margin-bottom:22px;list-style:none}
.steps li{font-size:12px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:10px}
.steps li i{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line-strong);color:var(--muted);font-family:var(--font-display);font-weight:800;font-style:normal;font-size:13px}
.steps li.active{color:var(--ink)}
.steps li.active i{background:var(--accent);border-color:var(--accent);color:#231603}
.pillar-choice{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:14px}
.pillar-choice label{border:1.5px solid var(--line);border-radius:10px;padding:14px;cursor:pointer;display:flex;flex-direction:column;gap:4px;font-weight:600;background:var(--surface);transition:border-color .15s, background .15s}
.pillar-choice label small{font-weight:500;font-size:12.5px;color:var(--muted)}
.pillar-choice input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.pillar-choice input[type=radio]:checked + label{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{padding-block:clamp(44px,6vw,80px)}
.final-card{border:1px solid var(--line-strong);border-radius:16px;background:var(--surface-alt);padding:clamp(28px,4.5vw,60px);text-align:center;position:relative;overflow:hidden}
.final-card::before,.final-card::after{content:"";position:absolute;width:300px;height:300px;border:1px solid var(--line);border-radius:50%;pointer-events:none}
.final-card::before{left:-130px;top:-130px}
.final-card::after{right:-110px;bottom:-150px;border-color:var(--accent);opacity:.5}
.final-card h2{font-size:clamp(24px,3.4vw,42px);max-width:22ch;margin:0 auto 12px}
.final-card p{color:var(--ink-soft);max-width:52ch;margin:0 auto 24px}
.final-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.final-meta{margin-top:18px;font-size:13px;color:var(--muted)}

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq-list{display:grid;gap:0;border-top:1px solid var(--line)}
.faq-list details{border-bottom:1px solid var(--line);padding:18px 4px}
.faq-list summary{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--accent-ink);transition:transform .2s}
.faq-list details[open] summary::after{content:"\2013"}
.faq-list details > p,.faq-list details > div{padding:12px 0 4px;color:var(--ink-soft);font-size:15.5px;line-height:1.7}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--surface-alt);border-top:1px solid var(--line)}
.foot-top{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(20px,4vw,60px);padding-block:clamp(30px,4vw,48px);border-bottom:1px solid var(--line);align-items:center}
.foot-top h2{font-size:clamp(20px,2.4vw,30px);max-width:24ch}
.news{display:flex;gap:8px;max-width:520px;margin-left:auto;width:100%}
.news input{flex:1;min-width:0;height:50px;border:1.5px solid var(--line-strong);border-radius:999px;background:var(--surface);padding:0 20px;font:inherit;font-size:14.5px;color:var(--ink)}
.news input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.news p.success{display:block;font-weight:600;color:var(--success);margin:0}
.foot-grid{display:grid;grid-template-columns:1.35fr 1fr 1fr 1fr 1.15fr;gap:clamp(18px,2.6vw,36px);padding-block:clamp(30px,4vw,52px)}
.foot-col h6{font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:13px}
.foot-col ul{display:grid;gap:8px}
.foot-col a{font-size:14px;color:var(--ink-soft);font-weight:500}
.foot-col a:hover{color:var(--primary)}
.foot-brand p{font-size:14px;color:var(--muted);margin:12px 0 16px;max-width:34ch}
.foot-contact li{display:flex;gap:10px;font-size:14px;color:var(--ink-soft);align-items:flex-start}
.foot-contact svg{flex:none;margin-top:3px;color:var(--accent-ink)}
.socials{display:flex;gap:8px;margin-top:16px}
.socials a{width:40px;height:40px;border:1.5px solid var(--line-strong);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--primary)}
.socials a:hover{border-color:var(--primary);background:var(--primary-soft)}
.foot-bottom{border-top:1px solid var(--line);padding-block:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.foot-bottom ul{display:flex;gap:18px;flex-wrap:wrap}
.foot-bottom a{color:var(--muted)}
.foot-bottom a:hover{color:var(--primary)}
.to-top{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--primary)}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;right:16px;bottom:16px;z-index:90;width:56px;height:56px;border-radius:50%;background:var(--wa);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-2);transition:transform .15s ease}
.wa-float:hover{transform:translateY(-2px);color:#fff}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease, transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   ANSWER BLOCK - AEO direct-answer card
   ============================================================ */
.answer-block{
  border:1.5px solid var(--accent);background:var(--accent-soft);border-radius:14px;
  padding:18px 22px;margin:18px 0 26px;display:grid;gap:6px;
}
.answer-block__label{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-ink)}
.answer-block__body{font-size:16.5px;line-height:1.6;color:var(--ink);margin:0;font-weight:500}

/* ============================================================
   STICKY CTA - mobile-bottom + desktop-bottom-right
   ============================================================ */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:80;background:rgba(22,34,44,.96);
  backdrop-filter:saturate(1.2) blur(8px);
  border-top:1px solid rgba(255,255,255,.08);
  transform:translateY(110%);transition:transform .3s ease;
  padding:10px var(--gutter) max(10px, env(safe-area-inset-bottom));
  color:#fff;
}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta__inner{max-width:var(--container);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.sticky-cta__context{font-size:13px;color:#CBD5DD;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sticky-cta__actions{display:flex;gap:8px;align-items:center}
.sticky-cta__btn{min-height:42px;padding:8px 18px;font-size:14px}
.sticky-cta__wa{min-height:42px;padding:8px 14px;font-size:13.5px;background:var(--wa);color:#fff;border-color:var(--wa)}
.sticky-cta__wa:hover{background:#198F4D;border-color:#198F4D;color:#fff}
@media (max-width:520px){.sticky-cta__context{display:none}}

/* ============================================================
   TOC - table of contents
   ============================================================ */
.toc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;position:sticky;top:96px;font-size:14px}
.toc__title{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.toc__list{counter-reset:toc;display:grid;gap:2px}
.toc__list li{counter-increment:toc;padding:5px 0;position:relative;padding-left:26px}
.toc__list li::before{content:counter(toc, decimal-leading-zero);position:absolute;left:0;top:5px;color:var(--accent-ink);font-family:var(--font-display);font-weight:700;font-size:12px}
.toc__list a{color:var(--ink-soft);font-weight:500}
.toc__list a:hover{color:var(--primary)}

/* ============================================================
   PACKAGE COMPARISON TABLE
   ============================================================ */
.pkg-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:14px;background:var(--surface)}
.pkg-table{width:100%;border-collapse:collapse;min-width:640px}
.pkg-table th,.pkg-table td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
.pkg-table tbody tr:last-child td,.pkg-table tbody tr:last-child th{border-bottom:0}
.pkg-table__feature{color:var(--ink-soft);font-weight:500;background:var(--surface-alt);font-size:13.5px}
.pkg-table thead th{vertical-align:bottom;background:var(--surface);position:relative;text-align:center}
.pkg-table__name{display:block;font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--ink);margin-bottom:4px}
.pkg-table__price{display:block;font-family:var(--font-display);font-weight:800;font-size:20px;color:var(--primary);font-variant-numeric:tabular-nums}
.pkg-table__billing{display:block;font-size:11.5px;color:var(--muted);font-weight:500;margin-top:2px}
.pkg-table__ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#231603;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:999px;white-space:nowrap}
.pkg-table tbody td{text-align:center;vertical-align:middle;color:var(--success)}
.pkg-table tbody td .pkg-table__no{color:var(--line-strong)}
.pkg-table__col--featured{background:var(--accent-soft) !important}
.pkg-table tbody tr:hover td:not(.pkg-table__feature){background:rgba(255,255,255,.5)}

/* ============================================================
   METHODOLOGY
   ============================================================ */
.methodology__list{display:grid;gap:18px;counter-reset:meth;list-style:none;padding:0;margin:0}
.methodology__item{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 26px 24px 78px;position:relative;
}
.methodology__item::before{
  counter-increment:meth;content:counter(meth, decimal-leading-zero);
  position:absolute;left:22px;top:22px;
  font-family:var(--font-display);font-weight:800;font-size:32px;color:var(--accent);line-height:1;
}
.methodology__item h3{font-size:18px;margin-bottom:6px}
.methodology__item p{font-size:14.5px;color:var(--ink-soft);line-height:1.65;max-width:60ch}
.methodology__detail{margin-top:8px;font-size:13.5px;color:var(--muted);font-style:italic}

/* ============================================================
   OUTCOMES BAND
   ============================================================ */
.outcomes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.outcome-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:left}
.outcome-card__metric{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(28px,3.2vw,40px);color:var(--primary);
  font-variant-numeric:tabular-nums;line-height:1.05;margin-bottom:6px;
}
.outcome-card h3{font-size:15px;margin-bottom:6px;color:var(--ink)}
.outcome-card p{font-size:13.5px;color:var(--muted);line-height:1.55}

/* ============================================================
   FIT / NOT-FIT GRID
   ============================================================ */
.fit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.fit-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;display:grid;grid-template-columns:36px 1fr;column-gap:12px;row-gap:6px;align-items:start}
.fit-card__marker{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid;grid-row:1 / span 2;grid-column:1}
.fit-card--fit .fit-card__marker{background:#EDFAF2;border-color:#B8E2C9;color:var(--success)}
.fit-card--not .fit-card__marker{background:#FDECEC;border-color:#F4BBBB;color:var(--danger)}
.fit-card h4{font-size:15.5px;margin-bottom:0;grid-column:2;grid-row:1}
.fit-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.55;grid-column:2;grid-row:2;margin:0}

/* ============================================================
   T2/T3/T4 SHARED - service / city / industry hero & body
   ============================================================ */
.lp-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:clamp(28px,4vw,60px);align-items:start}
@media (max-width:980px){.lp-grid{grid-template-columns:1fr}}
.lp-aside{position:sticky;top:96px}
.package-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.package{border:1px solid var(--line);border-radius:var(--radius);padding:22px;background:var(--surface);position:relative;display:flex;flex-direction:column;gap:10px}
.package.featured{border-color:var(--accent);box-shadow:var(--shadow-1)}
.package h4{font-size:18px}
.package .price{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--primary)}
.package .billing{font-size:12.5px;color:var(--muted)}
.package ul{display:grid;gap:6px;margin:6px 0 4px}
.package ul li{font-size:13.5px;color:var(--ink-soft);display:flex;gap:8px}
.package ul li::before{content:"\2713";color:var(--accent-ink);font-weight:700}
.package .ribbon{position:absolute;top:-12px;right:16px;background:var(--accent);color:#231603;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.deliverable-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin-top:8px}
.deliverable-list li{display:flex;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:14.5px;color:var(--ink-soft)}
.deliverable-list li::before{content:"\2713";color:var(--accent-ink);font-weight:700}
.pain-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.pain{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:20px}
.pain h4{font-size:17px;margin-bottom:6px;color:var(--ink)}
.pain p{font-size:14px;color:var(--muted);line-height:1.55}
.rec-mix-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.rec{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:18px;display:flex;flex-direction:column;gap:8px}
.rec h4{font-size:16px}
.rec p{font-size:13.5px;color:var(--muted)}
.rec a.pillar-more{margin-top:auto}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1180px){
  nav.primary{display:none}
  .burger{display:inline-flex}
  .mega,.dropdown{display:none}
}
@media (max-width:1024px){
  .pillars-grid,.work-grid,.posts-grid{grid-template-columns:repeat(2,1fr)}
  .verbs-grid{grid-template-columns:repeat(3,1fr)}
  .verb:nth-child(3n){border-right:0}
  .verb{border-bottom:1px solid var(--line)}
  .verb:nth-child(n+4){border-bottom:0}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:26px 14px}
  .split{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr 1fr}
  .foot-brand{grid-column:1/-1}
  .foot-top{grid-template-columns:1fr}
  .news{margin-left:0}
  .article-grid{grid-template-columns:1fr}
  .article-toc{position:static;border-left:0;border-top:2px solid var(--line);padding:18px 0 0}
}
@media (max-width:840px){
  .hero-grid{grid-template-columns:1fr}
  .report-card{margin:0 auto;max-width:520px}
  .report-note{left:6px;bottom:-14px}
  .wedge-card{grid-template-columns:1fr}
  .hero::after{display:none}
  .lead-form .form-row{grid-template-columns:1fr}
}
@media (max-width:640px){
  .pillars-grid,.work-grid,.posts-grid{grid-template-columns:1fr}
  .verbs-grid{grid-template-columns:1fr 1fr}
  .verb{border-bottom:1px solid var(--line) !important;border-right:1px solid var(--line)}
  .verb:nth-child(2n){border-right:0}
  .verb:nth-child(n+5){border-bottom:0 !important}
  .process-grid{grid-template-columns:1fr;gap:26px}
  .utility ul li:nth-child(2){display:none}
  .hero-stat{padding-right:16px;margin-right:16px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:430px){
  .verbs-grid{grid-template-columns:1fr}
  .verb{border-right:0 !important}
  .verb:nth-child(n+5){border-bottom:1px solid var(--line) !important}
  .verb:last-child{border-bottom:0 !important}
  .hero-ctas .btn{width:100%}
  .final-ctas .btn{width:100%}
  .news{flex-direction:column}
  .news .btn{width:100%}
  .foot-grid{grid-template-columns:1fr}
  .utility-in ul{gap:10px}
  .hero-stats{flex-direction:column;gap:0}
  .hero-stat{border-right:0;border-bottom:1px solid var(--line);padding:12px 0;margin:0;width:100%}
  .hero-stat:last-child{border-bottom:0}
  .t-card{flex-basis:94%}
}
@media (max-width:330px){
  .brand{font-size:19px}
  .utility ul li:nth-child(3){display:none}
  .rc-row{flex-wrap:wrap}
}

/* ============================================================
   SITE SEARCH
   ============================================================ */
.search-form{display:flex;gap:10px;margin:18px 0 8px;max-width:640px}
.search-form input[type=search]{flex:1;min-width:0;height:52px;padding:0 18px;font:inherit;font-size:16px;border:1.5px solid var(--line-strong);border-radius:999px;background:var(--surface);color:var(--ink)}
.search-form input[type=search]:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.search-meta{color:var(--muted);font-size:13.5px;margin-top:6px}
.search-list{display:grid;gap:18px;list-style:none;max-width:760px;padding:0;margin:0}
.search-result{padding-bottom:18px;border-bottom:1px solid var(--line)}
.search-result:last-child{border-bottom:0}
.search-result__title{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--ink);display:block;margin-bottom:6px}
.search-result__title:hover{color:var(--primary)}
.search-result__meta{display:flex;gap:10px;align-items:center;font-size:12.5px;color:var(--muted);margin-bottom:8px;flex-wrap:wrap}
.search-result__meta code{font-family:Consolas,Monaco,monospace;font-size:12px;color:var(--muted)}
.search-result__meta .badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border:1px solid var(--accent);border-radius:999px;padding:2px 9px}
.search-result__snippet{font-size:15px;color:var(--ink-soft);line-height:1.55;max-width:70ch}
.search-result__snippet mark{background:linear-gradient(transparent 62%, var(--accent-soft) 62%);color:var(--ink);padding:0 2px;font-weight:600}
.search-empty,.search-popular{padding:20px 0}
.search-suggestions{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}

/* Header search button + dropdown */
.header-search-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;border:1.5px solid var(--line-strong);color:var(--ink-soft);background:var(--surface)}
.header-search-btn:hover{border-color:var(--primary);color:var(--primary)}
.header-search-dropdown{position:absolute;top:100%;right:var(--gutter);width:min(540px, calc(100vw - 32px));background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-2);padding:16px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease, transform .18s ease, visibility .18s;z-index:101}
.header-search-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}
.header-search-dropdown form{display:flex;gap:8px}
.header-search-dropdown input{flex:1;min-width:0;height:44px;padding:0 14px;font:inherit;font-size:15px;border:1.5px solid var(--line-strong);border-radius:8px;background:var(--surface);color:var(--ink)}
.header-search-dropdown input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.header-search-results{margin-top:10px;max-height:480px;overflow-y:auto}
.header-search-results .hs-list{list-style:none;margin:0;padding:0;display:grid;gap:4px}
.header-search-results .hs-list a{display:block;padding:10px 12px;border-radius:6px;background:var(--surface);transition:background .12s;text-decoration:none}
.header-search-results .hs-list a:hover{background:var(--primary-soft)}
.header-search-results .hs-badge{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);background:var(--accent-soft);border:1px solid var(--accent);border-radius:999px;padding:1px 7px;white-space:nowrap;margin-bottom:4px}
.header-search-results .hs-title{display:block;font-weight:600;font-size:14.5px;color:var(--ink);line-height:1.3}
.header-search-results .hs-snippet{display:block;font-size:13px;color:var(--muted);margin-top:3px;line-height:1.4}
.header-search-results .hs-snippet mark{background:var(--accent-soft);color:var(--ink);padding:0 2px;font-weight:600}
.header-search-results .hs-empty{padding:14px;color:var(--muted);font-size:13.5px;text-align:center}
.header-search-results .hs-loading{padding:18px;color:var(--muted);font-size:13.5px;text-align:center}
.header-search-results .hs-all{display:block;text-align:center;padding:10px;margin-top:8px;font-size:13.5px;font-weight:600;color:var(--primary);border-top:1px solid var(--line);text-decoration:none}
.header-search-results .hs-all:hover{color:var(--primary-deep)}

/* ============================================================
   PRINT STYLESHEET - for pricing guides that clients print
   ============================================================ */
@media print {
  body{font-size:11pt;line-height:1.45;color:#000;background:#fff}
  .utility,header.site,.drawer,.wa-float,.sticky-cta,.lp-aside,.lead-form,.btn,.hero-ctas,.section-num,.t-controls,.marquee,.report-note,footer.site,.final-ctas,.btn-ghost,.toc,.pillar-card .arrow,.pkg-compare-toggle,.pillar-more,.read,.section-head .btn{display:none !important}
  main,section,.container,.container-narrow{max-width:none;margin:0;padding:8mm 0;border:0;background:#fff !important;box-shadow:none !important}
  .page-hero{padding:0 0 6mm}
  h1,h2,h3,h4{break-after:avoid;color:#000}
  h1.h-display{font-size:22pt;margin:0 0 4mm}
  h2.h-section{font-size:15pt;margin:6mm 0 3mm;border-top:.5pt solid #999;padding-top:3mm}
  .answer-block{border:.5pt solid #000;background:#fff;padding:4mm 6mm;margin:0 0 6mm;break-inside:avoid}
  .answer-block__label{color:#000;font-size:8pt}
  .answer-block__body{font-size:11pt}
  .reviewed-badge{border:.5pt solid #000;background:#fff;color:#000;padding:1mm 3mm}
  .cost-table{width:100%;border:.5pt solid #000;margin:4mm 0;break-inside:avoid}
  .cost-table th,.cost-table td{padding:2mm 3mm;border-bottom:.5pt solid #000;font-size:9pt}
  .cost-table thead th{background:#eee !important;color:#000;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .cost-table tbody tr:nth-child(even){background:#f7f7f7 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .factor-grid,.process-grid,.pillars-grid,.work-grid,.pain-grid,.rec-mix-grid,.fit-grid,.outcomes-grid{display:block !important}
  .factor-grid > *,.process-grid > *,.pillars-grid > *,.work-grid > *,.pain-grid > *,.rec-mix-grid > *,.fit-grid > *,.outcomes-grid > *{margin:0 0 4mm;break-inside:avoid;border:.5pt solid #999;padding:3mm 4mm;background:#fff !important}
  .step::before{position:static;color:#000;padding:0}
  a{color:#000;text-decoration:none}
  a[href^="http"]:not([href*="clickate.test"]):not([href*="clickate.com"])::after{content:" (" attr(href) ")";font-size:8pt;color:#555}
  .breadcrumbs{font-size:8pt;color:#555;margin:0 0 3mm}
  .breadcrumbs .sep{color:#555}
  .faq-list{max-width:none}
  .faq-list summary{font-size:11pt}
  .faq-list details > p,.faq-list details > div{font-size:10pt}
  .final-card,.final{border:.5pt solid #999;background:#fff !important;padding:4mm}
  .kicker{color:#000;font-size:8pt}
  .kicker::before{display:none}
  .answer-block,.cost-table,.faq-list details,.factor,.outcome-card,.fit-card,.pillar-card,.step,.pain,.rec,.case,.t-card,.post,.package{page-break-inside:avoid;break-inside:avoid}
}

/* ============================================================
   ACCESSIBILITY - focus rings on every interactive element
   ============================================================ */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--accent) !important;
  outline-offset:2px !important;
  border-radius:3px;
}
@media (prefers-reduced-motion:reduce){
  .marquee-track,.reveal{animation:none !important;opacity:1 !important;transform:none !important}
  .sticky-cta{transition:none}
}

/* ============================================================
   LEAD FORM V2 - enterprise-grade form styling
   ============================================================ */
.lead-form--v2{display:grid;gap:18px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:clamp(20px,2.8vw,30px);box-shadow:0 1px 0 rgba(0,0,0,0.02), 0 6px 30px -10px rgba(11,18,32,0.12);position:relative}
.lead-form--v2.is-compact{padding:clamp(16px,2vw,22px);gap:14px}
.lead-form--v2.is-compact .lead-form__head{margin-bottom:0}
.lead-form--v2 .lead-form__head{display:grid;gap:6px;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:2px}
.lead-form--v2 .lead-form__title{font-family:var(--font-display);font-weight:800;font-size:clamp(20px,2.2vw,24px);color:var(--ink);margin:0;line-height:1.2}
.lead-form--v2 .lead-form__sub{color:var(--muted);font-size:13.5px;margin:0;line-height:1.55}
.lead-form--v2 .lead-form__context{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.lead-form--v2 .lf-tag{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:99px;background:var(--accent-soft);color:var(--accent-ink);border:1px solid var(--accent)}
.lead-form--v2 .lf-tag--city{background:#F0F7FF;color:#1450A1;border-color:#A9C6EE}
.lead-form--v2 .lf-tag--industry{background:#F0F0FF;color:#3A2A8C;border-color:#C8C0F0}

.lead-form--v2 .lead-form__group{display:grid;gap:10px;padding:0;border:0}
.lead-form--v2 .lead-form__legend{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);padding:0;margin-bottom:4px}
.lead-form--v2 .lead-form__legend .optional{font-weight:500;text-transform:none;letter-spacing:normal;color:var(--muted);margin-left:6px}
.lead-form--v2 .lead-form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
.lead-form--v2 .lead-form__field{display:grid;gap:5px;align-content:start}
.lead-form--v2 .lead-form__field label{font-size:12.5px;font-weight:600;color:var(--ink);margin:0;display:flex;align-items:center;gap:4px}
.lead-form--v2 .lead-form__field label .req{color:var(--danger);font-weight:700}
.lead-form--v2 .lead-form__field label .optional{font-weight:500;color:var(--muted);font-size:11.5px;margin-left:2px}

/* Phone group: country code select + digits-only input as one visual field */
.lead-form--v2 .phone-group{display:grid;grid-template-columns:92px minmax(0,1fr);gap:8px;align-items:stretch}
.lead-form--v2 .phone-group select{padding:11px 20px 11px 8px;width:100%;font-size:14px;font-variant-numeric:tabular-nums;text-overflow:ellipsis;background-image:linear-gradient(45deg,transparent 50%,var(--ink-soft) 50%),linear-gradient(135deg,var(--ink-soft) 50%,transparent 50%);background-position:calc(100% - 10px) 50%,calc(100% - 6px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat;appearance:none;-webkit-appearance:none}
.lead-form--v2 .phone-group input{min-width:0}
@media (max-width:540px){.lead-form--v2 .phone-group{grid-template-columns:84px minmax(0,1fr);gap:6px}}
.lead-form--v2 input[type=text],.lead-form--v2 input[type=tel],.lead-form--v2 input[type=email],.lead-form--v2 textarea,.lead-form--v2 select{width:100%;font:inherit;color:var(--ink);background:var(--surface);border:1.5px solid var(--line-strong);border-radius:10px;padding:11px 14px;font-size:15px;transition:border-color .15s, box-shadow .15s, background .15s}
.lead-form--v2 input:focus,.lead-form--v2 textarea:focus,.lead-form--v2 select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}
.lead-form--v2 textarea{min-height:110px;resize:vertical;line-height:1.5}
.lead-form--v2 input[aria-invalid="true"],.lead-form--v2 textarea[aria-invalid="true"]{border-color:var(--danger);background:#FFF6F6}
.lead-form--v2 .field-error{color:var(--danger);font-size:12.5px;font-weight:500;margin:4px 0 0;display:flex;align-items:flex-start;gap:6px}
.lead-form--v2 .field-error::before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--danger);color:#fff;font-size:10px;font-weight:700;flex-shrink:0;margin-top:1px}
/* Make the inline error span full row when it's a direct child of a grid */
.pillar-choice .field-error,.quote-field-block .field-error,.quote-tile-grid + .field-error{grid-column:1 / -1;margin-top:6px}
.lead-form--v2 .hint{font-size:11.5px;color:var(--muted);line-height:1.4}
.lead-form--v2 .hint--counter{text-align:right;display:block;font-variant-numeric:tabular-nums;transition:color .15s}
.lead-form--v2 .hint--counter.is-short{color:var(--danger);font-weight:600}
.lead-form--v2 .hint--counter.is-short::after{content:" · " attr(data-counter-msg);font-weight:500}
.lead-form--v2 .hint--counter.is-near{color:#8A6500}
.lead-form--v2 .hint--counter.is-ok{color:var(--success)}
.lead-form--v2 .honeypot{position:absolute;left:-9999px;height:0;width:0;overflow:hidden}

/* Chip selectors for budget / timeline */
.lead-form--v2 .lead-form__chips{display:flex;flex-wrap:wrap;gap:7px}
.lead-form--v2 .lf-chip-input{position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.lead-form--v2 .lf-chip{display:inline-flex;align-items:center;font-size:13px;font-weight:600;padding:8px 14px;border-radius:99px;background:var(--surface);border:1.5px solid var(--line-strong);color:var(--ink);cursor:pointer;transition:border-color .15s, background .15s, color .15s;user-select:none}
.lead-form--v2 .lf-chip:hover{border-color:var(--accent)}
.lead-form--v2 .lf-chip-input:checked + .lf-chip{background:var(--accent);border-color:var(--accent);color:#231603}
.lead-form--v2 .lf-chip-input:focus-visible + .lf-chip{box-shadow:0 0 0 3px var(--accent-soft)}
.lead-form--v2 .lf-chip--alt{background:#F4F1FF;border-color:#D4CBF5;color:#3A2A8C}
.lead-form--v2 .lf-chip-input:checked + .lf-chip--alt{background:#3A2A8C;border-color:#3A2A8C;color:#fff}

.lead-form--v2 .lead-form__trust{list-style:none;padding:0;margin:0;display:grid;gap:6px;background:var(--surface-alt);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.lead-form--v2 .lead-form__trust li{font-size:12.5px;color:var(--ink-soft);display:flex;align-items:center;gap:8px;line-height:1.45}
.lead-form--v2 .lead-form__trust li span[aria-hidden]{font-size:14px;flex-shrink:0}
.lead-form--v2 .lead-form__trust a{color:var(--accent-ink);font-weight:600}

.lead-form--v2 .lead-form__submit{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding-top:4px}
.lead-form--v2 .lead-form__submit .btn{flex:1 1 auto;justify-content:center;min-width:160px}
.lead-form--v2 .lead-form__submit .btn-lg{padding:14px 28px;font-size:15.5px}
.lead-form--v2 .lf-meta{font-size:11.5px;color:var(--muted);flex:1 1 220px;text-align:right}

/* Success state for v2 */
.lead-form--v2.success{background:linear-gradient(180deg,#EDFAF2,#F7FDF9);border-color:#B8E2C9;text-align:center;padding:34px 26px}
.lead-form--v2.success .lf-success-icon{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:#B8E2C9;color:#11713C;font-size:28px;margin-bottom:12px}
.lead-form--v2.success h3{color:#11713C;font-size:22px;margin:0 0 8px}
.lead-form--v2.success p{color:#1a3a26;font-size:14.5px;line-height:1.55;margin:0 auto;max-width:46ch}
.lead-form--v2.success a{color:#0f5a30;font-weight:600;text-decoration:underline}
.lead-form--v2.success .lf-success-cta{margin-top:16px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

@media (max-width:640px){
  .lead-form--v2 .lead-form__row{grid-template-columns:1fr}
  .lead-form--v2 .lf-meta{text-align:left;flex-basis:100%}
}

/* ============================================================
   QUOTE V2 - multi-step with summary side-panel
   ============================================================ */
.quote-hero{padding-block:clamp(28px,3.4vw,48px) clamp(18px,2.4vw,32px)}
.quote-hero h1.h-display{font-size:clamp(24px,2.8vw,38px);max-width:none}
.quote-hero .lead{font-size:clamp(15px,1.4vw,17px);margin-top:8px}
.quote-hero__stats{list-style:none;padding:0;margin:20px 0 0;display:flex;gap:18px;flex-wrap:wrap}
.quote-hero__stats li{display:flex;flex-direction:column;gap:2px;padding:8px 14px;border-left:3px solid var(--accent);min-width:130px}
.quote-hero__stats li b{font-family:var(--font-display);font-weight:800;font-size:20px;color:var(--ink);line-height:1}
.quote-hero__stats li span{font-size:12.5px;color:var(--muted);line-height:1.4}

.quote-section{padding-block:clamp(28px,4vw,56px)}
.quote-shell{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:32px;align-items:flex-start}
@media (max-width:980px){.quote-shell{grid-template-columns:1fr}}
.quote-aside{position:sticky;top:90px;display:grid;gap:14px;min-width:0}
@media (max-width:980px){.quote-aside{position:static;order:2}}

.quote-summary{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px;box-shadow:var(--shadow-1)}
.quote-summary h3{font-family:var(--font-display);font-weight:800;font-size:18px;margin:6px 0 12px;line-height:1.25}
.quote-summary .kicker{margin-bottom:6px}
.quote-summary__list{margin:0 0 16px;padding:0;display:grid;gap:8px}
.quote-summary__list > div{display:grid;grid-template-columns:90px 1fr;gap:10px;font-size:12.5px;line-height:1.4}
.quote-summary__list dt{color:var(--muted);font-weight:600;margin:0}
.quote-summary__list dd{margin:0;color:var(--ink);font-weight:600;word-break:break-word}
.quote-summary__progress{border-top:1px solid var(--line);padding-top:12px}
.quote-summary__bar{height:6px;background:var(--surface-alt);border-radius:99px;overflow:hidden;margin-bottom:6px}
.quote-summary__bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-ink));border-radius:99px;transition:width .35s ease}
.quote-summary__progress small{font-size:11.5px;color:var(--muted);font-weight:600}

.quote-trust{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.quote-trust h4{font-size:13px;font-weight:700;margin:0 0 10px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}
.quote-trust ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.quote-trust li{font-size:12.5px;line-height:1.5;color:var(--ink-soft);padding-left:24px;position:relative}
.quote-trust li b{position:absolute;left:0;top:0;font-family:var(--font-display);font-weight:800;color:var(--accent-ink)}

.quote-fallback{background:var(--surface-alt);border:1px solid var(--line);border-radius:14px;padding:16px 20px;display:grid;gap:8px}
.quote-fallback p{margin:0 0 4px;font-size:13px}
.quote-fallback .btn{justify-content:center}

.quote-main{min-width:0}
.quote-stepper{list-style:none;padding:0;margin:0 0 18px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;counter-reset:step}
.quote-stepper li{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;border:1.5px solid var(--line);background:var(--surface);transition:border-color .2s, background .2s, color .2s;position:relative}
.quote-stepper li i{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line-strong);background:var(--surface);font-family:var(--font-display);font-weight:800;font-style:normal;font-size:14px;color:var(--muted);flex-shrink:0}
.quote-stepper li span{display:flex;flex-direction:column;line-height:1.2;font-size:12px}
.quote-stepper li span b{font-size:13.5px;color:var(--ink);font-weight:700}
.quote-stepper li span small{color:var(--muted);font-size:11.5px}
.quote-stepper li.active{border-color:var(--accent);background:#FFFBEC}
.quote-stepper li.active i{background:var(--accent);border-color:var(--accent);color:#231603}
.quote-stepper li.done i{background:var(--success);border-color:var(--success);color:#fff}
.quote-stepper li.done i::before{content:"✓"}
.quote-stepper li.done i:not(:empty){text-indent:-9999px}
@media (max-width:640px){.quote-stepper{grid-template-columns:1fr;gap:6px}.quote-stepper li span small{display:none}}

.quote-card--v2{max-width:100%;margin:0;border-radius:16px;padding:clamp(22px,3vw,34px);box-shadow:0 1px 0 rgba(0,0,0,0.02), 0 8px 30px -10px rgba(11,18,32,0.12)}
.quote-step{border:0;padding:0;margin:0;display:grid;gap:18px}
.quote-step[hidden]{display:none}
.quote-step > .kicker{margin-bottom:0}
.quote-step h2{margin:0;line-height:1.2}
.quote-step__sub{color:var(--muted);font-size:14px;margin:0;line-height:1.55}
.quote-step__actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:6px;flex-wrap:wrap}
.quote-step__actions .btn{min-width:140px;justify-content:center}

.pillar-choice--v2{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.pillar-choice--v2 label{padding:16px;border-radius:14px;gap:6px;border-width:1.5px}
.pillar-choice--v2 label .pillar-choice__icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:var(--accent-soft);color:var(--accent-ink);font-size:18px;line-height:1;margin-bottom:6px}
.pillar-choice--v2 label .pillar-choice__icon svg{width:20px;height:20px;display:block}
.pillar-choice--v2 label strong{font-size:14.5px;line-height:1.25}
.pillar-choice--v2 label small{font-size:12px;color:var(--muted);line-height:1.45;font-weight:500}

.quote-multi{margin-top:6px;border-top:1px dashed var(--line);padding-top:14px}
.quote-multi summary{cursor:pointer;font-size:13.5px;font-weight:600;color:var(--accent-ink);user-select:none;display:inline-flex;align-items:center;gap:6px}
.quote-multi summary small{font-weight:500;color:var(--muted)}
.quote-service-search{position:relative;margin-top:10px}
.quote-service-search input{width:100%;font:inherit;border:1.5px solid var(--line-strong);border-radius:10px;padding:10px 14px;font-size:14.5px;background:var(--surface)}
.quote-service-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.quote-service-search ul{list-style:none;padding:0;margin:6px 0 0;max-height:240px;overflow:auto;background:var(--surface);border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px -12px rgba(11,18,32,.18);position:absolute;left:0;right:0;z-index:20;display:none}
.quote-service-search ul.is-open{display:block}
.quote-service-search ul li{padding:10px 14px;font-size:13.5px;cursor:pointer;border-bottom:1px solid var(--line);transition:background .12s}
.quote-service-search ul li:last-child{border-bottom:0}
.quote-service-search ul li:hover, .quote-service-search ul li[aria-selected="true"]{background:var(--accent-soft);color:var(--accent-ink)}
.quote-service-picked{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.quote-service-picked .lf-tag{background:var(--accent-soft);color:var(--accent-ink);border:1px solid var(--accent);padding:4px 10px 4px 12px;border-radius:99px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.quote-service-picked .lf-tag button{background:none;border:0;cursor:pointer;color:var(--accent-ink);font-size:14px;line-height:1;padding:0;margin-left:2px;opacity:.65}
.quote-service-picked .lf-tag button:hover{opacity:1}

.quote-field-block{display:grid;gap:8px}
.quote-field-block__label{font-size:13.5px;font-weight:700;color:var(--ink)}
.quote-tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.quote-tile-grid--three{grid-template-columns:repeat(3,1fr)}
@media (max-width:720px){.quote-tile-grid{grid-template-columns:repeat(2,1fr)}.quote-tile-grid--three{grid-template-columns:1fr}}
.quote-tile-grid input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.quote-tile{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 14px;border:1.5px solid var(--line-strong);border-radius:12px;background:var(--surface);cursor:pointer;transition:border-color .15s, background .15s, color .15s}
.quote-tile strong{font-size:14px;font-weight:700;color:var(--ink);line-height:1.2}
.quote-tile small{font-size:11.5px;color:var(--muted);line-height:1.4}
.quote-tile:hover{border-color:var(--accent)}
.quote-tile-grid input[type=radio]:checked + .quote-tile{border-color:var(--accent);background:var(--accent-soft)}
.quote-tile-grid input[type=radio]:focus-visible + .quote-tile{box-shadow:0 0 0 3px var(--accent-soft)}

@media (max-width:640px){
  .quote-hero__stats{gap:12px}
  .quote-hero__stats li{flex:1 1 140px}
}

/* ============================================================
   QUOTE THANKS PAGE
   ============================================================ */
.quote-thanks-hero{padding-block:clamp(36px,5vw,80px) clamp(36px,5vw,80px)}
.quote-thanks-shell{display:grid;gap:32px;max-width:none}
.quote-thanks-icon{width:84px;height:84px;border-radius:50%;background:#E8F4EA;color:var(--success);display:inline-flex;align-items:center;justify-content:center;border:2px solid #B8E2C9;box-shadow:0 8px 30px -10px rgba(17,113,60,.35)}
.quote-thanks-kicker{margin-top:14px;color:var(--success)}
.quote-thanks-title{margin:8px 0 6px}
.quote-thanks-lead{margin:0 0 8px;color:var(--ink-soft)}

.quote-thanks-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:8px}
@media (max-width:880px){.quote-thanks-grid{grid-template-columns:1fr}}
.quote-thanks-step{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 22px 20px;display:grid;gap:6px;position:relative;box-shadow:var(--shadow-1)}
.quote-thanks-step__num{font-family:var(--font-display);font-weight:800;font-size:34px;color:var(--accent);line-height:1;margin-bottom:2px}
.quote-thanks-step__when{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--accent-ink);background:var(--accent-soft);padding:4px 10px;border-radius:99px;justify-self:start}
.quote-thanks-step h3{font-size:17px;margin:8px 0 2px;line-height:1.25}
.quote-thanks-step p{font-size:13.5px;color:var(--ink-soft);line-height:1.55;margin:0}

.quote-thanks-aside{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:4px}
@media (max-width:880px){.quote-thanks-aside{grid-template-columns:1fr}}
.quote-thanks-card{background:var(--surface-alt);border:1px solid var(--line);border-radius:14px;padding:18px 20px;display:grid;gap:8px;align-content:start}
.quote-thanks-card h4{font-size:14px;margin:0;line-height:1.3}
.quote-thanks-card p{font-size:13px;color:var(--ink-soft);line-height:1.55;margin:0}
.quote-thanks-card .btn{justify-self:start}

.quote-thanks-foot{margin-top:16px;padding:20px 22px;border-radius:14px;background:#F0F7FF;border:1px solid #A9C6EE}
.quote-thanks-foot p{margin:0;font-size:13.5px;color:#16335a;line-height:1.6}
.quote-thanks-home{color:#1450A1;font-weight:600;text-decoration:none}
.quote-thanks-home:hover{text-decoration:underline}

/* ============================================================
   ERROR PAGES (404, 500, 503, 419, 403, 429)
   ============================================================ */
.err-page{padding:clamp(60px, 9vw, 110px) 0;text-align:center}
.err-page .container-narrow{max-width:720px}
.err-page__badge{display:inline-flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:var(--surface-alt);border:1px solid var(--line);color:var(--ink-soft);font-family:var(--font-display);font-weight:800;font-size:32px;letter-spacing:.02em;margin:0 auto 24px}
.err-page__badge--danger{background:#FDECEC;border-color:#F0C2C2;color:#A14848}
.err-page__badge--warn{background:#FFF5DC;border-color:#E8D08C;color:#8A6500}
.err-page__badge--soft{background:var(--accent-soft);border-color:transparent;color:var(--accent-ink)}
.err-page__kicker{display:inline-block;margin:0 0 12px}
.err-page__title{margin:0 0 14px;max-width:18ch;margin-left:auto;margin-right:auto;font-size:clamp(28px,4.4vw,52px);line-height:1.1}
.err-page__lead{color:var(--ink-soft);max-width:54ch;margin:0 auto 32px;font-size:clamp(15px,1.6vw,17.5px)}
.err-page__meta{margin-top:28px;font-size:12.5px;color:var(--muted)}
.err-page__meta code{font-family:ui-monospace,monospace;background:var(--surface-alt);padding:2px 8px;border-radius:5px;border:1px solid var(--line);color:var(--ink-soft)}
.err-page__meta .dot{margin:0 8px;color:var(--line-strong)}

.err-search{display:flex;gap:8px;max-width:520px;margin:0 auto 36px;align-items:stretch}
.err-search input[type=search]{flex:1;min-width:0;font:inherit;font-size:15px;color:var(--ink);background:var(--surface);border:1.5px solid var(--line-strong);border-radius:10px;padding:13px 16px;transition:border-color .15s, box-shadow .15s}
.err-search input[type=search]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.err-search .btn{display:inline-flex;gap:6px;align-items:center;flex-shrink:0}

.err-destinations{margin:0 0 36px;text-align:left}
.err-destinations .kicker{display:block;text-align:center;margin-bottom:14px}
.err-destinations__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.err-destination{display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px 12px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);border-radius:12px;color:var(--ink);text-decoration:none;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.err-destination:hover{transform:translateY(-2px);box-shadow:0 8px 20px -10px rgba(15,23,42,.12);border-color:var(--accent);color:var(--ink)}
.err-destination strong{font-size:14.5px;font-weight:700;color:var(--ink);grid-column:1}
.err-destination small{display:block;font-size:12.5px;color:var(--ink-soft);line-height:1.45;grid-column:1;grid-row:2}
.err-destination .arrow{grid-column:2;grid-row:1 / span 2;align-self:center;font-size:18px;color:var(--accent-ink);font-weight:700;transition:transform .2s}
.err-destination:hover .arrow{transform:translateX(3px)}

.err-ctas{display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:8px}

@media (max-width:640px){
  .err-destinations__grid{grid-template-columns:1fr}
  .err-page__badge{width:80px;height:80px;font-size:26px}
  .err-search{flex-direction:column}
  .err-search .btn{justify-content:center}
}
