/* AI Architect Academy — shared design tokens + components.
   Lifted verbatim from public/sample-module.html (the canonical visual source).
   Each HTML page keeps its own Google Fonts <link> in <head> (same as the sample). */

:root{
  --bg:#0b0d10;
  --bg-2:#101317;
  --panel:#14181d;
  --panel-2:#181d23;
  --line:#262d35;
  --line-soft:#1c2228;
  --ink:#e9edf1;
  --ink-dim:#a4adb8;
  --ink-faint:#7d8794;
  --amber:#ff8c3b;
  --amber-soft:#ffb27a;
  --green:#4ade80;
  --green-deep:#16331f;
  --red:#ff6b6b;
  --red-deep:#3a1c1c;
  --blue:#6ab7ff;
  --radius:14px;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --body:'Hanken Grotesque',system-ui,sans-serif;
  --display:'Bricolage Grotesque',var(--body);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(255,140,59,0.10), transparent 60%),
    radial-gradient(900px 500px at -5% 110%, rgba(106,183,255,0.06), transparent 55%),
    var(--bg);
  color:var(--ink);
  font-family:var(--body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  min-height:100dvh;
}
::selection{background:rgba(255,140,59,.28);color:var(--ink)}
html{scrollbar-color:var(--line) transparent}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-thumb{background:var(--line);border:3px solid var(--bg);border-radius:999px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-faint)}
::-webkit-scrollbar-track{background:transparent}
/* tabular numerals so animating/changing metrics don't reflow */
.duebig,.scorebig,.mastery .pct,.qprog,.cost,table.srs td .due,.meta-row{font-variant-numeric:tabular-nums}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap{max-width:880px;margin:0 auto;padding:34px 22px 90px;position:relative;z-index:1}

/* Header */
.brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--amber);box-shadow:0 0 14px 2px rgba(255,140,59,.6)}
.brand .name{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}
.brand .name a{color:inherit;text-decoration:none}
.brand .tag{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:4px 11px}

.placement{
  margin:18px 0 8px;border:1px solid var(--line);border-left:3px solid var(--amber);
  background:linear-gradient(180deg,var(--panel),var(--bg-2));border-radius:var(--radius);
  padding:14px 16px;display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap;
}
.placement .pl-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--amber-soft)}
.placement .pl-body{font-size:14px;color:var(--ink-dim);max-width:62ch}
.placement b{color:var(--ink);font-weight:600}

h1{font-family:var(--display);font-weight:800;font-size:clamp(30px,5vw,46px);line-height:1.04;letter-spacing:-.02em;margin:22px 0 6px}
h1 .sub{display:block;font-size:14px;font-weight:600;font-family:var(--mono);letter-spacing:.04em;color:var(--amber);margin-top:14px;text-transform:none}
.meta-row{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:11.5px;color:var(--ink-faint);margin-bottom:18px}
.meta-row span b{color:var(--ink-dim);font-weight:500}

/* Stepper */
.stepper{display:flex;gap:6px;margin:22px 0 10px;flex-wrap:wrap}
.step{flex:1 1 0;min-width:96px;border:1px solid var(--line-soft);background:var(--panel);border-radius:10px;padding:9px 11px;transition:.25s}
.step .n{font-family:var(--mono);font-size:10px;color:var(--ink-faint);letter-spacing:.1em}
.step .t{font-size:12.5px;color:var(--ink-dim);font-weight:600;margin-top:2px}
.step.active{border-color:var(--amber);background:linear-gradient(180deg,rgba(255,140,59,.10),var(--panel))}
.step.active .n{color:var(--amber)}
.step.active .t{color:var(--ink)}
.step.done{border-color:var(--line)}
.step.done .t{color:var(--ink-faint)}
.step.done .n::after{content:" ✓";color:var(--green)}

