@import "https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,400;0,600;0,700;0,800;0,900;1,800&family=JetBrains+Mono:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0e17;--bg-soft:#17161f;--bg-sunk:#1e1d28;--bg-card:#1a1926;--bg-raise:#222132;--ink:#f4f2ff;--ink-2:#c4c0e0;--ink-3:#8b87a8;--ink-4:#5a5670;--line:#ffffff14;--line-2:#ffffff0d;--coral:#ff6b6b;--coral-soft:#ff6b6b26;--watch-color:#4cc9f0;--watch-glow:#4cc9f02e;--read-color:#f9c74f;--read-glow:#f9c74f2e;--record-color:#ff6b6b;--record-glow:#ff6b6b2e;--practice-color:#06d6a0;--practice-glow:#06d6a02e;--test-color:#a78bfa;--test-glow:#a78bfa2e;--teal:#4cc9f0;--teal-soft:#4cc9f026;--lime:#06d6a0;--amber:#f9c74f;--violet:#a78bfa;--primary:#4cc9f0;--radius:12px;--radius-lg:18px;--radius-xl:24px;--sidebar-w:256px;--topbar-h:56px;--tabbar-h:64px}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Nunito,system-ui,sans-serif;font-size:15px;line-height:1.5}button{cursor:pointer;background:0 0;border:none;font-family:inherit}a{color:inherit;cursor:pointer;text-decoration:none}input,textarea{font-family:inherit}.shell{grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;height:100vh;display:grid;overflow:hidden}.shell.shell-full{grid-template-columns:1fr}.topbar{background:var(--bg-soft);border-bottom:1px solid var(--line);z-index:10;grid-column:1/-1;align-items:center;gap:16px;padding:0 20px;display:flex;position:relative}.topbar:after{content:"";background:linear-gradient(90deg, transparent 0%, var(--watch-color) 25%, var(--practice-color) 50%, var(--record-color) 75%, transparent 100%);opacity:.4;height:1px;position:absolute;bottom:0;left:0;right:0}.logo{color:var(--ink);letter-spacing:-.03em;flex-shrink:0;align-items:center;gap:9px;font-size:19px;font-weight:900;display:flex}.logo-mark{background:linear-gradient(135deg, var(--coral) 0%, #ff4757 100%);color:#fff;border-radius:10px;place-items:center;width:32px;height:32px;font-size:17px;font-weight:900;display:grid;box-shadow:0 4px 14px #ff6b6b66}.topbar-nav{gap:2px;margin-left:12px;display:flex}.topbar-nav a{color:var(--ink-3);border-radius:8px;padding:6px 12px;font-size:13.5px;font-weight:700;transition:background .15s,color .15s}.topbar-nav a:hover{background:var(--bg-sunk);color:var(--ink)}.topbar-nav a.active{color:var(--ink);background:var(--bg-sunk)}.topbar-right{align-items:center;gap:10px;margin-left:auto;display:flex}.xp-bar-wrap{background:var(--bg-sunk);border:1px solid var(--line);border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 8px;display:flex}.xp-bar-label{color:var(--amber);letter-spacing:.03em;font-size:11px;font-weight:800}.xp-bar-track{background:#ffffff14;border-radius:999px;width:72px;height:5px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg, var(--amber), #f4a636);border-radius:999px;height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.streak{color:var(--amber);letter-spacing:-.01em;background:#f9c74f1f;border:1px solid #f9c74f33;border-radius:999px;align-items:center;gap:5px;padding:5px 11px;font-size:13px;font-weight:800;display:flex}.admin-toggle{color:var(--ink-3);border:1px solid var(--line);background:0 0;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:700;transition:all .15s}.admin-toggle:hover,.admin-toggle.on{background:var(--bg-sunk);color:var(--ink);border-color:var(--line-2)}.avatar{background:linear-gradient(135deg, var(--violet), #7c3aed);color:#fff;border-radius:50%;place-items:center;width:32px;height:32px;font-size:13px;font-weight:900;display:grid;box-shadow:0 0 0 2px #a78bfa4d}.sidebar{border-right:1px solid var(--line);background:var(--bg-soft);flex-direction:column;display:flex;overflow:hidden}.sidebar-nav-group{border-bottom:1px solid var(--line);flex-direction:column;gap:4px;padding:14px;display:flex}.sidebar-nav-btn{color:var(--ink-3);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:13.5px;font-weight:800;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex}.sidebar-nav-btn:hover{background:var(--bg-sunk);color:var(--ink)}.sidebar-nav-btn.active{color:var(--ink);background:var(--bg-raise)}.sidebar-nav-btn .nav-icon-box{background:var(--bg-sunk);width:26px;height:26px;color:var(--ink-3);border-radius:6px;flex-shrink:0;place-items:center;transition:all .2s;display:grid}.sidebar-nav-btn.active .nav-icon-box{color:#fff}.sidebar-nav-btn[data-mode=stories].active .nav-icon-box{background:var(--coral);box-shadow:0 0 10px #ff6b6b66}.sidebar-nav-btn[data-mode=roadmap].active .nav-icon-box{background:var(--practice-color);box-shadow:0 0 10px #06d6a066}.sidebar-nav-btn[data-mode=vocabs].active .nav-icon-box{background:var(--read-color);box-shadow:0 0 10px #f9c74f66}.sidebar-nav-btn[data-mode=stats].active .nav-icon-box{background:var(--violet);box-shadow:0 0 10px #a78bfa66}.sidebar-header{border-bottom:1px solid var(--line);padding:14px 16px}.sidebar-title{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4);margin-bottom:8px;font-size:10px;font-weight:800}.sidebar-story{justify-content:space-between;align-items:center;gap:6px;margin-bottom:3px;display:flex}.sidebar-story span:first-child{color:var(--ink);font-size:14px;font-weight:800}.level-pill{background:var(--bg-sunk);border:1px solid var(--line);color:var(--ink-3);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:800}.sidebar-story-meta{color:var(--ink-3);margin-bottom:8px;font-size:12px;font-weight:600}.progress-track{background:var(--bg-sunk);border-radius:999px;height:5px;margin-bottom:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--practice-color), var(--teal));border-radius:999px;height:100%;transition:width .4s cubic-bezier(.34,1.56,.64,1)}.autonext{color:var(--ink-3);justify-content:space-between;align-items:center;font-size:12px;font-weight:700;display:flex}.toggle{background:var(--bg-sunk);cursor:pointer;border:1px solid var(--line);border-radius:999px;width:32px;height:18px;transition:background .2s;position:relative}.toggle:after{content:"";background:var(--ink-3);border-radius:50%;width:12px;height:12px;transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.toggle.on{background:var(--practice-color);border-color:var(--practice-color)}.toggle.on:after{background:#fff;transform:translate(14px)}.sidebar-scroll{flex:1;padding:10px 0;overflow-y:auto}.sidebar-scroll::-webkit-scrollbar{width:3px}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}.story-group-header{cursor:pointer;border-radius:10px;align-items:center;gap:9px;margin:1px 8px;padding:8px 14px;transition:background .12s;display:flex}.story-group-header:hover{background:var(--bg-sunk)}.story-group-header.current{background:var(--bg-raise)}.story-icon{background:var(--bg-sunk);border-radius:8px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:15px;display:grid}.story-name{color:var(--ink);flex:1;font-size:13px;font-weight:700}.story-count{color:var(--ink-4);font-size:11px;font-weight:700}.caret{color:var(--ink-4);transition:transform .2s}.caret.open{transform:rotate(90deg)}.lesson-list{padding:4px 0 8px 36px;position:relative}.lesson-list:before{content:"";background:linear-gradient(to bottom, var(--line), transparent);border-radius:999px;width:2px;position:absolute;top:0;bottom:0;left:22px}.lesson-item{cursor:pointer;border-radius:10px;align-items:center;gap:9px;margin:1px 8px 1px 0;padding:6px 12px 6px 0;transition:background .12s;display:flex;position:relative}.lesson-item:hover{background:var(--bg-sunk)}.lesson-item.active{background:var(--bg-raise)}.lesson-num{background:var(--bg-raise);border:2px solid var(--line);width:22px;height:22px;color:var(--ink-3);z-index:1;border-radius:50%;flex-shrink:0;place-items:center;font-size:10px;font-weight:900;transition:border-color .2s,background .2s;display:grid;position:relative}.lesson-item.active .lesson-num{background:var(--coral);border-color:var(--coral);color:#fff;box-shadow:0 0 0 3px #ff6b6b40}.lesson-title{color:var(--ink-2);flex:1;font-size:12.5px;font-weight:700}.lesson-item.active .lesson-title{color:var(--ink)}.lesson-dots{gap:3px;display:flex}.dot{background:var(--bg-raise);border:1px solid var(--line);border-radius:50%;width:6px;height:6px}.dot.done{background:var(--practice-color);border-color:var(--practice-color);box-shadow:0 0 4px #06d6a080}.lesson-progress-text{color:var(--ink-4);font-size:10px;font-weight:700}.main{background:var(--bg);flex-direction:column;display:flex;overflow:hidden}.tabbar{background:var(--bg-soft);border-bottom:1px solid var(--line);min-height:var(--tabbar-h);flex-shrink:0;align-items:center;gap:4px;padding:8px 16px;display:flex}.tab{color:var(--ink-4);cursor:pointer;white-space:nowrap;letter-spacing:.02em;text-transform:uppercase;background:0 0;border:1.5px solid #0000;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:3px;min-width:72px;padding:8px 18px;font-size:11px;font-weight:800;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.tab-icon{background:var(--bg-sunk);border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex}.tab:hover{color:var(--ink-2);background:var(--bg-sunk)}.tab:hover .tab-icon{transform:translateY(-2px)}.tab:active{transform:scale(.94)}.tab[data-tab=watch].active{color:var(--watch-color);background:var(--watch-glow);border-color:#4cc9f04d}.tab[data-tab=watch].active .tab-icon{background:#4cc9f033;box-shadow:0 0 16px #4cc9f059}.tab[data-tab=vocab].active{color:var(--read-color);background:var(--read-glow);border-color:#f9c74f4d}.tab[data-tab=vocab].active .tab-icon{background:#f9c74f33;box-shadow:0 0 16px #f9c74f59}.tab[data-tab=read].active{color:var(--read-color);background:var(--read-glow);border-color:#f9c74f4d}.tab[data-tab=read].active .tab-icon{background:#f9c74f33;box-shadow:0 0 16px #f9c74f59}.tab[data-tab=record].active{color:var(--record-color);background:var(--record-glow);border-color:#ff6b6b4d}.tab[data-tab=record].active .tab-icon{background:#ff6b6b33;box-shadow:0 0 16px #ff6b6b59}.tab[data-tab=practice].active{color:var(--practice-color);background:var(--practice-glow);border-color:#06d6a04d}.tab[data-tab=practice].active .tab-icon{background:#06d6a033;box-shadow:0 0 16px #06d6a059}.tab[data-tab=test].active{color:var(--test-color);background:var(--test-glow);border-color:#a78bfa4d}.tab[data-tab=test].active .tab-icon{background:#a78bfa33;box-shadow:0 0 16px #a78bfa59}.count-pill{background:var(--coral);color:#fff;text-align:center;border-radius:999px;min-width:15px;padding:1px 5px;font-size:9px;font-weight:900;line-height:1.5;position:absolute;top:4px;right:4px;box-shadow:0 2px 6px #ff6b6b80}.tab-divider{background:var(--line);flex-shrink:0;width:1px;height:32px;margin:0 8px}.breadcrumb{color:var(--ink-3);background:var(--bg-soft);border-bottom:1px solid var(--line);flex-shrink:0;align-items:center;gap:6px;min-height:36px;padding:7px 20px;font-size:12px;font-weight:700;display:flex}.main-scroll{flex:1;overflow-y:auto}.watch-layout{flex-direction:column;gap:16px;padding:18px 24px 40px;display:flex}.player-wrap{aspect-ratio:16/9;border-radius:var(--radius-lg);background:#111;width:100%;max-width:85.3333vh;max-height:48vh;margin:0 auto;position:relative;overflow:hidden}@media (width<=800px){.player-wrap{max-width:100%}}.record-canvas-wrap{aspect-ratio:16/9;background:#000;border-radius:12px;width:100%;max-width:120.889vh;max-height:68vh;margin:0 auto;position:relative;overflow:hidden}@media (width<=800px){.record-canvas-wrap{max-width:100%}}.player-wrap iframe{border:0;width:100%;height:100%}.player-placeholder{color:#fff;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;height:100%;display:flex}.player-placeholder .big{font-size:20px;font-weight:800}.player-placeholder .hint{color:#aaa;font-size:13px}.placeholder-add{background:var(--coral);color:#fff;border-radius:10px;margin-top:6px;padding:10px 20px;font-size:14px;font-weight:700}.timestamp-ribbon{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden}.ribbon-header{border-bottom:1px solid var(--line-2);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.ribbon-title{color:var(--ink-2);align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.badge{background:var(--coral-soft);color:var(--coral);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:800}.ribbon-hint{color:var(--ink-3);font-size:12px}.ribbon-canvas{background:var(--bg-sunk);height:36px;position:relative;overflow:hidden}.ribbon-progress{background:var(--coral-soft);height:100%;transition:width .3s;position:absolute;top:0;left:0}.ribbon-wave{align-items:center;gap:1px;padding:4px 6px;display:flex;position:absolute;inset:0}.ribbon-wave span{background:var(--line);border-radius:1px;flex:1;min-width:2px}.ribbon-wave span.active{background:var(--coral)}.timestamp-chips{flex-wrap:wrap;gap:6px;padding:10px 12px;display:flex}.chip{background:var(--bg-sunk);width:30px;height:30px;color:var(--ink-2);border-radius:8px;place-items:center;font-size:12px;font-weight:800;transition:background .15s,color .15s;display:grid;position:relative}.chip:hover{background:var(--coral-soft);color:var(--coral)}.chip.active{background:var(--coral);color:#fff}.chip.done{background:var(--coral-soft);color:var(--coral)}.chip-preview{white-space:nowrap;background:var(--bg-raise);color:var(--ink);border:1px solid var(--line);pointer-events:none;z-index:10;border-radius:8px;padding:5px 10px;font-size:11.5px;font-weight:600;display:none;position:absolute;bottom:36px;left:50%;transform:translate(-50%)}.chip:hover .chip-preview{display:block}.video-sub-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.mini-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--radius);padding:14px 16px}.mini-card h4{text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);margin-bottom:10px;font-size:12px;font-weight:800}.word-list{flex-direction:column;margin-bottom:14px;display:flex}.word-entry{border-bottom:1px solid var(--line-2);padding:9px 0}.word-entry:last-child{border-bottom:none}.word-entry-top{align-items:baseline;gap:8px;margin-bottom:2px;display:flex}.word-entry-term{color:var(--ink);font-size:14px;font-weight:800}.word-entry-ipa{color:var(--ink-3);font-size:12px;font-style:italic}.word-entry-def{color:var(--ink-2);font-size:12px;line-height:1.4}.word-entry-vi{color:var(--primary);margin-top:2px;font-size:11px;font-weight:600}.word-progress{border-top:1px solid var(--line-2);flex-direction:column;gap:10px;padding-top:12px;display:flex}.word-progress-title{text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);margin-bottom:2px;font-size:10px;font-weight:800}.word-progress-step{align-items:flex-start;gap:10px;display:flex}.word-progress-step--dim{opacity:.45}.word-progress-check{background:var(--bg-soft);width:22px;height:22px;color:var(--ink-3);border:1.5px solid var(--line-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:800;display:flex}.word-progress-check--done{color:#fff;background:#4ade80;border-color:#4ade80}.word-progress-info{flex-direction:column;gap:1px;padding-top:2px;display:flex}.word-progress-label{color:var(--ink);font-size:12px;font-weight:700}.word-progress-action{color:var(--ink-3);font-size:11px}.word-progress-action--dim{font-style:italic}.lesson-stats{flex-direction:column;gap:8px;display:flex}.stat{color:var(--ink-2);justify-content:space-between;font-size:13px;display:flex}.stat b{color:var(--ink)}.bookread-wrapper{background:#0c0a08;flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.bookread-stage{flex:1;min-height:clamp(280px,42vh,520px);position:relative;overflow:hidden}.bookread-scene-bg{background-position:50%;background-repeat:no-repeat;background-size:contain;animation:.4s cubic-bezier(.25,0,.2,1) bookread-scene-in;position:absolute;inset:0}@keyframes bookread-scene-in{0%{opacity:.7;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.bookread-scene-empty{color:#ffffff26;background:linear-gradient(135deg,#1e1510,#0e0a14);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.bookread-text-panel{background:var(--bg-soft);border-top:1px solid var(--line);flex-shrink:0;align-items:center;gap:20px;min-height:100px;padding:18px 24px;display:flex;box-shadow:inset 0 1px #ffffff05}.bookread-audio-btn{border:2px solid var(--read-color);background:var(--read-glow);width:56px;height:56px;color:var(--read-color);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:0 4px 12px #f9c74f26}.bookread-audio-btn:hover{background:var(--read-color);color:#000;transform:scale(1.1)translateY(-1px);box-shadow:0 6px 20px #f9c74f4d}.bookread-audio-btn:active{transform:scale(.93)}.bookread-audio-btn.playing{background:var(--read-color);color:#000;animation:1.7s ease-in-out infinite bookread-pulse}@keyframes bookread-pulse{0%,to{box-shadow:0 0 #f9c74f66}55%{box-shadow:0 0 0 14px #f9c74f00}}.bookread-text-col{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.bookread-sentence{color:var(--ink);border-radius:6px;margin:0;font-size:24px;font-weight:800;line-height:1.45;transition:all .2s}.bookread-sentence.playing{background:#f9c74f14;margin:0 -8px;padding:2px 8px}.bookread-word{cursor:pointer;border-bottom:2px solid #0000;border-radius:6px;margin:0 -2px;padding:2px 4px;transition:all .15s;display:inline-block}.bookread-word:hover{background:var(--read-glow);color:var(--read-color);border-bottom-color:var(--read-color)}.bookread-word.speaking{background:var(--read-color);color:#000;border-bottom-color:#0000;font-weight:900;animation:.2s cubic-bezier(.34,1.56,.64,1) bookread-word-pop;box-shadow:0 4px 12px #f9c74f4d}@keyframes bookread-word-pop{0%{transform:scale(1)}50%{transform:scale(1.14)}to{transform:scale(1)}}.bookread-ipa{color:var(--violet);letter-spacing:.02em;background:#a78bfa1f;border:1px solid #a78bfa2e;border-radius:999px;align-self:flex-start;margin:2px 0;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.bookread-vi{color:var(--ink-2);background:var(--bg-sunk);border-left:3px solid var(--coral);border-radius:0 10px 10px 0;align-self:flex-start;margin-top:4px;padding:8px 14px;font-size:14.5px;font-weight:700}.bookread-no-transcript{color:var(--ink-4);margin:0;font-size:14px}.bookread-read-me-btn{background:var(--read-color);color:#000;cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:999px;flex-shrink:0;align-items:center;gap:8px;padding:10px 22px;font-size:13px;font-weight:900;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;box-shadow:0 4px 14px #f9c74f40}.bookread-read-me-btn:hover{background:#ffdb70;transform:scale(1.04)translateY(-1px);box-shadow:0 6px 20px #f9c74f66}.bookread-read-me-btn:active{transform:scale(.95)}.bookread-read-me-btn.on{color:var(--read-color);box-shadow:none;background:#ffffff0d;border-color:#f9c74f4d}.bookread-read-me-btn.on:hover{background:#ffffff14}.bookread-help-toggle-btn{color:var(--ink-3);cursor:pointer;white-space:nowrap;background:#ffffff0a;border:1.5px solid #ffffff0f;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:8px 18px;font-size:11.5px;font-weight:800;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex}.bookread-help-toggle-btn:hover{color:var(--ink-2);background:#ffffff14;transform:translateY(-1px)}.bookread-help-toggle-btn:active{transform:scale(.95)}.bookread-help-toggle-btn.on{color:var(--violet);background:#a78bfa1f;border-color:#a78bfa40}.bookread-help-toggle-btn.on:hover{color:#c4b5fd;background:#a78bfa2e}.bookread-nav{background:var(--bg-soft);border-top:1px solid var(--line);flex-shrink:0;justify-content:space-between;align-items:center;height:54px;padding:0 20px;display:flex}.bookread-turn-btn{border:1px solid var(--line);background:var(--bg-sunk);width:40px;height:40px;color:var(--ink-3);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.bookread-turn-btn:hover:not(:disabled){background:var(--bg-raise);color:#fff;transform:scale(1.08)}.bookread-turn-btn:active:not(:disabled){transform:scale(.93)}.bookread-turn-btn:disabled{opacity:.15;cursor:default}.bookread-pagenum{color:var(--ink-4);letter-spacing:.07em;font-size:13px;font-weight:800}.mastery-badge{color:var(--amber);white-space:nowrap;background:#ffbf001a;border:1px solid #ffbf0040;border-radius:20px;margin-left:auto;padding:2px 10px;font-size:11px;font-weight:800}.mastery-badge--done{color:#4ade80;background:#4ade801a;border-color:#4ade8040}.mastery-pip{color:var(--amber);white-space:nowrap;background:#ffbf001f;border-radius:10px;margin-left:2px;padding:1px 5px;font-size:9px;font-weight:800}.mastery-pip--done{color:#4ade80;background:#4ade801f}.book-complete-banner{text-align:center;color:#4ade80;background:#4ade801a;border:1px solid #4ade8040;border-radius:8px;margin-top:8px;padding:8px 12px;font-size:12px;font-weight:800}.mastery-summary{background:#ffbf000f;border:1px solid #ffbf0033;border-radius:12px;flex-wrap:wrap;align-items:center;gap:16px;margin-top:16px;padding:12px 16px;display:flex}.mastery-summary--done{background:#4ade800f;border-color:#4ade8033}.mastery-summary-score{align-items:baseline;gap:6px;display:flex}.mastery-summary-pct{color:var(--amber);font-size:22px;font-weight:900;line-height:1}.mastery-summary--done .mastery-summary-pct{color:#4ade80}.mastery-summary-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.mastery-summary-breakdown{color:var(--ink-2);gap:6px;font-size:12px;font-weight:600;display:flex}.mastery-summary-dot{color:var(--ink-4)}.mastery-summary-status{color:var(--ink-3);margin-left:auto;font-size:11px;font-style:italic}.mastery-summary-status--done{color:#4ade80;font-style:normal;font-weight:800}.segmented{background:var(--bg-sunk);border-radius:10px;gap:2px;padding:3px;display:inline-flex}.segmented button{color:var(--ink-2);border-radius:8px;padding:6px 12px;font-size:13px;font-weight:700;transition:background .15s,color .15s}.segmented button.active{color:var(--ink);background:#fff;box-shadow:0 1px 3px #00000014}.record-layout{flex-direction:column;padding:18px 24px 40px;display:flex}.duet-canvas{border-radius:var(--radius-lg);background:#0e0e0e;grid-template-columns:1fr 1fr;gap:12px;height:450px;margin-bottom:14px;transition:all .3s;display:grid;overflow:hidden}.duet-canvas.overlay{display:block;position:relative}.duet-panel{position:relative;overflow:hidden}.duet-panel.video{border-right:2px solid #222}.duet-canvas.overlay .duet-panel.video{border-right:none;width:100%;height:100%}.duet-canvas.overlay .duet-panel.webcam{z-index:10;background:#1a1a1a;border:2px solid #ffffff26;border-radius:14px;width:180px;height:120px;position:absolute;bottom:16px;right:16px;box-shadow:0 12px 32px #00000080}.duet-label{z-index:2;color:#fff;text-transform:uppercase;letter-spacing:.05em;background:#0009;border-radius:6px;padding:3px 8px;font-size:11.5px;font-weight:800;position:absolute;top:10px;left:10px}.duet-canvas.overlay .duet-label{padding:2px 5px;font-size:9px;top:6px;left:6px}.cam-preview{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:8px;height:100%;display:flex}.cam-preview h3{color:#ccc;font-size:16px}.cam-preview p{text-align:center;padding:0 20px;font-size:13px}.icon-circle{color:#666;background:#1e1e1e;border-radius:50%;place-items:center;width:56px;height:56px;display:grid}.record-controls{align-items:center;gap:16px;padding:14px 0;display:flex}.record-btn{background:var(--coral);border-radius:50%;flex-shrink:0;place-items:center;width:56px;height:56px;transition:transform .2s;display:grid}.record-btn:hover{transform:scale(1.05)}.record-btn .inner{background:#fff;border-radius:4px;width:20px;height:20px;transition:border-radius .2s,width .2s,height .2s}.record-btn.recording .inner{border-radius:50%;width:16px;height:16px}.record-btn.recording{animation:2s infinite pulse-record}.record-waveform{flex:1;align-items:center;gap:2px;height:36px;display:flex}.record-waveform span{background:var(--line);border-radius:1px;flex:1;min-width:3px;height:30%;transition:height .1s}.visualizer-canvas{filter:drop-shadow(0 0 8px #ff47574d)}.record-meta{color:var(--ink-3);font-size:12px;font-weight:600}.record-timer{color:var(--ink);font-family:JetBrains Mono,monospace;font-size:22px;font-weight:800}.recordings-list{flex-direction:column;gap:8px;margin-top:8px;display:flex}.recording-card{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--radius);padding:12px 14px;transition:transform .2s,box-shadow .2s}.recording-card:hover{border-color:var(--coral-soft);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.recording-card h5{font-size:14px;font-weight:800}.recording-card .time{color:var(--ink-3);font-size:12px;font-weight:600}.wave-strip{align-items:center;gap:2px;height:28px;margin-top:10px;display:flex}.wave-strip span{background:var(--line);border-radius:1.5px;flex:1;min-width:2px;transition:background .3s}.recording-card:hover .wave-strip span{background:var(--coral-soft)}.btn-ghost{color:var(--ink-2);border:1px solid var(--line);background:var(--bg-raise);border-radius:9px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex}.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}.btn-primary{background:var(--coral);color:#fff;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:700;transition:background .15s;display:inline-flex}.btn-primary:hover{background:oklch(68% .16 35)}@keyframes pulse-record{0%{box-shadow:0 0 oklch(72% .15 35/.4)}70%{box-shadow:0 0 0 10px oklch(72% .15 35/0)}to{box-shadow:0 0 oklch(72% .15 35/0)}}.practice-layout{flex-direction:column;min-height:100%;padding:18px 24px 40px;display:flex}.practice-mode-bar{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.mode-toggle{background:var(--bg-sunk);border-radius:10px;gap:2px;padding:3px;display:inline-flex}.mode-toggle button{color:var(--ink-2);border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:700;display:inline-flex}.mode-toggle button.active{background:var(--ink);color:var(--bg)}.practice-stage{background:var(--bg-card);border:1px solid var(--line-2);border-radius:var(--radius-lg);flex:1;min-height:480px;display:flex;overflow:hidden}.practice-stage.split>*{flex:1;min-width:0}.practice-stage.split .code-side{border-right:1px solid var(--line-2)}.code-side{background:var(--bg-sunk);flex-direction:column;display:flex}.code-head{border-bottom:1px solid var(--line-2);color:var(--ink-2);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;font-weight:700;display:flex}.file-badge{background:var(--bg-sunk);border-radius:6px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:11px}.code-head-actions{gap:6px;display:flex}.code-head-actions button{border:1px solid var(--line);color:var(--ink-2);cursor:pointer;background:#fff;border-radius:6px;padding:4px 10px;font-size:11.5px;font-weight:700}.code-head-actions button:hover{border-color:var(--ink);color:var(--ink)}.code-textarea{resize:none;width:100%;color:var(--ink);tab-size:2;background:0 0;border:none;outline:none;flex:1;padding:16px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.55}.preview-side{flex-direction:column;display:flex}.preview-head{border-bottom:1px solid var(--line-2);color:var(--ink-2);justify-content:space-between;align-items:center;padding:10px 14px;font-size:12px;font-weight:700;display:flex}.preview-head .dots{gap:4px;display:flex}.preview-head .dots span{background:var(--line);border-radius:50%;width:8px;height:8px}.preview-head .dots span:first-child{background:oklch(75% .14 25)}.preview-head .dots span:nth-child(2){background:oklch(82% .14 80)}.preview-head .dots span:nth-child(3){background:oklch(78% .12 145)}.preview-iframe{background:#fff;border:none;flex:1;width:100%}.template-strip{gap:8px;margin-top:14px;padding-bottom:4px;display:flex;overflow-x:auto}.template-chip{background:var(--bg-card);border:1px solid var(--line);color:var(--ink-2);border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:8px 14px;font-size:12.5px;font-weight:700;display:inline-flex}.template-chip:hover{border-color:var(--coral);color:var(--coral)}.template-chip .dot-mark{border-radius:50%;width:7px;height:7px}.icon-btn{width:32px;height:32px;color:var(--ink-2);border-radius:8px;place-items:center;display:grid}.icon-btn:hover{background:var(--bg-sunk);color:var(--ink)}body.accent-teal{--coral:oklch(72% .11 190);--coral-soft:oklch(94% .03 190)}body.accent-violet{--coral:oklch(66% .16 295);--coral-soft:oklch(94% .04 295)}body.accent-lime{--coral:oklch(72% .16 140);--coral-soft:oklch(94% .04 140)}body.dense{font-size:14px}@keyframes wave{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1.2)}}.auth-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:36px;box-shadow:0 8px 40px oklch(20% 0 0/.07)}.auth-logo{color:var(--ink);align-items:center;gap:8px;margin-bottom:24px;font-size:20px;font-weight:900;display:flex}.auth-title{margin-bottom:6px;font-size:22px;font-weight:900}.auth-sub{color:var(--ink-3);margin-bottom:24px;font-size:14px}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-field{flex-direction:column;gap:5px;display:flex}.auth-field label{color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:700}.auth-field input{border:1px solid var(--line);border-radius:10px;outline:none;padding:10px 12px;font-size:15px;transition:border-color .15s}.auth-field input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.auth-error{color:oklch(50% .16 25);background:oklch(95% .04 25);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600}.auth-submit{border-radius:12px;justify-content:center;width:100%;margin-top:4px;padding:12px;font-size:15px}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{text-align:center;color:var(--ink-3);margin-top:20px;font-size:13px}.auth-switch button{color:var(--coral);font-size:13px;font-weight:700;text-decoration:underline}.admin-modal-backdrop{z-index:200;background:oklch(20% 0 0/.45);place-items:center;display:grid;position:fixed;inset:0}.admin-modal{border-radius:var(--radius-lg);background:#fff;width:480px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 30px 60px oklch(20% 0 0/.3)}.admin-modal h3{margin:0 0 4px;font-size:18px;font-weight:800}.admin-modal p.sub{color:var(--ink-3);margin:0 0 18px;font-size:13px}.admin-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.admin-field label{color:var(--ink-2);font-size:12px;font-weight:700}.admin-field input{border:1px solid var(--line);border-radius:10px;outline:none;padding:10px 12px;font-size:14px}.admin-field input:focus{border-color:var(--coral)}.admin-field .help{color:var(--ink-3);font-family:JetBrains Mono,monospace;font-size:11.5px}.admin-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.admin-app{background:var(--bg);grid-template-columns:240px 1fr;height:100vh;display:grid;overflow:hidden}.admin-sidebar{background:var(--bg-soft);border-right:1px solid var(--line);flex-direction:column;display:flex}.admin-logo{color:var(--ink);border-bottom:1px solid var(--line-2);align-items:center;gap:8px;padding:20px;font-size:18px;font-weight:900;display:flex}.admin-nav{flex-direction:column;flex:1;gap:4px;padding:20px 12px;display:flex;overflow-y:auto}.admin-nav a{color:var(--ink-2);border-radius:10px;padding:10px 14px;font-size:14px;font-weight:700;transition:all .15s}.admin-nav a:hover{background:var(--bg-soft);color:var(--ink)}.admin-nav a.active{background:var(--coral-soft);color:var(--coral)}.admin-user-block{border-top:1px solid var(--line-2);flex-direction:column;gap:12px;padding:16px;display:flex}.admin-user-info{align-items:center;gap:10px;display:flex}.admin-user-info .details{flex-direction:column;display:flex}.admin-user-info .details strong{font-size:13px;font-weight:800}.admin-user-info .details span{color:var(--ink-3);font-size:11px}.admin-main{flex-direction:column;display:flex;overflow:hidden}.admin-header{border-bottom:1px solid var(--line);background:var(--bg-soft);justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex}.admin-content{flex:1;padding:32px 40px;overflow-y:auto}.admin-page-title{margin-bottom:8px;font-size:24px;font-weight:900}.admin-page-sub{color:var(--ink-3);margin-bottom:24px;font-size:14px}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:32px;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:0 2px 8px oklch(20% 0 0/.02)}.admin-stat-card h3{color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:13px;font-weight:700}.admin-stat-card .val{color:var(--ink);font-size:32px;font-weight:900}.admin-table-wrap{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 2px 8px oklch(20% 0 0/.02)}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th{background:var(--bg-soft);color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line);padding:12px 16px;font-size:12px;font-weight:800}.admin-table td{color:var(--ink);border-bottom:1px solid var(--line-2);padding:14px 16px;font-size:14px;font-weight:500}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-soft)}.admin-table .actions{gap:8px;display:flex}.admin-table .actions button{border-radius:6px;padding:4px 8px;font-size:12px;font-weight:700}.admin-table .actions .edit{color:var(--teal);background:var(--teal-soft)}.admin-table .actions .delete{color:oklch(60% .2 25);background:oklch(95% .05 25)}.admin-table .actions .promote{color:var(--violet);background:oklch(95% .05 295)}.admin-search{width:240px;position:relative}.admin-search input{border:1px solid var(--line);background:#fff;border-radius:10px;outline:none;width:100%;padding:8px 14px;font-size:14px;transition:all .2s}.admin-search input:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.admin-pagination{background:var(--bg-soft);border-top:1px solid var(--line);justify-content:center;align-items:center;gap:16px;padding:16px;display:flex}.admin-pagination span{color:var(--ink-2);font-size:13px;font-weight:700}.admin-pagination button{border:1px solid var(--line);color:var(--ink-2);background:#fff;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:700;transition:all .2s}.admin-pagination button:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}.admin-pagination button:disabled{opacity:.5;cursor:not-allowed}.admin-btn-primary{background:var(--coral);color:#fff;border-radius:10px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s;display:inline-flex}.admin-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px oklch(72% .15 35/.25)}.admin-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.admin-btn-outline{border:1px solid var(--line);color:var(--ink-2);border-radius:10px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s}.admin-btn-outline:hover{border-color:var(--ink);color:var(--ink);background:var(--bg-soft)}.admin-btn-ghost{color:var(--ink-3);border-radius:10px;padding:8px 16px;font-size:13px;font-weight:700}.admin-btn-ghost:hover{background:var(--bg-soft);color:var(--ink-2)}.admin-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.admin-modal{background:var(--bg-card);border-radius:20px;width:100%;max-width:440px;max-height:90vh;padding:32px;animation:.3s ease-out modal-slide-up;overflow-y:auto;box-shadow:0 20px 50px #0003}.admin-modal h3{letter-spacing:-.02em;margin-bottom:16px;font-size:20px;font-weight:900}.admin-modal p{color:var(--ink-2);margin-bottom:20px;font-size:14px}.admin-form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.admin-form-group label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:800}.admin-form-group input,.admin-form-group select,.admin-form-group textarea{border:1px solid var(--line);border-radius:10px;outline:none;padding:10px 14px;font-size:14px;transition:all .2s}.admin-form-group input:focus,.admin-form-group select:focus,.admin-form-group textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft)}.admin-form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.admin-modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.uplot-card{border:1px solid var(--line);border-radius:var(--radius);background:#fff;margin-top:24px;padding:24px;box-shadow:0 2px 12px oklch(20% 0 0/.04)}.uplot-card h3{color:var(--ink);align-items:center;gap:10px;margin-bottom:20px;font-size:15px;font-weight:800;display:flex}.uplot-container{width:100%;overflow:hidden}.u-legend{color:var(--ink-2)!important;font-size:12px!important;font-weight:700!important}.u-axis{font-family:inherit!important}.u-select{background:var(--coral-soft)!important;opacity:.3!important}.admin-loading{text-align:center;color:var(--ink-3);padding:60px;font-size:15px;font-weight:700}.admin-error{text-align:center;color:oklch(50% .16 25);border-radius:var(--radius);background:oklch(95% .04 25);margin:20px 0;padding:32px;font-weight:700}.admin-empty{text-align:center;color:var(--ink-3);background:var(--bg-soft);border-radius:var(--radius);padding:40px;font-size:14px;font-weight:600}.stat-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.02em;margin-top:6px;font-size:11px;font-weight:700}.modern-completion-toast{z-index:10000;-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-lg);background:#1a1926d9;border:1.5px solid #ffffff14;width:380px;animation:.5s cubic-bezier(.16,1,.3,1) forwards toast-slide-up;position:fixed;bottom:24px;right:24px;overflow:hidden;box-shadow:0 12px 40px #00000080,inset 0 1px #ffffff1a}@keyframes toast-slide-up{0%{opacity:0;transform:translateY(32px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-glow{background:linear-gradient(90deg, var(--practice-color), var(--teal));height:3px;position:absolute;top:0;left:0;right:0}.toast-content{align-items:center;gap:12px;padding:16px;display:flex}.toast-icon{background:var(--practice-glow);border-radius:12px;flex-shrink:0;place-items:center;width:42px;height:42px;font-size:24px;display:grid}.toast-info{flex:1}.toast-info h4{color:var(--ink);margin-bottom:2px;font-size:15px;font-weight:800}.toast-info p{color:var(--ink-3);margin:0;font-size:12.5px}.toast-btn-action{background:linear-gradient(90deg, var(--practice-color), #05c48f);color:var(--bg);cursor:pointer;white-space:nowrap;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:800;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 12px #06d6a04d}.toast-btn-action:hover{transform:translateY(-1px);box-shadow:0 6px 16px #06d6a066}.toast-btn-close{color:var(--ink-4);cursor:pointer;border-radius:50%;place-items:center;width:24px;height:24px;transition:background .2s,color .2s;display:grid}.toast-btn-close:hover{background:var(--line);color:var(--ink-2)}.practice-tab-container{flex-direction:column;height:100%;padding:18px 24px 40px;display:flex}.practice-nav-header{border-bottom:1.5px solid var(--line);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.practice-tabs{gap:16px;display:flex}.practice-tab-btn{color:var(--ink-3);border-radius:var(--radius);align-items:center;gap:8px;padding:8px 16px;font-size:15px;font-weight:800;transition:background .2s,color .2s;display:flex}.practice-tab-btn:hover{color:var(--ink-2);background:var(--line-2)}.practice-tab-btn.active{color:var(--practice-color);background:var(--practice-glow)}.results-dashboard{flex-direction:column;gap:20px;display:flex}.results-summary-cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.result-card{background:var(--bg-card);border:1.5px solid var(--line);border-radius:var(--radius-lg);align-items:center;gap:16px;padding:16px 20px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0003}.result-card-glow{width:4px;position:absolute;top:0;bottom:0;left:0}.result-card-icon{border-radius:12px;place-items:center;width:48px;height:48px;font-size:24px;display:grid}.result-card-info h5{text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);margin-bottom:2px;font-size:11px}.result-card-info .value{color:var(--ink);font-size:20px;font-weight:900}.results-table-container{background:var(--bg-card);border:1.5px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 20px #0003}.results-table-header{border-bottom:1.5px solid var(--line);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.results-table-header h3{color:var(--ink);font-size:16px;font-weight:800}.results-list{flex-direction:column;display:flex}.results-item{border-bottom:1px solid var(--line-2);justify-content:space-between;align-items:center;padding:16px 20px;transition:background .2s;display:flex}.results-item:hover{background:#ffffff03}.results-item:last-child{border-bottom:none}.result-scene-info{flex-direction:column;gap:4px;display:flex}.result-scene-title{color:var(--ink);font-size:14px;font-weight:800}.result-scene-meta{color:var(--ink-3);align-items:center;gap:8px;font-size:12px;display:flex}.result-score-badge{border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:800;display:flex}.result-score-badge.perfect{background:var(--practice-glow);color:var(--practice-color)}.result-score-badge.partial{background:var(--read-glow);color:var(--read-color)}.result-score-badge.failed{background:var(--record-glow);color:var(--record-color)}.gam-bar{align-items:center;gap:10px;display:flex}.gam-level{flex-shrink:0;width:34px;height:34px;position:relative}.gam-level svg{transform:rotate(-90deg)}.gam-ring-track{fill:none;stroke:#ffffff1a;stroke-width:3px}.gam-ring-fill{fill:none;stroke:var(--amber);stroke-width:3px;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.34,1.56,.64,1)}.gam-level-num{color:var(--ink);justify-content:center;align-items:center;font-size:12px;font-weight:900;display:flex;position:absolute;inset:0}.gam-xp{background:var(--bg-sunk);border:1px solid var(--line);border-radius:999px;align-items:center;gap:7px;padding:5px 10px;display:flex}.gam-xp-track{background:#ffffff14;border-radius:999px;width:64px;height:5px;overflow:hidden}.gam-xp-fill{background:linear-gradient(90deg, var(--amber), #f4a636);border-radius:999px;height:100%;transition:width .5s cubic-bezier(.34,1.56,.64,1)}.gam-xp-label{color:var(--ink-3);letter-spacing:.02em;white-space:nowrap;font-size:10px;font-weight:800}.gam-streak{color:var(--ink-3);background:var(--bg-sunk);border:1px solid var(--line);border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:13px;font-weight:800;display:flex}.gam-streak--lit{color:var(--amber);background:#f9c74f1f;border-color:#f9c74f33}.gam-freeze{color:var(--teal);align-items:center;gap:1px;font-size:10px;font-weight:800;display:inline-flex}.gam-goal{flex-shrink:0;width:20px;height:20px;position:relative}.gam-goal svg{transform:rotate(-90deg)}.gam-goal-fill{fill:none;stroke:var(--lime);stroke-width:3px;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.34,1.56,.64,1)}.gam-goal-check{color:var(--lime);justify-content:center;align-items:center;font-size:10px;font-weight:900;display:flex;position:absolute;inset:0}.gam-goal--done .gam-ring-track{stroke:#06d6a040}.celebration-layer{z-index:200;pointer-events:none;justify-content:center;align-items:flex-start;display:flex;position:fixed;inset:0}.xp-toast{background:var(--bg-raise);color:var(--amber);border:1px solid #f9c74f59;border-radius:999px;align-items:center;gap:8px;margin-top:72px;padding:8px 18px;font-size:15px;font-weight:900;animation:.35s cubic-bezier(.34,1.56,.64,1) xp-toast-in;display:flex;box-shadow:0 8px 30px #00000073}@keyframes xp-toast-in{0%{opacity:0;transform:translateY(-16px)scale(.85)}to{opacity:1;transform:translateY(0)scale(1)}}.celebration-overlay{z-index:210;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:auto;background:#0a0910c7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.goal-pop,.streak-pop{background:var(--bg-raise);border:1px solid var(--line);border-radius:var(--radius-xl);pointer-events:auto;cursor:pointer;flex-direction:column;align-items:center;gap:6px;margin-top:20vh;padding:22px 34px;display:flex;box-shadow:0 16px 50px #00000080}.goal-pop{border-color:#06d6a059}.goal-pop-ring{font-size:42px;line-height:1}.goal-pop-title{color:var(--lime);font-size:19px;font-weight:900}.goal-pop-sub{color:var(--ink-3);font-size:13px;font-weight:700}.streak-pop{border-color:#f9c74f59}.streak-pop-flame{font-size:44px;line-height:1}.streak-pop-days{color:var(--amber);font-size:38px;font-weight:900;line-height:1}.streak-pop-title{color:var(--ink);font-size:17px;font-weight:900}.streak-pop-sub{color:var(--ink-3);font-size:12px;font-weight:700}.badge-stage{perspective:800px;flex-direction:column;align-items:center;gap:20px;display:flex}.badge-card{background:var(--bg-raise);border:2px solid var(--line);border-radius:var(--radius-xl);flex-direction:column;align-items:center;gap:10px;padding:30px 44px;display:flex}.badge-card-rarity{letter-spacing:.18em;text-transform:uppercase;font-size:11px;font-weight:900}.badge-card-icon{font-size:58px;line-height:1}.badge-card-title{color:var(--ink);font-size:19px;font-weight:900}.badge-stage-sub{color:var(--ink-3);margin:0;font-size:13px;font-weight:700}.levelup-stage{text-align:center;flex-direction:column;align-items:center;gap:22px;padding:24px;display:flex}.levelup-title{letter-spacing:.04em;color:var(--amber);text-shadow:0 0 24px #f9c74f73;gap:2px;font-size:clamp(34px,7vw,56px);font-weight:900;display:flex}.levelup-title span{min-width:.3em;display:inline-block}.levelup-badge-wrap{place-items:center;width:150px;height:150px;display:grid;position:relative}.levelup-rays{background:conic-gradient(#f9c74f38 0deg,#0000 24deg,#f9c74f38 48deg,#0000 72deg,#f9c74f38 96deg,#0000 120deg,#f9c74f38 144deg,#0000 168deg,#f9c74f38 192deg,#0000 216deg,#f9c74f38 240deg,#0000 264deg,#f9c74f38 288deg,#0000 312deg,#f9c74f38 336deg,#0000 360deg);border-radius:50%;animation:9s linear infinite levelup-spin;position:absolute;inset:-45px}@keyframes levelup-spin{to{transform:rotate(360deg)}}.levelup-badge{background:radial-gradient(circle at 32% 28%, #ffe9a8, var(--amber) 55%, #d98f1f);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:130px;height:130px;animation:2.2s ease-in-out infinite celebrate-glow;display:flex;position:relative;box-shadow:0 0 0 6px #f9c74f40,0 12px 40px #f9c74f59}.levelup-badge-label{letter-spacing:.12em;color:#3c2600a6;font-size:14px;font-weight:900}.levelup-badge-num{color:#3c2600;font-size:52px;font-weight:900;line-height:1}.levelup-subtitle{color:var(--ink-2);margin:0;font-size:17px;font-weight:700}.levelup-cta{color:#3c2600;background:linear-gradient(135deg, #ffe9a8, var(--amber));cursor:pointer;border:none;border-radius:999px;padding:13px 34px;font-size:17px;font-weight:900;transition:transform .15s;box-shadow:0 8px 24px #f9c74f59}.levelup-cta:hover{transform:scale(1.05)}.levelup-cta:active{transform:scale(.97)}@keyframes celebrate-pop{0%{opacity:0;transform:scale(.4)}70%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes celebrate-glow{0%,to{filter:drop-shadow(0 0 12px #f9c74f66)}50%{filter:drop-shadow(0 0 32px #f9c74fcc)}}html,body{max-width:100%}@media (width<=1024px){body{overflow-x:hidden}}.mobile-tabbar{display:none}@media (width<=768px){.mobile-tabbar{z-index:60;background:var(--bg-card);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom,0px);display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000000f}.mtab{min-height:56px;color:var(--ink-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 2px;font-size:10px;font-weight:800;display:flex;position:relative}.mtab .mtab-icon{place-items:center;transition:transform .12s;display:grid}.mtab.active{color:var(--coral)}.mtab.active .mtab-icon{transform:translateY(-1px)}.mtab-dot{background:var(--coral);border-radius:50%;width:7px;height:7px;margin-right:-14px;position:absolute;top:8px;right:50%}}.mobile-drawer-root{display:none}@media (width<=1024px){.mobile-drawer-root{display:block}.mobile-drawer-scrim{z-index:70;opacity:0;pointer-events:none;background:#0006;transition:opacity .2s;position:fixed;inset:0}.mobile-drawer-panel{z-index:71;background:var(--bg-card);border-right:1px solid var(--line);width:min(82vw,320px);padding-top:env(safe-area-inset-top,0px);flex-direction:column;transition:transform .22s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:4px 0 24px #0000002e}.mobile-drawer-root.open .mobile-drawer-scrim{opacity:1;pointer-events:auto}.mobile-drawer-root.open .mobile-drawer-panel{transform:translate(0)}.mobile-drawer-panel .sidebar{border:0!important;width:100%!important;height:auto!important}}.topbar-burger{display:none}@media (width<=1024px){.shell{grid-template-columns:minmax(0,1fr)}.shell>.sidebar,.topbar-nav{display:none}.topbar-burger{width:40px;height:40px;color:var(--ink);background:0 0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;margin-right:2px;display:inline-flex}.topbar-burger:active{background:var(--bg-sunk)}.topbar{gap:8px;min-width:0;padding:0 12px}.admin-toggle{display:none}.logo{gap:0;font-size:0}}@media (width<=768px){.tabbar{display:none}.main-scroll{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.breadcrumb{flex-wrap:wrap;row-gap:4px;padding:7px 12px}.watch-layout{gap:12px;flex-direction:column!important;display:flex!important}.player-wrap{max-width:100%}.video-sub-grid{grid-template-columns:1fr!important}.timestamp-chips{gap:5px}.chip{width:34px;height:34px}.bookread-text-panel{padding:12px}.bookread-wrapper{height:auto;overflow:visible}.bookread-stage{min-height:clamp(220px,36vh,400px)}.bookread-nav{margin-bottom:calc(8px + env(safe-area-inset-bottom,0px))}.record-layout{gap:10px;flex-direction:column!important;display:flex!important}.record-canvas-wrap{max-width:100%;max-height:42vh}.record-controls{flex-wrap:wrap;gap:8px}.results-summary-cards{grid-template-columns:1fr!important}.practice-header{flex-direction:column;gap:10px;align-items:stretch!important}.exercise-nav{width:100%}.exercise-nav .btn-ghost,.exercise-nav .btn-primary{flex:1}.exercise-stage{min-height:60vh}.practice-tabs{width:100%}.practice-tab-btn{flex:1}.vocab-tab-body{padding-left:16px!important;padding-right:16px!important}.vocab-mastery-card{flex-direction:column!important;align-items:stretch!important;gap:14px!important}.vocab-mastery-progress{width:100%;min-width:0!important}.vocab-word-grid{grid-template-columns:minmax(0,1fr)!important;gap:12px!important}.vocab-library-grid{gap:10px;grid-template-columns:repeat(2,1fr)!important}}@media (width<=480px){.vocab-library-grid{grid-template-columns:1fr!important}}@media (width<=768px){.auth-page{align-items:flex-start;padding:20px 16px}.auth-card{width:100%;max-width:420px;margin:8vh auto 0;padding:24px 20px}.auth-field input{width:100%;font-size:16px}.auth-submit{width:100%;min-height:48px}button,.btn-primary,.btn-ghost,.tab,a.nav-link{min-height:44px}input,textarea,select{font-size:16px}.topbar{padding-top:env(safe-area-inset-top,0px)}.mobile-learn-drawer{flex-direction:column;display:flex}.continue-card{background:var(--bg-sunk);border:1px solid var(--line);border-radius:16px;margin:12px;padding:16px 16px 18px}.continue-card-label{color:var(--primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:12px;font-weight:800}.continue-card-title{color:var(--ink);align-items:center;gap:8px;margin-bottom:8px;font-size:18px;font-weight:900;display:flex}.continue-card-title span:first-child{text-overflow:ellipsis;flex:1;overflow:hidden}.continue-card-meta{color:var(--ink-3);margin-bottom:10px;font-size:12.5px;font-weight:600}.continue-card .progress-track{margin-bottom:14px}.continue-card-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:48px;font-size:15px;font-weight:800;display:flex}.continue-card-btn:disabled{opacity:.5;cursor:default}.mobile-learn-drawer .sidebar-nav-group{gap:2px;padding:4px 12px}.drawer-autonext{margin:6px 16px 10px}.drawer-lessons{border-top:1px solid var(--line);margin-top:4px}.drawer-lessons-toggle{width:100%;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;padding:14px 16px;font-size:13px;font-weight:800;display:flex}.drawer-lessons-toggle .caret{transition:transform .2s}.drawer-lessons-toggle .caret.open{transform:rotate(90deg)}.drawer-lessons-tree{padding:0 0 16px}}@media (width<=1024px){.radar-hero-grid{grid-template-columns:1fr!important}}@media (width<=768px){.stats-body{padding-left:16px!important;padding-right:16px!important}}@media (width<=480px){.radar-stat-dials{grid-template-columns:repeat(2,1fr)!important}}@media (width<=768px){.vw-root{padding-left:16px!important;padding-right:16px!important}.vw-title{font-size:26px!important}}
