/* ============================================================
   Deficit — Landing Page
   Bruce Lee yellow + matte black. iOS waitlist.
   ============================================================ */

/* ── tokens ─────────────────────────────────────────────────── */
:root{
  --ink-1000:#0A0A0B;
  --ink-900:#131316;
  --ink-800:#1C1D21;
  --ink-700:#26282E;
  --ink-600:#3A3D45;
  --fg-1:#F4F4F2;
  --fg-2:#8A8F99;
  --fg-3:#5C6069;
  --yellow:#E8BE2C;
  --yellow-pressed:#C9A11F;
  --on-track:#6FB988;
  --ahead:#7AB6C4;
  --behind:#D67A4F;
  --danger:#C7503F;

  --sans: "Geist", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  --display-italic: "Barlow Condensed", "Inter", sans-serif;
  --mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --serif: "Fraunces", Georgia, serif;

  --display: var(--sans);
  --body: var(--sans);

  --gutter: clamp(1.25rem, 1rem + 2vw, 2.5rem);
  --section-y: clamp(5rem, 4rem + 6vw, 9rem);
  --rule: 1px solid var(--ink-700);

  color-scheme: dark;
}

/* ── base ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin:0; padding:0; }
html { scroll-behavior: smooth; }
body{
  background: var(--ink-1000);
  color: var(--fg-1);
  font-family: var(--body);
  font-size:16px;
  line-height:1.5;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
/* hairline grain on the body — atmosphere, not texture */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  background-image:
    radial-gradient(rgba(255,255,255,0.018) 1px, transparent 1px);
  background-size: 3px 3px;
  mix-blend-mode: screen;
}

a{ color: inherit; text-decoration:none; }
button{ font: inherit; cursor: pointer; }
::selection{ background: var(--yellow); color: var(--ink-1000); }

.container{
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding-inline: var(--gutter);
}

/* visually hidden — for skip-link */
.sr-only{
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.skip-link{
  position: absolute;
  top: -40px; left: 12px;
  z-index: 100;
  padding: 10px 14px;
  background: var(--yellow);
  color: var(--ink-1000);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  border-radius: 6px;
  transition: top .15s ease;
}
.skip-link:focus{ top: 12px; outline: none; }

/* ── typography ─────────────────────────────────────────────── */
/* Eyebrow style 1 — Mono caps */
.eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
  font-weight:500;
}
.eyebrow .dot{
  display:inline-block;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--yellow);
  vertical-align: 2px;
  margin-right:8px;
}

/* Eyebrow style 2 — Barlow Condensed Italic caps */
.stencil{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  line-height: 1;
  color: var(--fg-1);
}

h1, h2, h3, .display{
  font-family: var(--sans);
  font-weight: 800;
  line-height: 0.96;
  letter-spacing: -0.045em;
  color: var(--fg-1);
  margin:0;
  text-wrap: balance;
}
.num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1, "lnum" 1; }
.mono { font-family: var(--mono); }
.serif { font-family: var(--serif); }

/* ── nav ────────────────────────────────────────────────────── */
nav.top{
  position: sticky; top:0; z-index:50;
  background: color-mix(in oklab, var(--ink-1000) 80%, transparent);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .25s ease, background .25s ease;
}
nav.top.scrolled{ border-bottom-color: var(--ink-700); }
nav.top .row{
  display:flex; align-items:center; justify-content:space-between;
  height: 68px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family: var(--sans);
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.04em;
}
.brand img{ width:28px; height:28px; display:block; border-radius:6px; }
.brand .stop{ color: var(--yellow); margin-left:-2px; }

nav.top .links{
  display:flex; gap: 28px;
  font-size: 14px;
  color: var(--fg-2);
}
nav.top .links a{ transition: color .15s ease; }
nav.top .links a:hover{ color: var(--fg-1); }
@media (max-width: 720px){ nav.top .links{ display:none; } }

