:root{--bg: #131f24;--bg-2: #0f191d;--card: #1f2c34;--card-2: #233640;--line: #37464f;--line-soft: #2b3a42;--text: #f0f6f8;--muted: #8fa3ad;--green: #58cc02;--green-d: #46a302;--blue: #1cb0f6;--blue-d: #1899d6;--purple: #ce82ff;--purple-d: #a568cc;--red: #ff4b4b;--red-d: #d63a3a;--gold: #ffc800;--gold-d: #e6a800;--orange: #ff9600;--radius: 16px;--shadow-lift: 0 4px 0;font-family:Nunito,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;touch-action:manipulation}html,body{margin:0;height:100%}.screen-stage,.lesson-stage,.home,.lesson{touch-action:pan-y}html{scrollbar-width:none;-ms-overflow-style:none;-webkit-text-size-adjust:100%}html::-webkit-scrollbar{display:none}body{background:radial-gradient(1200px 600px at 50% -10%,#1a2c33 0%,var(--bg) 55%) fixed;color:var(--text);overscroll-behavior:none;overflow-x:hidden;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}#app{min-height:100%;display:flex;flex-direction:column;overflow-x:clip;position:relative}.screen-stage,.lesson-stage{position:relative}button{font-family:inherit;cursor:pointer;border:none}.muted{color:var(--muted)}.btn{--c: var(--green);--cd: var(--green-d);display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;font-size:15px;letter-spacing:.4px;text-transform:uppercase;color:#06240a;background:var(--c);border-radius:14px;padding:14px 18px;box-shadow:0 4px 0 var(--cd);user-select:none;touch-action:manipulation;transition:transform .04s,box-shadow .04s,background .15s,filter .15s}.btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--cd)}.btn.blue{--c: var(--blue);--cd: var(--blue-d);color:#04293a}.btn.gray{--c: #2b3a42;--cd: #1c282e;color:var(--text)}.btn.red{--c: var(--red);--cd: var(--red-d);color:#2a0606}.btn.ghost{background:transparent;box-shadow:none;color:var(--muted);border:2px solid var(--line);text-transform:none}.btn[disabled]{background:#2b3a42;color:#5d717b;box-shadow:0 4px #1c282e;cursor:not-allowed;pointer-events:none}.btn.block{width:100%}.home{min-height:100%;padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}.topbar{position:sticky;top:0;z-index:20;padding:calc(10px + env(safe-area-inset-top,0px)) 0 12px;background:#131f24eb;backdrop-filter:blur(10px);border-bottom:2px solid var(--line-soft)}.tb-inner{width:min(520px,92vw);margin:0 auto;display:flex;align-items:center;gap:18px}.tb-item{display:flex;align-items:center;gap:7px;font-weight:800;font-size:17px}.tb-item .ic{font-size:22px;line-height:1}.tb-item.flame{color:#ff9600}.tb-item.gem{color:#1cb0f6}.tb-flag{width:38px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:16px;font-weight:900;color:#fff;background:linear-gradient(180deg,#ff6b6b,#e23b3b);box-shadow:inset 0 -3px #0000002e}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:900;color:#fff;font-size:16px;background:linear-gradient(135deg,var(--purple),var(--blue));box-shadow:inset 0 -3px #0000002e}.home-sticky{position:sticky;top:calc(60px + env(safe-area-inset-top,0px));z-index:16;padding:8px 0 4px;background:linear-gradient(180deg,#131f24fa,#131f24e6 70%,#131f2400)}.dev-flag{width:min(520px,92vw);margin:2px auto 4px;display:flex;align-items:center;gap:8px;font-size:11px;font-weight:800;letter-spacing:.3px;color:var(--orange);background:#ff96001a;border:1px dashed rgba(255,150,0,.4);border-radius:10px;padding:5px 10px}.dev-flag .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex:none;box-shadow:0 0 8px #ff9600cc}.unit-banner{margin:0 auto 8px;width:min(520px,92vw);border-radius:16px;padding:14px 16px;background:var(--c, var(--green));box-shadow:0 4px 0 var(--cd, var(--green-d));color:#fff;display:flex;align-items:center;gap:12px}.unit-banner .ub-txt{flex:1;min-width:0}.unit-banner .lvl{font-size:12px;font-weight:800;opacity:.85;text-transform:uppercase;letter-spacing:1.2px}.unit-banner h2{margin:3px 0 0;font-size:19px;font-weight:800}.unit-banner .guide{flex:none;align-self:stretch;display:grid;place-items:center;padding-left:14px;margin-left:2px;border-left:2px solid rgba(255,255,255,.25);font-size:22px;color:#fff}.path{width:min(520px,92vw);margin:0 auto;padding:36px 0 120px;position:relative;z-index:1;overflow:visible}.node-row{display:flex;justify-content:center;padding:0;position:relative}.node-row.has-popover{z-index:200}.node-offset{position:relative;z-index:1}.node-offset.has-popover{z-index:200}.node-pos{position:relative;display:grid;place-items:center;margin:13px 0}.node-pos.has-popover{z-index:200}.node-pos.bob{animation:bob 2.4s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.ground{position:absolute;bottom:-7px;left:50%;transform:translate(-50%);width:62px;height:14px;border-radius:50%;background:#00000052;filter:blur(1px);z-index:0}.node{position:relative;z-index:1;width:72px;height:64px;border-radius:50%;display:grid;place-items:center;user-select:none;border:none;background:var(--c, var(--green));box-shadow:0 8px 0 var(--cd, var(--green-d));transition:transform .06s,box-shadow .06s;cursor:pointer;touch-action:manipulation}.node:before{content:"";position:absolute;top:7px;left:16px;right:16px;height:24%;border-radius:50%;background:#ffffff38}.node:active{transform:translateY(5px);box-shadow:0 3px 0 var(--cd)}.node .ic{position:relative;font-size:30px;filter:drop-shadow(0 2px 1px rgba(0,0,0,.28))}.node.locked{background:#37464f;box-shadow:0 8px #28333a;cursor:default}.node.locked:before{background:#ffffff0f}.node.locked .ic{opacity:.55;filter:grayscale(1)}.node.done .ic{font-size:26px}.node.done:after{content:"★";position:absolute;bottom:-7px;right:-7px;background:var(--gold);color:#5b4500;width:27px;height:27px;border-radius:50%;display:grid;place-items:center;font-size:15px;box-shadow:0 3px 0 var(--gold-d);border:3px solid var(--bg)}.halo{position:absolute;z-index:0;width:92px;height:84px;border-radius:50%;border:5px solid var(--c);opacity:.35}.halo.pulse{animation:halo 2s ease-out infinite}@keyframes halo{0%{transform:scale(.86);opacity:.5}80%,to{transform:scale(1.25);opacity:0}}.bubble{position:absolute;z-index:3;bottom:calc(100% + 16px);left:50%;transform:translate(-50%);background:#fff;color:var(--c);font-weight:900;font-size:13px;letter-spacing:1px;padding:9px 16px;border-radius:14px;box-shadow:0 3px #0000002e;white-space:nowrap}.bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(-1px);border:9px solid transparent;border-top-color:#fff}.mascot{position:absolute;top:50%;transform:translateY(-50%);font-size:52px;opacity:.9;pointer-events:none;filter:drop-shadow(0 4px 6px rgba(0,0,0,.3))}.mascot.left{right:calc(50% + 96px)}.mascot.right{left:calc(50% + 96px)}.mascot.dim{opacity:.22;filter:grayscale(1)}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;background:#1a2b33;border-top:2px solid var(--line-soft);padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}.tab{flex:1;display:grid;place-items:center;height:58px;font-size:26px;background:none;border:2px solid transparent;border-radius:14px;margin:6px;opacity:.85}.tab.active{border-color:var(--blue);background:#1cb0f624;opacity:1}.lesson{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.lesson-head{display:flex;align-items:center;gap:14px;padding:calc(16px + env(safe-area-inset-top,0px)) 18px 12px;width:min(720px,94vw);margin:0 auto;width:100%;max-width:720px}.icon-x{font-size:26px;color:var(--muted);background:none;line-height:1;font-weight:800;padding:4px 8px;border-radius:8px}.icon-x:hover{color:var(--text)}.progress{flex:1;height:16px;border-radius:10px;background:#2b3a42;overflow:hidden;position:relative}.progress>i{position:absolute;inset:0 auto 0 0;border-radius:10px;background:linear-gradient(90deg,var(--green),#7ee63a);transition:width .35s cubic-bezier(.4,1.3,.5,1)}.progress>i:after{content:"";position:absolute;top:3px;left:8px;right:8px;height:4px;border-radius:4px;background:#ffffff59}.streak-pill{display:flex;align-items:center;gap:5px;font-weight:900;color:var(--orange);font-size:18px}.lesson-body{flex:1;width:min(720px,94vw);margin:0 auto;padding:10px 0 240px;display:flex;flex-direction:column}@media (max-width: 640px){.lesson-body{padding-bottom:230px}.footer-inner{padding:10px 14px}.footer .btn.block{padding:14px 16px;font-size:16px;border-radius:12px}}.afb-tag{align-self:flex-start;font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--blue);background:#1cb0f61f;border:1px solid rgba(28,176,246,.3);padding:4px 10px;border-radius:20px;margin-bottom:14px}.afb-tag.a2{color:var(--gold);background:#ffc8001a;border-color:#ffc8004d}.afb-tag.a3{color:var(--purple);background:#ce82ff1f;border-color:#ce82ff52}.afb-tag.info{color:var(--green);background:#58cc021f;border-color:#58cc0252}.q-title{font-size:23px;font-weight:800;line-height:1.25;margin:0 0 18px}.info-card{background:#1cb0f60f;border:1px solid rgba(28,176,246,.22);border-radius:16px;padding:16px 18px;margin-bottom:4px}.info-card .info-body{margin:0 0 6px;font-size:16px;line-height:1.5}.info-card .info-body:last-child{margin-bottom:0}.info-card .info-body code{background:#0000000f;padding:1px 5px;border-radius:6px;font-size:.92em}.info-card .code{margin-top:12px}.code{background:#0c161a;border:1px solid var(--line-soft);border-radius:14px;padding:16px;margin:0 0 18px;overflow-x:auto;font-family:JetBrains Mono,Consolas,ui-monospace,monospace;font-size:14.5px;line-height:1.7;color:#cfe3ea;white-space:pre}.code .ln{display:block;padding:0 6px;border-radius:6px}.tok-kw{color:#ff9eea;font-weight:700}.tok-num{color:#ffd479}.tok-str{color:#9ae87a}.tok-com{color:#5d717b;font-style:italic}.tok-fn{color:#79d3ff}.code.lines .ln{cursor:pointer;transition:background .12s}.code.lines .ln:hover{background:#16262d}.code.lines .ln.sel{background:#1cb0f62e;outline:1px solid var(--blue)}.code.lines .ln.good{background:#58cc0229;outline:1px solid var(--green)}.code.lines .ln.bad{background:#ff4b4b2e;outline:1px solid var(--red)}.fix-wrap{margin-top:12px;opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease}.fix-wrap.show{opacity:1;transform:none}.fix-cap{font-size:12px;font-weight:900;letter-spacing:.3px;color:var(--green);margin:0 0 6px}.code.fixed{border-color:#58cc0266}.code.fixed .ln.fix-line{background:#58cc021a;border-radius:6px}.fix-mark{background:var(--green);color:#06240a;border-radius:5px;padding:0 4px;margin:0 1px;font-weight:900;box-shadow:0 0 0 2px #58cc0259;animation:fixpop .5s ease}@keyframes fixpop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.25)}to{transform:scale(1);opacity:1}}.options{display:flex;flex-direction:column;gap:12px}.opt{display:flex;align-items:center;gap:14px;text-align:left;background:var(--card);border:2px solid var(--line);border-bottom-width:4px;color:var(--text);border-radius:14px;padding:16px;font-size:16px;font-weight:700;transition:transform .04s,background .12s,border-color .12s}.opt:active{transform:translateY(2px)}.opt .key{flex:none;width:28px;height:28px;border-radius:8px;border:2px solid var(--line);display:grid;place-items:center;font-size:13px;font-weight:800;color:var(--muted)}.opt.sel{border-color:var(--blue);background:#1cb0f61f}.opt.sel .key{border-color:var(--blue);color:var(--blue)}.opt.good{border-color:var(--green);background:#58cc0224}.opt.bad{border-color:var(--red);background:#ff4b4b24}.opt code{font-family:JetBrains Mono,Consolas,monospace;font-size:15px;color:#bfe7ff}.fill-code{background:#0c161a;border:1px solid var(--line-soft);border-radius:14px;padding:18px 16px;margin-bottom:18px;font-family:JetBrains Mono,Consolas,monospace;font-size:15px;line-height:2.3;color:#cfe3ea;white-space:pre-wrap;word-break:break-word}.blank{display:inline-block;min-width:78px;height:30px;vertical-align:middle;border-bottom:3px dashed var(--line);margin:0 3px;text-align:center;border-radius:6px;transition:background .12s,border-color .12s}.blank .chip{margin:-3px 0}.blank-input{display:inline-block;min-width:54px;height:30px;vertical-align:middle;margin:0 3px;padding:0 6px;text-align:center;font-family:inherit;font-size:15px;color:#bfe7ff;background:#1cb0f614;border:none;border-bottom:3px solid var(--blue);border-radius:6px;outline:none;transition:background .12s,border-color .12s}.blank-input::placeholder{color:#5d717b}.blank-input:focus{background:#1cb0f62e}.blank-input.soft{background:#1cb0f62e;border-color:var(--blue);border-bottom-style:solid}.blank-input.good{background:#58cc0233;border-color:var(--green);border-bottom-style:solid;color:#cdf3a6}.blank-input.bad{background:#ff4b4b33;border-color:var(--red);border-bottom-style:solid;color:#ffd6d6}.blank-input:disabled{opacity:1;-webkit-text-fill-color:currentColor}.bank{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.chip{display:inline-flex;align-items:center;font-family:JetBrains Mono,Consolas,monospace;font-weight:700;font-size:14px;color:var(--text);background:var(--card);border:2px solid var(--line);border-bottom-width:4px;border-radius:12px;padding:9px 14px;transition:transform .05s,opacity .12s}.chip:active{transform:translateY(2px)}.chip.used{opacity:0;pointer-events:none}.chip.ghost{visibility:hidden}.match{display:grid;grid-template-columns:1fr 1fr;gap:12px 18px}.match .col{display:flex;flex-direction:column;gap:12px}.mtile{text-align:left;background:var(--card);border:2px solid var(--line);border-bottom-width:4px;color:var(--text);border-radius:14px;padding:15px;font-size:15px;font-weight:700;transition:transform .04s,border-color .12s,background .12s;min-height:52px}.mtile:active{transform:translateY(2px)}.mtile code{font-family:JetBrains Mono,Consolas,monospace;color:#bfe7ff;font-size:15px}.mtile.sel{border-color:var(--blue);background:#1cb0f624}.mtile.matched{border-color:var(--green);color:var(--muted);background:#58cc0214}.mtile.done{opacity:.45;pointer-events:none}.mtile.bad{border-color:var(--red);background:#ff4b4b24;animation:shake .3s}.calc-input{width:100%;font-family:JetBrains Mono,Consolas,monospace;font-size:20px;font-weight:700;color:var(--text);background:#0c161a;border:2px solid var(--line);border-bottom-width:4px;border-radius:14px;padding:16px 18px;outline:none}.calc-input:focus{border-color:var(--blue)}.calc-input.good{border-color:var(--green)}.calc-input.bad{border-color:var(--red)}.hint{color:var(--muted);font-size:14px;margin-top:10px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.footer{position:fixed;left:0;right:0;bottom:0;z-index:60;border-top:2px solid var(--line-soft);background:var(--bg-2);padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -6px 24px #00000047;transition:background .2s,border-color .2s}.footer-inner{width:min(720px,94vw);margin:0 auto;padding:12px 0}.footer.correct{background:#16280a;border-color:#2d4b13}.footer.wrong{background:#2a0e0e;border-color:#4d1d1d}.feedback{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}.feedback .badge{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:26px;font-weight:900}.footer.correct .badge{background:var(--green);color:#06240a}.footer.wrong .badge{background:var(--red);color:#2a0606}.feedback h4{margin:2px 0 4px;font-size:19px}.footer.correct .feedback h4{color:#8be23a}.footer.wrong .feedback h4{color:#ff7b7b}.feedback p{margin:0;color:#d6e2e7;font-size:14.5px;line-height:1.45}.feedback code{font-family:JetBrains Mono,Consolas,monospace;color:#bfe7ff;background:#00000040;padding:1px 5px;border-radius:5px}.result{width:min(560px,92vw);margin:0 auto;padding:40px 0 60px;text-align:center}.result .crown{font-size:64px;margin-bottom:6px;animation:pop .5s}@keyframes pop{0%{transform:scale(.4);opacity:0}70%{transform:scale(1.12)}to{transform:scale(1);opacity:1}}.result h1{font-size:30px;margin:4px 0 26px}.result .cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:26px}.rcard{border-radius:16px;padding:2px}.rcard.gold{background:var(--gold)}.rcard.gold .inner{color:var(--gold)}.rcard.green{background:var(--green)}.rcard.green .inner{color:var(--green)}.rcard.blue{background:var(--blue)}.rcard.blue .inner{color:var(--blue)}.rcard.orange{background:var(--orange)}.rcard.orange .inner{color:var(--orange)}.rcard .inner{background:var(--bg);border-radius:14px;padding:14px}.rcard .lab{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.rcard .val{font-size:26px;font-weight:900;color:var(--text);margin-top:4px}.section-title{text-align:left;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:8px 0 12px}.badges{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:26px}.badge-pill{display:flex;flex-direction:column;align-items:center;gap:4px;width:92px;background:var(--card);border:1px solid var(--line-soft);border-radius:14px;padding:12px 6px}.badge-pill .b{font-size:30px}.badge-pill.locked .b{filter:grayscale(1);opacity:.35}.badge-pill .t{font-size:11px;font-weight:800;color:var(--muted)}.chart{background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:16px;margin-bottom:26px}.bars{display:flex;align-items:flex-end;gap:10px;height:120px}.bars .bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:6px;height:100%}.bars .bar>span:first-child{width:100%;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#7ee63a,var(--green));min-height:4px;transition:height .5s}.bars .bar .cap{font-size:10px;color:var(--muted);font-weight:800}.lb{background:var(--card);border:1px solid var(--line-soft);border-radius:16px;overflow:hidden;margin-bottom:30px}.lb-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line-soft)}.lb-row:last-child{border-bottom:none}.lb-row.you{background:#1cb0f61a}.lb-rank{width:26px;font-weight:900;color:var(--muted);text-align:center}.lb-rank.top{color:var(--gold)}.lb-name{flex:1;text-align:left;font-weight:800}.lb-xp{font-weight:800;color:var(--gold)}.toast{position:fixed;left:50%;bottom:96px;transform:translate(-50%) translateY(20px);background:#fff;color:#16280a;font-weight:800;padding:12px 18px;border-radius:14px;box-shadow:0 8px 24px #0006;opacity:0;transition:.3s;z-index:30;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.center-col{display:flex;flex-direction:column;gap:12px}.retry-note{color:#ffb3b3;background:#ff4b4b1a;border:1px solid rgba(255,75,75,.32);border-radius:12px;padding:11px 14px;font-size:14px;font-weight:700;margin:0 auto 18px;max-width:460px}.fadein{animation:fade .25s ease}@keyframes fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.unit-banner{cursor:pointer;transition:transform .05s}.unit-banner:active{transform:translateY(2px)}.unit-banner .ub-sub{font-size:12.5px;opacity:.9;margin-top:2px}.seq-foot{width:min(520px,92vw);margin:0 auto 8px}.seq-progress{height:12px;border-radius:8px;background:#2b3a42;overflow:hidden}.seq-progress>i{display:block;height:100%;border-radius:8px;background:linear-gradient(90deg,var(--green),#7ee63a);transition:width .4s}.seq-foot-txt{text-align:center;font-size:13px;font-weight:700;margin-top:8px}.sheet-overlay{position:fixed;inset:0;z-index:40;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .2s}.sheet-overlay.show{opacity:1}.sheet{width:min(520px,100%);max-height:82vh;overflow-y:auto;background:var(--card);border-radius:22px 22px 0 0;padding:10px 16px calc(20px + env(safe-area-inset-bottom,0px));transform:translateY(20px);transition:transform .22s;border-top:2px solid var(--line)}.sheet-overlay.show .sheet{transform:translateY(0)}.sheet-handle{width:44px;height:5px;border-radius:3px;background:var(--line);margin:6px auto 10px}.sheet h3{margin:4px 4px 12px;font-size:18px}.seq-item{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--bg-2);border:2px solid var(--line);border-bottom-width:4px;border-radius:14px;padding:12px 14px;margin-bottom:10px;color:var(--text)}.seq-item:active{transform:translateY(2px)}.seq-item.active{border-color:var(--c, var(--green));background:#58cc0214}.seq-emoji{font-size:28px;flex:none;width:40px;text-align:center}.seq-meta{flex:1;min-width:0}.seq-name{font-weight:800;font-size:15px}.seq-blurb{font-size:12.5px}.seq-count{font-weight:800;color:var(--c, var(--green))}.fill-code{line-height:2.1}.blank{min-width:56px;height:26px;border-bottom-width:2px;margin:0 2px;padding:0 4px;vertical-align:baseline}.chip{font-size:14px;padding:4px 9px;border-bottom-width:3px;border-radius:8px;line-height:1.2}.chip.in{padding:2px 6px;margin:0;border-bottom-width:2px;background:var(--card-2)}.blank.good .chip.in{background:#58cc0233}.blank.bad .chip.in{background:#ff4b4b33}.blank.soft .chip.in{background:#1cb0f633}.match{position:relative}.match-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:0}.mtile{position:relative;z-index:1}.mtile.good{border-color:var(--green);background:#58cc0224}.mtile.bad{border-color:var(--red);background:#ff4b4b24}.calc-input.soft{border-color:var(--blue);background:#1cb0f61a}.code-editor{width:100%;min-height:132px;resize:vertical;font-family:JetBrains Mono,Consolas,monospace;font-size:14.5px;line-height:1.6;color:#cfe3ea;background:#0c161a;border:2px solid var(--line);border-bottom-width:4px;border-radius:14px;padding:14px;outline:none;tab-size:2;white-space:pre}.code-editor:focus{border-color:var(--blue)}.code-editor.soft{border-color:var(--blue)}.code-editor.good{border-color:var(--green)}.code-editor.bad{border-color:var(--red)}.run-btn{width:auto;margin:12px 0 0;text-transform:none;font-size:14px;padding:10px 16px}.code-output{margin-top:14px;border-radius:12px;padding:12px 14px;border:1px solid var(--line-soft);background:#0a1216}.code-output.ok{border-color:#2d4b13}.code-output.err{border-color:#4d1d1d}.co-title{font-weight:800;font-size:13px;margin-bottom:6px}.code-output.ok .co-title{color:#8be23a}.code-output.err .co-title{color:#ff7b7b}.code-output pre{margin:0;font-family:JetBrains Mono,Consolas,monospace;font-size:14px;color:#cfe3ea;white-space:pre-wrap}.footer.tip{background:#0c2230;border-color:#1c4a63}.footer.tip .badge{background:var(--blue);color:#04293a}.footer.tip .feedback h4{color:#6fd0ff}.page{width:min(560px,92vw);margin:0 auto;padding:18px 0 30px}.goals-page{width:min(560px,92vw)}.page-title{font-size:26px;margin:6px 0 4px}.page-sub{font-size:14px;margin:0 0 18px}.goal-split{display:block}.goal-column{width:100%}.goal-list{display:flex;flex-direction:column;gap:12px;margin-bottom:22px}.goal{display:flex;gap:14px;background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:14px}.goal-ic{font-size:26px;flex:none;width:34px;text-align:center}.goal-main{flex:1;min-width:0}.goal-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}.goal-name{font-weight:800;font-size:15px;flex:1}.goal-lv{font-size:12px;font-weight:800;color:var(--gold);white-space:nowrap}.goal-bar{height:12px;border-radius:8px;background:#2b3a42;overflow:hidden}.goal-bar>i{display:block;height:100%;border-radius:8px;background:linear-gradient(90deg,var(--blue),#7ee3ff);transition:width .5s}.goal-meta{font-size:12px;margin-top:7px}.podium{display:flex;align-items:flex-end;justify-content:center;gap:10px;margin:8px 0 22px}.pod{flex:1;max-width:120px;display:flex;flex-direction:column;align-items:center;gap:4px}.pod-medal{font-size:26px}.pod-ava{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-weight:900;font-size:20px;color:#fff;background:linear-gradient(135deg,var(--purple),var(--blue));border:3px solid var(--card)}.pod-name{font-weight:800;font-size:13px}.pod-xp{font-weight:800;font-size:12px;color:var(--gold)}.pod-bar{width:100%;border-radius:10px 10px 0 0;background:linear-gradient(180deg,#34454e,#222f35)}.pod.p1 .pod-bar{height:84px;background:linear-gradient(180deg,#ffd84d,var(--gold))}.pod.p2 .pod-bar{height:60px;background:linear-gradient(180deg,#dfe7ea,#9fb0b8)}.pod.p3 .pod-bar{height:44px;background:linear-gradient(180deg,#e2a36b,#b9763f)}.pod.you .pod-name{color:var(--blue)}.lb-ava{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--purple),var(--blue));font-size:14px}.profile-head{display:flex;align-items:center;gap:16px;margin:10px 0 20px}.profile-ava{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-size:32px;background:linear-gradient(135deg,var(--purple),var(--blue))}.profile-name{font-size:24px;margin:0}.pstats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}.pstat{background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:14px;text-align:center}.pstat-ic{font-size:22px}.pstat-val{font-size:22px;font-weight:900;margin-top:2px}.pstat-lab{font-size:12px}.backup-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 0 8px}.backup-btn{min-height:54px}.btn-ic{display:grid;place-items:center}.btn-ic svg{width:18px;height:18px}.backup-note{font-size:13px;margin:0 0 18px;line-height:1.4}.badges.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.badges.grid .badge-pill{width:auto}@media (max-width: 640px){.goal-split{display:block}.goal-column{width:100%}.lesson-head{padding:calc(18px + env(safe-area-inset-top,0px)) 14px 10px}.btn{padding-top:12px;padding-bottom:12px}}@media (max-width: 480px){.badges.grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.badges.grid .badge-pill{padding:10px 4px;min-height:92px}.badge-pill .b{font-size:24px}.badge-pill .t{font-size:10px}}.modal-overlay{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:#0000009e;padding:18px;opacity:0;transition:opacity .2s}.modal-overlay.show{opacity:1}.backup-modal{width:min(480px,94vw);background:var(--card);border:2px solid var(--line);border-bottom-width:4px;border-radius:18px;padding:18px;box-shadow:0 24px 60px #00000094;transform:translateY(12px);transition:transform .22s}.modal-overlay.show .backup-modal{transform:translateY(0)}.modal-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.modal-head h3{margin:0 0 3px;font-size:20px}.modal-head p{margin:0;font-size:13px}.modal-x{margin-left:auto;width:34px;height:34px;display:grid;place-items:center;border-radius:10px;background:#2b3a42;color:var(--muted);font-size:22px;font-weight:900}.import-warning{background:#ffc8001f;border:1px solid rgba(255,200,0,.34);color:#ffe28a;border-radius:12px;padding:12px 13px;font-size:13px;line-height:1.4;margin-bottom:14px}.dropzone{width:100%;min-height:150px;display:grid;place-items:center;gap:6px;background:#0c161a;border:2px dashed var(--line);border-radius:14px;color:var(--text);padding:22px;transition:border-color .15s,background .15s,transform .05s}.dropzone:active{transform:translateY(2px)}.dropzone.drag{border-color:var(--blue);background:#1cb0f61f}.drop-ic{display:grid;place-items:center;color:var(--blue)}.dropzone strong{font-size:17px}.dropzone span:last-child{font-size:13px}.import-status{margin:12px 0 14px;min-height:22px;font-size:13px;font-weight:800;text-align:center;line-height:1.35}.import-status.ok{color:var(--green)}.import-status.err{color:var(--red)}.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}svg{display:block}.brand{display:inline-flex;align-items:center;gap:8px;font-weight:900;font-size:18px;letter-spacing:.2px;color:var(--text);background:none;border:none;padding:0}.brand:hover{opacity:.92}.brand:active{transform:translateY(1px)}.brand-mark{display:grid;place-items:center;width:30px;height:30px;border-radius:9px;background:var(--green);color:#06240a}.brand-mark svg{width:18px;height:18px}.tb-spacer{flex:1}.tb-streak{display:flex;align-items:center;gap:7px;font-weight:800;font-size:15px;color:var(--orange);background:#ff96001f;border:1px solid rgba(255,150,0,.28);padding:6px 12px;border-radius:20px}.tb-streak .ic{display:grid;place-items:center;color:var(--orange)}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--purple),var(--blue));box-shadow:inset 0 -2px #0000002e}.avatar svg{width:20px;height:20px}.tabbar{background:#0f191df5}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;height:60px;background:none;border:none;border-radius:0;margin:0;opacity:1;color:var(--muted)}.tab-ic{display:grid;place-items:center}.tab-ic svg{width:24px;height:24px}.tab-lab{font-size:11px;font-weight:800}.tab.active{color:var(--blue);background:none}.node:before{display:none}.node{box-shadow:0 6px 0 var(--cd, var(--green-d))}.node:active{transform:translateY(4px);box-shadow:0 2px 0 var(--cd)}.node .ic{font-size:0;color:#00000075;display:grid;place-items:center}.node .ic svg{width:34px;height:34px}.node.locked{box-shadow:0 6px #28333a}.node.locked .ic{color:#ffffff52;filter:none;opacity:1}.node.done .ic{color:#ffffffd9}.node.done:after{content:none}.ground{background:#00000047}.mascot{display:none}.day-progress{width:min(520px,92vw);margin:12px auto 0;display:flex;align-items:center;gap:12px}.dp-bar{flex:1;height:12px;border-radius:8px;background:#2b3a42;overflow:hidden}.dp-bar>i{display:block;height:100%;border-radius:8px;background:var(--c, var(--green));transition:width .4s}.dp-txt{font-size:13px;font-weight:800;white-space:nowrap}.locked-note{width:min(520px,92vw);margin:40px auto;display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:20px}.locked-note .ln-ic{width:48px;height:48px;flex:none;border-radius:12px;display:grid;place-items:center;background:#2b3a42;color:var(--muted)}.locked-note strong{font-size:16px}.seq-item{align-items:center}.seq-item.locked{opacity:.6}.seq-dot{width:14px;height:14px;border-radius:50%;flex:none}.seq-dot.status-none{background:#5d717b}.seq-dot.status-some{background:var(--orange)}.seq-dot.status-all{background:var(--green)}.seq-dot.status-locked{background:#2b3a42;border:2px solid #45565f}.seq-count svg{width:18px;height:18px;color:var(--muted)}.fill-code{line-height:2.4}.blank{display:inline-flex;align-items:center;justify-content:center;min-width:58px;height:30px;padding:0 6px;margin:0 2px;vertical-align:middle;border-bottom:2px dashed var(--line);border-radius:7px;box-sizing:border-box}.blank.filled{border-bottom-style:solid}.blank.good{background:#58cc0229;border-color:var(--green)}.blank.bad{background:#ff4b4b29;border-color:var(--red)}.blank.soft{background:#1cb0f629;border-color:var(--blue)}.blank.locked{cursor:default}.blank.over{background:#1cb0f638;border-color:var(--blue)}.blank .chip.in{margin:0;padding:1px 6px;border:none;box-shadow:none;background:transparent;height:auto;font-size:14px}.chip{cursor:grab}.chip.dragging{opacity:.4}.combo-pill{font-weight:800;font-size:14px;color:var(--orange);white-space:nowrap}.feedback .fb-main{flex:1;min-width:0}.fb-sub{font-size:13px;margin-top:8px}.linkbtn{background:none;border:none;color:var(--blue);font-weight:800;font-size:13px;text-decoration:underline;padding:0;cursor:pointer}.footer.tip .badge{background:var(--blue);color:#04293a;font-style:normal}.chart{position:relative;background:var(--card);border:1px solid var(--line-soft);border-radius:16px;padding:14px}.linechart{width:100%;height:auto;overflow:visible}.linechart .grid{stroke:#2b3a42;stroke-width:1}.linechart .axislbl{fill:#5d717b;font-size:9px;font-weight:700}.linechart .series{fill:none;stroke:var(--green);stroke-width:3;stroke-linejoin:round;stroke-linecap:round}.linechart .dot{fill:var(--green);stroke:var(--bg);stroke-width:2;cursor:pointer;transition:r .1s}.linechart .dot:hover{r:7}.chart-tip{position:absolute;transform:translate(-50%,calc(-100% - 12px));background:#fff;color:#16280a;font-size:12px;font-weight:700;padding:7px 10px;border-radius:10px;box-shadow:0 6px 18px #0006;pointer-events:none;white-space:nowrap;z-index:5}.chart-tip strong{font-weight:900}.result .crown{display:grid;place-items:center;margin:0 auto 6px;width:76px;height:76px;border-radius:50%}.result .crown.gold{color:var(--gold);background:#ffc80024}.result .crown.green{color:var(--green);background:#58cc0224}.result .crown.blue{color:var(--blue);background:#1cb0f624}.result .crown.orange{color:var(--orange);background:#ff960024}.center{text-align:center}.rcard.purple{background:var(--purple)}.rcard.purple .inner{color:var(--purple)}.goal-ic{display:grid;place-items:center;color:var(--blue)}.goal-ic svg{width:22px;height:22px}.profile-ava{color:#fff}.profile-ava svg{width:34px;height:34px}.pstat-ic{display:grid;place-items:center;color:var(--blue);margin-bottom:2px}.pstat-ic svg{width:22px;height:22px}.badge-pill{transition:border-color .15s,background .15s}.badge-pill .b{display:grid;place-items:center;color:var(--muted)}.badge-pill .b svg{width:26px;height:26px}.badge-pill.got{border-color:var(--green);background:#58cc021f}.badge-pill.got .b{color:var(--green)}.badge-pill.got .t{color:var(--text)}.badge-pill.locked .b{color:#4a5b64}.tb-flag{width:auto;height:auto;padding:6px 12px;border-radius:11px;font-size:15px;font-weight:900;letter-spacing:.3px;color:#fff;background:linear-gradient(180deg,#ff5b5b,#e23b3b);box-shadow:inset 0 -3px #00000038;display:inline-flex;align-items:center}.node-popover{position:absolute;z-index:260;top:calc(100% + 14px);left:50%;width:232px;max-width:78vw;text-align:center;opacity:0;transform:translate(-50%) translateY(-8px);background:var(--card);border:2px solid var(--line);border-bottom-width:4px;border-radius:16px;padding:14px;box-shadow:0 14px 34px #0000008c;transition:opacity .16s ease,transform .16s ease}.node-popover.show{opacity:1;transform:translate(-50%) translateY(0)}.node-popover:before,.node-popover:after{content:"";position:absolute;left:50%;transform:translate(-50%)}.node-popover:before{bottom:100%;border:10px solid transparent;border-bottom-color:var(--line)}.node-popover:after{bottom:calc(100% - 1px);border:9px solid transparent;border-bottom-color:var(--card)}.np-start{min-height:46px}.np-step{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--c, var(--green))}.np-name{font-size:17px;font-weight:900;margin:2px 0 5px}.np-goal{font-size:13px;color:var(--muted);line-height:1.35;margin-bottom:12px}.np-start{width:100%}.celebrate{position:fixed;inset:0;z-index:60;display:grid;place-items:center;background:#0009;opacity:0;transition:opacity .25s}.celebrate.show{opacity:1}.confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none}.confetti i{position:absolute;top:-16px;border-radius:2px;animation-name:fall;animation-timing-function:linear;animation-iteration-count:infinite}@keyframes fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(102vh) rotate(620deg);opacity:1}}.celebrate-card{position:relative;z-index:1;width:min(360px,86vw);text-align:center;background:var(--card);border:2px solid var(--line);border-bottom-width:4px;border-radius:22px;padding:26px 24px;box-shadow:0 22px 54px #0000008c;animation:pop .3s ease}.cc-emoji{font-size:48px;line-height:1}.celebrate-card h2{margin:8px 0 6px;font-size:24px}.celebrate-card p{color:var(--muted);margin:0 0 18px;line-height:1.4}
