*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%;background:#ECE7DB;color:var(--ink);font-family:var(--sans)}
body{min-width:0}
a{color:inherit;text-decoration:none}
button{font:inherit}
.stage{display:flex;flex-direction:column;width:100%;min-height:100vh}
.frame{position:relative;background:var(--paper);border:1px solid #D5CCB8;container-type:inline-size;container-name:page;flex:1 0 auto;width:100%;min-height:100vh}
.cn{font-family:var(--serif)}
.mono{font-family:var(--mono)}
a:focus-visible,button:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;border-bottom:1px solid var(--rule);gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand .mk{width:28px;height:28px;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-family:var(--mono);font-size:13px;font-weight:600;flex-shrink:0}
.brand .nm{font-family:var(--serif);font-size:17px;font-weight:600;letter-spacing:.02em;white-space:nowrap}
.brand .nm[data-href]{cursor:pointer}
.brand .sub{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;padding-left:12px;border-left:1px solid var(--rule2);margin-left:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.topbar .meta{display:flex;gap:20px;font-family:var(--mono);font-size:12px;color:var(--muted);align-items:center;flex-wrap:wrap}
.topbar .meta b{color:var(--ink);font-weight:500}
.shell-link{font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.rail-toggle{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;padding:6px 9px;border:1px solid var(--rule2);background:var(--paper);color:var(--ink);cursor:pointer}
.rail-toggle:hover{border-color:var(--ink)}
.bars{display:flex;gap:3px;align-items:center}
.bars i{display:block;width:18px;height:4px;background:var(--rule2)}
.bars i.on{background:var(--ink)}
.bars i.now{background:var(--amber)}

.home{display:grid;grid-template-columns:minmax(240px,300px) minmax(0,1fr);grid-template-areas:"rail main";min-height:700px}
.home.rail-hidden{grid-template-columns:minmax(0,1fr);grid-template-areas:"main"}
.rail{grid-area:rail;background:var(--rail);border-right:1px solid var(--rule);padding:28px 24px 36px;min-width:0}
.main{grid-area:main;padding:36px 48px 56px;position:relative;min-width:0;display:flex;justify-content:center}
.main-body{width:min(100%,1120px)}
.main.reading .main-body{width:min(100%,820px)}
.main.reading .crumbs,
.main.reading .lhead,
.main.reading .qblock,
.main.reading .pblock,
.main.reading .source-library-inline,
.main.reading .lesson-footer-nav{width:100%;max-width:820px;margin-left:auto;margin-right:auto}
.main.reading .body{width:100%;max-width:820px;margin-left:auto;margin-right:auto}
.reading{padding:44px 56px 80px;min-width:0}

.fold{display:block}
.fold > summary{display:none;list-style:none}
.fold > .foldbody{display:block}

.rail .rlabel{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-bottom:18px;display:flex;justify-content:space-between}
.day{display:grid;grid-template-columns:42px 1fr auto;gap:14px;padding:14px 0;border-top:1px solid var(--rule);align-items:baseline;position:relative}
.day:last-child{border-bottom:1px solid var(--rule)}
.day.done .n,.day.done .t,.day.done .lessons,.day.done .ck{color:var(--muted)}
.day .n{font-family:var(--serif);font-size:28px;font-weight:500;line-height:1;color:var(--ink)}
.day .n .lbl{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--muted);margin-top:4px;font-weight:400}
.day .t{font-size:13px;line-height:1.5;color:var(--ink2);min-width:0}
.day .t .s{display:block;font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:4px;letter-spacing:.05em}
.day .ck{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.08em;white-space:nowrap}
.day.now{background:linear-gradient(90deg,rgba(180,65,26,.06),transparent 80%);margin:0 -24px;padding-left:24px;padding-right:24px}
.day.now::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber)}
.day.now .n{color:var(--amber)}
.day.now .ck{color:var(--amber)}
.day .lessons{margin-top:8px;padding-left:0;list-style:none;font-family:var(--sans);font-size:12.5px;line-height:1.5;color:var(--ink2);grid-column:2 / -1}
.day .lessons li{padding:5px 0;border-top:1px dashed var(--rule2);display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.day .lessons li:first-child{border-top:0;padding-top:2px}
.day .lessons li .lx{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.04em;flex-shrink:0}
.day .lessons li .lt{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.day .lessons li .ls{font-family:var(--mono);font-size:10px;color:var(--muted);flex-shrink:0}
.day .lessons li.cur{color:var(--amber);font-weight:500}
.day .lessons li.cur .lx{color:var(--amber)}
.day .lessons li.done{color:var(--muted)}
.day .lessons li.done .lx{color:var(--muted)}

.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:10px;display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.kicker b{color:var(--ink);font-weight:500}
.h1{font-family:var(--serif);font-size:38px;line-height:1.2;font-weight:600;letter-spacing:-.005em;color:var(--ink)}
.lede{font-size:15px;line-height:1.7;color:var(--ink2);margin-top:18px;max-width:820px}
.meter{margin-top:32px;display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:baseline;padding-bottom:14px;border-bottom:1px solid var(--rule)}
.meter .big{font-family:var(--serif);font-size:64px;line-height:.9;font-weight:500;letter-spacing:-.02em}
.meter .big sup{font-size:22px;font-weight:500;color:var(--muted);letter-spacing:0}
.meter .mlabel{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;line-height:1.5}
.meter .mlabel b,.meter .right b{color:var(--ink);font-weight:500}
.meter .right{text-align:right;font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.08em}
.cont{margin-top:20px;padding:14px 18px;border:1px solid var(--ink);background:linear-gradient(180deg,#FBF3E8,var(--paper));display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;position:relative}
.cont::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber)}
.cont .cn-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--amber);text-transform:uppercase;font-weight:500}
.cont .cn-tt{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);line-height:1.4}
.cont .cn-tg{margin-top:4px;display:flex;gap:10px;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.06em;flex-wrap:wrap}
.cont .cn-tg span{padding:1px 6px;border:1px solid var(--rule2)}
.cont .cn-go{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:10px 16px;background:var(--ink);color:var(--paper);border:0;font-weight:500;white-space:nowrap}

