﻿/* ============================================================
   MechCompass V19: one design language.
   Principle: the design rules are the engineering conventions.
   Color is semantic and used nowhere else:
     red    = applied force
     green  = support reaction
     blue   = internal force / component
     gold   = dimension / geometry
   Accent teal is the brand; ink does the talking.
   ============================================================ */

:root{
  --paper:#f7f8fa;
  --surface:#ffffff;
  --ink:#202a33;
  --muted:#5f6d7a;
  --line:#d8dee7;
  --accent:#245f9d;
  --accent-dark:#17466f;
  --accent-soft:#eaf2fa;
  --blueprint:#eef4f8;
  --steel:#778493;
  --force:#b4233a;
  --reaction:#1f7a4d;
  --internal:#2563eb;
  --dimension:#a96f1a;
  --cyan:#2f7d5c;
  --lime:#6e7f8f;
  --electric:#245f9d;
  --navy:#24313f;
  --radius:8px;
  --shadow:0 1px 2px rgba(32,42,51,.04),0 10px 24px rgba(32,42,51,.055);
  --max:1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;background:
  linear-gradient(180deg,#fbfcfe 0%,#f7f8fa 42%,#f3f6f8 100%);
  color:var(--ink);line-height:1.65;font-size:1rem}
h1,h2,h3{line-height:1.15;letter-spacing:-.015em;margin:.3rem 0 .8rem}
h1{font-size:2.44rem;font-weight:760}
h2{font-size:1.95rem;font-weight:730}
h3{font-size:1.25rem;font-weight:700}
p{margin:.5rem 0 1rem}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.small,.muted{color:var(--muted);font-size:.92rem}
:focus-visible{outline:3px solid var(--dimension);outline-offset:2px}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--surface);padding:.7rem 1rem;z-index:99;border:2px solid var(--accent);border-radius:8px}

