/* ===========================================================================
   ML Atlas — Editorial design system
   Long-form, distill.pub-inspired reading experience with a dense, professional
   course navigation. Serif reading column, sans UI, numbered figures, footnote
   citations, line-art SVG icons. No emoji anywhere.
   =========================================================================== */

:root{
  --paper:#ffffff;
  --bg:#fbf7f1;            /* warm cream, matches the company site */
  --panel:#ffffff;
  --ink:#1c1714;           /* warm black */
  --ink-2:#3a322d;
  --reading:#2a221e;
  --muted:#6f635c;
  --muted-2:#9a8e85;
  --rule:#e8e2d8;
  --rule-2:#d8cfc2;

  --accent:#6a1b2a;        /* wine */
  --accent-ink:#511320;
  --accent-wash:#f3e7e8;
  --accent-2:#b45c38;      /* red clay */

  --ok:#15803d; --ok-wash:#eaf6ee;
  --warn:#b45309; --warn-wash:#fbf1e3;
  --err:#b91c1c; --err-wash:#fbecec;

  --sidebar-w:312px;
  --rail-w:212px;
  --measure:684px;
  --topbar-h:56px;

  --serif: "Times New Roman",Times,Georgia,serif;
  --sans: "Times New Roman",Times,Georgia,serif;
  --mono: "SF Mono",ui-monospace,"JetBrains Mono","Fira Code",Menlo,Consolas,monospace;

  --sh-1:0 1px 2px rgba(16,18,22,.05);
  --sh-2:0 6px 22px rgba(16,18,22,.09);
  --sh-3:0 18px 48px rgba(16,18,22,.16);
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5;
}
[hidden]{display:none !important;}
button{font-family:inherit;cursor:pointer;}
a{color:var(--accent);text-decoration:none;}
a:hover{text-decoration:underline;}
::selection{background:#f0d9dc;}
svg{display:block;}

::-webkit-scrollbar{width:11px;height:11px;}
::-webkit-scrollbar-thumb{background:#cfcfc9;border-radius:20px;border:3px solid transparent;background-clip:content-box;}
::-webkit-scrollbar-thumb:hover{background:#b9b9b1;background-clip:content-box;}

/* ============================ AUTH ============================ */
.auth{position:fixed;inset:0;display:grid;place-items:center;padding:24px;overflow:auto;z-index:60;
  background:
    radial-gradient(900px 480px at 8% -10%, #eef2fe 0%, rgba(238,242,254,0) 60%),
    radial-gradient(760px 480px at 108% 8%, #e9f5f2 0%, rgba(233,245,242,0) 55%),
    var(--bg);}
.auth-card{width:min(940px,100%);background:var(--paper);border:1px solid var(--rule);border-radius:14px;box-shadow:var(--sh-3);
  display:grid;grid-template-columns:1.04fr .96fr;overflow:hidden;}
.auth-hero{padding:48px 42px;background:#13182a;color:#fff;display:flex;flex-direction:column;gap:18px;position:relative;}
.auth-hero .kicker{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#8fa6ff;font-weight:700;}
.auth-hero h1{font-family:var(--serif);font-weight:600;font-size:33px;line-height:1.14;margin:4px 0 0;letter-spacing:-.01em;}
.auth-hero p{color:#c4ccde;font-size:15px;line-height:1.6;margin:0;}
.auth-hero ul{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:13px;}
.auth-hero li{display:flex;gap:11px;align-items:flex-start;font-size:14px;color:#dde3f0;}
.auth-hero li svg{flex:none;margin-top:2px;color:#7e97ff;}
.auth-hero .foot{margin-top:auto;font-size:12.5px;color:#94a0bd;}
.auth-form{padding:42px 40px;display:flex;flex-direction:column;gap:15px;}
.auth-form h2{margin:0;font-family:var(--serif);font-weight:600;font-size:23px;}
.auth-form .sub{margin:-6px 0 8px;color:var(--muted);font-size:14px;}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:12.5px;font-weight:600;color:var(--ink-2);}
.field input{font:inherit;font-size:15px;color:var(--ink);padding:11px 13px;border:1px solid var(--rule-2);border-radius:8px;background:var(--paper);transition:border-color .15s,box-shadow .15s;}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash);}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.chip{border:1px solid var(--rule-2);background:var(--paper);padding:8px 13px;border-radius:7px;font-size:13.5px;color:var(--ink-2);transition:all .14s;}
.chip[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:#fff;}
.chip:hover{border-color:var(--accent);}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;line-height:1;
  padding:10px 17px;border-radius:8px;border:1px solid var(--rule-2);background:var(--paper);color:var(--ink-2);
  transition:transform .05s,background .15s,border-color .15s,box-shadow .15s;}
.btn:active{transform:translateY(1px);}
.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:var(--sh-1);}
.btn--primary:hover{background:var(--accent-ink);}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn--good{background:var(--accent-2);border-color:var(--accent-2);color:#fff;}
.btn--lg{padding:12px 22px;font-size:15px;}
.btn--block{width:100%;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}
.linkbtn{background:none;border:none;color:var(--muted);font-size:12.5px;padding:4px;}
.linkbtn:hover{color:var(--err);text-decoration:underline;}
.iconbtn{background:transparent;border:1px solid transparent;color:var(--ink-2);width:36px;height:36px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;}
.iconbtn:hover{background:var(--bg);}

/* ============================ APP SHELL ============================ */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;}

/* ---- sidebar / table of contents ---- */
.side{position:sticky;top:0;height:100vh;background:var(--paper);border-right:1px solid var(--rule);display:flex;flex-direction:column;z-index:40;}
.side__top{display:flex;align-items:center;gap:10px;padding:15px 18px 12px;border-bottom:1px solid var(--rule);}
.brand{display:flex;align-items:center;gap:10px;}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;}
.brand:hover{text-decoration:none;}
.brand__mark{width:32px;height:32px;display:block;}
.brand__name{font-weight:700;font-size:15.5px;letter-spacing:-.01em;line-height:1;}
.brand__sub{font-size:10.5px;color:var(--muted-2);letter-spacing:.08em;text-transform:uppercase;margin-top:3px;}
.side__search{padding:11px 14px;border-bottom:1px solid var(--rule);}
.side__search input{width:100%;font:inherit;font-size:13px;padding:8px 11px 8px 31px;border:1px solid var(--rule-2);border-radius:8px;background:var(--bg);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23969ca5' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:10px center;}
.side__search input:focus{outline:none;border-color:var(--accent);background-color:#fff;box-shadow:0 0 0 3px var(--accent-wash);}

.toc{flex:1;overflow-y:auto;padding:8px 8px 26px;}
.toc__dash{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:none;border-radius:8px;padding:9px 12px;color:var(--ink-2);font-size:13.5px;font-weight:600;}
.toc__dash:hover{background:var(--bg);}
.toc__dash.active{background:var(--accent-wash);color:var(--accent-ink);}
.toc__dash svg{flex:none;color:var(--muted);}
.toc__dash.active svg{color:var(--accent);}

.toc__section{margin:16px 6px 4px;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);}
.unit{margin-bottom:1px;}
.unit__head{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:none;background:none;border-radius:8px;padding:8px 10px;color:var(--ink);font-size:13.5px;font-weight:600;line-height:1.3;}
.unit__head:hover{background:var(--bg);}
.unit__head .chev{flex:none;color:var(--muted-2);transition:transform .18s;}
.unit.collapsed .unit__head .chev{transform:rotate(-90deg);}
.unit__title{flex:1;}
.unit__time{font-size:11px;color:var(--muted-2);font-weight:600;}
.unit__lessons{display:flex;flex-direction:column;gap:1px;margin:2px 0 7px;}
.unit.collapsed .unit__lessons{display:none;}
.lrow{display:flex;align-items:center;gap:9px;width:100%;text-align:left;border:none;background:none;border-radius:8px;padding:6px 10px 6px 30px;color:var(--ink-2);font-size:13px;line-height:1.35;position:relative;}
.lrow:hover{background:var(--bg);color:var(--ink);}
.lrow.active{background:var(--accent-wash);color:var(--accent-ink);font-weight:600;}
.lrow.locked{color:var(--muted-2);}
.lrow__icon{flex:none;color:var(--muted-2);width:16px;height:16px;display:grid;place-items:center;}
.lrow.active .lrow__icon{color:var(--accent);}
.lrow.done .lrow__icon{color:var(--accent-2);}
.lrow__title{flex:1;overflow:hidden;text-overflow:ellipsis;}
.lrow__time{font-size:11px;color:var(--muted-2);}
.side__foot{padding:10px 16px;border-top:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;}
.side__foot .pct{font-size:11.5px;color:var(--muted);font-weight:600;}

/* ---- main ---- */
.main{display:flex;flex-direction:column;min-width:0;}
.top{position:sticky;top:0;height:var(--topbar-h);z-index:30;display:flex;align-items:center;gap:14px;padding:0 22px;
  background:rgba(255,255,255,.86);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--rule);}
.crumb{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px;min-width:0;}
.crumb a{color:var(--muted);}.crumb a:hover{color:var(--ink);}
.crumb b{color:var(--ink);font-weight:600;}
.crumb .sep{color:var(--muted-2);}
.top__right{margin-left:auto;display:flex;align-items:center;gap:18px;}
.oprog{display:flex;align-items:center;gap:9px;}
.oprog__bar{width:120px;height:6px;background:var(--rule);border-radius:99px;overflow:hidden;}
.oprog__bar span{display:block;height:100%;width:0;background:var(--accent);border-radius:99px;transition:width .5s ease;}
.oprog__lbl{font-size:12px;font-weight:700;color:var(--ink-2);min-width:30px;}
.userchip{display:flex;align-items:center;gap:9px;padding:5px 11px 5px 5px;border:1px solid var(--rule);border-radius:99px;background:var(--paper);}
.userchip:hover{box-shadow:var(--sh-1);}
.userchip__name{font-size:13px;font-weight:600;}
.avatar{width:29px;height:29px;border-radius:50%;display:grid;place-items:center;background:#13182a;color:#fff;font-weight:700;font-size:12px;}
.avatar--lg{width:42px;height:42px;font-size:16px;}
.backsite{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink-2);border:1px solid var(--rule-2);border-radius:8px;padding:8px 13px;background:var(--paper);transition:border-color .15s,color .15s;}
.backsite:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;}
.backsite svg{color:var(--muted);}
.backsite:hover svg{color:var(--accent);}

.view{flex:1;}

/* popover */
.pop{position:fixed;top:54px;right:18px;width:232px;background:var(--paper);border:1px solid var(--rule);border-radius:11px;box-shadow:var(--sh-3);z-index:70;overflow:hidden;}
.pop__h{display:flex;gap:11px;align-items:center;padding:14px;border-bottom:1px solid var(--rule);}
.pop__name{font-weight:700;font-size:14px;}
.pop__sub{font-size:12px;color:var(--muted);}
.pop__i{display:block;width:100%;text-align:left;padding:11px 14px;border:none;background:none;font-size:13.5px;color:var(--ink-2);}
.pop__i:hover{background:var(--bg);color:var(--ink);}

/* ============================ DASHBOARD ============================ */
.dash{max-width:1080px;margin:0 auto;padding:34px 34px 80px;}
.dash__hero{border:1px solid var(--rule);background:var(--paper);border-radius:14px;padding:34px 34px 30px;box-shadow:var(--sh-1);position:relative;overflow:hidden;}
.dash__hero::after{content:"";position:absolute;right:-90px;top:-90px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle at center,var(--accent-wash),rgba(243,231,232,0) 70%);}
.dash__hero .kicker{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-weight:700;}
.dash__hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(28px,3.4vw,40px);letter-spacing:-.01em;margin:10px 0 10px;}
.dash__hero p{color:var(--reading);font-size:16.5px;line-height:1.65;margin:0;max-width:640px;}
.dash__stats{display:flex;gap:30px;margin-top:26px;flex-wrap:wrap;position:relative;}
.stat .n{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--accent);}
.stat .l{font-size:12px;color:var(--muted);letter-spacing:.02em;}
.dash__cta{margin-top:24px;display:flex;gap:11px;flex-wrap:wrap;}

.resume{display:flex;align-items:center;gap:16px;border:1px solid var(--rule);border-left:3px solid var(--accent);background:var(--paper);border-radius:11px;padding:15px 18px;margin-top:22px;box-shadow:var(--sh-1);}
.resume .ey{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);font-weight:700;}
.resume h3{margin:3px 0 0;font-size:15.5px;}
.resume .meta{flex:1;min-width:0;}

.sec-h{display:flex;align-items:center;gap:12px;margin:34px 0 6px;}
.sec-h h2{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0;font-weight:800;}
.sec-h .line{flex:1;height:1px;background:var(--rule);}

.unitcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-top:14px;}
.ucard{text-align:left;background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:18px 18px 16px;display:flex;flex-direction:column;gap:10px;
  transition:transform .12s,box-shadow .15s,border-color .15s;position:relative;min-height:150px;}
