/* ============================================================================
   Six Second Pitch — Design System v1.0
   One stylesheet for every page. Tokens + chrome (nav/footer) + components.
   Brand: deep teal ink + gold accent, premium-SaaS restraint, mobile-first.
   Pages keep ONLY page-specific styles inline; tokens and shared components
   live here. Legacy analyzer class names are preserved so the app JS never
   has to change.
   ============================================================================ */

/* ── Tokens ────────────────────────────────────────────────────────────── */
:root{
  /* ink + neutrals */
  --ink:#152220;            /* primary text — near-black with a teal cast */
  --soft:#4e5e5a;           /* secondary text */
  --faint:#8a9692;          /* tertiary / placeholders */
  --line:#e3e9e7;           /* hairlines */
  --line-strong:#cfd9d6;
  --bg:#f6f8f7;             /* page background */
  --card:#ffffff;

  /* brand teal scale */
  --brand:#2f6f6b;
  --brand-d:#245855;        /* hover / emphasis text */
  --brand-deep:#10312e;     /* dark panels */
  --brand-ink:#0b201e;      /* hero / footer background */
  --brand-tint:#e7f0ef;     /* light fills */
  --brand-tint-2:#f0f7f6;
  --brand-line:#cfe3e1;

  /* gold accent */
  --gold:#c9952d;
  --gold-d:#8a6a18;
  --gold-bright:#ffd98a;    /* gold on dark panels */
  --gold-tint:#fbf4e3;

  /* score bands (baked into reports + emails — do not change) */
  --red:#d2483f;   --red-bg:#fdecea;
  --amber:#d79a2b; --amber-bg:#fdf3e3;
  --green:#2f8f5b; --green-bg:#e8f5ed;

  /* geometry */
  --r-sm:10px; --r-md:14px; --r-lg:18px; --r-xl:24px;
  --shadow-1:0 1px 2px rgba(11,32,30,.05),0 4px 14px rgba(11,32,30,.06);
  --shadow-2:0 2px 6px rgba(11,32,30,.06),0 14px 40px rgba(11,32,30,.10);
  --shadow:var(--shadow-1); /* legacy alias used by older page styles */
  --shadow-gold:0 8px 24px rgba(201,149,45,.28);

  /* type */
  --font:'Inter',-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --fs-hero:clamp(2.35rem,5.6vw,3.6rem);
  --fs-h2:clamp(1.45rem,3vw,1.85rem);
  --fs-h3:1.2rem;
  --nav-h:64px;
}

/* ── Base ──────────────────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);color:var(--ink);background:var(--bg);
  line-height:1.6;font-size:16.5px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:var(--brand-d)}
::selection{background:var(--brand);color:#fff}
:focus-visible{outline:3px solid rgba(47,111,107,.45);outline-offset:2px;border-radius:4px}

h1,h2,h3,h4{line-height:1.15;letter-spacing:-.015em;text-wrap:balance}
h2{font-size:var(--fs-h2);font-weight:800;margin-bottom:8px}
h3{font-size:var(--fs-h3);font-weight:700}

.wrap{max-width:880px;margin:0 auto;padding:32px 24px 96px}
.wrap-wide{max-width:1120px;margin:0 auto;padding:0 24px}
@media(max-width:640px){.wrap{padding:20px 16px 72px}.wrap-wide{padding:0 16px}}

/* small uppercase section label */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand-d);
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--gold);border-radius:2px}
.eyebrow.on-dark{color:var(--gold-bright)}

.badge{
  display:inline-block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand-d);background:var(--brand-tint);border:1px solid var(--brand-line);
  padding:6px 14px;border-radius:999px;font-weight:700;
}
.beta-pill{
  display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:#3d2f05;background:var(--gold-bright);
  padding:4px 10px;border-radius:999px;vertical-align:middle;margin-left:8px;
}
.new-pill{
  display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;color:#fff;background:var(--gold);
  padding:3px 9px;border-radius:999px;vertical-align:middle;margin-left:8px;
}