/* Mastery bar */
.mastery{display:flex;align-items:center;gap:12px;margin:6px 0 26px}
.mastery .lab{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.1em;white-space:nowrap}
.bar{flex:1;height:8px;border-radius:999px;background:var(--panel-2);overflow:hidden;border:1px solid var(--line-soft)}
.bar i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--amber),var(--amber-soft));transition:width .5s cubic-bezier(.2,.7,.2,1)}
.mastery .pct{font-family:var(--mono);font-size:12px;color:var(--amber-soft);width:42px;text-align:right}

/* Cards / sections */
section{display:none;animation:rise .4s ease both}
section.show{display:block}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.card{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px;margin-bottom:16px}
.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:10px}
h2{font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-.01em;margin:0 0 14px}
h3{font-family:var(--display);font-weight:700;font-size:16px;margin:20px 0 8px;color:var(--ink)}
p{margin:0 0 13px;color:var(--ink-dim)}
p strong,li strong{color:var(--ink);font-weight:600}
.lede{font-size:16.5px;color:var(--ink)}
code,.k{font-family:var(--mono);font-size:.86em;background:var(--panel-2);border:1px solid var(--line-soft);border-radius:5px;padding:1px 6px;color:var(--amber-soft)}

ul.obj{list-style:none;padding:0;margin:6px 0 0}
ul.obj li{position:relative;padding:11px 12px 11px 44px;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:8px;background:var(--panel);color:var(--ink-dim);font-size:14.5px}
ul.obj li .lo{position:absolute;left:11px;top:11px;font-family:var(--mono);font-size:10px;font-weight:700;color:var(--bg);background:var(--amber);border-radius:5px;padding:2px 5px}
ul.obj li b{color:var(--ink)}

/* code block */
pre{font-family:var(--mono);font-size:12.5px;line-height:1.7;background:#0a0c0f;border:1px solid var(--line);border-radius:10px;padding:16px 16px;overflow:auto;color:#cdd6df;margin:6px 0 14px}
pre .cm{color:#5d6b78}
pre .kw{color:var(--amber-soft)}
pre .fn{color:var(--blue)}
pre .st{color:#9ae6b4}

.callout{border:1px solid var(--line);border-left:3px solid var(--blue);background:var(--panel);border-radius:10px;padding:13px 15px;margin:14px 0;font-size:14px;color:var(--ink-dim)}
.callout.warn{border-left-color:var(--amber)}
.callout .h{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}
.callout.warn .h{color:var(--amber-soft)}

.footguns{margin:8px 0 0;padding:0;list-style:none;counter-reset:fg}
.footguns li{counter-increment:fg;position:relative;padding:12px 14px 12px 46px;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:9px;background:var(--panel);font-size:14px;color:var(--ink-dim)}
.footguns li::before{content:counter(fg);position:absolute;left:13px;top:12px;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--red);border:1px solid var(--red-deep);background:rgba(255,107,107,.08);border-radius:6px;width:22px;height:22px;display:grid;place-items:center}
.footguns li b{color:var(--ink)}

/* buttons */
.row{display:flex;gap:10px;align-items:center;margin-top:18px;flex-wrap:wrap}
button.btn,a.btn{font-family:var(--body);font-weight:700;font-size:14px;border:none;border-radius:10px;padding:12px 20px;cursor:pointer;transition:.2s;letter-spacing:.01em;text-decoration:none;display:inline-block;min-height:44px;line-height:1.45}
.btn.primary{background:var(--amber);color:#1a0f06}
.btn.primary:hover{background:var(--amber-soft);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink-dim);border:1px solid var(--line)}
.btn.ghost:hover{color:var(--ink);border-color:var(--ink-faint)}
.btn.primary:active,.btn.ghost:active{transform:translateY(0) scale(.985)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.hint{font-family:var(--mono);font-size:11px;color:var(--ink-faint)}

/* quiz */
.qprog{font-family:var(--mono);font-size:11px;color:var(--ink-faint);letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.scenario{font-size:15px;color:var(--ink);background:var(--panel-2);border:1px solid var(--line-soft);border-left:3px solid var(--amber);border-radius:10px;padding:14px 16px;margin-bottom:8px}
.scenario .sl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-soft);display:block;margin-bottom:6px}
.qstem{font-size:15.5px;font-weight:600;color:var(--ink);margin:14px 0 12px}
.opts{display:flex;flex-direction:column;gap:9px}
.opt{text-align:left;border:1px solid var(--line);background:var(--panel);border-radius:11px;padding:13px 15px 13px 46px;position:relative;cursor:pointer;transition:.18s;color:var(--ink-dim);font-size:14.5px;font-family:var(--body);width:100%;min-height:44px}
.opt:hover:not(.locked){border-color:var(--ink-faint);color:var(--ink)}
.opt .key{position:absolute;left:13px;top:12px;width:22px;height:22px;border-radius:6px;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--ink-faint)}
.opt.correct{border-color:var(--green);background:linear-gradient(180deg,rgba(74,222,128,.10),var(--panel));color:var(--ink)}
.opt.correct .key{border-color:var(--green);color:var(--green);background:var(--green-deep)}
.opt.wrong{border-color:var(--red);background:linear-gradient(180deg,rgba(255,107,107,.08),var(--panel));color:var(--ink)}
.opt.wrong .key{border-color:var(--red);color:var(--red);background:var(--red-deep)}
.opt.locked{cursor:default}
.opt.dim{opacity:.55}
.opt .verdict{display:none;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin-top:7px}
.opt.correct .verdict,.opt.wrong .verdict{display:block}
.opt.correct .verdict{color:var(--green)}
.opt.wrong .verdict{color:var(--red)}
.opt .why{display:none;margin-top:6px;font-size:13px;color:var(--ink-dim);line-height:1.55}
.opt.show-why .why{display:block}

.explain{display:none;margin-top:14px;border:1px solid var(--line);border-radius:11px;padding:14px 16px;background:var(--panel-2)}
.explain.show{display:block;animation:rise .35s ease both}
.explain .h{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);margin-bottom:6px}
.explain .obj-tag{font-family:var(--mono);font-size:10px;color:var(--ink-faint);margin-top:8px}
.explain .src{font-family:var(--mono);font-size:10px;color:var(--ink-faint);margin-top:4px}