/* Small btn (nav) */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.01em;
  border:none;
  transition: transform .15s ease, background .15s ease, color .15s ease;
}
.btn-primary{ background: var(--yellow); color: var(--ink-1000); }
.btn-primary:hover{ background: #F2CC44; }
.btn-primary:active{ transform: scale(.98); background: var(--yellow-pressed); }
.btn-ghost{ background: transparent; color: var(--fg-1); border:1px solid var(--ink-700); }
.btn-ghost:hover{ border-color: var(--ink-600); background: var(--ink-900); }

/* Hex button — 14px chamfer, Barlow Condensed Italic caps */
.hex{
  position: relative;
  display:inline-flex; align-items:center; justify-content:center;
  padding: 18px 40px;
  min-height: 56px;
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 17px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ink-1000);
  background: var(--yellow);
  border: none;
  clip-path: polygon(14px 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 14px 100%, 0 50%);
  transition: background .15s ease, transform .12s ease;
  cursor: pointer;
}
.hex:hover{ background: #F2CC44; }
.hex:active{ transform: scale(.985); background: var(--yellow-pressed); }

/* Secondary CTA — text link with arrow, athletic stencil */
.link-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding: 18px 4px;
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--fg-1);
  position: relative;
  transition: color .15s ease;
}
.link-cta::after{
  content: "";
  position: absolute;
  left: 4px; right: 4px; bottom: 12px;
  height: 1px;
  background: var(--ink-600);
  transform-origin: left center;
  transition: background .2s ease, transform .25s cubic-bezier(.22,1,.36,1);
}
.link-cta:hover{ color: var(--yellow); }
.link-cta:hover::after{ background: var(--yellow); }
.link-cta .arrow{
  display:inline-block;
  transition: transform .25s cubic-bezier(.22,1,.36,1);
}
.link-cta:hover .arrow{ transform: translateX(3px); }

/* ── reveal on scroll ───────────────────────────────────────── */
.reveal{ opacity:0; transition: opacity .9s cubic-bezier(.22,1,.36,1); }
.reveal.in{ opacity:1; }
.reveal[data-delay="1"]{ transition-delay: .08s; }
.reveal[data-delay="2"]{ transition-delay: .16s; }
.reveal[data-delay="3"]{ transition-delay: .24s; }
.reveal[data-delay="4"]{ transition-delay: .32s; }
.reveal[data-delay="5"]{ transition-delay: .40s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform: none; transition:none; }
  *{ animation: none !important; }
}

/* ── hero ───────────────────────────────────────────────────── */
.hero{
  padding-top: clamp(3rem, 2rem + 4vw, 6rem);
  padding-bottom: var(--section-y);
  position: relative;
}
.hero .tag{
  display:inline-flex; align-items:center; gap:10px;
  padding: 6px 12px 6px 10px;
  border:1px solid var(--ink-700);
  border-radius: 999px;
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg-2);
}
.hero .tag .pulse{
  width:6px; height:6px; border-radius:50%;
  background: var(--yellow);
  box-shadow: 0 0 0 0 rgba(232,190,44,.5);
  animation: pulse 2.2s ease-in-out infinite;
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 rgba(232,190,44,.55); opacity:1; }
  70%{ box-shadow: 0 0 0 8px rgba(232,190,44,0); opacity:.5; }
  100%{ box-shadow: 0 0 0 0 rgba(232,190,44,0); opacity:1; }
}