.daycrit{margin-top:28px;padding:18px 22px;background:var(--rail);border:1px solid var(--rule);border-left:3px solid var(--amber)}
.daycrit .dc-head{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:500}
.daycrit .dc-head span{color:var(--ink);font-weight:600;letter-spacing:.12em}
.daycrit .dc-head b{color:var(--olive);font-weight:500;letter-spacing:.04em;text-transform:none;font-size:11.5px}
.daycrit ol{list-style:none;counter-reset:dc;margin:0;padding:0}
.daycrit ol li{counter-increment:dc;padding:8px 0 8px 30px;position:relative;font-size:14px;line-height:1.65;color:var(--ink2);border-top:1px dashed var(--rule2)}
.daycrit ol li:first-child{border-top:0;padding-top:4px}
.daycrit ol li::before{content:counter(dc,decimal-leading-zero);position:absolute;left:0;top:10px;font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.04em;font-weight:500}

.sect{margin-top:40px}
.sect h3{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:14px;margin-bottom:18px;font-weight:500;flex-wrap:wrap}
.sect h3::after{content:"";flex:1;height:1px;background:var(--rule)}
.sect h3 b{color:var(--ink);font-weight:500}
.today,.source-list{display:grid;grid-template-columns:1fr;border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.les,.source-card{border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:22px 24px;position:relative;background:var(--paper);min-width:0;display:block}
.les .ix,.source-card .ix{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.12em;display:flex;justify-content:space-between;margin-bottom:10px;gap:8px}
.les .ix b,.source-card .ix b{color:var(--ink);font-weight:500}
.les .nm,.source-card .nm{font-family:var(--serif);font-size:20px;font-weight:600;line-height:1.35;color:var(--ink);margin-bottom:10px}
.les .ex,.source-card .ex{font-size:13.5px;line-height:1.65;color:var(--ink2)}
.les.active{background:linear-gradient(180deg,#FBF3E8,var(--paper))}
.les.active::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber)}
.les.complete .ix b{color:var(--olive)}

.crumb-lite,.crumbs{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-bottom:22px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.crumb-lite b,.crumbs b{color:var(--ink);font-weight:500}
.crumbs .sep{color:var(--rule2)}
.lhead{border-bottom:1px solid var(--ink);padding-bottom:24px;margin-bottom:32px}
.lhead .kk{display:flex;gap:14px;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:14px;flex-wrap:wrap}
.lhead .kk b{color:var(--amber);font-weight:500}
.lhead h1{font-family:var(--serif);font-size:40px;line-height:1.2;font-weight:600;color:var(--ink);max-width:720px;word-break:break-word}
.lhead .by{margin-top:18px;display:flex;gap:28px;font-family:var(--mono);font-size:11.5px;color:var(--muted);flex-wrap:wrap}
.lhead .by b{color:var(--ink);font-weight:500}
.body{font-family:var(--serif);font-size:16.5px;line-height:1.85;color:var(--ink2);max-width:760px}
.body p{margin-bottom:1.15em}
.body h2{font-family:var(--sans);font-size:18px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:44px 0 18px;font-weight:600;line-height:1.45}
.body ul{margin:0 0 1.2em 0;padding:0}
.body ul li{list-style:none;padding-left:26px;position:relative;margin-bottom:.5em;font-size:16px}
.body ul li::before{content:"—";position:absolute;left:0;color:var(--amber);font-family:var(--mono);font-weight:600}
.table-wrap{overflow:auto;margin:20px 0;border:1px solid var(--rule)}
.lesson-table{width:100%;border-collapse:collapse;font-size:14px;font-family:var(--sans)}
.lesson-table th,.lesson-table td{padding:12px 14px;border-bottom:1px solid var(--rule);text-align:left;vertical-align:top}
.lesson-table th{background:var(--rail);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.code-block{margin:20px 0;padding:18px;background:#F3EDDE;border:1px solid var(--rule);overflow:auto;font-family:var(--mono);font-size:13px;line-height:1.7;white-space:pre-wrap}
.diagram-block{margin:20px 0;display:grid;gap:12px}
.diagram-surface{padding:18px;border:1px solid var(--rule);background:linear-gradient(180deg,#FBF7EF,#F6F0E4)}
.diagram-surface[data-action="open-mermaid-zoom"]{cursor:zoom-in}
.diagram-surface[data-action="open-mermaid-zoom"]:hover{border-color:var(--ink)}
.diagram-render{overflow:auto}
.diagram-render svg{display:block;min-width:min(100%,480px);height:auto;margin:0 auto}
.diagram-error{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--amber);margin-top:12px}
.diagram-error.hidden{display:none}
.diagram-source{border:1px solid var(--rule);background:var(--paper)}
.diagram-source summary{list-style:none;cursor:pointer;padding:12px 14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.diagram-source summary::-webkit-details-marker{display:none}
.diagram-source[open] summary{border-bottom:1px solid var(--rule)}
.diagram-source .code-block{margin:0;border:0;background:#F3EDDE}
.mermaid-zoom-open{overflow:hidden}
.mermaid-zoom-overlay{position:fixed;inset:0;z-index:40;background:rgba(27,24,20,.72);padding:32px;display:flex;align-items:center;justify-content:center}
.mermaid-zoom-overlay.hidden{display:none}
.mermaid-zoom-dialog{width:min(1120px,100%);max-height:100%;display:grid;grid-template-rows:auto minmax(0,1fr);background:var(--paper);border:1px solid var(--rule);box-shadow:0 24px 60px rgba(27,24,20,.24)}
.mermaid-zoom-head{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;border-bottom:1px solid var(--rule);background:linear-gradient(180deg,#FBF7EF,#F6F0E4)}
.mermaid-zoom-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.mermaid-zoom-close{padding:8px 12px;border:1px solid var(--rule2);background:var(--paper);font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);cursor:pointer}
.mermaid-zoom-content{overflow:auto;padding:24px;background:var(--paper)}
.mermaid-zoom-content svg{display:block;max-width:none;width:max-content;min-width:min(100%,720px);height:auto;margin:0 auto}
.inline-sources{display:inline-flex;gap:6px;flex-wrap:wrap;margin-left:8px}
.callout-src{display:inline-flex;align-items:center;padding:1px 6px;border:1px solid var(--rule2);font-family:var(--mono);font-size:10px;letter-spacing:.04em}
.callout-src.missing{border-color:var(--amber);color:var(--amber)}
.qblock{margin:48px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--rule)}
.qblock .qh{padding:18px 0 16px;display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--rule);gap:12px;flex-wrap:wrap}
.qblock .qh .ll{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.qblock .qh .ll b{color:var(--ink);font-weight:500;margin-right:12px}
.qblock .qh .sc{font-family:var(--mono);font-size:11px;color:var(--olive);display:flex;align-items:center;gap:6px}
.qblock .qh .sc .dot{width:6px;height:6px;background:var(--olive);border-radius:50%;display:inline-block}
.qblock .qh .sc.warn{color:var(--amber)}
.qblock .qh .sc.warn .dot{background:var(--amber)}
.qblock .qh .sc.idle{color:var(--muted)}
.qblock .qh .sc.idle .dot{background:var(--rule2)}
.qblock .qbody{padding:22px 0 24px;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.qblock .qq{font-family:var(--serif);font-size:18px;line-height:1.55;color:var(--ink);font-weight:500}
.qblock .qn{font-family:var(--mono);font-size:11px;color:var(--muted);display:block;margin-bottom:8px;letter-spacing:.1em}
.qblock .ans{font-size:14.5px;line-height:1.7;color:var(--ink2);font-family:var(--sans);border-left:2px solid var(--olive);padding:4px 0 4px 18px;background:linear-gradient(90deg,rgba(74,107,58,.06),transparent 70%)}
.qblock .ans.hidden{display:none}
.qblock .ans .lab,.free-check-points .lab,.reference-output .lab{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--olive);margin-bottom:6px;text-transform:uppercase}
.qblock .foot{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:0 0 20px;font-family:var(--mono);font-size:10.5px;color:var(--muted);flex-wrap:wrap}
.quiz-options{display:grid;gap:10px;margin-top:20px}
.quiz-option{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border:1px solid var(--rule2);background:var(--paper);text-align:left}
.quiz-option.selected{border-color:var(--ink)}
.quiz-option.correct{border-color:var(--olive);background:rgba(74,107,58,.06)}
.quiz-option.incorrect{border-color:var(--amber);background:rgba(180,65,26,.06)}
.quiz-marker{font-family:var(--mono)}
.free-check-input{width:100%;margin-top:20px;min-height:140px;padding:14px;border:1px solid var(--rule2);background:var(--paper);font:inherit;color:var(--ink2)}
.free-check-points{margin-top:18px;border:1px solid var(--rule);padding:14px;background:var(--rail)}
.free-check-points ul{margin:0;padding-left:18px}
.free-check-points li{list-style:disc;padding-left:0}
.free-check-points li::before{content:none}
.pblock{margin:28px 0 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--rule)}
.pblock .ph{padding:18px 0 16px;display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--rule);gap:12px;flex-wrap:wrap}
.pblock .ph .ll{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.pblock .ph .ll b{color:var(--ink);font-weight:500;margin-right:12px}
.pblock .ph .st{font-family:var(--mono);font-size:11px;color:var(--amber)}
.pblock .ph .st.ok{color:var(--olive)}
.pblock .pb{padding:18px;display:grid;grid-template-columns:1fr 260px;gap:24px;background:#FBF7EF}
.pblock h4{font-family:var(--serif);font-size:24px;line-height:1.4;margin-bottom:10px}
.pblock .desc{font-size:14px;line-height:1.7;color:var(--ink2);margin-bottom:18px}
.pblock .steps{padding-left:18px}
.pblock .steps li{margin-bottom:8px}
.pinfo{font-family:var(--mono);font-size:11px;color:var(--muted);display:grid;gap:10px;align-content:start}
.criteria{padding:14px;border:1px solid var(--rule);background:var(--paper)}
.criteria .ct{margin-bottom:8px;color:var(--ink)}
.criteria ul{padding-left:18px}
.practice-answer{padding:20px 0 24px}
.score-strip{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:baseline;padding:0 0 16px;border-bottom:1px solid var(--rule)}
.score-strip .big{font-family:var(--serif);font-size:44px;line-height:1}
.score-strip .big sup{font-size:18px;color:var(--muted)}
.score-strip .rt{font-family:var(--mono);font-size:11px;color:var(--muted)}
.score-strip .rt b{color:var(--ink)}
.check-list{display:grid;gap:10px;margin-top:16px}
.check-list .h{display:flex;justify-content:space-between;gap:12px;font-family:var(--mono);font-size:11px;color:var(--muted)}
.check-list li{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;padding:12px;border:1px solid var(--rule);background:var(--paper);list-style:none}
.check-list .c{font-family:var(--mono);color:var(--olive)}
.check-list .ref{font-family:var(--mono);font-size:10px;color:var(--muted)}
.reference-output{margin-top:16px;padding:14px;border:1px solid var(--rule);background:var(--paper)}
.reference-output pre{white-space:pre-wrap;font-family:var(--mono);font-size:12px;line-height:1.7}
.source-library-inline{margin-top:32px}
.source-inline-grid{display:grid;gap:12px}
.source-inline-card{display:grid;gap:6px;padding:14px;border:1px solid var(--rule);background:var(--paper)}
.source-inline-card span{font-family:var(--mono);font-size:10px;color:var(--muted)}
.source-summary-strip{margin-top:26px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.source-summary-strip div{padding:14px 16px;border:1px solid var(--rule);background:var(--rail);display:grid;gap:6px}
.source-summary-strip span{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.source-summary-strip b{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--ink)}
.source-topic-section{margin-top:28px}
.source-library-card{display:grid;gap:12px}
.source-card-meta,.usage-row{display:flex;gap:8px;flex-wrap:wrap}
.topic-chip,.usage-chip{display:inline-flex;align-items:center;padding:4px 8px;border:1px solid var(--rule2);font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.04em;min-width:0}
.usage-chip{color:var(--ink)}
.source-card-actions{display:flex;justify-content:flex-start}
.source-card-actions button[disabled]{opacity:.55;cursor:not-allowed}
.review-stack{display:grid;gap:16px;margin-top:28px}
.review-card{padding:22px 24px;border:1px solid var(--rule);background:var(--paper);display:grid;gap:14px}
.review-card.active{border-color:var(--amber);box-shadow:inset 0 0 0 1px rgba(180,65,26,.12)}
.review-card-body{max-width:none}
.review-card-body p:last-child,.review-card-body ul:last-child,.review-card-body .table-wrap:last-child,.review-card-body .code-block:last-child,.review-card-body .diagram-block:last-child{margin-bottom:0}
.settings-current-card,.settings-custom-card,.settings-pack-card{display:grid;gap:12px}
.settings-pack-card.active{border-color:var(--amber);box-shadow:inset 0 0 0 1px rgba(180,65,26,.12)}
.settings-pack-path{padding:10px 12px;border:1px solid var(--rule2);background:var(--rail);font-size:11px;line-height:1.6;color:var(--ink);overflow-wrap:anywhere}
.settings-form{display:grid;gap:12px}
.settings-label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.settings-input{width:100%;padding:12px 14px;border:1px solid var(--rule2);background:var(--paper);font:inherit;color:var(--ink)}
.settings-input:disabled{opacity:.6}
.settings-hint{font-size:10.5px;line-height:1.7;color:var(--muted)}
.settings-error{padding:12px 14px;border:1px solid rgba(180,65,26,.3);background:rgba(180,65,26,.08);font-size:13px;line-height:1.6;color:var(--amber)}
.lesson-footer-nav{margin-top:48px;padding-top:20px;border-top:1px solid var(--ink);display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.lesson-prev-next{font-size:11px;color:var(--muted);letter-spacing:.1em}
.lesson-prev-next{display:flex;gap:14px;flex-wrap:wrap}
.lesson-prev-next a{color:var(--ink)}
.placeholder-panel{margin-top:40px;padding:18px 22px;border:1px solid var(--rule);background:var(--rail);max-width:760px}
.placeholder-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin-bottom:10px}
.lesson-actions{margin-top:18px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.btn{padding:10px 14px;border:1px solid var(--ink);cursor:pointer}
.btn.solid{background:var(--ink);color:var(--paper)}
.btn.ghost{background:transparent;color:var(--ink)}
.lesson-progress-note{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted)}
.boot-error{padding:24px;white-space:pre-wrap}

@container page (max-width: 640px){
  .home{grid-template-columns:1fr;grid-template-areas:"rail" "main";min-height:0}
  .rail{border-right:0;border-bottom:1px solid var(--rule);padding:0}
  .main{padding:22px 20px 28px}
  .main-body{width:100%}
  .reading{padding:24px 18px 48px}
  .today,.source-list{grid-template-columns:1fr}
  .les,.source-card{padding:18px 20px}
  .topbar{padding:14px 20px}
  .brand .sub{display:none}
  .topbar .meta{gap:14px;font-size:11px;width:100%;justify-content:space-between}
  .topbar .meta .hide-sm{display:none}
  .rail-toggle{padding:6px 8px;font-size:10px}
  .h1{font-size:29px;line-height:1.28}
  .lede{font-size:15.5px;line-height:1.8}
  .meter{grid-template-columns:1fr;gap:12px}
  .cont{grid-template-columns:1fr;gap:10px;padding:14px}
  .cont .cn-tt{font-size:18px;line-height:1.5}
  .cont .cn-go{width:100%;text-align:center;padding:12px}
  .kicker{flex-direction:column;gap:4px;align-items:flex-start}
  .day{grid-template-columns:32px 1fr auto;padding:10px 12px}
  .day .n{font-size:24px}
  .day .t{font-size:14px;line-height:1.65}
  .day .lessons{font-size:13.5px;line-height:1.65}
  .day.now{margin:0}
  .day .lessons li .lt{white-space:normal}
  .les .nm,.source-card .nm{font-size:22px;line-height:1.4}
  .les .ex,.source-card .ex{font-size:14.5px;line-height:1.75}
  .lhead h1{font-size:29px;line-height:1.28}
  .lhead .by{gap:12px 18px;font-size:11.5px}
  .body{font-size:16.5px;line-height:1.9}
  .body h2{font-size:19px;line-height:1.5}
  .body ul li{font-size:16.5px;line-height:1.85}
  .lesson-table{font-size:14.5px}
  .qblock .qq{font-size:19px;line-height:1.65}
  .qblock .ans{font-size:15.5px;line-height:1.8}
  .quiz-option{font-size:15px;line-height:1.7}
  .free-check-input{font-size:15.5px;line-height:1.8}
  .pblock h4{font-size:26px;line-height:1.45}
  .pblock .desc{font-size:15.5px;line-height:1.8}
  .check-list li{font-size:15px;line-height:1.75}
  .source-summary-strip{grid-template-columns:1fr}
  .source-card-actions .btn,.usage-chip,.topic-chip{max-width:100%}
  .usage-row{gap:6px}
  .review-card{padding:18px}
  .qblock .qbody,.pblock .pb,.score-strip{grid-template-columns:1fr}
  .lesson-footer-nav{align-items:stretch}
  .diagram-surface{padding:14px}
  .diagram-render svg{min-width:320px}
  .mermaid-zoom-overlay{padding:16px}
  .mermaid-zoom-head{padding:14px 16px;align-items:flex-start;flex-direction:column}
  .mermaid-zoom-content{padding:16px}
  .mermaid-zoom-content svg{min-width:0}
}