/* mastery summary */
.scorebig{font-family:var(--display);font-weight:800;font-size:54px;letter-spacing:-.02em;line-height:1}
.scorebig small{font-size:20px;color:var(--ink-faint);font-weight:600}
.verdict-line{font-size:16px;margin:8px 0 4px}
.verdict-line.pass{color:var(--green)}
.verdict-line.fail{color:var(--amber-soft)}
table.srs{width:100%;border-collapse:collapse;margin-top:10px;font-size:13px}
table.srs th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;padding:8px 10px;border-bottom:1px solid var(--line)}
table.srs td{padding:9px 10px;border-bottom:1px solid var(--line-soft);color:var(--ink-dim);vertical-align:top}
table.srs td .res{font-family:var(--mono);font-size:11px;font-weight:700}
.res.ok{color:var(--green)} .res.no{color:var(--red)}
table.srs td .due{font-family:var(--mono);color:var(--amber-soft)}

/* coach */
.chat{display:flex;flex-direction:column;gap:12px;margin-top:6px}
.msg{max-width:88%;padding:13px 15px;border-radius:13px;font-size:14px;line-height:1.6}
.msg.learner{align-self:flex-end;background:var(--panel-2);border:1px solid var(--line);color:var(--ink-dim);border-bottom-right-radius:4px}
.msg.coach{align-self:flex-start;background:linear-gradient(180deg,rgba(255,140,59,.07),var(--panel));border:1px solid var(--line);border-left:3px solid var(--amber);color:var(--ink);border-bottom-left-radius:4px}
.who{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:5px}
.msg.coach .who{color:var(--amber-soft)}
.annot{font-family:var(--mono);font-size:11px;color:var(--ink-faint);border:1px dashed var(--line);border-radius:8px;padding:8px 11px;margin-top:4px}
.annot b{color:var(--amber-soft)}

