:root{--bg: #e7e0cf;--bg2: #f0e9d8;--card: #fbf7ee;--card2: #efe7d4;--ink: #17160f;--muted: #6c6555;--line: #17160f;--brand: #17160f;--brand2: #17160f;--accent: #fb4d1e;--cobalt: #2b46ff;--yellow: #ffd83e;--yellow-soft: #fdf3cf;--soft: #d8d0bd;--easy: #1c9a52;--medium: #c5841a;--hard: #e23a1d;--good: #1c9a52;--bad: #d62f1f;--goodbg: #e6f1e8;--badbg: #fbe6e1;--gold: #caa219;--gold-soft: #fbeec2;--gold-ink: #8a6d12;--silver: #9aa0a6;--silver-soft: #eceef0;--bronze: #c08457;--bronze-soft: #f3e2d4;--shadow: 4px 4px 0 var(--ink);--r: 9px;--font-body: "Avenir Next", "Avenir", "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;--font-head: "Futura", "Avenir Next Condensed", "Avenir Next", "Arial Black", system-ui, sans-serif;--font-mono: "Courier New", "Courier", ui-monospace, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);line-height:1.55;min-height:100vh;background-color:var(--bg)}a{color:var(--brand)}::selection{background:#ffd83e;color:var(--ink)}.wrap{max-width:1080px;margin:0 auto;padding:20px 18px 80px}header.app{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:14px 0 18px;border-bottom:2px solid var(--ink);margin-bottom:24px}.logo{width:64px;height:64px;border-radius:10px;flex:0 0 auto;background:var(--accent);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--ink);display:grid;place-items:center;font-weight:800;font-size:17px;color:#fff;font-family:var(--font-head);letter-spacing:.5px;transform:rotate(-4deg);cursor:pointer}.title h1{font-family:var(--font-head);font-size:22px;margin:0;font-weight:800;letter-spacing:-.2px}.title p{margin:3px 0 0;color:var(--muted);font-size:12.5px;font-weight:600}.spacer{flex:1}.countdown{text-align:right;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:700}.countdown b{display:block;font-size:26px;color:var(--accent);font-weight:800;line-height:1;font-family:var(--font-head)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--ink);background:var(--card2);color:var(--ink);padding:9px 14px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .1s,box-shadow .1s;display:inline-flex;align-items:center;gap:8px;box-shadow:2px 2px 0 var(--ink);font-family:var(--font-body)}.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.btn.primary{background:var(--brand);color:#fff}.btn.ghost{background:transparent;box-shadow:none;border-width:1.5px}.btn.ghost:hover{background:var(--card2);box-shadow:2px 2px 0 var(--ink)}.btn.sm{padding:6px 11px;font-size:13px}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:2px 2px 0 var(--ink)}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.grid{display:grid;gap:16px}.modes{grid-template-columns:repeat(5,1fr);margin-bottom:28px}@media (max-width: 900px){.modes{grid-template-columns:repeat(3,1fr)}}@media (max-width: 560px){.modes{grid-template-columns:repeat(2,1fr)}}.mode{background:var(--card);border:2px solid var(--ink);border-radius:var(--r);padding:18px 16px;cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative;box-shadow:4px 4px 0 var(--ink)}.mode:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--accent)}.mode .ic{font-size:28px;line-height:1}.mode h3{margin:12px 0 4px;font-size:16px;font-family:var(--font-head);font-weight:800;letter-spacing:-.2px}.mode p{margin:0;color:var(--muted);font-size:12px;font-weight:600}.section-h{display:flex;align-items:center;gap:12px;margin:10px 0 16px}.section-h h2{font-family:var(--font-head);font-size:14px;margin:0;color:var(--ink);font-weight:800;text-transform:uppercase;letter-spacing:1.5px}.section-h .line{flex:1;height:2px;background:var(--ink)}.stats{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}.stat{background:var(--card);border:2px solid var(--ink);border-radius:8px;padding:10px 14px;min-width:96px;box-shadow:3px 3px 0 var(--ink)}.stat b{display:block;font-size:22px;font-family:var(--font-head);font-weight:800}.stat span{color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;font-weight:700}.chapters{grid-template-columns:repeat(2,1fr)}@media (max-width: 820px){.chapters{grid-template-columns:1fr}}.chapter{background:var(--card);border:2px solid var(--ink);border-radius:10px;padding:15px 16px;display:flex;flex-direction:column;gap:11px;box-shadow:3px 3px 0 var(--ink);transition:transform .12s,box-shadow .12s}.chapter:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--brand)}.chapter .top{display:flex;align-items:flex-start;gap:12px}.chapter .num{width:36px;height:36px;border-radius:7px;flex:0 0 auto;display:grid;place-items:center;font-weight:800;background:var(--ink);color:var(--card);border:2px solid var(--ink);font-family:var(--font-head)}.chapter h4{margin:0;font-size:14.5px;font-weight:800;font-family:var(--font-head);letter-spacing:-.1px}.chapter .meta{color:var(--muted);font-size:12px;margin-top:3px;font-weight:600}.chapter .bar{height:10px;background:var(--bg2);border-radius:0;overflow:hidden;border:2px solid var(--ink)}.chapter .bar i{display:block;height:100%;background:var(--brand);width:0%}.chapter .acts{display:flex;gap:8px;justify-content:space-between;align-items:center}.chapter .acts .pct{color:var(--muted);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;border:1.5px solid var(--ink)}.badge.easy{color:#0f5f31;background:#d8efdf}.badge.medium{color:#7a5208;background:#fbeccb}.badge.hard{color:#8f2113;background:#fbdcd4}.badge.type{color:#142a99;background:#dde2ff}.badge.src{color:#9c2f12;background:#ffe1d6}.badge.topic{color:var(--ink);background:var(--card2)}.study-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.study-top h2{font-family:var(--font-head);font-size:18px;margin:0;font-weight:800;letter-spacing:-.2px}.progress{flex:1;min-width:160px;height:12px;background:var(--bg2);border:2px solid var(--ink);border-radius:0;overflow:hidden}.progress i{display:block;height:100%;background:var(--brand);width:0%}.counter{color:var(--muted);font-size:13px;font-variant-numeric:tabular-nums;font-weight:700;font-family:var(--font-mono)}.fc-scene{perspective:1600px;margin:0 auto;max-width:760px}.fc{position:relative;display:grid;width:100%;min-height:340px;cursor:pointer;transform-style:preserve-3d;-webkit-transform-style:preserve-3d;transition:transform .5s cubic-bezier(.2,.7,.2,1);will-change:transform}.fc.flipped{transform:rotateY(180deg);-webkit-transform:rotateY(180deg)}.fc .face{position:relative;grid-area:1 / 1;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:12px;border:2px solid var(--ink);padding:30px 34px;display:flex;flex-direction:column;box-shadow:7px 7px 0 var(--ink);overflow:hidden;transition:opacity 0s linear .25s}.fc .front{opacity:1;background-color:#fdf8ea;background-image:repeating-linear-gradient(transparent 0 32px,#2b46ff1a 32px,#2b46ff1a 33px)}.fc.flipped .front,.fc .back{opacity:0;pointer-events:none}.fc.flipped .back{opacity:1;pointer-events:auto}.fc .front:before{content:"";position:absolute;left:52px;top:0;bottom:0;width:2px;background:#fb4d1e80}.fc .front:after{content:"";position:absolute;left:0;right:0;top:58px;height:2px;background:#fb4d1e66}.fc .back{transform:rotateY(180deg);-webkit-transform:rotateY(180deg);background:#eef0ff;background-image:repeating-linear-gradient(transparent 0 32px,#17160f0f 32px,#17160f0f 33px)}.fc .face .tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px;position:relative;z-index:1}.fc .qa{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;z-index:1}.fc .qa .txt{font-size:21px;font-weight:700;max-width:60ch;white-space:pre-wrap;font-family:var(--font-head);letter-spacing:-.2px}.fc .back .qa .txt{font-size:18px;font-weight:600;text-align:left;line-height:1.6;font-family:var(--font-body)}.fc .label{position:absolute;top:14px;right:18px;font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;font-weight:800;font-family:var(--font-mono);z-index:1}.fc .hint{text-align:center;color:var(--muted);font-size:11.5px;margin-top:10px;position:relative;z-index:1;font-weight:600}.fc .expl{margin-top:14px;padding:12px 14px;background:#fff;border:2px solid var(--ink);border-radius:9px;color:var(--ink);font-size:13.5px;white-space:pre-wrap;position:relative;z-index:1}.fc .expl b{color:var(--accent)}.controls{display:flex;align-items:center;justify-content:center;gap:12px;margin:20px 0 8px;flex-wrap:wrap}.iconbtn{width:48px;height:48px;border-radius:9px;display:grid;place-items:center;font-size:20px;border:2px solid var(--ink);background:var(--card);color:var(--ink);cursor:pointer;transition:transform .1s,box-shadow .1s;box-shadow:3px 3px 0 var(--ink)}.iconbtn:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--ink)}.iconbtn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.iconbtn.big{width:60px;height:60px;font-size:24px;background:var(--brand);color:#fff}.toolbar{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:8px;color:var(--muted);font-size:12.5px;align-items:center;font-weight:600}.toolbar label{display:flex;align-items:center;gap:6px;cursor:pointer}.switch{gap:8px}.switch input{position:absolute;width:1px;height:1px;opacity:0;margin:0}.switch-track{flex:none;display:inline-flex;align-items:center;width:38px;height:22px;padding:2px;border:2px solid var(--ink);border-radius:999px;background:var(--card2);transition:background .15s}.switch-thumb{width:14px;height:14px;border-radius:50%;background:var(--ink);transition:transform .15s,background .15s}.switch input:checked+.switch-track{background:var(--good)}.switch input:checked+.switch-track .switch-thumb{transform:translate(16px);background:#fff}.switch input:focus-visible+.switch-track{box-shadow:0 0 0 3px var(--accent)}.fc-star{position:absolute;top:12px;right:14px;z-index:2;background:none;border:none;padding:4px;font-size:20px;line-height:1;color:var(--muted);opacity:.45;cursor:pointer;transition:opacity .12s,color .12s,transform .12s}.fc-star:hover{opacity:1;transform:scale(1.12)}.fc-star.on{opacity:1;color:#e8a90c}.iconbtn.check{background:var(--goodbg);color:var(--good)}.iconbtn.cross{background:var(--badbg);color:var(--bad)}.iconbtn.check.sel{background:var(--good);color:#fff}.iconbtn.cross.sel{background:var(--bad);color:#fff}.iconbtn.check.active,.iconbtn.cross.active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.controls-wrap{position:relative}.srs-pop-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:19}.srs-pop{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%);z-index:20;display:flex;gap:8px;padding:8px;background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:var(--shadow);animation:srs-pop-in .12s ease-out}@keyframes srs-pop-in{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.96)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.srs-pop:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:8px solid transparent;border-top-color:var(--ink)}.srs-pop-opt{flex:1;max-width:170px;padding:11px 12px;border:2px solid var(--ink);border-radius:9px;background:var(--card);color:var(--ink);cursor:pointer;font-family:var(--font-head);font-weight:800;font-size:13px;line-height:1.15;text-align:center;box-shadow:2px 2px 0 var(--ink);transition:transform .1s,box-shadow .1s}.srs-pop-opt:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.srs-pop-opt:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.srs-pop-opt.soon{background:#cf2e1e;color:#fff}.srs-pop-opt.later{background:#f0916a;color:var(--ink)}.srs-pop-opt.tomorrow{background:#79c08d;color:var(--ink)}.srs-pop-opt.done{background:#178a48;color:#fff}@media (max-width: 480px){.srs-pop{flex-direction:column;width:min(86vw,280px)}.srs-pop-opt{max-width:none}}.review-banner{background:var(--accent);box-shadow:4px 4px 0 var(--ink)}.review-banner .cb-label{color:#fff}.review-banner .cb-topic{color:#fff;opacity:.85}select,input[type=text]{background:var(--card);border:2px solid var(--ink);color:var(--ink);border-radius:7px;padding:8px 10px;font-size:13.5px;font-weight:600;font-family:var(--font-body)}.qcard{max-width:760px;margin:0 auto;background:var(--card);border:2px solid var(--ink);border-radius:12px;padding:26px;box-shadow:6px 6px 0 var(--ink)}.qcard .tags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}.qcard .q{font-size:20px;font-weight:700;white-space:pre-wrap;font-family:var(--font-head);letter-spacing:-.2px}.opts{display:grid;gap:10px;margin-top:18px}.opt{text-align:left;border:2px solid var(--ink);background:var(--card);color:var(--ink);padding:12px 14px;border-radius:9px;cursor:pointer;font-size:15px;transition:.1s;display:flex;gap:11px;align-items:center;font-weight:600;box-shadow:2px 2px 0 var(--ink)}.opt:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.opt .k{width:25px;height:25px;border-radius:6px;flex:0 0 auto;display:grid;place-items:center;background:var(--card2);border:1.5px solid var(--ink);font-size:12.5px;font-weight:800;color:var(--ink);font-family:var(--font-mono)}.opt.sel{background:var(--yellow-soft);box-shadow:2px 2px 0 var(--accent)}.opt.correct{background:var(--goodbg);border-color:var(--good);box-shadow:2px 2px 0 var(--good)}.opt.correct .k{background:var(--good);color:#fff;border-color:var(--ink)}.opt.wrong{background:var(--badbg);border-color:var(--bad);box-shadow:2px 2px 0 var(--bad)}.opt.wrong .k{background:var(--bad);color:#fff;border-color:var(--ink)}.opt.correct:after,.opt.wrong:after{margin-left:auto;padding-left:10px;font-weight:800;font-size:16px;line-height:1}.opt.correct:after{content:"✓";color:var(--good)}.opt.wrong:after{content:"✗";color:var(--bad)}.opt.muteline{opacity:.7}.reveal{margin-top:18px;padding:16px;border-radius:10px;border:2px solid var(--ink);background:#fff;white-space:pre-wrap;font-size:15px;line-height:1.6}.reveal .lbl{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);font-weight:800;margin-bottom:6px;font-family:var(--font-mono)}.expl2{margin-top:12px;color:var(--muted);font-size:13.5px}.feedback{margin-top:16px;font-weight:800;display:flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:16px}.feedback.good{color:var(--good)}.feedback.bad{color:var(--bad)}.selfgrade{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}.blist{display:grid;gap:10px}.bitem{background:var(--card);border:2px solid var(--ink);border-radius:10px;padding:14px 16px;box-shadow:2px 2px 0 var(--ink)}.bitem .bq{font-weight:700;cursor:pointer;display:flex;justify-content:space-between;gap:10px;font-family:var(--font-body)}.bitem .bq .chev{color:var(--accent);transition:.2s;font-weight:800}.bitem.open .chev{transform:rotate(90deg)}.bitem .ba{display:none;margin-top:10px;padding-top:12px;border-top:2px solid var(--ink);white-space:pre-wrap;color:var(--ink)}.bitem.open .ba{display:block}.bitem .btags{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}.bitem .opt-line{margin:4px 0 0 2px;color:var(--muted);font-size:13.5px}.bitem .opt-line.cor{color:var(--good);font-weight:700}.result{max-width:760px;margin:0 auto;text-align:center}.score-ring{font-size:72px;font-weight:800;margin:8px 0;font-family:var(--font-head)}.score-sub{color:var(--muted);margin-bottom:20px;font-weight:600}.rev-item{text-align:left;background:var(--card);border:2px solid var(--ink);border-left-width:7px;border-radius:9px;padding:13px 15px;margin-bottom:10px;box-shadow:2px 2px 0 var(--ink)}.rev-item.ok{border-left-color:var(--good)}.rev-item.no{border-left-color:var(--bad)}.rev-item .rq{font-weight:700;margin-bottom:6px}.rev-item .ra{font-size:13.5px;color:var(--muted);white-space:pre-wrap}.empty{color:var(--muted);text-align:center;padding:50px;font-weight:600}.kbd{display:inline-block;border:1.5px solid var(--ink);background:var(--card);border-radius:5px;padding:1px 7px;font-size:12px;color:var(--ink);font-family:var(--font-mono);box-shadow:1px 1px 0 var(--ink)}.hide{display:none!important}footer{margin-top:44px;padding-top:16px;border-top:2px solid var(--ink);text-align:center;color:var(--muted);font-size:12px;font-weight:600}.lesson{width:100%}.lsec{margin:0 0 28px}.lh{font-family:var(--font-head);font-size:19px;margin:0 0 12px;color:var(--ink);font-weight:800;border-left:5px solid var(--accent);padding-left:12px;letter-spacing:-.3px}.lp{margin:0 0 11px;color:var(--ink);font-size:15.5px;line-height:1.72;max-width:70ch}.lp-h{font-family:var(--font-head);font-weight:800;font-size:15.5px;color:var(--ink);margin:15px 0 8px;letter-spacing:-.2px}.lp-h:first-child{margin-top:0}h5.lp-h{font-size:14px;color:var(--ink-soft, var(--ink))}.lp-list{margin:0 0 11px;padding-left:22px;color:var(--ink);font-size:15.5px;line-height:1.72;max-width:70ch}.lp-list li{margin:3px 0}.lp code,.lp-list code,.lformula code,.lnote code,.lex-q code,.lex-step code,.lfline code{background:var(--card2);border:1px solid var(--ink);border-radius:4px;padding:1px 6px;font-family:var(--font-mono);font-size:.9em;color:#142a99}.lformula{background:#fff;border:2px solid var(--ink);border-left:6px solid var(--brand);border-radius:8px;padding:12px 14px;margin:0 0 12px;font-family:var(--font-mono);font-size:14px;color:var(--ink);white-space:pre-wrap;overflow-x:auto;box-shadow:3px 3px 0 var(--ink)}.lmath{margin:12px 0;padding:6px 2px;text-align:center;overflow-x:auto;overflow-y:hidden}.lmath .katex-display{margin:0}.lnote{background:#fff7d6;border:2px solid var(--ink);border-radius:8px;padding:11px 14px;margin:0 0 12px;font-size:13.5px;color:var(--ink);box-shadow:2px 2px 0 var(--ink)}.lnote b{color:var(--accent)}.lbody em{font-style:italic}.lbody a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}.lbody a:hover{color:#b45309}.lq{border-left:4px solid var(--accent, #f59e0b);margin:8px 0;padding:4px 0 4px 14px;color:#444;font-style:italic}.ldiagram{background:#fff;border:2px solid var(--ink);border-radius:12px;padding:18px;margin:8px 0 14px;box-shadow:3px 3px 0 var(--ink)}.lvideo{background:#000;border:2px solid var(--ink);border-radius:12px;margin:8px 0 14px;box-shadow:3px 3px 0 var(--ink);overflow:hidden}.lvideo video{display:block;width:100%;height:auto}.lexample{background:#fff;border:2px solid var(--ink);border-left:6px solid var(--medium);border-radius:10px;padding:14px 16px;margin:8px 0 14px;box-shadow:3px 3px 0 var(--ink)}.lex-h{font-family:var(--font-mono);font-size:12px;color:var(--medium);margin-bottom:8px;letter-spacing:.4px;text-transform:uppercase;font-weight:700}.lex-q{font-size:14.5px;color:var(--ink);line-height:1.6;font-weight:600}.lex-sol{margin-top:12px}.lex-step{display:flex;gap:10px;align-items:flex-start;margin:8px 0;font-size:14px;color:var(--ink);line-height:1.55}.lex-n{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--ink);border:none;display:grid;place-items:center;font-size:11px;color:#fff;font-weight:800;font-family:var(--font-mono)}.lex-a{margin-top:12px;padding-top:10px;border-top:2px dashed var(--ink);font-size:14.5px;color:var(--ink)}.lex-a b{color:var(--accent)}.lformbox{max-width:100%;background:var(--ink);color:#f3eee0;border:1px solid var(--ink);border-radius:12px;padding:16px 18px;margin:8px 0 18px}.lfh{font-family:var(--font-head);font-size:15px;font-weight:800;margin-bottom:10px}.lfline{font-family:var(--font-mono);font-size:13.5px;color:#ffd9c9;padding:6px 0;border-bottom:1px dashed #5b5446}.lfline:last-child{border-bottom:none}.lpractice{max-width:100%;margin:14px 0 0;padding-top:20px;border-top:1px solid var(--soft)}.logo{background:#ffd83e;padding:3px}.logo svg,.logo img{width:100%;height:100%;display:block;object-fit:contain}#userarea{display:flex;align-items:center;gap:10px}.userchip{display:inline-flex;align-items:center;gap:7px;background:var(--card2);border:2px solid var(--ink);border-radius:20px;padding:5px 12px;font-weight:800;font-size:13px;font-family:inherit;color:var(--ink);cursor:pointer;box-shadow:2px 2px 0 var(--ink)}.usermenu{position:relative}.userchip-caret{font-size:10px;margin-left:2px;transition:transform .15s}.usermenu.open .userchip-caret{transform:rotate(180deg)}.usermenu-dd{position:absolute;top:calc(100% + 8px);right:0;min-width:190px;background:var(--card2);border:2px solid var(--ink);border-radius:12px;box-shadow:3px 3px 0 var(--ink);padding:6px;display:none;flex-direction:column;gap:4px;z-index:60}.usermenu.open .usermenu-dd{display:flex}.usermenu-item{text-align:left;background:transparent;border:2px solid transparent;border-radius:8px;padding:8px 10px;font-family:inherit;font-weight:700;font-size:13px;color:var(--ink);cursor:pointer}.usermenu-item:hover{background:var(--card);border-color:var(--ink)}.usermenu-item.danger{color:var(--bad)}.usermenu-item.danger:hover{background:var(--badbg);border-color:var(--bad)}.udot{width:8px;height:8px;border-radius:50%;background:var(--good);display:inline-block}.brand-foot{display:inline-flex;align-items:center;gap:7px}.brand-foot a{font-weight:800;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--accent)}.foot-sloth{width:20px;height:20px;vertical-align:middle}.authwrap{max-width:380px;margin:6vh auto 0}.authcard{background:var(--card);border:2px solid var(--ink);border-radius:14px;box-shadow:6px 6px 0 var(--ink);padding:26px}.auth-h{font-family:var(--font-head);font-size:24px;font-weight:800;margin-bottom:4px}.auth-sub{color:var(--muted);font-size:13.5px;margin:0 0 18px;font-weight:600}.authcard input{display:block;width:100%;margin-bottom:12px;padding:11px 13px;font-size:15px}.auth-err{background:var(--badbg);border:2px solid var(--bad);color:#8f2113;border-radius:8px;padding:9px 12px;font-size:13px;font-weight:700;margin-bottom:12px}.auth-toggle{margin-top:14px;text-align:center;color:var(--muted);font-size:13px;font-weight:600}.auth-toggle a{color:var(--brand);font-weight:800}.lb-sub{margin:-6px 0 4px;color:var(--muted);font-weight:600}.av{display:inline-grid;place-items:center;width:34px;height:34px;flex:0 0 auto;border-radius:50%;border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);color:#fff;font-family:var(--font-head);font-weight:800;font-size:15px;line-height:1}.av-lg{width:60px;height:60px;font-size:26px;box-shadow:3px 3px 0 var(--ink)}.climb{display:flex;align-items:center;gap:16px;background:var(--yellow-soft);border:2px solid var(--ink);border-radius:14px;box-shadow:5px 5px 0 var(--ink);padding:16px 18px;margin:18px 0 24px}.climb-king{background:#fff4d6;border-color:var(--gold);box-shadow:5px 5px 0 var(--gold)}.climb-join{background:var(--card)}.climb-rank{flex:0 0 auto;min-width:60px;text-align:center}.climb-num{display:block;font-family:var(--font-head);font-weight:800;font-size:34px;line-height:1;color:var(--accent)}.climb-king .climb-num{color:var(--gold)}.climb-q{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:50%;border:2px dashed var(--ink);font-family:var(--font-head);font-weight:800;font-size:26px;color:var(--muted)}.climb-of{display:block;margin-top:2px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.climb-body{flex:1;min-width:0}.climb-title{font-family:var(--font-head);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.climb-msg{font-family:var(--font-head);font-weight:800;font-size:19px;line-height:1.25;margin:2px 0 9px}.climb-track{height:12px;background:var(--card2);border:2px solid var(--ink);border-radius:8px;overflow:hidden}.climb-track i{display:block;height:100%;background:var(--accent);transition:width .5s ease}.climb-king .climb-track i{background:var(--gold)}.climb-target{flex:0 0 auto;text-align:center}.climb-target-rank{display:block;margin-top:3px;font-family:var(--font-head);font-weight:800;font-size:12px;color:var(--muted)}.podium{display:grid;grid-template-columns:repeat(3,1fr);align-items:end;gap:12px;margin:18px 0 26px}.pod{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--ink);padding:18px 12px 0}.pod1{order:2;border-color:var(--gold);box-shadow:6px 6px 0 var(--gold)}.pod2{order:1;box-shadow:5px 5px 0 var(--silver)}.pod3{order:3;box-shadow:5px 5px 0 var(--bronze)}.pod.me{outline:3px dashed var(--brand);outline-offset:3px}.pod-crown{position:absolute;top:-19px;font-size:26px}.pod-name{font-family:var(--font-head);font-weight:800;font-size:15px;margin:9px 0 7px;word-break:break-word}.pod-big{font-family:var(--font-head);font-weight:800;font-size:28px;line-height:1;color:var(--accent)}.pod-big span{display:block;margin-top:2px;font-family:var(--font-body);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}.pod-sub{margin-top:6px;font-size:11.5px;font-weight:700;color:var(--muted)}.pod .ach{flex-basis:auto;justify-content:center;margin-top:10px}.pod-base{width:calc(100% + 24px);margin:14px -12px 0;border-top:2px solid var(--ink);display:grid;place-items:center;font-family:var(--font-head);font-weight:800;color:var(--muted);border-radius:0 0 10px 10px}.pod1 .pod-base{height:56px;font-size:30px;background:var(--gold-soft);color:var(--gold-ink)}.pod2 .pod-base{height:42px;font-size:24px;background:var(--silver-soft)}.pod3 .pod-base{height:32px;font-size:22px;background:var(--bronze-soft)}.ladder{display:flex;flex-direction:column;gap:8px}.lrow{display:flex;align-items:center;gap:12px;background:var(--card);border:2px solid var(--ink);border-radius:10px;box-shadow:2px 2px 0 var(--ink);padding:9px 14px}.lrow.me{background:#fff4d6;box-shadow:3px 3px 0 var(--accent)}.lrow-rank{flex:0 0 auto;min-width:26px;text-align:center;font-family:var(--font-head);font-weight:800;font-size:17px;color:var(--muted)}.lrow-main{flex:1;min-width:0}.lrow-name{display:flex;align-items:center;gap:8px;font-weight:800;font-size:14px;word-break:break-word}.lrow-you{font-size:10px;font-weight:800;background:var(--brand);color:#fff;border-radius:10px;padding:1px 7px}.lrow-bar{height:7px;margin-top:5px;background:var(--card2);border:1.5px solid var(--ink);border-radius:5px;overflow:hidden}.lrow-bar i{display:block;height:100%;background:var(--accent);transition:width .4s ease}.lrow-stats{flex:0 0 auto;display:flex;gap:14px;font-size:11.5px;font-weight:700;color:var(--muted)}.lrow-stats span{min-width:62px;text-align:right}.lrow-stats b{color:var(--ink);font-family:var(--font-head);font-size:15px}.lrow .ach{flex-basis:auto;margin-top:0}.lrow-res{flex:0 0 auto;font-family:var(--font-head);font-weight:800;font-size:12.5px;padding:3px 9px;border:2px solid var(--ink);border-radius:999px;white-space:nowrap}.lrow-res.good{background:var(--goodbg);color:var(--good)}.lrow-res.bad{background:var(--badbg);color:var(--bad)}.vs-tally{text-align:center;font-family:var(--font-head);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin:4px 0 12px}@media (max-width: 620px){.podium{grid-template-columns:1fr}.pod1{order:1}.pod2{order:2}.pod3{order:3}.pod-base{height:auto!important;padding:7px 0}.climb{flex-wrap:wrap;gap:12px}.climb-body{flex-basis:100%;order:3}}@media (max-width: 560px){.lrow{flex-wrap:wrap}.lrow-stats{width:100%;padding-left:38px}}.lesson-tip{margin-top:14px;padding:11px 13px;background:#fff4d6;border:2px solid var(--ink);border-radius:9px;font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rev-lesson{margin-top:8px}.lwidget{margin:8px 0 16px}.lwidget-frame{margin:10px 0 18px}.lwidget-caption{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:6px;text-align:right}.lwidget-iframe{width:100%;min-height:120px;border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--ink);background:#fbf7ee;display:block}.pg{background:#fff;border:2px solid var(--ink);border-radius:12px;box-shadow:3px 3px 0 var(--ink);overflow:hidden}.pg-h{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--ink);color:#f3eee0}.pg-tag{font-family:var(--font-mono);font-size:10px;background:var(--accent);color:#fff;padding:2px 7px;border-radius:4px;font-weight:700}.pg-title{font-family:var(--font-head);font-weight:800;font-size:14px}.pg-sub{color:#bdb6a5;font-size:12px;margin-left:auto}.pg-body{padding:16px}.pg-caption{color:var(--muted);font-size:12px;margin:8px 0;font-weight:600}.pg-status{margin-top:10px;font-size:13.5px;color:var(--ink);font-weight:600}.pg-ctrls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px}.pg-ctrls.col{flex-direction:column;align-items:stretch}.pg-slider{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);font-weight:700}.pg-slabel{min-width:92px}.pg-snum{font-family:var(--font-mono);color:var(--ink);min-width:34px;text-align:right}.pg input[type=range]{flex:1;accent-color:var(--brand);height:6px}.pg-bars{display:flex;flex-direction:column;gap:7px}.pg-brow{display:flex;align-items:center;gap:10px}.pg-blabel{min-width:118px;font-size:13px;font-weight:600;color:var(--muted);font-family:var(--font-mono)}.pg-brow.kept .pg-blabel{color:var(--ink)}.pg-btrack{flex:1;height:18px;background:var(--bg2);border:1.5px solid var(--ink);border-radius:5px;overflow:hidden}.pg-bfill{height:100%;transition:width .25s}.pg-num{min-width:104px;text-align:right;font-size:12px;font-family:var(--font-mono);color:var(--ink)}.pg-eq{margin-top:12px;font-family:var(--font-mono);font-size:13.5px;background:var(--bg2);border:1.5px solid var(--ink);border-radius:7px;padding:9px 12px}.pg-eq b{color:var(--brand)}.pg-segwrap{display:flex;align-items:center;gap:10px}.pg-seg{display:inline-flex;border:2px solid var(--ink);border-radius:8px;overflow:hidden}.pg-seg button{border:none;background:var(--card);color:var(--ink);padding:7px 12px;font-weight:700;cursor:pointer;font-size:13px;border-right:2px solid var(--ink)}.pg-seg button:last-child{border-right:none}.pg-seg button.on{background:var(--brand);color:#fff}.pg-extra{margin-top:4px}.pg-pick{font-family:var(--font-head);font-size:16px;color:var(--accent);font-weight:800;min-width:60px}.pg-tally{margin-top:12px;display:flex;flex-direction:column;gap:5px}.pg-trow{display:flex;align-items:center;gap:8px;font-size:12px}.pg-tk{font-family:var(--font-mono);min-width:60px}.pg-tbar{height:12px;background:var(--accent);border:1px solid var(--ink);border-radius:3px;min-width:2px}.pg-tn{font-family:var(--font-mono);color:var(--muted)}.pg-op{font-family:var(--font-head);font-size:18px;font-weight:800}.tokrow{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}.tok{padding:7px 12px;border:2px solid var(--ink);border-radius:8px;background:var(--card);font-weight:700;font-size:14px;transition:.15s}.tok.cur{background:var(--brand);color:#fff;transform:translateY(-2px)}.tok.done{opacity:.5}.hcells{display:flex;gap:6px;margin:6px 0}.hcell{flex:1;height:34px;border:2px solid var(--ink);border-radius:6px;background:#fff;transition:background .3s}.pg-canvaswrap{background:var(--bg2);border:1.5px solid var(--ink);border-radius:8px;padding:8px}.vs-wait{text-align:center;padding:40px 0}.vs-spin{font-size:46px;animation:vspin 1.4s ease-in-out infinite}@keyframes vspin{0%,to{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}.vs-lobby{display:flex;justify-content:center;margin:10px 0 16px}.vs-pinwrap{background:var(--ink);color:#fbf7ee;border:2px solid var(--ink);border-radius:14px;box-shadow:5px 5px 0 var(--accent);padding:18px 30px;text-align:center}.vs-pinlabel{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;color:#bdb6a5}.vs-pin{font-family:var(--font-head);font-size:52px;font-weight:800;letter-spacing:10px;line-height:1.1}.vs-meta{font-size:12px;color:#bdb6a5;font-weight:700;margin-top:4px}.vs-players{display:flex;flex-wrap:wrap;gap:10px}.vs-player{display:flex;align-items:center;gap:9px;background:var(--card);border:2px solid var(--ink);border-radius:24px;padding:6px 14px 6px 6px;font-weight:800;box-shadow:2px 2px 0 var(--ink)}.vs-player.me{background:#fff4d6}.vs-av{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--font-head)}.vs-tag{font-size:10px;background:var(--accent);color:#fff;border-radius:10px;padding:1px 7px}.vs-waitmsg{color:var(--muted);font-weight:700;align-self:center}.vs-settings{display:flex;flex-direction:column;gap:10px;background:var(--card);border:2px solid var(--ink);box-shadow:var(--shadow);border-radius:14px;padding:14px 16px;margin-bottom:14px}.vs-setrow{display:flex;align-items:center;justify-content:space-between;gap:12px}.vs-setrow-chips{flex-direction:column;align-items:flex-start;gap:8px}.vs-setlabel{font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:12px}.vs-settings select{border:2px solid var(--ink);border-radius:9px;background:var(--card2);color:var(--ink);font-weight:800;padding:7px 10px}.vs-chips{display:flex;flex-wrap:wrap;gap:7px;width:100%}.vs-chip{border:2px solid var(--ink);background:var(--card2);color:var(--ink);font-weight:800;font-size:13px;border-radius:999px;padding:5px 12px;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .05s,box-shadow .05s}.vs-chip:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}.vs-chip:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.vs-chip.on{background:var(--accent);color:#fff}.vs-chip.all{background:var(--ink);color:var(--card)}.vs-chip.all.on{background:var(--accent);color:#fff}.vs-makehost{margin-left:6px;border:2px solid var(--ink);background:var(--card2);color:var(--ink);font-weight:800;font-size:11px;border-radius:999px;padding:3px 9px;cursor:pointer;box-shadow:1px 1px 0 var(--ink)}.vs-makehost:hover{background:#fff4d6}.vs-qtop{display:flex;align-items:center;gap:12px;margin-bottom:8px;font-weight:800}.vs-qnum{font-family:var(--font-head);font-size:16px}.vs-topic{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.vs-prog{margin-left:auto;font-size:12px;color:var(--muted);font-family:var(--font-mono)}.vs-timer{height:14px;background:var(--bg2);border:2px solid var(--ink);border-radius:8px;overflow:hidden;margin-bottom:14px}.vs-timerfill{height:100%;width:100%;background:var(--accent);transition:width .1s linear}.vs-question{font-family:var(--font-head);font-size:24px;font-weight:800;text-align:center;background:var(--yellow-soft);border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--ink);padding:24px 18px;margin-bottom:16px}.vs-opts{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 560px){.vs-opts{grid-template-columns:1fr}}.vs-opt{display:flex;align-items:center;gap:12px;border:2px solid var(--ink);border-radius:12px;padding:15px 16px;font-size:16px;font-weight:700;color:var(--ink);background:var(--card);cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:transform .1s,box-shadow .1s;text-align:left}.vs-opt:not(:disabled):not(.vs-faded):not(.vs-correct):hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--ink)}.vs-opt:disabled{cursor:default}.vs-opt .vs-key{width:28px;height:28px;border-radius:6px;flex:0 0 auto;display:grid;place-items:center;background:var(--yellow);border:1.5px solid var(--ink);font-family:var(--font-mono);font-size:13px;font-weight:800;color:var(--ink)}.vs-opt .vs-otext{flex:1}.vs-opt.picked{background:var(--yellow-soft);box-shadow:3px 3px 0 var(--accent)}.vs-opt.picked .vs-key{background:var(--accent);border-color:var(--ink);color:#fff}.vs-opt.dim{opacity:.45}.vs-opt.vs-faded{opacity:.45;cursor:default;box-shadow:2px 2px 0 var(--ink)}.vs-opt.vs-correct{cursor:default;background:var(--goodbg);border-color:var(--good);box-shadow:3px 3px 0 var(--good)}.vs-opt.vs-correct .vs-key{background:var(--good);border-color:var(--ink);color:#fff}.vs-check{margin-left:auto;font-size:20px;color:var(--good)}.vs-locked{text-align:center;margin-top:14px;font-weight:800;color:var(--good)}.vs-myresult{text-align:center;font-family:var(--font-head);font-size:20px;font-weight:800;margin:14px 0;padding:12px;border:2px solid var(--ink);border-radius:10px}.vs-myresult.good{background:var(--goodbg);color:var(--good)}.vs-myresult.bad{background:var(--badbg);color:var(--bad)}.vs-next{text-align:center;color:var(--muted);font-weight:700;margin-top:14px}.vs-win{text-align:center;margin:10px 0}.vs-trophy{font-size:54px}.vs-win h2{font-family:var(--font-head);font-size:28px;margin:4px 0}.vc-panel{margin:16px 0}.vc-chips{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.vc-chip{display:flex;align-items:center;gap:9px;background:var(--card);border:2px solid var(--ink);border-radius:24px;padding:6px 14px 6px 6px;font-weight:800;box-shadow:2px 2px 0 var(--ink)}.vc-chip.me{background:#fff4d6}.vc-chip .vc-av{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--font-head);transition:box-shadow .12s ease}.vc-chip.on-air .vc-av{box-shadow:0 0 0 3px #4ade80}.vc-chip.dead{opacity:.55}.vc-mutedicon{font-size:12px}.vc-actions{gap:8px}.vc-hint{color:var(--muted);font-weight:700;font-size:12px;margin-top:8px}.vc-err{color:var(--bad);font-weight:700;font-size:13px;margin:6px 0}.vc-strip{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:10px 0 14px}.vc-dots{display:flex;gap:6px}.vc-dot{width:28px;height:28px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-size:13px;border:2px solid var(--ink);transition:box-shadow .12s ease}.vc-dot.me{background:var(--accent)}.vc-dot.on-air{box-shadow:0 0 0 3px #4ade80}.vc-dot.dead{opacity:.45;border-style:dashed}.home-hero{position:relative;display:grid;grid-template-columns:minmax(0,5fr) minmax(0,7fr);align-items:stretch;gap:32px;background:var(--card);border:2px solid var(--ink);border-radius:16px;box-shadow:6px 6px 0 var(--ink);padding:24px 28px;margin:0 0 22px;overflow:hidden}.home-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(23,22,15,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(23,22,15,.05) 1px,transparent 1px);background-size:18px 18px;pointer-events:none}.home-hero>*{position:relative}.hh-left{min-width:0;display:flex;flex-direction:column;justify-content:center}.hh-right{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:14px;border-left:2px dashed var(--line);padding-left:32px}.hh-stats-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.hh-stats-label{font-family:var(--font-head);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.6px;color:var(--muted)}.hh-stats-pct{font-family:var(--font-head);font-size:13px;font-weight:800;color:var(--accent);letter-spacing:.4px}.hh-bar{height:10px;background:var(--card2);border:2px solid var(--ink);border-radius:6px;overflow:hidden;box-shadow:inset 2px 2px #17160f14}.hh-bar i{display:block;height:100%;background:repeating-linear-gradient(45deg,var(--accent) 0 8px,#e44417 8px 16px);transition:width .5s ease}.hh-stats{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.hh-stat{position:relative;display:flex;align-items:center;gap:12px;background:var(--card2);border:2px solid var(--ink);border-radius:10px;padding:12px 14px;box-shadow:3px 3px 0 var(--ink);min-width:0;overflow:hidden;grid-column:span 2}.hh-stat:nth-child(4),.hh-stat:nth-child(5){grid-column:span 3}.hh-stat.clickable{cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.hh-stat.clickable:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}.hh-stat.clickable:active{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}.hh-stat.clickable:focus-visible{outline:none;box-shadow:5px 5px 0 var(--ink);transform:translate(-2px,-2px)}.hh-stat-ic{flex:0 0 auto;width:38px;height:38px;border-radius:8px;background:var(--card);border:2px solid var(--ink);display:grid;place-items:center;font-family:var(--font-head);font-weight:800;font-size:18px;color:var(--ink)}.hh-stat-body{min-width:0;flex:1;line-height:1.1;overflow:hidden}.hh-stat-val{font-family:var(--font-head);font-size:22px;font-weight:800;letter-spacing:-.3px;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hh-stat-lbl{font-family:var(--font-head);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.9px;color:var(--muted);margin-top:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hh-stat-sub{font-size:11px;font-weight:600;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hh-ach{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px;padding-top:12px;border-top:2px dashed var(--line)}.hh-ach-lbl{font-family:var(--font-head);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;color:var(--muted);flex:0 0 auto}.hh-ach-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap;min-width:0}.hh-ach-b{position:relative;display:inline-grid;place-items:center;width:32px;height:32px;padding:0;background:var(--card2);border:2px solid var(--ink);border-radius:8px;font-size:16px;box-shadow:2px 2px 0 var(--ink)}.hh-ach-x{position:absolute;right:-6px;bottom:-6px;background:var(--accent);color:var(--card);border:2px solid var(--ink);border-radius:10px;font-family:var(--font-head);font-weight:800;font-size:10px;padding:0 4px;line-height:14px;min-width:18px;text-align:center}.hh-ach-empty{font-size:12px;font-weight:600;color:var(--muted);font-style:italic}.hh-greet{font-family:var(--font-head);font-size:32px;font-weight:800;margin:0 0 10px;letter-spacing:-.5px;line-height:1.1}.hh-count{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:4px}.hh-count-num{font-family:var(--font-head);font-size:96px;font-weight:800;color:var(--card);line-height:.9;letter-spacing:-3px;background:var(--accent);border:3px solid var(--ink);border-radius:18px;padding:8px 22px 12px;box-shadow:6px 6px 0 var(--ink);text-shadow:2px 2px 0 rgba(23,22,15,.35);transform:rotate(-2deg);display:inline-block}.hh-count-lbl{font-family:var(--font-head);font-size:20px;font-weight:800;text-transform:uppercase;letter-spacing:2px;color:var(--ink);line-height:1.15;max-width:160px}.hh-count-lbl b{color:var(--accent)}.hh-tag{margin-top:16px;display:inline-block;text-align:center;font-family:var(--font-head);font-weight:800;font-size:14px;letter-spacing:.5px;background:var(--ink);color:#fbf7ee;border:2px solid var(--ink);border-radius:20px;padding:5px 12px;box-shadow:3px 3px 0 var(--accent)}@media (max-width:820px){.home-hero{grid-template-columns:1fr;gap:18px;padding:20px}.hh-right{border-left:none;border-top:2px dashed var(--line);padding-left:0;padding-top:18px}}@media (max-width:560px){.hh-greet{font-size:26px}.hh-count-num{font-size:68px;padding:6px 16px 10px}.hh-count-lbl{font-size:16px}.hh-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.hh-stat,.hh-stat:nth-child(4),.hh-stat:nth-child(5){grid-column:span 1}.hh-stat:nth-child(5){grid-column:span 2}}.continue-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--ink);color:#fbf7ee;border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--accent);padding:14px 18px;margin:14px 0 4px}.cb-label{font-family:var(--font-head);font-weight:800;font-size:15px}.cb-topic{color:#bdb6a5;font-size:13px;font-weight:600;margin-top:2px}.lreadbar{position:sticky;top:0;z-index:30;height:6px;background:var(--bg2);border:2px solid var(--ink);border-radius:6px;overflow:hidden;margin:0 0 16px}.lreadbar i{display:block;height:100%;width:0;background:var(--accent);transition:width .1s linear}.lhero{background:var(--card);border:2px solid var(--ink);border-radius:16px;box-shadow:6px 6px 0 var(--ink);padding:20px 22px;margin-bottom:22px}.lhero>.btn{margin-bottom:12px}.lhero-row{display:flex;gap:18px;align-items:flex-start}.lhero-num{flex:0 0 auto;width:60px;height:60px;border-radius:14px;background:var(--ink);color:var(--card);display:grid;place-items:center;font-family:var(--font-head);font-weight:800;font-size:30px;box-shadow:3px 3px 0 var(--accent)}.lhero-txt{flex:1;min-width:0}.lhero-badges{display:flex;gap:7px;margin-bottom:6px;flex-wrap:wrap}.lhero-title{font-family:var(--font-head);font-size:30px;font-weight:800;margin:0 0 8px;letter-spacing:-.5px;line-height:1.1}.lhero-sub{color:var(--muted);font-size:16px;font-weight:600;margin:6px 0 0;max-width:68ch;line-height:1.6;border-top:2px dashed var(--line);padding-top:10px}.ltoc{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:14px;border-top:2px dashed var(--line)}.ltoc-chip{font-size:12.5px;font-weight:700;text-decoration:none;color:var(--ink);background:var(--card2);border:1.5px solid var(--ink);border-radius:20px;padding:5px 12px;transition:.12s}.ltoc-chip:hover{background:var(--brand);color:#fff;transform:translateY(-1px)}.lslide{background:var(--card);border:2px solid var(--ink);border-radius:14px;box-shadow:4px 4px 0 var(--ink);padding:24px 28px;margin:0 0 22px;scroll-margin-top:14px}.lslide-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:12px;border-bottom:1.5px dashed var(--line)}.lslide-num{flex:0 0 auto;width:32px;height:32px;border-radius:9px;background:var(--accent);color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:800;font-size:15px;border:2px solid var(--ink)}.lslide-head .lh{margin:0;border-left:none;padding-left:0;font-size:19px}.lnav{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}@media (max-width:560px){.lnav{grid-template-columns:1fr}}.lnav-card{text-align:left;border:2px solid var(--ink);background:var(--card);border-radius:12px;padding:13px 16px;cursor:pointer;box-shadow:3px 3px 0 var(--ink);transition:.12s;display:flex;flex-direction:column;gap:3px}.lnav-card.next{text-align:right}.lnav-card:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--brand)}.lnav-dir{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--accent)}.lnav-t{font-family:var(--font-head);font-weight:800;font-size:14.5px}.lesson-link{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.lesson-link-pick{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--muted)}.lesson-link-sel{font:inherit;font-size:12px;font-weight:700;color:var(--ink);background:var(--card);border:2px solid var(--ink);border-radius:8px;padding:4px 8px;max-width:200px;cursor:pointer}.lesson-link-sel:disabled{opacity:.6;cursor:default}.lesson-link-err{font-size:11.5px;font-weight:700;color:var(--accent)}.lmodal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#17160f8c;display:flex;align-items:center;justify-content:center;padding:18px}.lmodal{width:min(860px,100%);max-height:88vh;display:flex;flex-direction:column;background:var(--bg2);border:2px solid var(--ink);border-radius:16px;box-shadow:8px 8px 0 var(--ink);overflow:hidden}.lmodal-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:2px solid var(--ink);background:var(--card)}.lmodal-title{display:flex;align-items:center;gap:8px;min-width:0;font-family:var(--font-head);font-size:16px;font-weight:800}.lmodal-title strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lmodal-close{flex:0 0 auto;width:32px;height:32px;border:2px solid var(--ink);background:var(--card);border-radius:8px;font-size:15px;font-weight:800;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:.1s}.lmodal-close:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--accent)}.lmodal-body{flex:1 1 auto;position:relative;overflow-y:auto;padding:18px 20px}.lmodal-summary{color:var(--muted);font-size:14px;font-weight:600;margin:0 0 16px;line-height:1.55}.lslide.is-target{box-shadow:4px 4px 0 var(--accent);border-color:var(--accent)}.lslide.is-target .lslide-num{background:var(--ink)}.lsec2.is-target .lsec2-head .num{background:var(--ink);color:var(--card)}.lsec2.is-target>.prose{border-left:2px solid var(--soft);padding-left:12px}.wrap.wrap--wide{max-width:1800px;padding-left:32px;padding-right:32px}.lshell{--lleft:240px;--lright:320px;--lgap:44px;margin:0 auto;padding:30px 0 90px;position:relative;display:grid;grid-template-columns:var(--lleft) minmax(0,1fr) var(--lright);gap:var(--lgap);align-items:start}.lrail{position:sticky;top:24px}.lrail h4{margin:0 0 10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}.lrail-toc{list-style:none;margin:0 0 20px;padding:0;overflow:hidden}.lrail-toc li{display:flex;gap:11px;align-items:center;padding:9px 12px;border-bottom:1px solid var(--soft);font-weight:600;font-size:13.5px;cursor:pointer;color:var(--muted);transition:background .1s}.lrail-toc li:last-child{border-bottom:0}.lrail-toc li:hover{background:var(--card2);color:var(--ink)}.lrail-toc li .n{width:20px;height:20px;border:1px solid var(--soft);border-radius:5px;display:grid;place-items:center;font-size:11.5px;font-weight:700;background:var(--card);flex:0 0 auto;color:var(--muted)}.lrail-toc li.active{background:var(--yellow-soft);color:var(--ink);border-left:3px solid var(--yellow)}.lrail-toc li.active .n{background:var(--yellow);border-color:var(--ink);color:var(--ink)}.lrail-progress{padding:10px 0 0}.lrail-progress .bar{height:5px;border-radius:999px;background:var(--card2);overflow:hidden}.lrail-progress .bar>i{display:block;height:100%;background:var(--yellow);transition:width .15s linear}.lrail-progress .lab{display:flex;justify-content:space-between;font-size:11px;font-weight:600;margin-top:6px;color:var(--muted)}.lpage-hero{padding:6px 0 24px;margin:0 0 26px;border-bottom:1px solid var(--soft)}.lpage-hero .lpage-eyebrow{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.lpage-hero h1{margin:0 0 12px;font-size:40px;line-height:1.06;font-family:var(--font-head);font-weight:800;letter-spacing:-.5px;overflow-wrap:break-word}.lpage-hero .summary{margin:0;font-size:17px;line-height:1.65;color:var(--muted);max-width:64ch;text-align:left}.lsec2{margin:0 0 34px;padding-top:6px}.lsec2-head{display:flex;align-items:center;gap:11px;margin:0 0 14px}.lsec2-head .num{background:var(--yellow);border:1px solid var(--ink);border-radius:6px;padding:1px 8px;color:var(--ink);font-family:var(--font-head);font-weight:800;font-size:14px;flex:0 0 auto;line-height:1.6}.lsec2-head h2{margin:0;font-size:24px;font-family:var(--font-head);font-weight:800;letter-spacing:-.2px}.lsec2 .prose{max-width:68ch;font-size:16.5px;line-height:1.7;text-align:left}.lsec2 .prose p{margin:0 0 12px}.lsec2 .prose strong{font-weight:800}.lsec2 .prose em{font-style:italic}.lsec2 .prose a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;font-weight:600}.lsec2 .prose ul{margin:0 0 12px;padding-left:20px}.lsec2 .prose li{margin:4px 0}.lmedia{margin:18px 0;border:1px solid var(--soft);border-radius:var(--r);background:var(--card);overflow:hidden;width:100%}.lmedia .cap{display:flex;align-items:center;justify-content:space-between;padding:7px 13px;border-bottom:1px solid var(--soft);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}.lmedia .cap .tag{border:1px solid var(--soft);border-radius:999px;padding:2px 9px;font-size:10.5px}.lmedia .cap .tag.dia{background:var(--card2);color:var(--muted)}.lmedia .cap .tag.vid{background:#fef0eb;color:#a03010}.lmedia .cap .tag.wid{background:var(--yellow-soft);color:var(--ink)}.lmedia .body{padding:16px}.lmedia .body video{display:block;width:100%;height:auto}.lmedia .body .lwidget-iframe{border:none;box-shadow:none;border-radius:0;min-height:200px}.lnote2{border-left:3px solid var(--accent);border-radius:0 6px 6px 0;background:#fff9f7;padding:11px 16px;margin:16px 0;font-size:15.5px;line-height:1.65}.lnote2 b{color:var(--accent)}.lex2{border:1px solid var(--soft);border-radius:var(--r);background:var(--card);padding:15px 18px;margin:16px 0}.lex2 .h{font-family:var(--font-head);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 8px}.lex2 .q{font-weight:700;margin:0 0 8px}.lex2 .step{display:flex;gap:9px;margin:5px 0;font-size:15px;align-items:flex-start}.lex2 .step .b{width:20px;height:20px;flex:none;border:1px solid var(--soft);border-radius:5px;background:var(--card2);display:grid;place-items:center;font-size:11px;font-weight:700;color:var(--muted)}.lex2 .a{margin:10px 0 0;font-weight:700;background:#eaf0e0;color:#4f7a42;border-radius:6px;padding:5px 12px;display:inline-block;font-size:14.5px}.lpager{display:flex;justify-content:space-between;gap:14px;margin-top:36px;padding-top:20px;border-top:1px solid var(--soft)}.lpager a{flex:1;padding:10px 0;font-weight:700;text-decoration:none;color:var(--ink);font-size:15px}.lpager a.next{text-align:right}.lpager small{display:block;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:3px}.lpager a:hover{color:var(--accent)}.lpage-editrow{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0 0 22px}.lref{position:sticky;top:24px;display:flex;flex-direction:column;gap:16px}.lrefcard{border:1px solid var(--soft);border-radius:var(--r);background:var(--card);padding:14px 16px}.lrefcard h4{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 10px;font-weight:800}.lref-examrow{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px dashed var(--soft)}.lref-examrow:last-child{border-bottom:0}.lref-examrow b{font-weight:700}.lref-terms{display:flex;flex-wrap:wrap;gap:6px}.lterm{font-size:12px;font-weight:600;border:1px solid var(--soft);border-radius:999px;padding:3px 10px;background:#fff;color:var(--ink)}.lref-formula{font-family:var(--font-mono);font-size:12.5px;padding:5px 0;border-bottom:1px dashed var(--soft);color:#33302a}.lref-formula:last-child{border-bottom:0}.lref-cta{display:block;border:2px solid var(--ink);border-radius:var(--r);background:var(--yellow);text-align:center;padding:10px 12px;font-weight:800;font-size:14px;cursor:pointer;color:var(--ink);text-decoration:none;transition:transform .1s,box-shadow .1s;box-shadow:2px 2px 0 var(--ink)}.lref-cta:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}@media (max-width:1180px){.lshell{grid-template-columns:var(--lleft) minmax(0,1fr)}.lref{grid-column:1/-1;flex-direction:row;flex-wrap:wrap;position:static}.lrefcard{flex:1;min-width:200px}.snote-add{right:0}}@media (max-width:760px){.wrap.wrap--wide{padding-left:14px;padding-right:14px}.lshell{grid-template-columns:1fr;gap:22px}.lrail,.lref,.snote-layer,.snote-add{display:none}.lpage-hero h1{font-size:31px}}.mex-top{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}.mex-title{font-family:var(--font-head);font-size:18px;font-weight:800}.mex-timer{font-family:var(--font-mono);font-size:26px;font-weight:800;background:var(--ink);color:#fbf7ee;border:2px solid var(--ink);border-radius:9px;padding:4px 14px;box-shadow:3px 3px 0 var(--accent)}.mex-timer.low{color:#ffd9c9}.mex-top .btn{margin-left:auto}.mex-palette{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}.mex-pchip{width:34px;height:34px;border:2px solid var(--ink);background:var(--card);border-radius:8px;font-family:var(--font-head);font-weight:800;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:.1s}.mex-pchip:hover{transform:translate(-1px,-1px)}.mex-pchip.done{background:#dde2ff}.mex-pchip.cur{background:var(--brand);color:#fff}.mex-pchip.marked{outline:2px solid var(--accent);outline-offset:1px}.mex-ta{width:100%;min-height:120px;margin-top:16px;border:2px solid var(--ink);border-radius:10px;padding:12px 14px;font-size:15px;font-family:var(--font-body);resize:vertical;box-sizing:border-box}.mex-hint{color:var(--muted);font-weight:700;font-size:12.5px;margin-top:10px}.ach{flex-basis:100%;display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.ach-b{display:inline-flex;align-items:center;background:var(--card2);border:1.5px solid var(--ink);border-radius:8px;padding:2px 7px;font-size:15px;line-height:1;box-shadow:1px 1px 0 var(--ink)}.ach-x{font-family:var(--font-mono);font-size:11px;font-weight:800;color:var(--accent);margin-left:2px}.tbadge{cursor:pointer;color:inherit;font-family:inherit}.tbadge:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.bdg-tip{position:fixed;z-index:1000;display:block;transform:translate(-50%,calc(-100% - 9px));width:max-content;max-width:220px;background:var(--ink);color:#fff;text-align:left;border-radius:9px;padding:8px 11px;box-shadow:3px 3px #17160f59;pointer-events:none}.bdg-tip b{display:block;font-family:var(--font-head);font-size:13px;font-weight:800;margin-bottom:3px}.bdg-tip>span{display:block;font-size:11.5px;font-weight:600;line-height:1.4;color:#ffffffd1}.bdg-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--ink)}.ach-legend{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}@media (max-width:560px){.ach-legend{grid-template-columns:1fr}}.ach-leg{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--muted)}.ach-leg .ach-b{font-size:16px}.mex-recent-list{display:flex;flex-direction:column;gap:8px}.mex-rrow{display:flex;align-items:center;gap:14px;background:var(--card);border:2px solid var(--ink);border-radius:9px;padding:10px 14px;box-shadow:2px 2px 0 var(--ink)}.mex-rpct{font-family:var(--font-head);font-weight:800;font-size:20px;min-width:54px}.mex-rmeta{flex:1;font-size:13px;color:var(--muted);font-weight:600}.mex-rmeta b{color:var(--ink);font-family:var(--font-head)}.mex-rdate{font-size:12px;color:var(--muted);font-family:var(--font-mono)}.fc-opts{margin:18px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:10px;text-align:left}@media (max-width:560px){.fc-opts{grid-template-columns:1fr}}.fc-opt{display:flex;align-items:center;gap:10px;text-align:left;background:#fff;border:2px solid var(--ink);border-radius:10px;padding:10px 12px;font-family:var(--font-body);font-weight:600;font-size:14.5px;line-height:1.35;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .1s,box-shadow .1s}.fc-opt:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.fc-opt .fco-k{flex:0 0 auto;width:24px;height:24px;border-radius:6px;display:grid;place-items:center;background:var(--yellow);color:var(--ink);font-family:var(--font-head);font-weight:800;font-size:13px;border:1.5px solid var(--ink)}.fc-opt .fco-t{flex:1}.fc-opt.sel{background:var(--yellow-soft);box-shadow:2px 2px 0 var(--accent)}.fc-opt.answered{cursor:default}.fc-opt.answered:hover{transform:none;box-shadow:2px 2px 0 var(--ink)}.fc-opt.correct{background:var(--goodbg);border-color:var(--good);box-shadow:2px 2px 0 var(--good)}.fc-opt.wrong{background:var(--badbg);border-color:var(--bad);box-shadow:2px 2px 0 var(--bad)}.fc-opt.answered:not(.correct):not(.wrong){opacity:.55}.fc-check{margin-top:12px;width:100%}.fc-fb{margin-top:8px}.fc-fb .feedback{justify-content:center}.fc-hint2{margin-top:12px;font-family:var(--font-mono);font-size:11px;color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-weight:700;text-align:center}html{-webkit-text-size-adjust:100%}body{overflow-x:hidden}.fc .qa .txt,.fc-opt,.fco-t,.q,.opt,.lp,.lex-q,.bitem .bq,.bitem .ba,.vs-opt,.vs-otext,.reveal,.rev-item .rq,.rev-item .ra,.pg-blabel,.mex-rmeta,.auth-sub,.cb-topic{overflow-wrap:break-word;word-break:break-word}.wrap{padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}@media (max-width:600px){.wrap{padding-top:14px;padding-bottom:calc(64px + env(safe-area-inset-bottom));padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}header.app{gap:8px 10px;padding:12px 0 14px;margin-bottom:18px}.spacer{display:none}.logo{width:52px;height:52px;border-radius:9px}.title{flex:1 1 58%;min-width:0}.title h1{font-size:18px}.title p{font-size:11px}.countdown b{font-size:20px}.userchip{padding:4px 10px;font-size:12px}.btn{padding:8px 11px;font-size:13px}.btn.sm{padding:6px 9px;font-size:12px}.modes{grid-template-columns:1fr 1fr;gap:10px}.mode{padding:14px 12px;box-shadow:3px 3px 0 var(--ink)}.mode .ic{font-size:24px}.mode h3{font-size:15px}.chapters{grid-template-columns:1fr}.stats{gap:8px}.stat{min-width:0;flex:1 1 40%;padding:9px 11px}.stat b{font-size:18px}.section-h h2{font-size:13px}.fc-scene{max-width:100%}.fc{min-height:260px}.fc .face{padding:20px 18px;box-shadow:5px 5px 0 var(--ink)}.fc .qa .txt{font-size:18px;max-width:100%}.fc .back .qa .txt{font-size:15.5px}.fc .front:before{left:34px}.fc-opts{grid-template-columns:1fr;gap:8px}.fc-opt{font-size:14px;padding:9px 11px}.controls{gap:9px}.iconbtn{width:44px;height:44px;font-size:18px}.iconbtn.big{width:54px;height:54px;font-size:22px}.qcard{padding:18px 16px;box-shadow:4px 4px 0 var(--ink)}.q{font-size:18px}.opt{font-size:14.5px;padding:11px 12px}select,input[type=text],input[type=password],input[type=number],textarea,.mex-ta{font-size:16px}.score-ring{font-size:54px}.lhero{padding:16px}.lhero-row{gap:12px}.lhero-num{width:46px;height:46px;font-size:23px;border-radius:11px}.lhero-title{font-size:22px}.lhero-sub{font-size:14.5px;padding-top:8px;margin-top:4px}.lslide{padding:16px}.lslide-head{padding-bottom:10px;margin-bottom:12px}.lh{font-size:16px}.lp,.lp-list,.lp-h{font-size:14.5px}.lnav{grid-template-columns:1fr}.lformula{font-size:13px}.vs-pin{font-size:42px;letter-spacing:7px}.vs-pinwrap{padding:16px 22px}.vs-question{font-size:19px;padding:18px 14px}.vs-opt{font-size:15px;padding:13px 14px}.vs-opts{grid-template-columns:1fr}.mex-top{gap:10px}.mex-timer{font-size:22px}.mex-top .btn{margin-left:0}.mex-pchip{width:30px;height:30px;font-size:13px}.mex-ta{min-height:110px}.pg-body{padding:12px}.pg-blabel{min-width:88px;font-size:12px}.pg-num{min-width:78px}.pg-slabel{min-width:74px}.tok{padding:6px 9px;font-size:13px}.ach-legend{grid-template-columns:1fr}}@media (max-width:380px){.modes{grid-template-columns:1fr}.title h1{font-size:16px}.fc .qa .txt{font-size:16.5px}.score-ring{font-size:44px}.vs-pin{font-size:34px;letter-spacing:4px}}.coursechip{border:2px solid var(--ink);background:var(--card);color:var(--ink);font-weight:800;font-size:13px;border-radius:999px;padding:6px 13px;cursor:pointer;box-shadow:2px 2px 0 var(--ink);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coursechip:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink);background:#fff4d6}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-bottom:26px}.course-card{display:flex;flex-direction:column;gap:8px;background:var(--card);border:2px solid var(--ink);border-radius:14px;padding:16px 18px;box-shadow:4px 4px 0 var(--ink)}.course-card.current{box-shadow:6px 6px 0 var(--accent);background:#fff8ec}.cc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.cc-top h3{margin:0;font-size:17px;line-height:1.25;min-width:0;overflow:hidden;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.cc-cur,.cc-badge{flex:0 0 auto;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:999px;border:1.5px solid var(--ink)}.cc-cur{background:var(--accent);color:#fff}.cc-badge{background:var(--card2);color:var(--muted)}.cc-meta{color:var(--muted);font-size:12.5px;font-weight:700}.cc-exam{color:var(--ink);font-size:12.5px;font-weight:700}.cc-acts{margin-top:auto;padding-top:6px}.courses-toolbar{display:flex;gap:10px;align-items:center;margin:0 0 20px}.courses-toolbar input{flex:1;min-width:0;border:2px solid var(--ink);background:var(--card);color:var(--ink);border-radius:10px;font-family:var(--font-body);font-weight:600;font-size:14.5px;padding:10px 13px}.courses-toolbar input:focus{outline:none;box-shadow:3px 3px 0 var(--ink)}.courses-toolbar .btn{flex:0 0 auto}.course-hero{background:#fff8ec;border:2px solid var(--ink);border-radius:16px;box-shadow:6px 6px 0 var(--accent);padding:20px 22px;margin:0 0 26px}.ch-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.ch-id{min-width:0}.ch-id h2{margin:8px 0 4px;font-size:24px;line-height:1.1;overflow-wrap:anywhere}.ch-exam{flex:0 0 auto;text-align:right;border-left:2px dashed var(--line);padding-left:16px}.ch-exam-num{font-family:var(--font-head);font-size:38px;font-weight:800;line-height:1;color:var(--accent)}.ch-exam-lbl{font-size:11.5px;font-weight:700;color:var(--muted)}.ch-exam-date{font-size:11.5px;font-weight:700;color:var(--ink);margin-top:2px}.ch-bars{display:flex;flex-direction:column;gap:12px;margin:18px 0}.ch-bar-top{display:flex;justify-content:space-between;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:4px}.ch-track{height:10px;background:var(--card2);border:1.5px solid var(--ink);border-radius:999px;overflow:hidden}.ch-track i{display:block;height:100%;border-radius:999px}.ch-track i.good{background:var(--good)}.ch-track i.quiz{background:var(--accent)}.ch-acts{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cc-row{display:flex;gap:12px;align-items:flex-start}.cc-ring{flex:0 0 auto}.cc-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:6px}@media (max-width: 560px){.ch-head{flex-direction:column}.ch-exam{border-left:none;padding-left:0;text-align:left;border-top:2px dashed var(--line);padding-top:8px;display:flex;align-items:baseline;gap:8px}.courses-toolbar{flex-wrap:wrap}}.cc-step{font-weight:800;color:var(--ink);margin:18px 0 8px;font-size:14.5px}.cc-step:first-child{margin-top:4px}.cc-input{width:100%;box-sizing:border-box;border:2px solid var(--ink);border-radius:10px;background:var(--card);color:var(--ink);font-family:var(--font-body);font-weight:600;font-size:14.5px;padding:11px 13px;margin-bottom:10px}.cc-input:focus{outline:none;box-shadow:3px 3px 0 var(--ink)}.cc-daterow{display:flex;align-items:center;gap:10px}.cc-date{width:auto;margin-bottom:0}.cc-hint{color:var(--muted);font-size:12px;font-weight:700}.cc-textarea{width:100%;box-sizing:border-box;min-height:180px;resize:vertical;border:2px solid var(--ink);border-radius:10px;background:var(--card);color:var(--ink);font-family:var(--font-mono, monospace);font-size:12.5px;line-height:1.5;padding:12px 14px;margin-bottom:10px}.cc-textarea:focus{outline:none;box-shadow:3px 3px 0 var(--ink)}@media (max-width: 560px){.courses-grid{grid-template-columns:1fr}.coursechip{max-width:120px}}.wrap .wrap{max-width:none;margin:0;padding:0}.ed-head{margin-bottom:8px}.ed-tabs{display:flex;flex-wrap:wrap;gap:6px;border-bottom:2px solid var(--ink);margin:8px 0 18px;padding-bottom:0}.ed-tab{border:2px solid var(--ink);border-bottom:none;border-radius:10px 10px 0 0;background:var(--card);color:var(--ink);font-family:var(--font-body);font-weight:800;font-size:13.5px;padding:9px 14px;cursor:pointer;position:relative;bottom:-2px}.ed-tab.on{background:var(--ink);color:var(--card)}.ed-body{min-height:240px}.ed-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:6px}.ed-list{display:flex;flex-direction:column;gap:10px}.ed-row{display:flex;align-items:center;gap:12px;border:2px solid var(--ink);border-radius:12px;background:var(--card);padding:12px 14px;cursor:pointer;text-align:left}.ed-row:hover{box-shadow:3px 3px 0 var(--ink)}.ed-row-main{flex:1;min-width:0}.ed-row-q{font-weight:700;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ed-row-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.ed-chip{font-size:11px;font-weight:800;color:var(--muted);background:var(--bg);border:1.5px solid var(--ink);border-radius:6px;padding:2px 7px}.ed-role-owner{color:var(--accent)}.ed-role-admin{color:var(--ink)}.ed-form .ed-q{min-height:80px}.ed-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.ed-field{display:flex;flex-direction:column}.ed-field .cc-hint{margin-bottom:4px}.ed-opt-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.ed-opt-row>input[type=radio],.ed-opt-row>input[type=checkbox]{width:18px;height:18px;flex:none}.ed-actions{display:flex;align-items:center;gap:10px;margin-top:12px}.ed-check{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13.5px;color:var(--ink)}.ed-check input{width:18px;height:18px}.ed-chrow{display:flex;gap:12px;align-items:flex-start;padding:14px}.ed-chnum{font-weight:900;font-size:18px;color:var(--card);background:var(--ink);border-radius:9px;width:34px;height:34px;display:grid;place-items:center;flex:none}.ed-chfields{flex:1;min-width:0}.ed-chfields .cc-input:last-child{margin-bottom:0}.ed-section{padding:14px;margin-bottom:14px}.ed-section-h{display:flex;align-items:center;margin:18px 0 10px}.ed-section-h h4{margin:0;font-size:14px}.ed-example{border-left:3px solid var(--accent);padding-left:12px;margin-top:6px}.ed-widgets,.ed-mrow{display:flex;flex-wrap:wrap;gap:8px}.ed-wchip{display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:1.5px solid var(--ink);border-radius:8px;padding:5px 9px;font-size:12px;font-weight:700;background:var(--card)}.ed-wchip.on{background:var(--ink);color:var(--card)}.ed-mrow{align-items:center;justify-content:space-between;padding:12px 14px}.ed-settings .cc-input,.ed-settings .cc-textarea{max-width:640px}.ed-savebar{position:sticky;bottom:0;display:flex;align-items:center;justify-content:flex-end;gap:14px;margin-top:22px;padding:12px 0;background:var(--bg);border-top:2px solid var(--ink)}.ed-savemsg{font-size:12.5px;font-weight:700;color:var(--muted)}.ed-savemsg.ok{color:#1f8f3a}.ed-savemsg.err{color:var(--accent)}.btn.danger{border-color:var(--accent);color:var(--accent)}.btn.danger:hover{background:var(--accent);color:#fff}.ad-picker{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 16px}.ad-coursechip{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--ink);border-radius:10px;background:var(--card);color:var(--ink);font-family:var(--font-body);font-weight:800;font-size:13px;padding:8px 12px;cursor:pointer}.ad-coursechip.on{background:var(--ink);color:var(--card)}.ad-coursechip.on .ed-chip{color:var(--card);border-color:var(--card)}.ad-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin:4px 0 10px}.ad-mrow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;flex-wrap:wrap}.ad-mwho{display:flex;align-items:center;gap:8px}.study-top .edit-link{margin-left:auto}.mbar{position:relative;height:10px;overflow:hidden;background:var(--bg2);border:2px solid var(--ink);border-radius:0}.mbar.mbar-hero{border-radius:6px;background:var(--card2);box-shadow:inset 2px 2px #17160f14}.mbar i{position:absolute;left:0;top:0;height:100%;transition:width .4s ease}.mbar-flash{background:#b3ad9c}.mbar-quiz{background:var(--accent)}.mbar-hero .mbar-quiz{background:repeating-linear-gradient(45deg,var(--accent) 0 8px,#e44417 8px 16px)}.mbar-legend{display:flex;gap:14px;margin-top:6px;font-size:11px;font-weight:700;color:var(--muted)}.mbar-legend .sw{display:inline-block;width:11px;height:11px;border:1.5px solid var(--ink);margin-right:5px;vertical-align:-1px}.mbar-legend .sw.flash{background:#b3ad9c}.mbar-legend .sw.quiz{background:var(--accent)}@media (max-width: 560px){.ed-grid2{grid-template-columns:1fr}}.cl-toolbar{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 10px}.cl-list{display:flex;flex-direction:column;gap:10px;margin-top:4px}.cl-class{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--ink);padding:16px 18px;cursor:pointer;text-align:left;transition:transform .1s,box-shadow .1s}.cl-class:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--ink)}.cl-class-name{font-family:var(--font-head);font-weight:800;font-size:17px}.cl-class-desc{color:var(--muted);font-size:13px;margin-top:3px}.cl-class-meta{display:flex;gap:14px;margin-top:9px;font-size:12.5px;font-weight:700;color:var(--muted)}.cl-chip{flex-shrink:0;font-size:11px;font-weight:800;color:var(--muted);background:var(--bg);border:1.5px solid var(--ink);border-radius:6px;padding:3px 8px;white-space:nowrap}.cl-chip.is-teacher{background:var(--accent);color:#fff}.cl-empty{text-align:center;color:var(--muted);padding:30px 18px}.cl-empty p{margin:0}.cl-empty p+p{margin-top:6px;font-size:13px}.cl-note{color:var(--muted);text-align:center;padding:22px 0}.cl-state{margin-top:24px}.cl-head{align-items:flex-start}.cl-head-desc{color:var(--muted);margin:4px 0 0;font-size:14px}.cl-danger{color:var(--bad)}.cl-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:16px 0;border-bottom:2px solid var(--ink)}.cl-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:13.5px;color:var(--muted);background:transparent;border:2px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;padding:8px 14px;margin-bottom:-2px}.cl-tab:hover{color:var(--ink)}.cl-tab.is-active{background:var(--card);color:var(--ink);border-color:var(--ink);font-weight:800}.cl-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.cl-tile{background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:4px 4px 0 var(--ink);padding:18px 12px;text-align:center}.cl-tile-val{font-family:var(--font-head);font-size:26px;font-weight:800;line-height:1.1}.cl-tile-label{font-size:12px;color:var(--muted);margin-top:6px;font-weight:700}.cl-add{background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:3px 3px 0 var(--ink);padding:14px 16px;margin-bottom:14px}.cl-add .cc-input,.cl-add .cc-textarea{margin-bottom:0}.cl-create{margin-top:14px}.cl-ta{min-height:72px}.cl-fieldrow{display:flex;gap:8px;flex-wrap:wrap}.cl-fieldrow>.cc-input,.cl-fieldrow>select.cc-input{flex:1}.cl-field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:130px}.cl-input-auto{width:auto}.cl-grow{flex:1;min-width:0}.cl-actions{display:flex;gap:8px;margin-top:10px}.cl-add .auth-err{margin:10px 0 0}.cl-rows{display:flex;flex-direction:column;gap:8px}.cl-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--card);border:2px solid var(--ink);border-radius:10px;box-shadow:2px 2px 0 var(--ink);padding:10px 14px}.cl-row-name{flex:1;font-weight:700;min-width:120px;word-break:break-word}.cl-row-meta{font-size:12px;color:var(--muted);font-weight:600}.cl-assign{background:var(--card);border:2px solid var(--ink);border-radius:12px;box-shadow:3px 3px 0 var(--ink);padding:14px 16px}.cl-assign-head{display:flex;align-items:flex-start;gap:10px}.cl-assign-title{font-family:var(--font-head);font-weight:800;font-size:15.5px}.cl-assign-desc{font-size:13px;color:var(--muted);margin-top:3px}.cl-assign-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:8px;font-size:12px;color:var(--muted);font-weight:600}.cl-assign-prog{margin-top:10px}.cl-assign-prog-body{margin-top:8px}.cl-bar{flex:1;min-width:60px;height:8px;background:var(--card2);border:1.5px solid var(--ink);border-radius:5px;overflow:hidden}.cl-bar>i{display:block;height:100%;background:var(--accent);transition:width .3s ease}.cl-bar.meets>i{background:var(--good)}.cl-bar.partial>i{background:var(--medium)}.cl-progress-groups{display:flex;flex-direction:column;gap:16px}.cl-progress-course{font-family:var(--font-head);font-weight:800;margin-bottom:10px}.cl-tablewrap{overflow-x:auto}.cl-table{width:100%;border-collapse:collapse;font-size:13px}.cl-table th{text-align:left;color:var(--muted);font-weight:700;padding:4px 8px;border-bottom:2px solid var(--ink)}.cl-table td{padding:6px 8px;border-bottom:1px solid var(--soft)}.cl-table tr:last-child td{border-bottom:none}.cl-table .num{text-align:right;white-space:nowrap}.cl-table .center{text-align:center}.cl-table .prog{min-width:80px}@media (max-width: 620px){.cl-tiles{grid-template-columns:1fr 1fr}}.mcp-token-row{display:flex;gap:12px;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.08)}.mcp-token-label{font-weight:600;min-width:120px}.mcp-create{display:flex;gap:8px;margin:8px 0 16px}.mcp-fresh{margin-top:16px;padding:12px;border:1px solid rgba(245,158,11,.5);border-radius:8px}.mcp-code{display:block;padding:8px;margin:6px 0;font-family:ui-monospace,monospace;font-size:13px;word-break:break-all;-webkit-user-select:all;user-select:all;background:#ffffff0f;border-radius:6px}.mcp-error{color:#f87171}.mcp-code-row{display:flex;gap:8px;align-items:flex-start}.mcp-code-row .mcp-code{flex:1}.settings-form{display:flex;flex-direction:column;gap:10px;max-width:360px;margin-top:8px}.settings-form .btn{align-self:flex-start}.settings-form .cc-input{margin-bottom:0}.course-welcome{display:flex;align-items:center;gap:24px;background:var(--card, #fbf7ee);border:3px solid var(--ink, #17160f);border-radius:16px;box-shadow:4px 4px 0 var(--ink, #17160f);padding:24px 28px;margin:8px 0 24px}.cw-buffalo{width:110px;height:110px;flex:none}.cw-body h2{margin:0 0 6px}.cw-body p{margin:0 0 16px;color:var(--muted);max-width:56ch}.cw-paths{display:flex;gap:12px;flex-wrap:wrap}.cw-path{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 18px;cursor:pointer;text-align:left;background:var(--bg, #e7e0cf);border:2px solid var(--ink, #17160f);border-radius:12px;box-shadow:3px 3px 0 var(--ink, #17160f);transition:transform .06s ease,box-shadow .06s ease}.cw-path:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink, #17160f)}.cw-path.primary{background:var(--yellow, #ffd83e)}.cw-path-t{font-weight:700;font-size:15px}.cw-path-p{font-size:12.5px;color:var(--muted)}@media (max-width: 640px){.course-welcome{flex-direction:column;text-align:center}.cw-body p{margin-inline:auto}.cw-paths{justify-content:center}.cw-path{align-items:center;text-align:center}}.invite-banner{border:2px solid var(--ink, #17160f);border-radius:12px;padding:10px 14px;margin:0 0 16px;font-weight:600}.invite-banner.err{background:#ffe1d6}.ad-invite{margin:0 0 16px;padding:12px 14px;background:var(--bg2);border:2px solid var(--ink);border-radius:12px}.snote-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:55}.snote{position:absolute;width:190px;border:1.5px solid var(--ink);box-shadow:3px 3px #17160f2e;border-radius:2px;display:flex;flex-direction:column;pointer-events:auto;transform:rotate(-1.5deg);transition:box-shadow .1s ease;-webkit-user-select:none;user-select:none}.snote--dragging{transform:rotate(0);box-shadow:6px 6px #17160f47;z-index:20}.snote-grip{display:flex;align-items:center;gap:5px;padding:5px 6px 4px;border-bottom:1px solid rgba(23,22,15,.18);cursor:grab;-webkit-user-select:none;user-select:none}.snote--dragging .snote-grip{cursor:grabbing}.snote-grip-spacer{flex:1}.snote--min .snote-text{display:none}.snote--min .snote-grip{border-bottom:none}.snote-dot{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(23,22,15,.4);padding:0;cursor:pointer;flex:0 0 auto;transition:border-color .1s}.snote-dot--yellow{background:#ffd83e}.snote-dot--pink{background:#ffb3d1}.snote-dot--green{background:#bfe3a6}.snote-dot--active{border-color:var(--ink);border-width:2px}.snote-dot:hover{border-color:var(--ink)}.snote-expand,.snote-min{background:none;border:none;padding:0 2px;cursor:pointer;color:var(--muted);line-height:1;display:flex;align-items:center;transition:color .1s}.snote-expand:hover,.snote-min:hover{color:var(--ink)}.snote-del{background:none;border:none;padding:0 2px;cursor:pointer;font-size:11px;color:var(--muted);line-height:1;transition:color .1s}.snote-del:hover{color:var(--ink)}.snote-text{width:100%;min-height:80px;border:none;background:transparent;padding:7px 8px;font-family:var(--font-body);font-size:13px;color:var(--ink);resize:vertical;outline:none;line-height:1.5;cursor:text;-webkit-user-select:text;user-select:text}.snote-text::placeholder{color:var(--muted);opacity:.7}.snote-add{position:absolute;top:4px;right:calc(var(--lright) + var(--lgap));z-index:11;pointer-events:auto;background:var(--yellow);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);padding:4px 10px;font-size:12px;font-weight:700;font-family:var(--font-body);color:var(--ink);cursor:pointer;border-radius:4px;transition:transform .06s ease,box-shadow .06s ease}.snote-add:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}.snote-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9500;background:#17160f00;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.snote-modal-backdrop--visible{background:#17160f73}.snote-modal{position:relative;width:min(520px,90vw);min-height:280px;max-height:80vh;display:flex;flex-direction:column;border:1.5px solid var(--ink);box-shadow:5px 5px #17160f38;border-radius:4px;transform:scale(.9);opacity:0;transition:transform .18s ease,opacity .18s ease}.snote-modal--visible{transform:scale(1);opacity:1}.snote-modal-grip{display:flex;align-items:center;gap:6px;padding:7px 10px 6px;border-bottom:1px solid rgba(23,22,15,.18);-webkit-user-select:none;user-select:none}.snote-modal-close{background:none;border:1.5px solid var(--ink);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:11px;color:var(--ink);padding:0;transition:background .1s}.snote-modal-close:hover{background:#17160f14}.snote-modal-text{flex:1;width:100%;min-height:220px;border:none;background:transparent;padding:12px 14px;font-family:var(--font-body);font-size:15px;color:var(--ink);resize:none;outline:none;line-height:1.6}.snote-modal-text::placeholder{color:var(--muted);opacity:.7}.pomo-launch{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--ink);background:var(--card);color:var(--ink);width:38px;height:38px;border-radius:9px;display:grid;place-items:center;cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .1s,box-shadow .1s,background .1s;flex-shrink:0}.pomo-launch:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink);background:var(--yellow-soft)}.pomo-launch:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.pomo-launch--active{background:var(--yellow)}.pomo{position:fixed;bottom:24px;right:24px;z-index:9000;width:230px;background:var(--card);border:2px solid var(--ink);border-radius:var(--r);box-shadow:5px 5px 0 var(--ink);padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px;-webkit-user-select:none;user-select:none}.pomo-drag-handle{cursor:grab}.pomo-drag-handle:active{cursor:grabbing}.pomo-header{display:flex;align-items:center;gap:6px}.pomo-mode-label{font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);background:var(--soft);border-radius:4px;padding:2px 5px;flex-shrink:0}.pomo-title{font-family:var(--font-head);font-weight:800;font-size:12px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);flex:1;text-align:center}.pomo-icon-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:transparent;color:var(--muted);cursor:pointer;padding:2px;line-height:1;display:grid;place-items:center;border-radius:4px;transition:color .1s,background .1s;flex-shrink:0}.pomo-icon-btn:hover{color:var(--ink);background:var(--card2)}.pomo-icon-btn--active{color:var(--ink);background:var(--yellow-soft)}.pomo-settings{display:flex;flex-direction:column;gap:8px;padding:10px;border:2px solid var(--soft);border-radius:9px;background:var(--soft)}.pomo-set-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.pomo-set-label{font-size:12px;font-weight:700;color:var(--ink)}.pomo-stepper{display:flex;align-items:center;gap:6px}.pomo-step-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border:2px solid var(--ink);border-radius:6px;background:var(--card);color:var(--ink);font-size:16px;font-weight:700;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:1px 1px 0 var(--ink);transition:transform .1s,box-shadow .1s,background .1s}.pomo-step-btn:hover:not(:disabled){background:var(--yellow-soft);transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink)}.pomo-step-btn:active:not(:disabled){transform:translate(1px,1px);box-shadow:0 0 0 var(--ink)}.pomo-step-btn:disabled{opacity:.35;cursor:not-allowed}.pomo-step-val{min-width:46px;text-align:center;font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--ink)}.pomo-step-val small{font-family:var(--font-body);font-size:10px;font-weight:600;color:var(--muted);margin-left:2px}.pomo-time{font-family:var(--font-mono);font-size:42px;font-weight:700;letter-spacing:-1px;text-align:center;line-height:1;color:var(--ink);padding:4px 0 2px}.pomo-time--done{font-family:var(--font-head);font-size:28px;letter-spacing:0;color:var(--easy)}.pomo-controls{display:flex;gap:8px}.pomo-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;border:2px solid var(--ink);border-radius:7px;padding:7px 10px;font-size:13px;font-weight:700;font-family:var(--font-body);cursor:pointer;box-shadow:2px 2px 0 var(--ink);transition:transform .1s,box-shadow .1s}.pomo-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}.pomo-btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.pomo-btn--yellow{background:var(--yellow);color:var(--ink)}.pomo-btn--ghost{background:transparent;color:var(--ink);box-shadow:none;border-color:var(--soft)}.pomo-btn--ghost:hover{background:var(--card2);box-shadow:2px 2px 0 var(--ink);border-color:var(--ink)}@media (max-width: 600px){.pomo{bottom:16px;right:16px;width:210px}.pomo-time{font-size:36px}}.nf-wrap{min-height:78vh;display:grid;place-items:center;padding:24px}.nf-card{max-width:460px;width:100%;text-align:center;background:var(--card);border:2px solid var(--ink);border-radius:16px;box-shadow:6px 6px 0 var(--ink);padding:40px 30px}.nf-code{font-family:var(--font-head);font-weight:800;font-size:92px;line-height:.9;color:var(--accent);letter-spacing:-2px;text-shadow:3px 3px 0 var(--ink)}.nf-bison{font-size:40px;margin-top:8px}.nf-title{font-family:var(--font-head);font-size:24px;font-weight:800;margin:12px 0 6px}.nf-text{color:var(--muted);font-size:14.5px;font-weight:600;line-height:1.55;margin:0 auto 22px;max-width:36ch}.nf-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}@media (max-width: 480px){.nf-code{font-size:72px}.nf-card{padding:30px 20px}.nf-actions .btn{flex:1}}