/* ---- Navigation (keeps .topnav/.menu-toggle/.navlinks so script.js works) */
.topnav{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 4vw;background:rgba(251,253,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid rgba(123,143,164,.22)}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:760;color:var(--ink);letter-spacing:-.01em}
.brand:hover{text-decoration:none}
.brand-mark{display:inline-grid;place-items:center;width:2.25rem;height:2.25rem;border-radius:50%;background:linear-gradient(135deg,#0f5f8c,#14a38b);color:#fff;font-weight:800;position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.28),0 10px 24px rgba(15,95,140,.18)}
.brand-mark svg{display:none}
.brand-mark::before{content:"";width:1.28rem;height:1.28rem;border-radius:50%;background:repeating-conic-gradient(#fff 0 11deg,transparent 11deg 22deg);box-shadow:0 0 0 .12rem rgba(255,255,255,.55)}
.brand-mark::after{content:"";position:absolute;width:.52rem;height:.52rem;border-radius:50%;background:var(--accent);box-shadow:inset 0 0 0 1px rgba(255,255,255,.35)}
.navlinks{display:flex;gap:.2rem;align-items:center;flex-wrap:wrap}
.navlinks a{font-weight:600;color:var(--ink);font-size:.93rem;padding:.45rem .7rem;border-radius:8px}
.navlinks a:hover{background:var(--surface);text-decoration:none;box-shadow:inset 0 0 0 1px var(--line)}
.navlinks a.active{background:transparent;color:var(--ink);box-shadow:none}
.nav-more{position:relative}
.nav-more summary{list-style:none;cursor:pointer;font-weight:600;color:var(--ink);font-size:.93rem;padding:.45rem .7rem;border-radius:8px}
.nav-more summary::-webkit-details-marker{display:none}
.nav-more summary::after{content:"";display:inline-block;width:.42rem;height:.42rem;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-left:.42rem;margin-bottom:.18rem}
.nav-more[open] summary,.nav-more summary:hover{background:var(--surface);box-shadow:inset 0 0 0 1px var(--line)}
.nav-more-menu{position:absolute;right:0;top:calc(100% + .45rem);z-index:40;display:grid;gap:.1rem;min-width:12rem;padding:.35rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}
.nav-more-menu a{display:block;white-space:nowrap}
.menu-toggle{display:none;background:var(--surface);border:1px solid var(--line);border-radius:8px;font-size:1.15rem;padding:.4rem .6rem;cursor:pointer}

/* ---- Buttons */
.btn,.cta-small{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--accent);color:#fff!important;border-radius:8px;padding:.66rem 1.05rem;font-weight:680;font-size:.95rem;text-decoration:none!important;border:1px solid var(--accent)}
.btn:hover,.cta-small:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.navlinks a.cta-small:hover,.navlinks a.cta-small:focus,.navlinks a.cta-small:active,.navlinks a.cta-small.active{background:var(--accent-dark);border-color:var(--accent-dark);color:#fff!important;box-shadow:none}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--surface);color:var(--accent)!important;border:1px solid var(--line);border-radius:8px;padding:.66rem 1.05rem;font-weight:680;font-size:.95rem;text-decoration:none!important}
.btn-outline:hover{border-color:var(--accent)}


.actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.1rem}

/* ---- Guided, visual homepage */















/* ---- Roadmap and lesson-template views */








.lesson-template{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}
.lesson-template>div{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:.85rem;box-shadow:var(--shadow)}
.lesson-template strong{display:block;color:var(--ink)}
.lesson-template span{display:block;color:var(--muted);margin-top:.2rem}

/* ---- Layout */
.wrap{max-width:var(--max);margin:0 auto;padding:0 4vw;min-width:0}
.hero{padding:3.6rem 0 1.6rem}
.hero .lead{font-size:1.22rem;color:var(--muted);max-width:46rem;margin-top:.4rem}
.kicker{font-size:.8rem;font-weight:760;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 .4rem}
.breadcrumbs{font-size:.88rem;color:var(--muted);padding:1.1rem 0 0}
.breadcrumbs a{color:var(--muted)}
section.block{padding:2.1rem 0 1.7rem;min-width:0}
.sec-head{display:flex;align-items:baseline;gap:.9rem;border-top:1px solid rgba(23,32,42,.2);padding-top:1.3rem;margin-bottom:1.05rem}
.sec-num{font-weight:800;font-size:.95rem;color:var(--accent);font-variant-numeric:tabular-nums}
.sec-head h2{font-size:1.5rem;margin:0}
.sec-foot{margin:1.4rem 0 0}
main [id]{scroll-margin-top:124px}
.lesson-rail{position:sticky;top:64px;z-index:20;display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 1.6rem;padding:.5rem .15rem;background:rgba(251,253,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.lesson-rail a{font-size:.85rem;font-weight:620;color:var(--muted);text-decoration:none;padding:.32rem .72rem;border-radius:999px;white-space:nowrap}
.lesson-rail a:hover,.lesson-rail a:focus{color:var(--ink);background:rgba(123,143,164,.14)}
@media(max-width:640px){.lesson-rail{position:static;overflow-x:auto}}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}

/* ---- Cards and panels */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem 1.4rem;box-shadow:var(--shadow);min-width:0}
.card h3{margin-top:0}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1.1rem;min-width:0}
.statement{font-size:1.35rem;font-weight:730;letter-spacing:-.015em;line-height:1.3;margin:.2rem 0 .8rem}
.equation{display:inline-block;max-width:100%;overflow-x:auto;vertical-align:middle;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.5rem .85rem;font-family:"Cambria Math","STIX Two Math",Cambria,"Times New Roman",Georgia,serif;font-style:italic;font-size:1.18rem;line-height:1.3;margin:.25rem .35rem .25rem 0;font-variant-numeric:tabular-nums;white-space:nowrap}
.equation sup,.equation sub{font-style:normal}
sup,sub{line-height:0}
.note-pair{display:grid;gap:.6rem;margin-top:1rem}
.note-pair div{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.7rem .9rem;font-size:.95rem;color:var(--muted)}
.note-pair strong{color:var(--ink)}

/* ---- Figures: the heart of V19 */
figure.fig{margin:1.2rem 0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem 1rem .6rem;min-width:0;overflow:hidden}
figure.fig svg{width:100%;height:auto;display:block;overflow:hidden}
figure.fig figcaption{font-size:.9rem;color:var(--muted);border-top:1px solid var(--line);margin-top:.6rem;padding-top:.6rem}
figure.fig figcaption strong{color:var(--ink)}
.fig-legend{display:flex;gap:1.1rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted);margin:.4rem 0 0}
.fig-legend span{display:inline-flex;align-items:center;gap:.4rem}
.swatch{width:1.05rem;height:.3rem;border-radius:2px;display:inline-block}
.swatch.force{background:var(--force)}
.swatch.reaction{background:var(--reaction)}
.swatch.internal{background:var(--internal)}
.swatch.dimension{background:var(--dimension)}
/* SVG semantic strokes */
.f-body{fill:var(--surface);stroke:var(--ink);stroke-width:3}
.f-solid{fill:var(--ink)}
.f-line{stroke:var(--ink);stroke-width:3;stroke-linecap:round;fill:none}
.f-thin{stroke:var(--muted);stroke-width:1.5;stroke-linecap:round;fill:none}
.f-force{stroke:var(--force);stroke-width:4;stroke-linecap:round;fill:none}
.f-react{stroke:var(--reaction);stroke-width:4;stroke-linecap:round;fill:none}
.f-int{stroke:var(--internal);stroke-width:3.5;stroke-linecap:round;fill:none}
.f-dim{stroke:var(--dimension);stroke-width:1.6;stroke-linecap:round;fill:none}
.f-ext{stroke:var(--dimension);stroke-width:1;stroke-dasharray:3 4;fill:none}
figure.fig text{font:600 16px Inter,Arial,sans-serif;fill:var(--ink)}
figure.fig text.t-force{fill:var(--force)}
figure.fig text.t-react{fill:var(--reaction)}
figure.fig text.t-int{fill:var(--internal)}
figure.fig text.t-dim{fill:var(--dimension);font-size:14px}
figure.fig text.t-muted{fill:var(--muted);font-size:14px;font-weight:500}

/* ---- Teaching components */
ul.checklist{list-style:none;margin:.7rem 0 0;padding:0;display:grid;gap:.5rem}
ul.checklist li{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.65rem .9rem .65rem 2.4rem;position:relative}
ul.checklist li::before{content:"";position:absolute;left:.85rem;top:1.05rem;width:.55rem;height:.55rem;border:2px solid var(--reaction);border-radius:3px}
.ready-enhanced .routing{display:none}
.ready-enhanced .ready-prompt{margin:.8rem 0 .55rem;color:var(--muted);font-size:.95rem}
.ready-enhanced ul.checklist{margin:.55rem 0 0}
.ready-enhanced ul.checklist li{padding:0;background:transparent;border:0}
.ready-enhanced ul.checklist li::before{display:none}
.ready-choice{display:flex;align-items:flex-start;gap:.7rem;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.72rem .85rem;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.ready-choice:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.ready-choice input{width:1.05rem;height:1.05rem;margin:.22rem 0 0;accent-color:var(--accent);flex:0 0 auto}
.ready-choice span{color:var(--ink)}
.ready-choice:has(input:checked){background:var(--accent-soft);border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.ready-result{display:grid;gap:.25rem;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:0 8px 8px 0;padding:1rem 1.05rem;margin-top:1rem;color:var(--muted);box-shadow:var(--shadow)}
.ready-result-label{font-size:.74rem;font-weight:760;letter-spacing:.07em;text-transform:uppercase;color:var(--accent)}
.ready-result strong{color:var(--ink);font-size:1.05rem}
.ready-result p{margin:.1rem 0 0}
.routing{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:1rem}
.routing div{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:8px;padding:.8rem .95rem;font-size:.93rem;color:var(--muted)}
.routing strong{display:block;color:var(--ink);margin-bottom:.15rem}
ol.steps{list-style:none;counter-reset:st;margin:1rem 0 0;padding:0;display:grid;gap:.5rem}
ol.steps li{counter-increment:st;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.7rem .95rem .7rem 2.9rem;position:relative;color:var(--muted);min-width:0;overflow:hidden;overflow-wrap:anywhere}
ol.steps li::before{content:counter(st);position:absolute;left:.8rem;top:.72rem;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:.78rem;font-weight:740}
ol.steps strong{display:block;color:var(--ink)}
ol.steps .equation{display:block;margin:.45rem 0;max-width:100%}
.method{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.method div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.9rem 1rem}
.method span{display:inline-grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:50%;background:var(--accent);color:#fff;font-weight:740;font-size:.85rem;margin-bottom:.45rem}
.method strong{display:block}
.method p{margin:.25rem 0 0;font-size:.9rem;color:var(--muted)}
.table-wrap{overflow-x:auto;max-width:100%;min-width:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
table.doc{width:100%;border-collapse:collapse;min-width:620px}
table.doc th{background:var(--paper);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:1px solid var(--line);padding:.75rem .9rem;text-align:left}
table.doc td{border-bottom:1px solid var(--line);padding:.75rem .9rem;color:var(--muted);vertical-align:top;font-size:.95rem}
table.doc td:first-child{color:var(--ink);font-weight:600}
table.doc tr:last-child td{border-bottom:none}
details.reveal{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.65rem .95rem;margin:.5rem 0}
details.reveal summary{cursor:pointer;font-weight:680;color:var(--accent)}
details.reveal p{margin:.55rem 0 0;color:var(--muted)}
.level{display:inline-flex;background:var(--paper);border:1px solid var(--line);color:var(--accent);border-radius:6px;padding:.22rem .6rem;font-size:.74rem;font-weight:760;letter-spacing:.07em;text-transform:uppercase;margin:1rem 0 .3rem}
.review-row{display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem;margin-top:1rem}
.review-row div{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.75rem .85rem;font-size:.9rem;color:var(--muted)}
.review-row strong{display:block;color:var(--ink);margin-bottom:.15rem}
.do{border-left:4px solid var(--reaction);background:var(--paper);border-radius:0 8px 8px 0;padding:.6rem .85rem;margin:.5rem 0;color:var(--muted)}
.dont{border-left:4px solid var(--force);background:var(--paper);border-radius:0 8px 8px 0;padding:.6rem .85rem;margin:.5rem 0;color:var(--muted)}
.warn-card{border-left:4px solid var(--force)}
.ok-card{border-left:4px solid var(--reaction)}
.progress{display:grid;grid-template-columns:repeat(11,1fr);gap:.35rem;margin-top:1.2rem;max-width:30rem}

.progress.p16{grid-template-columns:repeat(16,1fr);max-width:36rem}


.progress.p19{grid-template-columns:repeat(19,1fr);max-width:42rem}
.course-trail{border-left:3px solid var(--accent);background:var(--accent-soft);padding:.6rem .85rem;border-radius:0 8px 8px 0;font-size:.96rem;color:var(--ink);margin:1rem 0 .2rem;max-width:46rem}
.course-trail strong{color:var(--accent-dark)}
.progress span{height:5px;border-radius:99px;background:var(--line)}
.progress span.done{background:var(--accent)}
.progress span.now{background:var(--dimension)}
.result{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:0 8px 8px 0;padding:.8rem 1rem;margin-top:.8rem}

/* Roadmap hero */
.roadmap-hero{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:2rem;align-items:center;padding-bottom:2.2rem}
.roadmap-hero-copy{max-width:48rem}
.readiness-card{background:linear-gradient(180deg,#fff 0%,#f6f9fc 100%);border:1px solid rgba(123,143,164,.24);border-radius:14px;padding:1.15rem 1.2rem;box-shadow:0 18px 42px rgba(32,42,51,.08)}
.readiness-card h2{font-size:1.35rem;margin:.1rem 0 .3rem}
.readiness-card p:not(.kicker){color:var(--muted);font-size:.93rem;line-height:1.45;margin:0 0 .8rem}
.readiness-card ul.checklist{gap:.45rem;margin-top:.6rem}
.readiness-card ul.checklist li{background:#fff;padding:.55rem .75rem .55rem 2.1rem;font-size:.92rem}
.readiness-card ul.checklist li::before{left:.75rem;top:.9rem;width:.5rem;height:.5rem}
@media(max-width:760px){.roadmap-hero{grid-template-columns:1fr;gap:1.2rem}.readiness-card{margin-top:.3rem}}

/* ---- Homepage components */






.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.card .num-tag{font-size:.8rem;color:var(--muted);font-weight:700;font-variant-numeric:tabular-nums}
.card .go{margin-top:.6rem;display:inline-block;font-weight:680}
.track-outcome{border-top:1px solid var(--line);margin:.9rem 0 0;padding-top:.75rem;color:var(--muted);font-size:.93rem}
.track-outcome strong{color:var(--ink)}

/* ---- Module nav and footer */
.module-nav{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid rgba(23,32,42,.16);padding:1.1rem 0 0;margin-top:1rem}
footer{margin-top:3rem;padding:2.2rem 4vw;background:#121b25;color:#fff;display:grid;grid-template-columns:minmax(220px,1fr) minmax(0,2fr);gap:2rem;align-items:start}
footer p{color:#c9cdd1;max-width:34rem}
footer a{color:#fff;margin-right:0}
.footer-brand strong{display:block;margin-bottom:.35rem}
.beta-note{font-size:.86rem;line-height:1.45}
.footer-columns{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:1.2rem 1.6rem}
.footer-column strong{display:block;margin-bottom:.45rem;color:var(--ink)}
.footer-column a{display:block;margin:.22rem 0;font-size:.92rem}

/* ---- Responsive */
@media(max-width:980px){
  .grid-2,.grid-3,.card-grid{grid-template-columns:1fr}
  .lesson-template{grid-template-columns:1fr}
  
  .method{grid-template-columns:1fr 1fr}
  .routing{grid-template-columns:1fr}
  .review-row{grid-template-columns:1fr 1fr}
  
  h1{font-size:2rem}
}
@media(max-width:680px){
  .menu-toggle{display:block}
  .navlinks{display:none;width:100%;flex-direction:column;align-items:stretch}
  .topnav.open .navlinks{display:flex}
  .topnav{flex-wrap:wrap}
  .navlinks a{width:100%}
  .nav-more{width:100%}
  .nav-more summary{width:100%}
  .nav-more-menu{position:static;min-width:0;margin:.25rem 0 .35rem;padding:.25rem;border-radius:8px;box-shadow:none}
  .method,.review-row{grid-template-columns:1fr}
  .actions .btn,.actions .btn-outline{width:100%}
  footer{grid-template-columns:1fr}
  .footer-columns{grid-template-columns:1fr 1fr}
}

/* ---- V19 compatibility for legacy shell pages ---- */
body > main > .hero,main > .hero{max-width:var(--max);margin:0 auto;padding:3.6rem 4vw 1.8rem}
.lead{font-size:1.18rem;color:var(--muted);max-width:48rem}

.hero-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;background:var(--accent);color:#fff!important;border-radius:8px;padding:.66rem 1.05rem;font-weight:680;font-size:.95rem;text-decoration:none!important;border:1px solid var(--accent)}
.button:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.button.secondary{background:var(--surface);color:var(--accent)!important;border:1px solid var(--line)}
.button.secondary:hover{border-color:var(--accent)}
.section{max-width:var(--max);margin:0 auto;padding:1.6rem 4vw}
.section-head{display:flex;justify-content:space-between;gap:1rem;align-items:end;border-top:1px solid rgba(23,32,42,.16);padding-top:1rem;margin-bottom:1rem}
.content-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.content-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}


.panel,.module-card,.career-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow)}
.module-card{display:flex;flex-direction:column;gap:.45rem}
.module-card h3,.career-card h3{margin-top:0}

.pill-row{display:flex;gap:.45rem;flex-wrap:wrap;margin:.5rem 0 1rem}
.chip-list{list-style:none;padding:0}
.chip-list li{display:flex;margin:0}
.pill,.badge{display:inline-flex;align-items:center;border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:.28rem .65rem;font-size:.83rem;font-weight:650;color:var(--accent)}

/* ---- Product-led homepage */
body.product-home .wrap{max-width:1180px}
.product-hero{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(340px,.96fr);gap:1.35rem;align-items:center;padding:3.8rem 0 1.5rem}
.product-copy h1{font-size:clamp(3rem,6.1vw,5.75rem);line-height:.94;letter-spacing:-.06em;margin:.55rem 0 .85rem;max-width:820px}
.product-copy h1::after{content:"";display:block;width:min(12rem,38vw);height:.38rem;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--lime));margin:.75rem 0 0}
.product-copy .lead{font-size:clamp(1.08rem,1.55vw,1.36rem);line-height:1.38;max-width:720px}













.product-block{scroll-margin-top:5rem}












.learning-dashboard{background:linear-gradient(145deg,#132337,#182d40);color:#fff;border-radius:18px;padding:1rem;box-shadow:0 24px 64px rgba(19,35,55,.24)}
.study-panel{background:linear-gradient(145deg,#ffffff,#eef8fb);color:var(--ink);border:1px solid rgba(123,143,164,.24);box-shadow:0 18px 44px rgba(31,47,68,.08)}
.dash-top{display:flex;justify-content:space-between;gap:1rem;align-items:start;margin-bottom:.8rem}
.dash-top h2{margin:.1rem 0 0;color:#fff}
.study-panel .dash-top h2{color:var(--ink)}
.dash-kicker{color:#9ee8ff;font-size:.78rem;font-weight:760;text-transform:uppercase;letter-spacing:.12em}
.study-panel .dash-kicker{color:var(--accent)}

.next-lesson{background:#fff;color:var(--ink);border-radius:14px;padding:1rem;margin-bottom:.9rem}
.next-lesson .level{margin:0 0 .55rem}
.next-lesson h3{font-size:1.35rem;letter-spacing:-.025em;margin:.35rem 0}
.next-lesson p{color:var(--muted);margin:.3rem 0 .65rem}






.study-steps{display:grid;gap:.55rem}
.study-steps div{display:grid;grid-template-columns:7rem 1fr;gap:.7rem;align-items:start;background:rgba(255,255,255,.72);border:1px solid rgba(123,143,164,.22);border-radius:10px;padding:.72rem .8rem}
.study-steps strong{color:var(--accent)}
.study-steps span{color:var(--muted);font-size:.9rem}
.product-block .sec-head h2{font-size:clamp(1.8rem,3.5vw,3.2rem);line-height:1.02;letter-spacing:-.04em;max-width:780px}

.choice-card,.area-tiles a{background:rgba(255,255,255,.82);border:1px solid rgba(123,143,164,.22);border-radius:12px;padding:1rem;box-shadow:0 10px 26px rgba(31,47,68,.055)}





.choice-card h3{letter-spacing:-.025em;margin:.75rem 0 .35rem}






.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(12.5rem,1fr));gap:1rem}
.choice-card{min-height:230px;display:flex;flex-direction:column}
.choice-card .go{margin-top:auto}
.area-tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem}
.area-tiles a{display:grid;gap:.25rem;color:var(--ink)}
.area-tiles a:hover,.choice-card:hover{transform:translateY(-2px);text-decoration:none;transition:.18s ease;box-shadow:0 14px 34px rgba(26,28,30,.10)}
.area-tiles span{color:var(--muted);font-size:.9rem}
.assessment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.assessment-card,.route-card{background:rgba(255,255,255,.84);border:1px solid rgba(123,143,164,.22);border-radius:var(--radius);padding:1.1rem 1.25rem;box-shadow:0 10px 26px rgba(31,47,68,.055)}
.assessment-card h3,.route-card h3{margin-top:.25rem}
.assessment-card-enhanced ul.checklist li{padding:0;background:transparent;border:0}
.assessment-card-enhanced ul.checklist li::before{display:none}
.assessment-choice{display:flex;align-items:flex-start;gap:.7rem;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:.72rem .85rem;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.assessment-choice:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.assessment-choice input{width:1.05rem;height:1.05rem;margin:.22rem 0 0;accent-color:var(--accent);flex:0 0 auto}
.assessment-choice span{color:var(--ink)}
.assessment-choice:has(input:checked){background:var(--accent-soft);border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.assessment-result{background:#fff;border:1px solid var(--line);border-left:5px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow);padding:1.15rem 1.25rem;margin-top:1rem}
.assessment-result-label{display:block;color:var(--accent);font-size:.74rem;font-weight:760;letter-spacing:.08em;text-transform:uppercase}
.assessment-result h3{margin:.25rem 0 .35rem}
.assessment-result p{margin:.25rem 0;color:var(--muted)}
.assessment-result .btn{margin-top:.85rem}
.route-result-card{background:linear-gradient(180deg,#fff 0%,#f6f9fc 100%);border:1px solid var(--line);border-left:5px solid var(--accent);border-radius:0 12px 12px 0;box-shadow:var(--shadow);padding:1.2rem 1.35rem}
.route-result-card h3{margin:.15rem 0 .45rem}
.result-columns{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0}
.result-columns h4{margin:.1rem 0 .35rem;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.result-columns ul{margin:.2rem 0 0;padding-left:1.2rem}
.result-action{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:1rem;margin-top:.2rem}
.result-action div{flex:1 1 16rem}
.result-action strong,.result-action span{display:block}
.result-action span{color:var(--muted);font-size:.9rem}
.first-lesson{background:var(--accent-soft);border:1px solid var(--line);border-radius:8px;padding:.75rem .9rem}
.route-grid{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:1rem;align-items:stretch}
.route-card{display:flex;flex-direction:column}
.route-card .btn,.route-card .btn-outline{margin-top:auto;width:max-content}
.primary-route{border-left:5px solid var(--accent)}
.next-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}
.next-steps div{background:rgba(255,255,255,.72);border:1px solid rgba(123,143,164,.22);border-left:4px solid var(--accent);border-radius:10px;padding:.85rem .95rem}
.next-steps strong{display:block}
.next-steps span{display:block;color:var(--muted);font-size:.9rem;margin-top:.2rem}
.final-cta{padding-top:2rem;padding-bottom:0}
.final-cta-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:1rem;align-items:center;background:linear-gradient(135deg,#ffffff 0%,#eef5fb 100%)}
.final-cta-card h2{margin:.1rem 0 .35rem}
.final-cta-card p{margin:.2rem 0;color:var(--muted)}
.final-cta-card .actions{margin:0}
@media(max-width:980px){
  .product-hero{grid-template-columns:1fr}
  .choice-grid,.area-tiles,.assessment-grid,.route-grid,.next-steps{grid-template-columns:1fr 1fr}
  
}
@media(max-width:680px){
  .product-hero{padding-top:2.2rem;gap:1rem}
  .product-copy h1{font-size:clamp(2.25rem,11.5vw,3.25rem);line-height:.96}
  
  .choice-grid,.area-tiles,.assessment-grid,.route-grid,.next-steps{grid-template-columns:1fr}
  
  
  .learning-dashboard{border-radius:14px}
  .study-steps div{grid-template-columns:1fr;gap:.15rem}
  .route-card .btn,.route-card .btn-outline{width:100%}
  .result-columns{grid-template-columns:1fr}
  .final-cta-card{grid-template-columns:1fr}
  .final-cta-card .actions{margin-top:.5rem}
}
.muted-pill{color:var(--muted);background:var(--surface)}




.empty-state{display:none;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;color:var(--muted)}





.school-band{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);max-width:none}.school-band .inner{max-width:var(--max);margin:0 auto}
.learning-cycle{display:grid;grid-template-columns:repeat(7,1fr);gap:.55rem;margin-top:1rem}.learning-cycle div{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:.7rem}.learning-cycle strong,.learning-cycle span{display:block}.learning-cycle span{color:var(--muted);font-size:.82rem}
.checklist{margin:.7rem 0;padding-left:1.2rem}.checklist li{margin:.35rem 0}
@media(max-width:980px){.content-grid,.content-grid.two{grid-template-columns:1fr}.learning-cycle{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){body > main > .hero,main > .hero,.section{padding-left:4vw;padding-right:4vw}.learning-cycle{grid-template-columns:1fr}.section-head{display:block}}

/* ---- Calm STEM learning workspace
   Research direction: prioritize clarity, progress visibility, recognition over recall,
   and a focused visual field over promotional energy.
*/
:root{
  --paper:#f7f8fa;
  --surface:#ffffff;
  --ink:#202a33;
  --muted:#5f6d7a;
  --line:#d8dee7;
  --accent:#245f9d;
  --accent-dark:#17466f;
  --accent-soft:#eaf2fa;
  --blueprint:#eef4f8;
  --steel:#778493;
  --cyan:#2f7d5c;
  --lime:#6e7f8f;
  --electric:#245f9d;
  --navy:#24313f;
  --radius:8px;
  --shadow:0 1px 2px rgba(32,42,51,.04),0 10px 24px rgba(32,42,51,.055);
}

body{
  background:linear-gradient(180deg,#fbfcfe 0%,#f7f8fa 42%,#f3f6f8 100%);
  color:var(--ink);
}

h1,h2,h3{letter-spacing:-.01em}

.topnav{
  background:rgba(251,252,254,.94);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(10px);
}

.brand-mark{
  border-radius:9px;
  background:var(--accent);
  box-shadow:none;
}

.brand-mark::before{
  width:1.1rem;
  height:1.1rem;
  background:none;
  border:2px solid rgba(255,255,255,.94);
  border-radius:4px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.28);
  transform:rotate(45deg);
}

.brand-mark::after{
  width:.34rem;
  height:.34rem;
  background:#fff;
}

.btn,.cta-small{
  background:var(--accent);
  border-color:var(--accent);
  box-shadow:none;
}

.btn:hover,.cta-small:hover,.navlinks a.cta-small:hover,.navlinks a.cta-small:focus,.navlinks a.cta-small:active,.navlinks a.cta-small.active{
  background:var(--accent-dark);
  border-color:var(--accent-dark);
}

.btn-outline,.button.secondary{
  border-color:var(--line);
  background:#fff;
  color:var(--accent)!important;
}

.kicker{
  color:var(--accent);
  letter-spacing:.1em;
}

body.product-home .wrap{max-width:1120px}

.product-hero{
  grid-template-columns:minmax(0,1fr) minmax(330px,.82fr);
  gap:1.6rem;
  align-items:start;
  padding:2.35rem 0 1.3rem;
}

.product-copy h1{
  font-size:clamp(2.2rem,4.2vw,3.65rem);
  line-height:1.05;
  letter-spacing:-.025em;
  max-width:680px;
}

.product-copy h1::after{
  width:min(9rem,32vw);
  height:.22rem;
  background:var(--accent);
  opacity:.9;
  margin-top:.85rem;
}

.product-copy .lead{
  font-size:clamp(1.05rem,1.2vw,1.18rem);
  line-height:1.55;
  max-width:680px;
}









.study-panel,.choice-card,.area-tiles a,.assessment-card,.route-card,.card{
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.study-panel{
  background:#fff;
  border-radius:12px;
  padding:1rem;
}

.next-lesson{
  border:1px solid var(--line);
  border-radius:10px;
  background:#fbfcfe;
}

.study-steps div{
  background:#fff;
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  border-radius:8px;
}

.study-steps strong{
  color:var(--ink);
}



































.product-block .sec-head h2{
  font-size:clamp(1.55rem,2.6vw,2.45rem);
  line-height:1.08;
  letter-spacing:-.025em;
}

.choice-card,.area-tiles a{
  border-radius:8px;
}









.next-steps div{
  background:#fbfcfe;
  border:1px solid var(--line);
  border-left:3px solid var(--accent);
  border-radius:8px;
}

.area-tiles a:hover,.choice-card:hover{
  transform:none;
  box-shadow:0 1px 2px rgba(32,42,51,.04),0 10px 24px rgba(32,42,51,.07);
}

footer{
  background:#edf2f6;
  color:var(--ink);
  border-top:1px solid var(--line);
}

footer p{
  color:var(--muted);
}

footer a{
  color:var(--accent);
}

@media(max-width:680px){
  .product-hero{
    grid-template-columns:1fr;
    padding-top:2rem;
  }
  .product-copy h1{font-size:clamp(2.05rem,9.2vw,2.85rem)}
  
}

/* ---- Homepage launch polish after review */
body.product-home .product-hero{
  align-items:center;
  gap:clamp(2rem,5vw,4.25rem);
  padding:clamp(3rem,6vw,4.8rem) 0 clamp(2.6rem,5vw,4rem);
}

body.product-home .product-copy h1{
  max-width:670px;
  font-size:clamp(2.55rem,5vw,4.6rem);
  line-height:1.02;
  letter-spacing:-.035em;
}

body.product-home .product-copy .lead{
  max-width:590px;
  line-height:1.65;
}

body.product-home .study-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 18px 44px rgba(31,47,68,.06);
  padding:1.05rem;
}

body.product-home .dash-top{
  margin-bottom:.75rem;
}

body.product-home .dash-top h2{
  font-size:1.55rem;
  line-height:1.08;
}

body.product-home .next-lesson{
  background:#fbfcfe;
  border-radius:10px;
  margin-bottom:.7rem;
  padding:.9rem;
}

body.product-home .next-lesson h3{
  font-size:1.18rem;
}

body.product-home .study-steps{
  display:grid;
  gap:0;
  border-top:1px solid var(--line);
}

body.product-home .study-steps div{
  display:grid;
  grid-template-columns:5.2rem 1fr;
  gap:.65rem;
  padding:.62rem 0;
  border:0;
  border-bottom:1px solid var(--line);
  border-radius:0;
  background:transparent;
}

body.product-home .study-steps div:last-child{
  border-bottom:0;
}

body.product-home .study-steps strong{
  color:var(--ink);
}

body.product-home .study-steps span{
  color:var(--muted);
}

body.product-home .sec-head{
  display:block;
  border-top:1px solid var(--line);
  padding-top:1.45rem;
  margin-bottom:1.35rem;
}

body.product-home .sec-num{
  display:none;
}

body.product-home section.block{
  padding:clamp(2.4rem,5vw,4rem) 0;
}

body.product-home .choice-grid,body.product-home .card-grid{
  gap:1.05rem;
}

body.product-home .choice-card,body.product-home .card{
  min-height:0;
  padding:1.15rem;
  border-radius:12px;
  box-shadow:0 1px 2px rgba(31,47,68,.035);
}

body.product-home .choice-card h3,body.product-home .card h3{
  margin-top:.35rem;
}

body.product-home .area-tiles{
  gap:1rem;
}

body.product-home .area-tiles a{
  min-height:112px;
  align-content:start;
  padding:1rem;
  border-radius:12px;
  box-shadow:0 1px 2px rgba(31,47,68,.035);
}

body.product-home .go{
  font-weight:680;
}
body.product-home .quiet-go{
  color:var(--muted);
  font-weight:650;
}

body.product-home .sec-foot{
  margin-top:1.1rem;
}

@media(max-width:680px){
  body.product-home .product-hero{
    gap:1.35rem;
    padding:2.05rem 0 2.4rem;
  }

  body.product-home .product-copy h1{
    font-size:clamp(2rem,9.5vw,2.85rem);
    line-height:1.05;
  }

  body.product-home .product-copy h1::after{
    width:7rem;
    height:.16rem;
    margin-top:.65rem;
  }

  body.product-home .product-copy .lead{
    font-size:1rem;
    line-height:1.58;
  }

  body.product-home .actions{
    margin-top:1rem;
  }

  body.product-home .study-panel{
    padding:.9rem;
    border-radius:12px;
    box-shadow:none;
  }

  body.product-home .dash-top h2{
    font-size:1.32rem;
  }

  body.product-home .next-lesson{
    padding:.8rem;
  }

  body.product-home .next-lesson p,body.product-home .study-steps span{
    display:none;
  }

  body.product-home .study-steps div{
    grid-template-columns:1fr;
    padding:.48rem 0;
  }

  body.product-home section.block{
    padding:2.25rem 0;
  }

  body.product-home .choice-card,body.product-home .card,body.product-home .area-tiles a{
    padding:1rem;
  }
}

/* ---- Unified brand mark: same free-body diagram in header and favicon */
.brand-mark{
  border-radius:10px;
  background:var(--accent);
  box-shadow:none;
}

.brand-mark svg{
  display:block;
  width:1.35rem;
  height:1.35rem;
}

.brand-mark::before,.brand-mark::after{
  content:none;
}







































































/* Careers coach — interactive "choose what you enjoy" router */
.coach-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(184px,1fr));gap:12px;margin:20px 0 0}
.coach-opt{-webkit-appearance:none;appearance:none;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;cursor:pointer;display:flex;flex-direction:column;gap:4px;font:inherit;color:inherit;transition:border-color .15s,box-shadow .15s,background .15s}
.coach-opt:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.coach-opt:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.coach-opt strong{color:var(--ink);font-size:1rem}
.coach-opt span{color:var(--muted);font-size:.84rem;line-height:1.35}
.coach-opt[aria-pressed="true"]{border-color:var(--accent);background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--accent)}
.coach-hint{color:var(--muted);font-size:.92rem;margin:14px 0 0}
.group-head{margin:1.6rem 0 .2rem;font-size:1.06rem}
.coach-freedom{color:var(--muted);font-size:.9rem;font-style:italic;margin:18px 0 0;padding-top:14px;border-top:1px solid var(--line)}
.coach-result{margin-top:22px;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow)}
.coach-result h3{margin:0 0 4px;font-size:1.3rem}
.coach-track-sub{color:var(--muted);margin:0 0 4px}
.coach-field{margin:16px 0 0}
.coach-field>strong{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:7px}
.coach-field>p{margin:0}
.coach-callouts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.coach-callout{border-radius:var(--radius);padding:12px 14px;font-size:.92rem;line-height:1.45}
.coach-callout.avoid{background:#fdf0f1;border:1px solid #f0c9ce}
.coach-callout.start{background:#eef7f1;border:1px solid #c5e3d1}
.coach-callout strong{display:block;margin-bottom:4px;color:var(--ink)}
.career-filter-bar{display:flex;flex-wrap:wrap;gap:.45rem;margin:1rem 0 .35rem}
.career-filter-bar button{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:999px;padding:.42rem .75rem;font:inherit;font-size:.9rem;font-weight:650;cursor:pointer}
.career-filter-bar button:hover{border-color:var(--accent)}
.career-filter-bar button.active,.career-filter-bar button[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff}
.career-card[hidden]{display:none!important}
@media(max-width:640px){.coach-callouts{grid-template-columns:1fr}}

/* ---- Roadmap dependency flow (replaces the 6x5 matrix) */
.flow{display:grid;gap:0;margin:1rem 0 0}
.flow-layer{padding:1.5rem 0;border-top:1px solid var(--line);position:relative}
.flow-layer:first-child{border-top:0;padding-top:.4rem}
.flow-head{display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap;margin-bottom:1rem}
.flow-stage{font-size:.7rem;font-weight:760;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--accent);border-radius:999px;padding:.28rem .65rem;white-space:nowrap}
.flow-head h3{margin:0;font-size:1.2rem;letter-spacing:-.01em}
.flow-head p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.5;flex-basis:100%}
.flow-nodes{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.7rem}
.flow-node{display:flex;flex-direction:column;gap:.35rem;background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:.85rem .95rem;color:var(--ink);box-shadow:0 1px 2px rgba(32,42,51,.035);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.flow-node:hover{text-decoration:none;transform:translateY(-2px);border-color:#c5d6cc;box-shadow:0 12px 28px rgba(36,49,63,.08)}
.flow-node strong{font-size:.98rem;line-height:1.22}
.needs{font-size:.82rem;color:var(--muted);line-height:1.4}
.needs b{color:var(--ink);font-weight:600}
.flow-node.nav-node{border-left-style:dashed;justify-content:center}
.flow-node.nav-node strong{color:var(--accent)}
/* per-layer semantic color */
.l-found .flow-node{border-left-color:var(--steel)} .l-found .flow-stage{background:var(--steel)}
.l-gate .flow-node{border-left-color:var(--reaction)} .l-gate .flow-stage{background:var(--reaction)}
.l-core .flow-node{border-left-color:var(--internal)} .l-core .flow-stage{background:var(--internal)}
.l-integrate .flow-node{border-left-color:var(--dimension)} .l-integrate .flow-stage{background:var(--dimension)}
.l-spec .flow-node{border-left-color:var(--accent-dark)} .l-spec .flow-stage{background:var(--accent-dark)}
@media(max-width:680px){.flow-nodes{grid-template-columns:1fr}.flow-layer{padding:1.2rem 0}}

/* ---- Curriculum: numbered core path with needs chips */
.path-core{list-style:none;counter-reset:pc;margin:1rem 0 0;padding:0;display:grid;gap:.6rem}
.path-core li{counter-increment:pc;display:grid;grid-template-columns:2.2rem 1fr;gap:.7rem;align-items:stretch}
.path-core li::before{content:counter(pc);display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-dark);font-weight:760;border-radius:10px;font-variant-numeric:tabular-nums;font-size:.95rem}
.path-core .flow-node{height:100%}
.card .needs{margin:.15rem 0 .6rem}

/* Homepage roadmap preview strip */
.stage-flow{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem;margin-top:.2rem}
.stage-flow .stage{flex:1 1 8.5rem;min-width:8rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.7rem .8rem;text-align:center}
.stage-flow .stage strong{display:block;font-size:.95rem;color:var(--ink)}
.stage-flow .stage span{display:block;font-size:.78rem;color:var(--muted);margin-top:.15rem;line-height:1.3}
.stage-flow .arrow{flex:0 0 auto;color:var(--accent);font-weight:800}
@media(max-width:720px){.stage-flow{flex-direction:column;align-items:stretch}.stage-flow .arrow{transform:rotate(90deg);align-self:center}}

/* Self-assessment wizard */
.wizard{max-width:46rem}
.wizard-progress{display:flex;gap:.4rem;margin:0 0 1.5rem;padding:0;list-style:none}
.wizard-progress li{flex:1;height:6px;border-radius:99px;background:var(--line)}
.wizard-progress li.done{background:var(--accent)}
.wizard-progress li.active{background:var(--accent-dark)}
.wizard-step{display:none}
.wizard-step.active{display:block}
.wizard-q{font-weight:700;font-size:1.08rem;margin:.2rem 0 1rem;color:var(--ink)}
.wizard-opts{display:grid;gap:.55rem;margin:0 0 1.4rem}
.wizard-opt{display:flex;gap:.6rem;align-items:flex-start;border:1px solid var(--line);border-radius:10px;padding:.75rem .9rem;cursor:pointer;background:var(--surface)}
.wizard-opt:hover{border-color:var(--accent)}
.wizard-opt.sel{border-color:var(--accent);background:var(--accent-soft)}
.wizard-opt input{margin-top:.15rem;flex:0 0 auto}
.wizard-nav{display:flex;justify-content:space-between;gap:.6rem}
.wizard-result h3{margin:.1rem 0 .4rem}
.wizard-result .start-list,.wizard-result .skip-list{margin:.3rem 0 1.1rem}

/* Advanced Track waitlist */
.locked-card{border:1px dashed var(--steel);background:var(--blueprint);border-radius:12px;padding:1.2rem}
.locked-card .lock-badge{display:inline-block;font-size:.78rem;font-weight:700;color:var(--accent-dark);background:var(--accent-soft);border-radius:99px;padding:.15rem .6rem;margin-bottom:.5rem}
.waitlist-form{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:.5rem;max-width:34rem}
.waitlist-form input[type=email]{flex:1 1 16rem;border:1px solid var(--line);border-radius:8px;padding:.62rem .8rem;font:inherit;background:var(--surface);color:var(--ink)}
.waitlist-form input[type=email]:focus-visible{outline:3px solid var(--dimension);outline-offset:2px}
.form-honeypot{display:none!important}