/* coach input */
.coach-input{display:flex;gap:10px;margin-top:14px;align-items:flex-end;flex-wrap:wrap}
.coach-input textarea{flex:1;min-width:200px;min-height:48px;resize:vertical;font-family:var(--body);font-size:14px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:11px 13px;color:var(--ink);line-height:1.5}
.coach-input textarea::placeholder{color:var(--ink-faint)}
.cost{font-family:var(--mono);font-size:10.5px;color:var(--ink-faint);margin-top:8px}

/* dashboard */
.grid{display:grid;gap:16px}
.duebig{font-family:var(--display);font-weight:800;font-size:54px;letter-spacing:-.02em;line-height:1;color:var(--amber)}
.duebig small{font-size:18px;color:var(--ink-faint);font-weight:600}
.masrow{display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center;padding:10px 0;border-top:1px solid var(--line-soft)}
.masrow:first-of-type{border-top:none}
.masrow .lo{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--amber)}
.pill{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;border-radius:999px;padding:3px 9px;border:1px solid var(--line)}
.pill.learning{color:var(--ink-faint)}
.pill.mastered{color:var(--green);border-color:var(--green-deep);background:rgba(74,222,128,.07)}
.muted{color:var(--ink-faint);font-size:13px}
.cardlink{color:var(--amber-soft);text-decoration:none;font-weight:600}
.cardlink:hover{color:var(--amber)}

/* diagnostic */
.choices{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.choice{text-align:left;border:1px solid var(--line);background:var(--panel);border-radius:11px;padding:14px 16px;cursor:pointer;transition:.18s;color:var(--ink-dim);font-size:15px;font-family:var(--body);width:100%;min-height:44px}
.choice:hover{border-color:var(--ink-faint);color:var(--ink)}
.choice.sel{border-color:var(--amber);background:linear-gradient(180deg,rgba(255,140,59,.10),var(--panel));color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{font-family:var(--mono);font-size:12px;border:1px solid var(--line);background:var(--panel);border-radius:999px;padding:8px 14px;cursor:pointer;color:var(--ink-dim);transition:.18s;min-height:44px;display:inline-flex;align-items:center}
.chip:hover{border-color:var(--ink-faint);color:var(--ink)}
.chip.sel{border-color:var(--amber);color:var(--ink);background:rgba(255,140,59,.10)}
.steplab{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:8px}

/* mapping footer */
details.map{margin-top:24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);overflow:hidden}
details.map summary{cursor:pointer;padding:15px 18px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--ink-dim);list-style:none}
details.map summary::-webkit-details-marker{display:none}
details.map summary::before{content:"▸ ";color:var(--amber)}
details.map[open] summary::before{content:"▾ "}
details.map .inner{padding:4px 18px 18px}
.maprow{display:grid;grid-template-columns:180px 1fr;gap:10px;padding:9px 0;border-top:1px solid var(--line-soft);font-size:13.5px}
.maprow .pr{color:var(--amber-soft);font-weight:600}
.maprow .ex{color:var(--ink-dim)}
@media(max-width:560px){.maprow{grid-template-columns:1fr;gap:2px}}

footer.foot{margin-top:30px;font-family:var(--mono);font-size:11px;color:var(--ink-faint);text-align:center;line-height:1.7}

/* skeleton loaders — shimmer placeholders while data loads */
.skel{position:relative;overflow:hidden;background:var(--panel-2);border:1px solid var(--line-soft);border-radius:8px;height:14px;margin:10px 0}
.skel.lg{height:20px;width:55%}
.skel.sm{height:12px;width:40%}
.skel.bar{height:8px}
.skel::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(233,237,241,.06),transparent);animation:skel 1.3s ease-in-out infinite}
@keyframes skel{100%{transform:translateX(100%)}}

/* accessibility */
:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
.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}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after,section{animation:none!important;transition:none!important}
}