.ucard:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--rule-2);}
.ucard__n{font-family:var(--serif);font-size:13px;color:var(--muted-2);font-weight:600;}
.ucard h3{margin:0;font-size:17px;letter-spacing:-.01em;line-height:1.25;}
.ucard p{margin:0;font-size:13px;color:var(--muted);line-height:1.5;flex:1;}
.ucard__foot{display:flex;align-items:center;gap:10px;margin-top:2px;}
.ucard__bar{flex:1;height:5px;background:var(--rule);border-radius:99px;overflow:hidden;}
.ucard__bar span{display:block;height:100%;background:var(--accent-2);border-radius:99px;}
.ucard__meta{font-size:11.5px;color:var(--muted-2);font-weight:600;white-space:nowrap;}
.ucard.soon{opacity:.72;}
.ucard .tagsoon{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--bg);border:1px solid var(--rule);border-radius:99px;padding:2px 8px;}

/* ============================ LESSON (editorial) ============================ */
.lesson-wrap{display:grid;grid-template-columns:minmax(0,1fr) var(--rail-w);gap:40px;max-width:calc(var(--measure) + var(--rail-w) + 40px);margin:0 auto;padding:30px 34px 90px;}
.lesson{min-width:0;max-width:var(--measure);}
.lesson__eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700;}
.lesson__pos{font-size:12px;color:var(--muted-2);font-weight:600;margin-left:auto;}
.lesson__headrow{display:flex;align-items:center;gap:10px;}
.lesson h1{font-family:var(--serif);font-weight:600;font-size:36px;line-height:1.12;letter-spacing:-.015em;color:var(--ink);margin:10px 0 0;}
.lesson__sub{font-family:var(--serif);font-size:20px;line-height:1.5;color:var(--muted);margin:12px 0 0;font-weight:400;font-style:italic;}
.lesson__meta{display:flex;gap:16px;align-items:center;color:var(--muted);font-size:13px;margin:16px 0 22px;padding-bottom:18px;border-bottom:1px solid var(--rule);}
.lesson__meta .m{display:inline-flex;gap:6px;align-items:center;}
.lesson__meta svg{color:var(--muted-2);}