.hero h1{
  margin-top: 28px;
  font-size: clamp(2.6rem, 1.4rem + 6vw, 7rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: .9;
}
@media (max-width: 640px){
  .hero h1{
    line-height: 1.02;
    letter-spacing: -0.035em;
  }
}
.hero h1 .stop{ color: var(--yellow); }
.hero h1 em{
  font-style: normal;
  color: var(--fg-3);
  font-weight: 800;
}
.hero .sub{
  margin-top: 28px;
  max-width: 620px;
  font-size: clamp(1rem, .9rem + .5vw, 1.25rem);
  color: var(--fg-2);
  line-height: 1.5;
}
.hero .ctas{
  margin-top: 36px;
  display:flex; flex-wrap: wrap; gap: 12px; align-items:center;
}
.hero .ctas .meta{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-left: 6px;
}

/* hero numeric motif */
.weight-motif{
  margin-top: clamp(3.5rem, 2.5rem + 4vw, 6rem);
  display:grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: end;
  padding-top: 28px;
  border-top: var(--rule);
}
@media (min-width: 900px){
  .weight-motif{
    grid-template-columns: 1.4fr 1fr;
    gap: 64px;
  }
}
.weight-motif .nums{
  display:flex; align-items: baseline; flex-wrap: wrap;
  gap: clamp(.5rem, 0.4rem + 1vw, 1.5rem);
  font-family: var(--sans);
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: .9;
  color: var(--fg-1);
}
.weight-motif .nums .from,
.weight-motif .nums .to{
  font-size: clamp(3rem, 1.5rem + 9vw, 9.5rem);
  font-variant-numeric: tabular-nums;
}
.weight-motif .nums .to{ color: var(--yellow); }
.weight-motif .nums .arrow{
  font-size: clamp(2.2rem, 1rem + 6vw, 6rem);
  color: var(--fg-3);
  font-weight: 500;
  transform: translateY(-.05em);
}
.weight-motif .nums .unit{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: clamp(.9rem, .7rem + .6vw, 1.3rem);
  color: var(--fg-3);
  letter-spacing: .1em;
  text-transform: uppercase;
  align-self: flex-end;
  transform: translateY(-1.2em);
}
.weight-motif .annotate{
  display:flex; flex-direction: column; gap: 16px;
  padding-bottom: 12px;
}
.weight-motif .annotate .row{
  display:flex; justify-content: space-between; gap: 20px;
  padding: 12px 0;
  border-bottom: var(--rule);
}
.weight-motif .annotate .row:last-of-type{ border-bottom: none; }
.weight-motif .annotate .k{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.weight-motif .annotate .v{
  font-family: var(--mono);
  font-size: 13px;
  color: var(--fg-1);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

/* ── built-for strip ────────────────────────────────────────── */
.built-for{
  border-top: var(--rule);
  border-bottom: var(--rule);
  padding-block: clamp(1.75rem, 1rem + 2vw, 2.5rem);
}
.built-for .wrap{
  display:grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items:center;
}
@media (min-width: 880px){
  .built-for .wrap{
    grid-template-columns: 220px 1fr;
    gap: 40px;
  }
}
.built-for .label{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: .18em;
  text-transform: uppercase;
  line-height: 1.55;
}
.built-for ul{
  list-style:none; margin:0; padding:0;
  display:flex; flex-wrap: wrap;
  gap: clamp(1.25rem, .8rem + 2vw, 2.5rem) clamp(1.5rem, 1rem + 2.5vw, 3rem);
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.25rem);
  color: var(--fg-1);
}
.built-for li{ display:flex; align-items:baseline; gap:10px; }
.built-for li::before{
  content:"";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--yellow);
  align-self: center;
  flex: 0 0 6px;
}

/* ── section heads ──────────────────────────────────────────── */
.section{ padding-block: var(--section-y); }
.section-head{
  display:grid;
  grid-template-columns: 1fr;
  gap: 28px;
  align-items: end;
  padding-bottom: clamp(2.5rem, 2rem + 2.5vw, 4.5rem);
}
@media (min-width: 920px){
  .section-head{ grid-template-columns: 1.2fr 1fr; gap: 64px; }
}
.section-head .eyebrow + h2{ margin-top: 18px; }
.section-head h2{
  font-size: clamp(1.9rem, 1.3rem + 2.5vw, 3.6rem);
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 1.02;
}
.section-head .lead{
  font-size: clamp(.95rem, .9rem + .25vw, 1.075rem);
  color: var(--fg-2);
  line-height: 1.55;
  max-width: 46ch;
  justify-self: end;
}
@media (max-width: 919px){
  .section-head .lead{ justify-self: start; }
}

/* ── how it works (steps) ───────────────────────────────────── */
.steps{
  display:grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 1rem + 3vw, 3rem);
}
@media (min-width: 880px){
  .steps{ grid-template-columns: repeat(3, 1fr); gap: 28px; }
}
.step{
  display:flex; flex-direction: column;
  align-items: stretch;
  text-align: center;
}
.step .preview{
  background: var(--ink-900);
  border: 1px solid var(--ink-700);
  border-radius: 20px;
  padding: 28px 24px;
  min-height: 280px;
  display:flex; align-items:center; justify-content:center;
  position: relative;
  overflow: hidden;
  transition: border-color .25s ease;
}
.step:hover .preview{ border-color: var(--ink-600); }
.step .n{
  margin-top: 28px;
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .14em;
  color: var(--yellow);
  text-transform: uppercase;
}
.step h3{
  margin-top: 14px;
  font-size: clamp(1.3rem, 1.05rem + 1vw, 1.6rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.15;
}
.step p{
  margin-top: 12px;
  color: var(--fg-2);
  font-size: 14px;
  line-height: 1.55;
  max-width: 32ch;
  margin-inline: auto;
}

/* preview-card mock pieces */
.pv-card{
  width: 100%;
  max-width: 240px;
  background: var(--ink-1000);
  border: 1px solid var(--ink-700);
  border-radius: 14px;
  padding: 16px;
  text-align: left;
}
.pv-eyebrow{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.pv-big{
  margin-top: 8px;
  font-family: var(--sans);
  font-weight: 800;
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.05em;
  font-variant-numeric: tabular-nums;
}
.pv-row{
  display:flex; justify-content: space-between; align-items: baseline;
  padding-block: 6px;
  border-bottom: 1px dashed var(--ink-700);
  font-family: var(--mono);
  font-size: 11px;
}
.pv-row:last-child{ border-bottom: none; }
.pv-row .k{ color: var(--fg-3); }
.pv-row .v{ color: var(--fg-1); font-variant-numeric: tabular-nums; font-weight: 500; }
.pv-chip{
  display:inline-flex; align-items:center;
  padding: 6px 10px;
  border-radius: 8px;
  background: var(--ink-800);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 11px;
  color: var(--fg-1);
}
.pv-chip.on{ background: var(--yellow); color: var(--ink-1000); }

/* preview-card inline helpers (no inline styles in markup) */
.pv-card.on-track{ border-top: 2px solid var(--on-track); }
.pv-chips-row{
  margin-top: 12px;
  display:flex; flex-wrap: wrap; gap: 6px;
}
.pv-two{
  margin-top: 14px;
  display:grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.pv-big.sm{ font-size: 22px; margin-top: 4px; }
.pv-big.yellow{ color: var(--yellow); }
.pv-big.kcal{ margin-top: 10px; font-size: 30px; }
.pv-state{
  display:flex; justify-content: space-between; align-items: center;
}
.pv-phase{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .12em;
  color: var(--on-track);
  text-transform: uppercase;
}
.pv-unit{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-top: 2px;
}
.pv-macro{
  background: var(--ink-800);
  border-radius: 8px;
  padding: 8px 10px;
}
.pv-macro .pv-eyebrow{ font-size: 9px; }
.pv-macro .pv-big{ font-size: 16px; margin-top: 2px; }
.pv-status-good{
  color: var(--on-track) !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
}
.pv-coach-card{
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  background: color-mix(in oklab, var(--yellow) 8%, var(--ink-1000));
  border: 1px solid color-mix(in oklab, var(--yellow) 30%, var(--ink-700));
}
.pv-coach-card .pv-eyebrow{ color: var(--yellow); }
.pv-coach-card .pv-eyebrow .ydot{
  display:inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--yellow);
  vertical-align: 1px;
  margin-right: 6px;
}
.pv-coach-card .msg{
  margin-top: 6px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-2);
  line-height: 1.5;
}

/* ── safety ─────────────────────────────────────────────────── */
.safety{
  border-top: 1px solid var(--ink-700);
  padding-block: var(--section-y);
}
.safety .label{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 14px;
  color: var(--danger);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.safety h2{
  margin-top: 14px;
  font-size: clamp(2rem, 1.4rem + 2.6vw, 3.8rem);
  font-weight: 800;
  letter-spacing: -0.045em;
  line-height: 1.02;
  max-width: 18ch;
}
.safety h2 .strike{ color: var(--fg-3); }
.safety .intro{
  margin-top: 22px;
  max-width: 54ch;
  color: var(--fg-2);
  font-size: clamp(.95rem, .9rem + .25vw, 1.075rem);
  line-height: 1.55;
}

.limits{
  margin-top: clamp(2rem, 1.5rem + 2vw, 3.5rem);
  border-top: var(--rule);
}
.limit{
  display:grid;
  grid-template-columns: minmax(140px, 22%) 1fr;
  align-items: baseline;
  gap: 28px;
  padding: clamp(20px, 1rem + 1.5vw, 36px) 0;
  border-bottom: var(--rule);
}
@media (min-width: 860px){
  .limit{ grid-template-columns: minmax(220px, 28%) 1fr; gap: 64px; }
}
.limit .n{
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(2.2rem, 1.4rem + 4.5vw, 5rem);
  line-height: .9;
  letter-spacing: -0.05em;
  font-variant-numeric: tabular-nums;
  color: var(--fg-1);
}
.limit .n .unit{
  font-size: .5em;
  color: var(--fg-3);
}
.limit .n .unit-sm{
  font-size: .45em;
  color: var(--fg-3);
}
.limit .n.never{
  font-size: clamp(2rem, 1rem + 4vw, 4rem);
  letter-spacing: -0.04em;
}
.limit.danger .n{ color: var(--danger); }
.limit .copy .k{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.limit .copy .desc{
  margin-top: 8px;
  font-size: clamp(.95rem, .9rem + .2vw, 1.05rem);
  color: var(--fg-2);
  line-height: 1.55;
  max-width: 56ch;
}
.safety .foot{
  margin-top: 36px;
  color: var(--fg-2);
  font-family: var(--sans);
  font-size: clamp(.95rem, .9rem + .2vw, 1.05rem);
  max-width: 60ch;
  line-height: 1.55;
  font-weight: 400;
}

/* ── pricing ────────────────────────────────────────────────── */
.pricing-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 820px){
  .pricing-grid{ grid-template-columns: 1fr 1fr; gap: 24px; }
}
.price{
  border: 1px solid var(--ink-700);
  border-radius: 20px;
  padding: clamp(1.5rem, 1rem + 1.5vw, 2.5rem);
  background: var(--ink-900);
  display:flex; flex-direction: column;
  min-height: 380px;
  transition: border-color .25s ease;
}
.price:hover{ border-color: var(--ink-600); }
.price.featured{
  border-color: var(--yellow);
  background: linear-gradient(180deg, color-mix(in oklab, var(--yellow) 6%, var(--ink-900)) 0%, var(--ink-900) 40%);
}
.price .head{
  display:flex; justify-content: space-between; align-items: flex-start;
}
.price .which{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.price.featured .which{ color: var(--yellow); }
.price .badge{
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--ink-700);
  color: var(--fg-2);
}
.price.featured .badge{ border-color: var(--yellow); color: var(--yellow); }
.price .amount{
  margin-top: 28px;
  display:flex; align-items: baseline; gap: 8px;
}
.price .amount .v{
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(3rem, 2rem + 4vw, 4.5rem);
  line-height: 1;
  letter-spacing: -0.05em;
  font-variant-numeric: tabular-nums;
}
.price .amount .per{
  font-family: var(--display-italic);
  font-style: italic;
  font-weight: 800;
  color: var(--fg-3);
  font-size: 15px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.price h3{
  margin-top: 16px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.price p.who{
  margin-top: 8px;
  color: var(--fg-2);
  font-size: 14px;
  line-height: 1.55;
  max-width: 38ch;
}
.price ul.feats{
  list-style: none; margin: 24px 0 0; padding: 0;
  display:flex; flex-direction: column; gap: 12px;
  flex: 1;
}
.price ul.feats li{
  display:flex; gap: 12px; align-items: flex-start;
  color: var(--fg-1);
  font-size: 14px;
  line-height: 1.5;
}
.price ul.feats li::before{
  content: "";
  flex: 0 0 18px;
  width: 18px; height: 18px;
  margin-top: 2px;
  border-radius: 50%;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'><path d='M5 9.5l3 3 5-6' fill='none' stroke='%23F4F4F2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>")
    center/12px 12px no-repeat,
    var(--ink-700);
}
.price.featured ul.feats li::before{
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'><path d='M5 9.5l3 3 5-6' fill='none' stroke='%230A0A0B' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/></svg>")
    center/12px 12px no-repeat,
    var(--yellow);
}
.price .footnote{
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--ink-700);
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* ── waitlist ───────────────────────────────────────────────── */
.waitlist{
  border-top: var(--rule);
  padding-block: var(--section-y);
}
.waitlist .grid{
  display:grid; grid-template-columns: 1fr; gap: 40px;
}
@media (min-width: 920px){
  .waitlist .grid{ grid-template-columns: 1.05fr 1fr; gap: 80px; align-items: start; }
}
.waitlist h2{
  font-size: clamp(2rem, 1.4rem + 2.8vw, 4rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: .98;
  margin-top: 18px;
}
.waitlist h2 .stop{ color: var(--yellow); }
.waitlist .lead{
  margin-top: 20px;
  color: var(--fg-2);
  font-size: clamp(.95rem, .9rem + .25vw, 1.075rem);
  line-height: 1.55;
  max-width: 46ch;
}
.waitlist .platform{
  margin-top: 36px;
  display:flex; flex-direction: column; gap: 18px;
  max-width: 38ch;
}
.waitlist .platform .row{
  display:flex; justify-content: space-between;
}
.waitlist .platform .k{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.waitlist .platform .v{
  font-family: var(--mono);
  font-size: 13px;
  color: var(--fg-1);
}
.waitlist form{
  background: var(--ink-900);
  border: 1px solid var(--ink-700);
  border-radius: 20px;
  padding: clamp(1.5rem, 1rem + 1.5vw, 2.25rem);
  display:flex; flex-direction: column; gap: 18px;
}
.waitlist form fieldset{
  border: 0;
  padding: 0;
  margin: 0;
  min-width: 0;
}
.field label{
  display:block;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.field input[type=email],
.field input[type=text]{
  width: 100%;
  padding: 14px 16px;
  background: var(--ink-800);
  border: 1px solid var(--ink-700);
  border-radius: 10px;
  color: var(--fg-1);
  font: 500 15px/1.4 var(--body);
  transition: border-color .15s ease, background .15s ease;
}
.field input::placeholder{ color: var(--fg-3); }
.field input:focus{
  outline: none;
  border-color: var(--yellow);
  background: var(--ink-800);
}
.check{
  display:flex; gap:10px; align-items: flex-start;
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.5;
}
.check input{
  appearance: none;
  -webkit-appearance: none;
  width: 16px; height: 16px;
  border-radius: 4px;
  border: 1px solid var(--ink-600);
  background: var(--ink-800);
  margin-top: 2px;
  flex: 0 0 16px;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease;
  position: relative;
}
.check input:checked{
  background: var(--yellow);
  border-color: var(--yellow);
}
.check input:checked::after{
  content: "";
  position: absolute;
  left: 5px; top: 1px;
  width: 4px; height: 9px;
  border: solid var(--ink-1000);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.sport-grid{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
}
@media (min-width: 520px){
  .sport-grid{ grid-template-columns: repeat(3, 1fr); }
}
.sport-grid label{
  display:flex; align-items:center; justify-content: center;
  padding: 12px 8px;
  border: 1px solid var(--ink-700);
  background: var(--ink-800);
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-1);
  cursor: pointer;
  text-align: center;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
  margin-bottom: 0;
  letter-spacing: 0.01em;
  text-transform: none;
}
.sport-grid input{ position: absolute; opacity: 0; pointer-events: none; }
.sport-grid label:hover{ border-color: var(--ink-600); }
.sport-grid input:checked + label,
.sport-grid label.checked,
.sport-grid input:focus-visible + label{
  background: var(--yellow);
  border-color: var(--yellow);
  color: var(--ink-1000);
}
.sport-grid input:focus-visible + label{
  box-shadow: 0 0 0 2px var(--ink-1000), 0 0 0 4px var(--yellow);
}
.honeypot{
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
}
.submit{
  margin-top: 6px;
  padding: 16px 20px;
  background: var(--yellow);
  border:none;
  border-radius: 12px;
  color: var(--ink-1000);
  font: 700 14px/1 var(--body);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .15s ease, transform .15s ease;
}
.submit:hover{ background: #F2CC44; }
.submit:active{ transform: scale(.99); }
.submit[disabled]{ opacity: .7; cursor: progress; }
.waitlist .small{
  font-family: var(--mono);
  font-size: 10px;
  color: var(--fg-3);
  letter-spacing: .12em;
  text-transform: uppercase;
  line-height: 1.6;
}
.waitlist .small a{
  text-decoration: underline;
  color: var(--fg-2);
}
.waitlist .small a:hover{ color: var(--fg-1); }

.success{
  display:none;
  padding: 24px;
  background: var(--ink-900);
  border: 1px solid var(--yellow);
  border-radius: 16px;
}
.success.show{ display:block; }
.success .h{
  font-family: var(--display);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.success .b{ margin-top: 10px; color: var(--fg-2); font-size: 14px; }

/* ── footer ─────────────────────────────────────────────────── */
footer{
  border-top: var(--rule);
  padding-block: 48px;
  color: var(--fg-3);
}
footer .row{
  display:flex; flex-wrap: wrap; gap: 24px;
  justify-content: space-between; align-items: center;
}
footer .links{ display:flex; gap: 24px; }
footer .links a{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-2);
  transition: color .15s ease;
}
footer .links a:hover{ color: var(--fg-1); }
footer .brand{ font-size: 18px; }
footer .copy{
  font-family: var(--mono);
  font-size: 11px;
  color: var(--fg-3);
  letter-spacing: .14em;
  text-transform: uppercase;
}

/* ── focus states (accessibility) ───────────────────────────── */
a:focus-visible,
button:focus-visible{
  outline: 2px solid var(--yellow);
  outline-offset: 3px;
  border-radius: 4px;
}
.hex:focus-visible{
  outline: 2px solid var(--yellow);
  outline-offset: 4px;
}
.field input:focus-visible{
  outline: none;
  border-color: var(--yellow);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--yellow) 25%, transparent);
}
