/* ============================================================================
   Stats Cram Cohort — landing page
   Concept: "The Distribution." The page is a coordinate plane; the student
   travels from the shaded fail-tail to the green pass-region where the CTA lives.
   Palette: graph-paper ground, ink navy, exam-red (reject), confident green (pass).
   Type: Space Grotesk (display) · Space Mono (data/labels) · Inter (body).
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --paper:#eff1ec;        /* graph-paper ground */
  --paper-raised:#f7f8f4; /* cards / raised panels */
  --ink:#11183a;          /* primary text + curve */
  --ink-soft:#48507a;     /* secondary text */
  --ink-faint:#8b93b6;    /* tertiary / captions */
  --grid:rgba(17,24,58,.055);
  --grid-major:rgba(17,24,58,.10);
  --reject:#e5484d;       /* rejection region / urgency / fail */
  --reject-soft:rgba(229,72,77,.12);
  --pass:#0f9d6b;         /* CTA / pass-state */
  --pass-deep:#0b7d55;
  --pass-soft:rgba(15,157,107,.12);
  --hi:rgba(245,200,66,.55); /* highlighter, used once */
  --line:rgba(17,24,58,.14);
  --shadow:0 1px 0 rgba(17,24,58,.04), 0 18px 40px -24px rgba(17,24,58,.35);

  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-mono:'Space Mono',ui-monospace,monospace;
  --font-body:'Inter',system-ui,sans-serif;
  --maxw:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  line-height:1.65;
  background-color:var(--paper);
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px),
    linear-gradient(var(--grid-major) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-major) 1px, transparent 1px);
  background-size: 28px 28px, 28px 28px, 140px 140px, 140px 140px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---- type ---- */
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.04;letter-spacing:-.02em;color:var(--ink);margin:0}
p{margin:0 0 1rem}
strong{font-weight:600;color:var(--ink)}
a{color:var(--pass-deep)}

.eyebrow{
  font-family:var(--font-mono);font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ink-faint);
  display:inline-flex;align-items:center;gap:.6ch;margin:0 0 1.1rem;
}
.eyebrow .sigma{color:var(--reject)}
.eyebrow.pass .sigma{color:var(--pass)}
.mono{font-family:var(--font-mono)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative;padding:84px 0}
.rule{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}

/* axis rail: the through-line down the page */
.section-coord{
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-faint);display:flex;align-items:center;gap:10px;margin-bottom:18px;
}
.section-coord::before{content:"";width:34px;height:1px;background:var(--ink-faint);opacity:.6}

/* ---- top bar ---- */
.topbar{
  position:sticky;top:0;z-index:40;backdrop-filter:blur(8px);
  background:rgba(239,241,236,.82);border-bottom:1px solid var(--line);
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:1.06rem;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
.brand svg{display:block}
.topbar .nav-cta{
  font-family:var(--font-mono);font-size:.78rem;font-weight:700;letter-spacing:.04em;
  text-decoration:none;color:#fff;background:var(--pass);padding:9px 16px;border-radius:8px;
  white-space:nowrap;transition:background .15s;
}
.topbar .nav-cta:hover{background:var(--pass-deep)}

/* ---- hero ---- */
.hero{padding-top:54px;padding-bottom:40px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(2.3rem,5.4vw,4.4rem)}
.hero .lead{font-size:clamp(1.05rem,1.55vw,1.26rem);color:var(--ink-soft);max-width:46ch;margin:1.4rem 0 0}
.hero .mark{background:linear-gradient(transparent 62%, var(--hi) 62%);padding:0 .1em}
.hero-cta{margin-top:2.2rem;display:flex;flex-wrap:wrap;align-items:center;gap:14px 20px}
.hero-note{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-soft);letter-spacing:.01em}