/* reading prose */
.prose{font-family:var(--serif);font-size:19px;line-height:1.72;color:var(--reading);}
.prose > p{margin:0 0 20px;}
.prose h2{font-family:var(--sans);font-weight:700;font-size:23px;line-height:1.25;letter-spacing:-.01em;color:var(--ink);margin:42px 0 14px;scroll-margin-top:74px;}
.prose h3{font-family:var(--sans);font-weight:700;font-size:18px;color:var(--ink);margin:30px 0 10px;scroll-margin-top:74px;}
.prose ul,.prose ol{margin:0 0 20px;padding-left:26px;}
.prose li{margin-bottom:9px;}
.prose li::marker{color:var(--muted-2);}
.prose strong{color:var(--ink);font-weight:700;}
.prose a{font-weight:600;border-bottom:1px solid rgba(31,79,216,.3);}
.prose a:hover{text-decoration:none;border-bottom-color:var(--accent);}
.prose em.term{font-style:normal;font-weight:600;color:var(--accent-ink);}
.prose code{font-family:var(--mono);font-size:.84em;background:#f0f1ee;color:#33373d;padding:2px 6px;border-radius:5px;}
.prose blockquote{margin:0 0 20px;padding:6px 0 6px 20px;border-left:3px solid var(--rule-2);color:var(--muted);font-style:italic;}
.prose hr{border:none;border-top:1px solid var(--rule);margin:34px 0;}

/* citation superscripts */
.cite{font-family:var(--sans);font-size:.62em;font-weight:700;color:var(--accent);vertical-align:super;line-height:0;}
.cite a{border:none;}
.cite a:hover{text-decoration:underline;}

/* callouts (labelled, no emoji) */
.callout{font-family:var(--sans);font-size:15.5px;line-height:1.6;border:1px solid var(--rule);border-left:3px solid var(--accent);
  background:var(--accent-wash);border-radius:8px;padding:14px 17px;margin:0 0 22px;color:var(--ink-2);}
.callout .lbl{display:block;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:5px;}
.callout p{margin:0;}
.callout--key{border-left-color:#6d28d9;background:#f4f0fe;}.callout--key .lbl{color:#6d28d9;}
.callout--tip{border-left-color:var(--accent-2);background:#e9f5f2;}.callout--tip .lbl{color:var(--accent-2);}
.callout--warn{border-left-color:var(--warn);background:var(--warn-wash);}.callout--warn .lbl{color:var(--warn);}

/* analogy */
.analogy{border:1px dashed var(--rule-2);border-radius:10px;background:var(--bg);padding:15px 18px;margin:0 0 22px;font-family:var(--sans);}
.analogy .lbl{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.analogy p{margin:0;font-size:15.5px;line-height:1.6;color:var(--ink-2);}

/* math */
.math{font-family:var(--serif);background:var(--bg);border:1px solid var(--rule);border-radius:9px;padding:16px 18px;margin:0 0 22px;text-align:center;font-size:19px;color:var(--ink);overflow-x:auto;}
.math .muted{display:block;font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:8px;}
.sub{vertical-align:sub;font-size:.72em;}.sup{vertical-align:super;font-size:.72em;}

/* figures */
.fig{margin:8px 0 26px;}
.fig__frame{border:1px solid var(--rule);border-radius:10px;overflow:hidden;background:var(--paper);}
.fig__frame img{display:block;width:100%;height:auto;}
.fig figcaption{font-family:var(--sans);font-size:13.5px;line-height:1.5;color:var(--muted);margin-top:10px;}
.fig figcaption b{color:var(--ink-2);font-weight:700;}
.fig__credit{display:block;font-size:12px;color:var(--muted-2);margin-top:3px;}
.fig--wide{max-width:none;}

/* tables */
.prose table{width:100%;border-collapse:collapse;margin:0 0 22px;font-family:var(--sans);font-size:14.5px;}
.prose th,.prose td{text-align:left;padding:10px 13px;border-bottom:1px solid var(--rule);vertical-align:top;}
.prose th{background:var(--bg);font-weight:700;color:var(--ink);font-size:13px;}
.prose tbody tr:hover td{background:#fafafa;}

/* ============================ INTERACTIVE LAB ============================ */
.lab{font-family:var(--sans);border:1px solid var(--rule-2);border-radius:12px;background:var(--paper);margin:10px 0 26px;overflow:hidden;box-shadow:var(--sh-1);}
.lab__bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--bg);border-bottom:1px solid var(--rule);}
.lab__bar .tag{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.lab__bar .tag svg{color:var(--accent);}
.lab__bar h4{margin:0;font-size:14px;font-weight:700;color:var(--ink);}
.lab__bar .spacer{flex:1;}
.lab__body{padding:18px;}
.lab__stage{display:grid;place-items:center;background:var(--bg);border:1px solid var(--rule);border-radius:9px;padding:14px;}
.lab__stage canvas,.lab__stage svg{max-width:100%;height:auto;}
.lab__hint{font-size:13px;color:var(--muted);margin-top:12px;line-height:1.55;}
.lab__grid{display:grid;gap:18px;}
@media(min-width:700px){.lab__grid--2{grid-template-columns:1fr 1fr;align-items:start;}.lab__grid--side{grid-template-columns:1fr 232px;align-items:start;}}

.controls{display:flex;flex-direction:column;gap:14px;}
.control{display:flex;flex-direction:column;gap:6px;}
.control__row{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.control label{font-size:13px;font-weight:600;color:var(--ink-2);}
.control .val{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--accent-ink);background:var(--accent-wash);padding:2px 8px;border-radius:6px;min-width:44px;text-align:center;}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:99px;background:var(--rule-2);outline:none;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:17px;height:17px;border-radius:50%;background:var(--accent);border:3px solid #fff;box-shadow:var(--sh-1);cursor:pointer;}
input[type=range]::-moz-range-thumb{width:17px;height:17px;border-radius:50%;background:var(--accent);border:3px solid #fff;cursor:pointer;}
.btnrow{display:flex;flex-wrap:wrap;gap:9px;}
.seg{display:inline-flex;border:1px solid var(--rule-2);border-radius:8px;overflow:hidden;}
.seg button{border:none;background:var(--paper);padding:8px 13px;font-size:13px;color:var(--ink-2);border-right:1px solid var(--rule);}
.seg button:last-child{border-right:none;}
.seg button.active{background:var(--accent);color:#fff;}
.toggle{display:inline-flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-2);cursor:pointer;}
.readout{font-family:var(--mono);font-size:13px;background:var(--bg);border:1px solid var(--rule);border-radius:8px;padding:10px 13px;color:var(--ink-2);line-height:1.6;}
.readout b{color:var(--ink);}
.statpills{display:flex;flex-wrap:wrap;gap:8px;}
.statpill{background:var(--bg);border:1px solid var(--rule);border-radius:99px;padding:5px 12px;font-size:12.5px;font-family:var(--sans);}
.statpill b{font-family:var(--mono);color:var(--accent-ink);}

/* quiz */
.quiz{font-family:var(--sans);border:1px solid var(--rule);border-radius:11px;padding:18px;margin:8px 0 24px;background:var(--paper);}
.quiz__q{font-weight:600;font-size:16px;margin-bottom:13px;color:var(--ink);}
.quiz__opt{display:block;width:100%;text-align:left;padding:11px 14px;border:1px solid var(--rule-2);border-radius:8px;background:var(--paper);margin-bottom:8px;font-size:14.5px;color:var(--ink-2);transition:all .12s;}
.quiz__opt:hover{border-color:var(--accent);}
.quiz__opt.correct{background:var(--ok-wash);border-color:var(--ok);color:#14622f;}
.quiz__opt.wrong{background:var(--err-wash);border-color:var(--err);color:#8d1c1c;}
.quiz__fb{font-size:14px;margin-top:8px;padding:11px 14px;border-radius:8px;display:none;line-height:1.55;}
.quiz__fb.show{display:block;}

/* exercise scaffold */
.exercise{font-family:var(--sans);}

/* references */
.refs{margin-top:46px;padding-top:20px;border-top:1px solid var(--rule);font-family:var(--sans);}
.refs h3{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;font-weight:800;}
.refs ol{margin:0;padding-left:22px;font-size:13.5px;color:var(--muted);line-height:1.6;}
.refs li{margin-bottom:7px;}
.refs li a{font-weight:600;}
.refs .lic{color:var(--muted-2);}

/* complete bar + prevnext */
.complete{display:flex;align-items:center;gap:14px;margin-top:34px;padding:18px;border-radius:11px;background:var(--bg);border:1px solid var(--rule);flex-wrap:wrap;font-family:var(--sans);}
.complete.done{background:var(--ok-wash);border-color:#bfe6cb;}
.complete .t{font-weight:600;font-size:14.5px;}
.prevnext{display:flex;gap:12px;margin-top:30px;}
.prevnext a{flex:1;border:1px solid var(--rule);border-radius:11px;padding:14px 16px;display:flex;flex-direction:column;gap:3px;background:var(--paper);font-family:var(--sans);}
.prevnext a:hover{border-color:var(--accent);text-decoration:none;box-shadow:var(--sh-1);}
.prevnext .dir{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-weight:700;}
.prevnext .t{font-weight:600;color:var(--ink);font-size:14.5px;}
.prevnext .next{text-align:right;align-items:flex-end;}

/* on-this-page rail */
.rail{position:sticky;top:74px;align-self:start;max-height:calc(100vh - 96px);overflow:auto;font-family:var(--sans);}
.rail__h{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-weight:800;margin-bottom:12px;}
.rail a{display:block;font-size:13px;color:var(--muted);padding:5px 0 5px 12px;border-left:2px solid var(--rule);line-height:1.4;}
.rail a:hover{color:var(--ink);text-decoration:none;border-left-color:var(--rule-2);}
.rail a.active{color:var(--accent-ink);border-left-color:var(--accent);font-weight:600;}
.rail a.sub{padding-left:24px;font-size:12.5px;}

/* coming soon */
.soon-note{font-family:var(--sans);border:1px dashed var(--rule-2);border-radius:11px;padding:26px;background:var(--bg);color:var(--muted);text-align:center;}
.soon-note h3{color:var(--ink-2);margin:0 0 6px;font-size:17px;}
.soon-note p{margin:0 auto;max-width:440px;font-size:14.5px;line-height:1.6;}

.empty{text-align:center;padding:70px 20px;color:var(--muted);font-family:var(--sans);}

/* ============================ RESPONSIVE ============================ */
@media(max-width:1120px){
  .lesson-wrap{grid-template-columns:minmax(0,1fr);max-width:var(--measure);}
  .rail{display:none;}
}
@media(max-width:900px){
  .app{grid-template-columns:1fr;}
  .side{position:fixed;left:0;top:0;width:300px;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--sh-3);}
  .app.nav-open .side{transform:translateX(0);}
  .iconbtn{display:inline-flex;}
  .lesson-wrap,.dash{padding:22px 18px 70px;}
  .auth-card{grid-template-columns:1fr;}.auth-hero{display:none;}
  .oprog__bar{width:70px;}
  .scrim{position:fixed;inset:0;background:rgba(16,18,22,.4);z-index:35;}
}
@media(max-width:560px){
  .lesson h1{font-size:28px;}
  .dash__hero h1{font-size:24px;}
  .userchip__name{display:none;}
}
@media(prefers-reduced-motion:reduce){*{animation:none !important;transition:none !important;}}

/* ============================ DASHBOARD: collapsible sections ============================ */
.dsec{border:1px solid var(--rule);border-radius:12px;background:var(--paper);margin-top:16px;overflow:hidden;box-shadow:var(--sh-1);}
.dsec__head{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:none;border:none;padding:18px 20px;cursor:pointer;color:var(--ink);font-family:var(--sans);}
.dsec__head:hover{background:var(--bg);}
.dsec__chev{color:var(--muted);transition:transform .25s ease;display:grid;place-items:center;flex:none;}
.dsec.open .dsec__chev{transform:rotate(180deg);}
.dsec__title{font-family:var(--serif);font-weight:600;font-size:18px;flex:1;}
.dsec__meta{font-size:12.5px;color:var(--muted);white-space:nowrap;}
.dsec__bar{width:96px;height:6px;background:var(--rule);border-radius:99px;overflow:hidden;flex:none;}
.dsec__bar span{display:block;height:100%;background:var(--accent-2);border-radius:99px;}
.dsec__pct{font-size:12.5px;font-weight:700;color:var(--accent);min-width:36px;text-align:right;}
.dsec__body{display:none;padding:2px 18px 20px;}
.dsec.open .dsec__body{display:block;}
.dsec__body .unitcards{margin-top:8px;}
@media(max-width:600px){ .dsec__meta,.dsec__bar{display:none;} }

.toc__empty{padding:22px 14px;color:var(--muted);font-size:13.5px;text-align:center;line-height:1.5;}

/* ============================ THEME TOGGLE ============================ */
.theme-toggle{position:relative;width:36px;height:36px;flex:none;border-radius:8px;border:1px solid var(--rule-2);background:transparent;color:var(--ink-2);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,color .15s,background .15s;}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--bg);}
.theme-toggle svg{width:18px;height:18px;}
.theme-toggle .sun{display:none;}
.theme-toggle .moon{display:block;}
html[data-theme="dark"] .theme-toggle .sun{display:block;}
html[data-theme="dark"] .theme-toggle .moon{display:none;}

/* ============================ SIDEBAR COLLAPSE (desktop) ============================ */
@media(min-width:901px){
  .app{transition:grid-template-columns .26s cubic-bezier(.2,.7,.2,1);}
  .app.side-collapsed{grid-template-columns:0 1fr;}
  .app.side-collapsed .side{overflow:hidden;border-right-color:transparent;}
}

/* ============================ DARK MODE ============================ */
html[data-theme="dark"]{
  --paper:#1e1813; --bg:#161210; --panel:#1e1813;
  --ink:#f0e8de; --ink-2:#cfc4b8; --reading:#e4dace; --muted:#a1968b; --muted-2:#7c7167;
  --rule:#2e2720; --rule-2:#3d342b;
  --accent:#cf7382; --accent-ink:#e3919e; --accent-wash:rgba(207,115,130,.16); --accent-2:#d6855b;
  --ok:#5fbf85; --ok-wash:rgba(95,191,133,.14);
  --warn:#d98a4a; --warn-wash:rgba(217,138,74,.14);
  --err:#e07a7a; --err-wash:rgba(224,122,122,.14);
  --sh-1:0 1px 2px rgba(0,0,0,.45); --sh-2:0 6px 22px rgba(0,0,0,.55); --sh-3:0 18px 48px rgba(0,0,0,.62);
  color-scheme:dark;
}
html[data-theme="dark"] ::selection{background:rgba(207,115,130,.32);}
html[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#3a332c;}
html[data-theme="dark"] .top{background:rgba(22,18,16,.86);}
/* keep brand buttons rich with light text */
html[data-theme="dark"] .btn--primary{background:#9c3144;border-color:#9c3144;color:#fff;}
html[data-theme="dark"] .btn--primary:hover{background:#b23c51;}
html[data-theme="dark"] .btn--good{background:#a85230;border-color:#a85230;color:#fff;}
html[data-theme="dark"] .seg button.active{background:#9c3144;color:#fff;}
html[data-theme="dark"] input[type=range]::-webkit-slider-thumb{border-color:var(--paper);}
html[data-theme="dark"] input[type=range]::-moz-range-thumb{border-color:var(--paper);}
html[data-theme="dark"] .side__search input:focus{background-color:#241d17;}
html[data-theme="dark"] .prose code{background:#2a2218;color:#e7c08f;}
html[data-theme="dark"] .prose a{border-bottom-color:rgba(207,115,130,.4);}
html[data-theme="dark"] .prose tbody tr:hover td{background:rgba(255,255,255,.04);}
html[data-theme="dark"] .callout--key{background:rgba(139,92,246,.16);border-left-color:#a78bfa;}
html[data-theme="dark"] .callout--key .lbl{color:#a78bfa;}
html[data-theme="dark"] .callout--tip{background:rgba(95,191,133,.12);}
html[data-theme="dark"] .quiz__opt.correct{color:#8fe0ab;}
html[data-theme="dark"] .quiz__opt.wrong{color:#f0a3a3;}
html[data-theme="dark"] .complete.done{border-color:rgba(95,191,133,.4);}
/* keep interactive stages + figures on a light card so canvas/SVG visuals stay legible */
html[data-theme="dark"] .lab__stage{background:#f4efe7;border-color:#dcd3c6;color:#1c1714;}
html[data-theme="dark"] .fig__frame{background:#f6f1e9;border-color:#dcd3c6;}
html[data-theme="dark"] .math{background:#241d17;}