/* ── Buttons ───────────────────────────────────────────────────────────── */
.btn{
  appearance:none;border:none;cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:16px;padding:14px 26px;border-radius:12px;
  text-decoration:none;line-height:1.2;
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--brand);color:#fff;box-shadow:0 6px 18px rgba(47,111,107,.30)}
.btn.primary:hover{background:var(--brand-d);box-shadow:0 8px 22px rgba(47,111,107,.36)}
.btn.primary:disabled{opacity:.55;cursor:default;box-shadow:none}
.btn.gold{background:var(--gold);color:#241a02;box-shadow:var(--shadow-gold)}
.btn.gold:hover{background:#daa838}
.btn.ghost{background:#fff;color:var(--brand-d);border:1.5px solid var(--line-strong)}
.btn.ghost:hover{border-color:var(--brand);background:var(--brand-tint-2)}
.btn.on-dark{background:rgba(255,255,255,.08);color:#eafaf6;border:1px solid rgba(255,255,255,.22)}
.btn.on-dark:hover{background:rgba(255,255,255,.14)}
.btn.sm{font-size:14px;padding:10px 18px;border-radius:10px}
.btn.lg{font-size:17.5px;padding:16px 32px;border-radius:14px}

/* ── Site nav (injected by site.js into [data-site-nav]) ──────────────── */
.sx-nav{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.sx-nav.on-dark-page{background:rgba(11,32,30,.82);border-bottom-color:rgba(255,255,255,.08)}
.sx-nav-inner{
  max-width:1120px;margin:0 auto;padding:0 24px;height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.sx-brand{
  display:flex;align-items:center;gap:10px;text-decoration:none;
  font-weight:800;font-size:16.5px;letter-spacing:-.02em;color:var(--ink);white-space:nowrap;
}
.sx-brand .mark{
  width:32px;height:32px;border-radius:9px;flex:none;
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);
  color:var(--gold-bright);font-weight:900;font-size:13.5px;letter-spacing:0;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 10px rgba(16,49,46,.35);
}
.sx-nav.on-dark-page .sx-brand{color:#fff}
.sx-links{display:flex;align-items:center;gap:4px}
.sx-links>a,.sx-drop>button{
  font-family:inherit;background:none;border:none;cursor:pointer;
  color:var(--soft);text-decoration:none;font-size:14.5px;font-weight:600;
  padding:9px 13px;border-radius:9px;display:flex;align-items:center;gap:5px;
  transition:background .12s,color .12s;white-space:nowrap;
}
.sx-links>a:hover,.sx-drop>button:hover{background:var(--brand-tint-2);color:var(--brand-d)}
.sx-links>a[data-here]{color:var(--brand-d);background:var(--brand-tint)}
.sx-nav.on-dark-page .sx-links>a,.sx-nav.on-dark-page .sx-drop>button{color:#bcd6d2}
.sx-nav.on-dark-page .sx-links>a:hover,.sx-nav.on-dark-page .sx-drop>button:hover{background:rgba(255,255,255,.08);color:#fff}
.sx-drop{position:relative}
.sx-drop .car{font-size:9px;transition:transform .15s;opacity:.7}
.sx-drop.open .car{transform:rotate(180deg)}
.sx-menu{
  position:absolute;top:calc(100% + 8px);left:0;min-width:264px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-2);padding:8px;display:none;
}
.sx-drop.open .sx-menu{display:block;animation:sx-pop .14s ease}
@keyframes sx-pop{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}
.sx-menu a,.sx-menu .menu-soon{
  display:flex;gap:11px;align-items:flex-start;padding:10px 12px;border-radius:10px;
  text-decoration:none;transition:background .12s;
}
.sx-menu a:hover{background:var(--brand-tint-2)}
.sx-menu .menu-soon{opacity:.55;cursor:default}
.soon-pill{
  display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;color:var(--gold-d);background:var(--gold-tint);
  border:1px solid #ecd9a8;padding:2px 7px;border-radius:999px;vertical-align:1px;
}
.mob-soon{opacity:.55}
.sx-menu .mi{
  width:34px;height:34px;border-radius:9px;flex:none;font-size:17px;
  background:var(--brand-tint);display:flex;align-items:center;justify-content:center;
}
.sx-menu .mt{display:block;font-size:14.5px;font-weight:700;color:var(--ink);line-height:1.25}
.sx-menu .md{display:block;font-size:12.5px;color:var(--soft);line-height:1.35;margin-top:1px}
.sx-cta{display:flex;align-items:center;gap:10px}
.sx-burger{
  display:none;background:none;border:none;cursor:pointer;padding:8px;border-radius:8px;
  flex-direction:column;gap:4.5px;
}
.sx-burger span{width:21px;height:2.2px;background:var(--ink);border-radius:2px;transition:.18s}
.sx-nav.on-dark-page .sx-burger span{background:#fff}
.sx-burger.open span:nth-child(1){transform:translateY(6.7px) rotate(45deg)}
.sx-burger.open span:nth-child(2){opacity:0}
.sx-burger.open span:nth-child(3){transform:translateY(-6.7px) rotate(-45deg)}
.sx-mobile{
  display:none;border-top:1px solid var(--line);background:#fff;padding:10px 16px 18px;
}
.sx-mobile a,.sx-mobile .mob-soon{
  display:flex;align-items:center;gap:10px;padding:13px 10px;border-radius:10px;
  text-decoration:none;color:var(--ink);font-weight:600;font-size:16px;
  border-bottom:1px solid var(--line);
}
.sx-mobile a:last-of-type{border-bottom:none}
.sx-mobile .grp{
  font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;
  color:var(--faint);padding:14px 10px 4px;
}
.sx-mobile .btn{width:100%;margin-top:12px}
@media(max-width:880px){
  .sx-links,.sx-cta .btn{display:none}
  .sx-burger{display:flex}
  .sx-nav.menu-open .sx-mobile{display:block;animation:sx-pop .15s ease}
}

/* ── Site footer (injected by site.js into [data-site-footer]) ────────── */
.sx-footer{background:var(--brand-ink);color:#9fc1bc;margin-top:72px}
.sx-footer-inner{
  max-width:1120px;margin:0 auto;padding:52px 24px 28px;
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px;
}
.sx-footer .fb{max-width:300px}
.sx-footer .fb .sx-brand{color:#fff;margin-bottom:12px}
.sx-footer .fb p{font-size:14px;line-height:1.6;color:#9fc1bc}
.sx-footer h5{
  color:#fff;font-size:12px;font-weight:800;text-transform:uppercase;
  letter-spacing:.12em;margin-bottom:14px;
}
.sx-footer ul{list-style:none}
.sx-footer ul a{
  display:inline-block;color:#9fc1bc;text-decoration:none;font-size:14.5px;padding:5px 0;
}
.sx-footer ul a:hover{color:var(--gold-bright)}
.sx-footer .legal{
  max-width:1120px;margin:0 auto;padding:20px 24px 30px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-size:12.5px;color:#6f928d;
}
.sx-footer .legal a{color:#9fc1bc;text-decoration:none}
@media(max-width:760px){
  .sx-footer-inner{grid-template-columns:1fr 1fr;gap:28px;padding:40px 18px 20px}
  .sx-footer .fb{grid-column:1/-1}
}

/* ── Cards / panels ────────────────────────────────────────────────────── */
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:34px;box-shadow:var(--shadow-1);
}
.panel-dark{
  background:linear-gradient(150deg,#11393599 0%,transparent 60%),var(--brand-ink);
  color:#eafaf6;border-radius:var(--r-xl);
}

/* ── Forms (shared) ────────────────────────────────────────────────────── */
label{display:block;font-weight:650;font-size:15.5px;margin:20px 0 7px}
.opt{font-weight:400;color:var(--soft);font-size:13.5px}
input[type=text],input[type=url],input[type=email],textarea,select{
  width:100%;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);
  padding:13px 15px;font-size:16px;font-family:inherit;color:var(--ink);background:#fff;
  transition:border-color .12s, box-shadow .12s;
}
textarea{min-height:88px;resize:vertical;line-height:1.5}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(47,111,107,.13);
}
.hint{font-size:13.5px;color:var(--soft);margin-top:6px}
.note-box{
  font-size:14.5px;color:var(--brand-d);background:var(--brand-tint-2);
  border:1px solid var(--brand-line);border-radius:var(--r-sm);padding:13px 16px;margin:14px 0;
}
.warn-box{
  font-size:14.5px;color:#7c5200;background:#fdf6e8;border:1px solid #efe0bd;
  border-radius:var(--r-sm);padding:13px 16px;margin:14px 0;
}

/* =========================================================================
   ANALYZER APP COMPONENTS (legacy class names — JS renders these)
   ========================================================================= */
.step-tag{
  font-size:12px;font-weight:800;color:var(--brand-d);text-transform:uppercase;
  letter-spacing:.1em;margin-bottom:10px;display:flex;align-items:center;gap:8px;
}
.step-tag::before{content:"";width:18px;height:2px;background:var(--gold);border-radius:2px}
.lead{color:var(--soft);font-size:16px;margin-bottom:18px}

/* progress bar */
.prog-wrap{margin:26px 0}
.prog-bar{height:5px;background:var(--line);border-radius:999px;overflow:hidden}
.prog-bar>i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand),var(--gold));transition:width .35s ease}
.prog-label{font-size:13px;color:var(--soft);margin-top:6px;text-align:right;font-weight:600}

/* path cards inside the app */
.path-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:22px 0}
.path-card{
  border:1.5px solid var(--line);border-radius:var(--r-md);padding:24px 18px;
  text-align:center;cursor:pointer;background:#fff;
  transition:border-color .15s, box-shadow .15s, transform .15s;
}
.path-card:hover{border-color:var(--brand);box-shadow:var(--shadow-1);transform:translateY(-2px)}
.path-card.sel{border-color:var(--brand);background:var(--brand-tint-2);box-shadow:inset 0 0 0 1px var(--brand)}
.path-icon{margin-bottom:10px;display:flex;justify-content:center;color:var(--brand-d)}
.path-icon .icn{width:28px;height:28px}
.path-title{font-weight:750;font-size:15.5px;color:var(--ink)}
.path-desc{font-size:14px;color:var(--soft);margin-top:7px;line-height:1.45}

.brand-block{border:1.5px solid var(--line);border-radius:var(--r-md);padding:18px;margin:12px 0;background:#fcfdfd}
.brand-block h4{font-size:15.5px;font-weight:750;margin-bottom:12px;color:var(--brand-d)}

/* draft helper */
.draft-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:4px 0 2px}
.draft-help{font-size:13.5px;color:var(--soft);line-height:1.45;flex:1;min-width:200px}
.is-draft{background:#fffaf0;border-color:#e6c25f}
.is-draft:focus{border-color:var(--brand)}

/* form nav row (the app's back/next row — class predates the site nav) */
.nav{display:flex;justify-content:space-between;margin-top:28px;gap:12px;align-items:center;flex-wrap:wrap}

/* result screen */
.section-head{
  font-size:12px;font-weight:800;color:var(--brand-d);text-transform:uppercase;
  letter-spacing:.1em;margin:28px 0 10px;display:flex;align-items:center;gap:8px;
}
.section-head::after{content:"";flex:1;height:1px;background:var(--line)}
.snapshot{
  background:linear-gradient(150deg,#15403c 0%,var(--brand-deep) 70%);
  color:#eafaf6;border-radius:var(--r-md);padding:24px;margin:6px 0 18px;
}
.snap-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#8fcfca;font-weight:800;margin-bottom:4px}
.snap-val{font-size:16.5px;line-height:1.45;margin-bottom:14px}
.snap-val:last-child{margin-bottom:0}
.snap-val b{color:var(--gold-bright)}
.total-wrap{text-align:center;margin:26px 0 8px}
.dial{font-size:74px;font-weight:900;line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.dial-sub{color:var(--soft);font-size:14px;margin-top:2px}
.band-tag{display:inline-block;margin-top:10px;padding:6px 18px;border-radius:999px;font-weight:800;font-size:14px;color:#fff}
.legend{text-align:center;font-size:12.5px;color:var(--soft);margin-top:12px}
.nextmove{
  background:var(--brand-tint-2);border:1px solid var(--brand-line);
  border-left:4px solid var(--gold);border-radius:var(--r-sm);padding:15px 18px;margin:18px 0 4px;
}
.nextmove .nm-lbl{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--brand-d);margin-bottom:4px}
.nextmove .nm-txt{font-size:15.5px;color:var(--ink);line-height:1.5}
.score-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.score-item{border:1px solid var(--line);border-radius:var(--r-sm);padding:14px 16px;background:#fff}
.si-lbl{font-size:13px;font-weight:650;color:var(--soft)}
.si-val{font-size:26px;font-weight:850;margin-top:3px;font-variant-numeric:tabular-nums}
.si-bar{height:5px;background:var(--line);border-radius:999px;margin-top:9px;overflow:hidden}
.si-bar>i{display:block;height:100%;border-radius:999px;transition:width .5s ease}
.pitch-box{
  background:linear-gradient(150deg,#15403c 0%,var(--brand-deep) 70%);
  color:#eafaf6;border-radius:var(--r-md);padding:24px;
  font-size:19px;line-height:1.5;margin:6px 0 4px;font-weight:550;
}
.pitch-box b{color:var(--gold-bright)}
.draft-note{font-size:13px;color:var(--soft);margin-top:7px;font-style:italic}
.lane{
  border-left:3px solid var(--brand);padding:13px 16px;margin:9px 0;
  background:var(--brand-tint-2);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:15px;
}
.lane-n{font-size:11px;font-weight:800;color:var(--soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.lane b{color:var(--brand-d)}
.fix-item{border:1px solid var(--line);border-radius:var(--r-sm);padding:14px 16px;margin:9px 0;font-size:15px;background:#fff}
.fix-n{font-size:11px;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.gap-prose{font-size:15px;color:var(--ink)}
.gap-prose p{margin:0 0 10px}
.cta-box{
  margin-top:24px;text-align:center;background:var(--gold-tint);
  border:1px solid #ecd9a8;border-radius:var(--r-md);padding:24px;
}
.cta-box h3{margin-bottom:6px;font-size:17px}
.result-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.save-note{
  font-size:13px;color:var(--soft);background:var(--brand-tint-2);
  border:1px solid var(--brand-line);border-radius:var(--r-sm);padding:11px 14px;
  margin-bottom:18px;line-height:1.5;
}
.spinner{
  width:36px;height:36px;border:3px solid var(--line);border-top-color:var(--brand);
  border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 14px;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* coming-soon / waitlist */
.soon-box{
  background:linear-gradient(180deg,var(--brand-tint-2),var(--brand-tint));
  border:1px solid var(--brand-line);border-radius:var(--r-md);padding:22px 22px 20px;margin:22px 0;
}
.soon-badge{
  display:inline-block;font-size:11px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:#fff;background:var(--brand);padding:4px 11px;
  border-radius:999px;margin-bottom:10px;
}
.soon-box h3{font-size:19px;margin:0 0 8px;color:var(--ink)}
.soon-box p{color:var(--soft);font-size:14.5px;margin:0 0 10px;line-height:1.55}
.soon-list{list-style:none;margin:0 0 6px;padding:0}
.soon-list li{color:var(--ink);font-size:14px;padding:3px 0}
.soon-note{font-size:13.5px;color:var(--brand-d);font-weight:600;margin:0}
.wl-check{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;color:var(--soft);margin-top:12px;cursor:pointer;line-height:1.4}
.wl-check input{margin-top:2px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--brand)}

/* ── Tool result blocks (competitors / pain / hooks / report) ──────────── */
.quote-card{
  border:1px solid var(--line);border-left:3px solid var(--gold);
  border-radius:0 var(--r-sm) var(--r-sm) 0;background:#fffdf8;
  padding:14px 16px;margin:10px 0;font-size:15px;
}
.quote-card .q{font-style:italic;color:var(--ink);line-height:1.55}
.quote-card .src{display:inline-block;font-size:12.5px;color:var(--soft);margin-top:7px;font-style:normal}
.quote-card .src a{color:var(--brand-d);font-weight:600;text-decoration:none}
.quote-card .src a:hover{text-decoration:underline}
.before-after{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}
.before-after .ba{border-radius:var(--r-sm);padding:13px 15px;font-size:14.5px;line-height:1.5}
.before-after .ba .ba-lbl{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}
.before-after .before{background:var(--red-bg);border:1px solid #f3cdc9}
.before-after .before .ba-lbl{color:var(--red)}
.before-after .after{background:var(--green-bg);border:1px solid #cbe7d6}
.before-after .after .ba-lbl{color:var(--green)}
@media(max-width:560px){.before-after{grid-template-columns:1fr}}

/* progress stepper (report pipeline) */
.stepper{margin:26px 0;display:grid;gap:0}
.stepper .st{display:flex;gap:14px;align-items:flex-start;position:relative;padding-bottom:22px}
.stepper .st::before{
  content:"";position:absolute;left:13px;top:30px;bottom:2px;width:2px;
  background:var(--line);border-radius:2px;
}
.stepper .st:last-child::before{display:none}
.stepper .st .ic{
  width:28px;height:28px;border-radius:50%;flex:none;z-index:1;
  border:2px solid var(--line-strong);background:#fff;color:var(--faint);
  display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:800;
}
.stepper .st .tt{font-weight:700;font-size:15px;padding-top:3px}
.stepper .st .dd{font-size:13px;color:var(--soft);line-height:1.4;margin-top:1px}
.stepper .st.done .ic{background:var(--green);border-color:var(--green);color:#fff}
.stepper .st.done::before{background:var(--green)}
.stepper .st.active .ic{
  border-color:var(--brand);color:var(--brand);
  animation:pulse-ring 1.4s ease infinite;
}
@keyframes pulse-ring{
  0%{box-shadow:0 0 0 0 rgba(47,111,107,.30)}
  70%{box-shadow:0 0 0 9px rgba(47,111,107,0)}
  100%{box-shadow:0 0 0 0 rgba(47,111,107,0)}
}
.stepper .st.error .ic{background:var(--red-bg);border-color:var(--red);color:var(--red)}

/* ── Inline SVG icons (sprite injected by site.js) ─────────────────────── */
.icn{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;flex:none}
.icn.sm{width:17px;height:17px}
.icn.lg{width:26px;height:26px}
.icn-chip{
  width:46px;height:46px;border-radius:13px;flex:none;
  background:var(--brand-tint);color:var(--brand-d);
  display:flex;align-items:center;justify-content:center;
}
.icn-chip.gold{background:var(--gold-tint);color:var(--gold-d)}
.icn-chip.on-dark{background:rgba(255,255,255,.08);color:var(--gold-bright)}

/* ── Section bands (each section owns its background, full-bleed) ──────── */
.band{padding:64px 0}
.band-tint{background:var(--brand-tint-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band-dark{
  background:
    radial-gradient(700px 360px at 90% -10%,rgba(201,149,45,.14),transparent 60%),
    var(--brand-ink);
  color:#eafaf6;
}
@media(max-width:640px){.band{padding:46px 0}}

/* agitate strip (the quiet-cost section) */
.agitate{max-width:680px;margin:0 auto;text-align:center}
.agitate h2{font-size:clamp(1.35rem,3vw,1.7rem)}
.agitate ul{list-style:none;margin:22px 0 18px;display:grid;gap:12px;text-align:left}
.agitate li{
  display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--red);
  border-radius:var(--r-sm);padding:14px 18px;line-height:1.5;
}
.agitate li .icn{color:var(--red);margin-top:2px}
.agitate .turn{font-size:16.5px;color:var(--soft)}
.agitate .turn b{color:var(--brand-d)}

/* ── Steps flow (connected, numbered, action-first) ────────────────────── */
.steps-flow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:8px}
.sf{position:relative;padding:0 26px;text-align:center}
.sf .sf-num{
  width:52px;height:52px;border-radius:50%;margin:0 auto 16px;position:relative;z-index:1;
  background:#fff;border:2px solid var(--brand);color:var(--brand-d);
  font-weight:900;font-size:20px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(47,111,107,.18);
}
.sf::before{ /* the connecting line */
  content:"";position:absolute;top:26px;left:-50%;width:100%;height:2px;
  background:linear-gradient(90deg,var(--brand-line),var(--brand));
}
.sf:first-child::before{display:none}
.sf h3{font-size:17px;margin-bottom:6px}
.sf .do{font-size:15px;color:var(--ink);line-height:1.5}
.sf .get{font-size:14px;color:var(--soft);line-height:1.5;margin-top:6px}
.sf .get b{color:var(--brand-d)}
.steps-cta{text-align:center;margin-top:36px}
@media(max-width:760px){
  .steps-flow{grid-template-columns:1fr;gap:0}
  .sf{display:grid;grid-template-columns:52px 1fr;gap:0 18px;text-align:left;padding:0 0 30px}
  .sf .sf-num{margin:0}
  .sf h3,.sf .do,.sf .get{grid-column:2}
  .sf::before{top:52px;left:25px;width:2px;height:calc(100% - 52px);background:linear-gradient(180deg,var(--brand),var(--brand-line))}
  .sf:first-child::before{display:block}
  .sf:last-child::before{display:none}
}

/* ── Toolbox band (dark, the tools section that can't be missed) ───────── */
.toolbox-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:30px}
.toolbox-head h2{font-size:clamp(2.1rem,5vw,3rem);color:#fff;letter-spacing:-.03em}
.toolbox-head p{color:#b9d6d2;font-size:17px;max-width:420px}
.tb-featured{
  display:flex;gap:22px;align-items:center;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(201,149,45,.16),rgba(255,255,255,.05));
  border:1px solid rgba(255,217,138,.35);border-radius:var(--r-lg);
  padding:26px 28px;margin-bottom:16px;text-decoration:none;
  transition:transform .16s ease, border-color .16s ease;
}
.tb-featured:hover{transform:translateY(-3px);border-color:var(--gold-bright)}
.tb-featured .icn-chip{width:56px;height:56px;border-radius:16px}
.tb-featured .tb-body{flex:1;min-width:220px}
.tb-featured h3{color:#fff;font-size:19px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.tb-featured p{color:#b9d6d2;font-size:15px;line-height:1.55;margin-top:5px}
.tb-featured .btn{flex:none}
.start-pill{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#241a02;background:var(--gold-bright);padding:4px 11px;border-radius:999px}
.tb-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tb-card{
  display:flex;gap:16px;align-items:flex-start;text-decoration:none;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.13);
  border-radius:var(--r-lg);padding:22px;
  transition:transform .16s ease, border-color .16s ease, background .16s ease;
}
.tb-card:hover{transform:translateY(-3px);border-color:rgba(255,217,138,.5);background:rgba(255,255,255,.08)}
.tb-card h3{color:#fff;font-size:16px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}
.tb-card p{color:#b9d6d2;font-size:14px;line-height:1.5;margin-top:4px}
.tb-foot{text-align:center;margin-top:22px;font-size:14.5px;color:#9fc1bc}
.tb-foot a{color:var(--gold-bright);font-weight:700;text-decoration:none}
.tb-foot a:hover{text-decoration:underline}
.free-pill-dark{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#9fe8c0;background:rgba(47,143,91,.25);border:1px solid rgba(47,143,91,.5);padding:3px 9px;border-radius:999px;margin-left:8px}
@media(max-width:680px){.tb-grid{grid-template-columns:1fr}.tb-featured .btn{width:100%}}

/* ── Scroll reveal (site.js adds .in when visible) ─────────────────────── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001s !important}
}

/* ── Mobile app adjustments ────────────────────────────────────────────── */
@media(max-width:640px){
  .card{padding:22px 18px}
  .path-grid{grid-template-columns:1fr}
  .score-grid{grid-template-columns:1fr}
  .dial{font-size:60px}
  .btn{width:100%}
  .nav{flex-direction:column-reverse}
  .nav .btn{width:100%}
  .result-actions .btn{width:auto;flex:1}
}

/* ── Print ─────────────────────────────────────────────────────────────── */
.print-head{display:none}
@media print{
  @page{margin:14mm}
  *{-webkit-print-color-adjust:exact !important;print-color-adjust:exact !important}
  body{background:#fff !important}
  .wrap{max-width:100% !important;padding:0 !important}
  header,.prog-wrap,.nav,.cta-box,.soon-box,.result-actions,.save-note,footer,
  .sx-nav,.sx-footer,[data-site-nav],[data-site-footer],.no-print{display:none !important}
  .card{box-shadow:none !important;border:none !important;padding:0 !important;margin:0 !important}
  .print-head{display:block !important;text-align:center;margin-bottom:16px;border-bottom:2px solid var(--brand);padding-bottom:10px}
  .print-head .ph-brand{font-weight:800;color:var(--brand-d);font-size:18px}
  .print-head .ph-sub{color:#555;font-size:12px;margin-top:3px}
  .section-head{break-after:avoid}
  .score-item,.fix-item,.lane,.pitch-box,.snapshot,.total-wrap,.nextmove,.quote-card{break-inside:avoid}
}