/* hero curve figure */
.curve-fig{position:relative}
.curve-fig svg{width:100%;height:auto;overflow:visible}
.curve-stroke{fill:none;stroke:var(--ink);stroke-width:4;stroke-linecap:round}
.axis-line{stroke:var(--ink);stroke-width:2.5;opacity:.45}
.tick{stroke:var(--ink);stroke-width:2.5;opacity:.4}
.tick-label{font-family:var(--font-mono);font-size:28px;fill:var(--ink-faint)}
.region-label{font-family:var(--font-mono);font-size:38px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.you-are-here{font-family:var(--font-mono);font-size:32px;fill:var(--reject);font-weight:700}
.here-dot{fill:var(--reject)}
/* SVG fills/strokes must be set in CSS — var() is ignored in SVG presentation attributes */
.reject-region{fill:var(--reject-soft)}
.pass-region{fill:var(--pass-soft)}
.lbl-fail{fill:var(--reject)}
.lbl-pass{fill:var(--pass-deep)}
.here-tick{stroke:var(--reject)}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);
  font-weight:600;font-size:1.02rem;text-decoration:none;cursor:pointer;border:none;
  padding:15px 26px;border-radius:11px;transition:transform .12s ease, box-shadow .15s ease, background .15s;
}
.btn-primary{background:var(--pass);color:#fff;box-shadow:0 12px 24px -10px rgba(15,157,107,.6)}
.btn-primary:hover{background:var(--pass-deep);transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(15,157,107,.7)}
.btn-primary .arrow{transition:transform .15s}
.btn-primary:hover .arrow{transform:translateX(3px)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}

/* ---- panic section (the fog) ---- */
.panic{background:linear-gradient(180deg, transparent, rgba(229,72,77,.04))}
.panic h2{font-size:clamp(1.7rem,3.4vw,2.6rem);max-width:18ch}
.fog{display:flex;flex-wrap:wrap;gap:10px 16px;margin:26px 0 6px;font-family:var(--font-mono);font-size:1.25rem;color:var(--reject)}
.fog span{opacity:.85;filter:blur(.4px)}
.panic-list{list-style:none;padding:0;margin:30px 0 0;display:grid;gap:14px;max-width:62ch}
.panic-list li{position:relative;padding-left:30px;color:var(--ink-soft)}
.panic-list li::before{content:"×";position:absolute;left:4px;top:-1px;color:var(--reject);font-family:var(--font-mono);font-weight:700}
.panic-list li strong{color:var(--ink)}
.reframe{margin-top:34px;font-size:1.2rem;max-width:50ch;font-family:var(--font-display);font-weight:500;line-height:1.4}
.reframe b{color:var(--pass-deep)}

/* ---- the turn / promise ---- */
.turn h2{font-size:clamp(1.9rem,3.8vw,3rem);max-width:20ch}
.fromto{display:grid;grid-template-columns:1fr auto 1fr;gap:22px;align-items:stretch;margin-top:36px}
.state{border:1px solid var(--line);border-radius:14px;padding:24px;background:var(--paper-raised)}
.state .tag{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.state.before{border-color:rgba(229,72,77,.35)}
.state.before .tag{color:var(--reject)}
.state.after{border-color:rgba(15,157,107,.4)}
.state.after .tag{color:var(--pass-deep)}
.state p{margin:0;font-size:1.12rem;line-height:1.4;color:var(--ink)}
.state .src{font-family:var(--font-mono);font-size:.72rem;color:var(--ink-faint);margin-top:12px;font-style:normal}
.fromto .conn{display:flex;align-items:center;justify-content:center;color:var(--ink-faint);font-family:var(--font-mono)}

/* ---- included ---- */
.included h2{font-size:clamp(1.7rem,3.2vw,2.4rem);margin-bottom:8px}
.included .sub{color:var(--ink-soft);margin-bottom:34px}
.stack{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.item{display:flex;gap:14px;padding:20px;border:1px solid var(--line);border-radius:13px;background:var(--paper-raised)}
.item .ic{flex:0 0 auto;width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-family:var(--font-mono);font-weight:700;font-size:.9rem;background:var(--pass-soft);color:var(--pass-deep)}
.item.bonus .ic{background:rgba(245,200,66,.22);color:#9a7a07}
.item h3{font-size:1.04rem;margin-bottom:4px}
.item p{margin:0;font-size:.94rem;color:var(--ink-soft);line-height:1.5}

/* ---- sessions plotted on the journey ---- */
.sessions{background:var(--paper-raised);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sessions h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:6px}
.sessions .sub{color:var(--ink-soft);margin-bottom:38px;max-width:60ch}
.track{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:14px}
.track::before{content:"";position:absolute;left:0;right:0;top:13px;height:2px;
  background:linear-gradient(90deg,var(--reject),var(--ink-faint) 45%,var(--pass));opacity:.5}
.stop{position:relative;padding-top:40px}
.stop .node{position:absolute;top:6px;left:0;width:16px;height:16px;border-radius:50%;background:var(--paper-raised);border:2px solid var(--ink)}
.stop:first-child .node{border-color:var(--reject)}
.stop:last-child .node{border-color:var(--pass);background:var(--pass)}
.stop .n{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;color:var(--ink-faint);text-transform:uppercase}
.stop h3{font-size:1.05rem;margin:6px 0 6px}
.stop p{font-size:.9rem;color:var(--ink-soft);margin:0;line-height:1.5}

/* ---- guarantee ---- */
.guarantee .box{border:1.5px solid var(--pass);border-radius:16px;background:var(--pass-soft);padding:34px;max-width:760px}
.guarantee .box .eyebrow{color:var(--pass-deep)}
.guarantee .box .eyebrow .sigma{color:var(--pass)}
.guarantee h2{font-size:clamp(1.5rem,2.8vw,2.1rem);margin-bottom:12px}
.guarantee p{color:var(--ink-soft);max-width:60ch;margin:0}
.guarantee p + p{margin-top:12px}

/* ---- pricing / CTA ---- */
.pricing{padding-bottom:96px}
.price-card{
  border:1.5px solid var(--ink);border-radius:20px;background:var(--paper-raised);
  padding:42px;max-width:560px;margin:0 auto;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.price-card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--reject),var(--pass))}
.price-card .founding{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--reject);font-weight:700}
.price-card .num{font-family:var(--font-display);font-weight:700;font-size:4.2rem;line-height:1;margin:10px 0 2px}
.price-card .num small{font-size:1.1rem;font-weight:500;color:var(--ink-soft);font-family:var(--font-body)}
.price-card .deposit{color:var(--ink-soft);margin:14px 0 24px}
.price-card .deposit b{color:var(--ink)}
.price-card .btn{width:100%;justify-content:center;font-size:1.1rem}
.safety{font-family:var(--font-mono);font-size:.76rem;color:var(--ink-soft);margin-top:16px;line-height:1.6}
.badges{display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:center;margin-top:22px;padding-top:22px;border-top:1px solid var(--line);font-size:.82rem;color:var(--ink-soft)}
.badges span{display:inline-flex;align-items:center;gap:7px}
.scarcity{font-family:var(--font-mono);font-size:.8rem;color:var(--reject);text-align:center;margin:22px auto 0;max-width:46ch;letter-spacing:.02em}

/* ---- founder ---- */
.founder{max-width:680px;margin:48px auto 0;border-left:3px solid var(--ink);padding:6px 0 6px 26px}
.founder p{font-size:1.12rem;line-height:1.55;font-style:italic;color:var(--ink);margin:0 0 12px}
.founder .who{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;color:var(--ink-faint);font-style:normal}
.founder-by{display:flex;align-items:center;gap:14px;margin-top:18px}
.founder-photo{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--line);flex:0 0 auto}
.who-name{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.02rem;line-height:1.1}
.who-role{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.03em;color:var(--ink-faint);margin-top:3px}

/* ---- faq ---- */
.faq h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:26px}
.faq details{border-bottom:1px solid var(--line);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;padding:16px 40px 16px 0;position:relative;font-family:var(--font-display);font-weight:600;font-size:1.08rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--font-mono);font-size:1.5rem;color:var(--pass-deep);transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq details p{margin:0 0 18px;color:var(--ink-soft);max-width:66ch}

/* ---- footer ---- */
.site-footer{border-top:1px solid var(--line);background:var(--paper-raised);padding:44px 0;text-align:center;color:var(--ink-soft);font-size:.9rem}
.site-footer .brand-row{font-family:var(--font-display);font-weight:700;color:var(--ink);margin-bottom:6px}
.site-footer nav{margin:14px 0}
.site-footer nav a{color:var(--pass-deep);text-decoration:none;margin:0 12px}
.site-footer nav a:hover{text-decoration:underline}
.site-footer .fine{font-size:.78rem;color:var(--ink-faint);margin-top:12px}
.fill{background:rgba(245,200,66,.3);padding:0 5px;border-radius:3px}

/* ---- motion ---- */
.curve-stroke{stroke-dasharray:2000;stroke-dashoffset:2000;animation:draw 1.6s .2s ease forwards}
.region-fill,.tick,.tick-label,.you-are-here,.here-dot,.region-label{opacity:0;animation:fade .8s 1.1s ease forwards}
.here-dot{transform-box:fill-box;transform-origin:center}
.here-dot.pulse{animation:fade .8s 1.1s ease forwards, pulse 2.4s 1.9s ease-in-out infinite}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes fade{to{opacity:1}}
@keyframes pulse{0%,100%{filter:drop-shadow(0 0 0 rgba(229,72,77,0))}50%{filter:drop-shadow(0 0 7px rgba(229,72,77,.8))}}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .curve-stroke{stroke-dashoffset:0}
  .region-fill,.tick,.tick-label,.you-are-here,.here-dot,.region-label{opacity:1}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ---- focus ---- */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--pass);outline-offset:3px;border-radius:6px}

/* ---- responsive ---- */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .curve-fig{order:-1}
  .stack{grid-template-columns:1fr}
  .fromto{grid-template-columns:1fr;gap:14px}
  .fromto .conn{transform:rotate(90deg)}
  .track{grid-template-columns:1fr 1fr;gap:28px 18px}
  .track::before{display:none}
  section{padding:60px 0}
}
@media (max-width:480px){
  .price-card{padding:30px 22px}
  .price-card .num{font-size:3.4rem}
  .topbar .brand span{display:none}
}
