:root{--bg: #141416;--bg1: #1c1c20;--bg2: #26262c;--bg3: #303038;--border: #2e2e36;--text: #f4f4f6;--muted: #a3a3ad;--faint: #6e6e78;--accent: #7e6cf5;--accent-2: #9a8bff;--accent-soft: rgba(126, 108, 245, .16);--on-accent: #ffffff;--gold: #ffce5c;--ok: #5fcf9e;--danger: #ff6b81;--card-shadow: 0 1px 0 rgba(255, 255, 255, .03);--lift-shadow: 0 18px 40px rgba(0, 0, 0, .4);--radius: 14px;--radius-sm: 11px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--nav-h: 62px;--fbody: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--fdisp: "Space Grotesk", var(--fbody);--fmono: "Space Mono", ui-monospace, "SF Mono", monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--fbody);background:var(--bg);color:var(--text);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}img{display:block}input,select,textarea{font-family:inherit}h1,h2,h3{font-family:var(--fdisp);letter-spacing:-.02em}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-track{background:transparent}.full-center{min-height:100vh;display:grid;place-items:center}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}.faint{color:var(--faint)}.eyebrow{font-family:var(--fmono);text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--faint)}.mono{font-family:var(--fmono)}.row{display:flex;align-items:center;gap:10px}.spacer{flex:1}.hidden{display:none!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid var(--border);background:var(--bg1);color:var(--text);padding:11px 18px;border-radius:var(--radius-sm);font-size:14.5px;font-weight:600;transition:filter .15s,background .15s,transform .05s,border-color .15s}.btn:active{transform:scale(.985)}.btn:hover{background:var(--bg2)}.btn svg{width:19px;height:19px;flex:0 0 auto}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent);box-shadow:0 8px 24px var(--accent-soft)}.btn.primary:hover{filter:brightness(1.08);background:var(--accent)}.btn.ghost{background:transparent}.btn.danger{background:transparent;border-color:var(--danger);color:var(--danger)}.btn.block{width:100%}.btn.lg{padding:15px 24px;font-size:16px;border-radius:13px}.btn.lg svg{width:21px;height:21px}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{display:inline-grid;place-items:center;background:transparent;border:none;color:var(--text);width:42px;height:42px;border-radius:11px;transition:background .15s}.icon-btn:hover{background:var(--bg2)}.icon-btn svg{width:22px;height:22px}.field{margin-bottom:14px}.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);background:var(--bg1);border:1px solid var(--border);color:var(--text);font-size:16px}.input:focus{outline:none;border-color:var(--accent)}.error-banner{background:#ff6b811f;border:1px solid rgba(255,107,129,.4);color:#ffb3bf;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:14px}.ok-banner{background:#5fcf9e1f;border:1px solid rgba(95,207,158,.4);color:#aef0d2;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:14px}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1100px 560px at 50% -10%,rgba(126,108,245,.2),transparent 60%),var(--bg)}.auth-card{width:100%;max-width:380px;background:var(--bg1);border:1px solid var(--border);border-radius:var(--radius);padding:30px 26px;box-shadow:var(--lift-shadow)}.auth-logo{display:flex;justify-content:center;margin-bottom:6px}.auth-logo .mark{width:42px;height:42px;border-radius:12px;background:var(--accent);display:grid;place-items:center}.auth-logo .mark svg{width:21px;height:21px}.auth-title{text-align:center;font-size:24px;font-weight:700;margin:10px 0 2px}.auth-sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:22px}.shell{min-height:100vh;padding-bottom:calc(var(--nav-h) + var(--safe-bottom))}.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;padding:calc(11px + var(--safe-top)) 16px 11px;background:#141416d1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px;font-family:var(--fdisp);font-weight:700;font-size:19px}.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--accent);display:grid;place-items:center}.brand .mark svg{width:16px;height:16px}.content{padding:20px 16px 28px;max-width:1680px;margin:0 auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;background:#16161af2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);height:calc(var(--nav-h) + var(--safe-bottom))}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--faint);font-size:11px;font-weight:600;padding-top:8px}.bottom-nav a.active{color:var(--accent-2)}.bottom-nav a svg{width:23px;height:23px}.side-nav{display:none}.home-head{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:30px}.home-head h1{margin:5px 0 0;font-weight:700;font-size:26px}.search-pill{display:none}.section{margin-bottom:40px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 16px}.section-head h2{font-size:20px;font-weight:600;margin:0}.section-head a,.see-all{font-family:var(--fbody);font-size:13.5px;color:var(--accent);font-weight:600;background:none;border:none;cursor:pointer}.rail{display:flex;gap:16px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.rail::-webkit-scrollbar{display:none}.rail>*{scroll-snap-align:start;flex:0 0 auto}.poster-card{width:158px;text-align:left;border:none;background:transparent;padding:0;cursor:pointer;display:flex;flex-direction:column;gap:11px;transition:transform .18s}.poster-card:hover{transform:translateY(-3px)}.poster-card .poster{position:relative;width:100%;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;background:var(--bg2);box-shadow:var(--card-shadow)}.poster-card .poster img{width:100%;height:100%;object-fit:cover}.poster-card .poster:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#ffffff0d,#00000057);pointer-events:none}.poster-card .cat-badge{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--fmono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#ffffffd9;background:#0006;padding:3px 8px;border-radius:6px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.poster-card .fav-pin{position:absolute;top:10px;right:10px;z-index:2;width:27px;height:27px;border-radius:50%;background:#00000080;display:grid;place-items:center;color:var(--gold)}.poster-card .fav-pin svg{width:14px;height:14px}.poster-card .title{font-weight:600;font-size:14px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.poster-card .meta{font-family:var(--fmono);font-size:12px;color:var(--faint);margin-top:4px}.poster-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:end center;padding:0 10px 18px;text-align:center;font-family:var(--fdisp);font-weight:700;font-size:30px;color:#ffffffeb;background:linear-gradient(160deg,#2b2540,#1a1722);text-shadow:0 2px 14px rgba(0,0,0,.4)}.progress-line{position:absolute;bottom:0;left:0;right:0;height:4px;background:#ffffff2e;z-index:2}.progress-line>span{display:block;height:100%;background:var(--accent)}.cw-card{width:320px;text-align:left;border:none;background:transparent;padding:0;cursor:pointer;display:flex;flex-direction:column;gap:12px;transition:transform .18s}.cw-card:hover{transform:translateY(-3px)}.cw-card .thumb{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;background:var(--bg2);box-shadow:var(--card-shadow)}.cw-card .thumb img{width:100%;height:100%;object-fit:cover}.cw-card .thumb .scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000 40%,#0000008c)}.cw-card .thumb .ct-on-art{position:absolute;left:16px;bottom:16px;right:16px;font-family:var(--fdisp);font-weight:600;font-size:15px;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.5)}.cw-card .play-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:#1414169e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;color:#fff}.cw-card .play-circle svg{width:22px;height:22px;margin-left:2px}.cw-card .label .ey{font-family:var(--fmono);font-size:11px;color:var(--faint);margin-bottom:4px}.cw-card .label .lt{font-weight:600;font-size:15px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.cw-card .label .sub{font-size:13px;color:var(--muted);margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.grid{display:grid;gap:22px 16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.grid .poster-card{width:100%}.chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.chip{display:inline-flex;align-items:center;gap:9px;padding:9px 16px;border-radius:999px;background:var(--bg1);border:1px solid var(--border);color:var(--text);font-size:14px;font-weight:500;white-space:nowrap;transition:background .14s,color .14s,border-color .14s}.chip:hover{background:var(--bg2)}.chip.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.chip-count{font-family:var(--fmono);font-size:12px;color:var(--faint)}.chip.on .chip-count{color:#fffc}.chip-row.scroll{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.chip-row.scroll::-webkit-scrollbar{display:none}.chip-row.scroll .chip{flex:0 0 auto}.cat-strip{margin-bottom:40px}.cat-strip-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.cat-strip-head h2{margin:0;font-size:22px;font-weight:700}.cat-nav{display:flex;gap:8px}.cat-nav button{width:38px;height:38px;border-radius:50%;background:var(--bg1);border:1px solid var(--border);color:var(--muted);display:grid;place-items:center;transition:background .14s,color .14s,opacity .14s}.cat-nav button:hover:not(:disabled){background:var(--bg2);color:var(--text)}.cat-nav button:disabled{opacity:.35;cursor:default}.cat-nav button svg{width:18px;height:18px}.cat-tiles{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}.cat-tiles::-webkit-scrollbar{display:none}.cat-tiles{align-items:stretch}.cat-tile{scroll-snap-align:start;flex:0 0 auto;width:120px;min-height:104px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:13px;padding:18px 10px 16px;border-radius:16px;background:var(--bg1);border:1.5px solid transparent;color:var(--muted);cursor:pointer;text-align:center;transition:background .14s,border-color .14s,color .14s,box-shadow .14s}.cat-tile:hover{background:var(--bg2);color:var(--text)}.cat-tile.on{border-color:var(--accent);background:var(--bg2);color:var(--text);box-shadow:0 0 0 3px var(--accent-soft)}.cat-tile .cat-ic{display:grid;place-items:center;color:inherit;flex:0 0 auto}.cat-tile .cat-ic svg{width:26px;height:26px}.cat-tile.on .cat-ic{color:var(--accent-2)}.cat-label{font-size:13px;font-weight:600;line-height:1.25;text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (max-width: 560px){.cat-strip-head h2{font-size:20px}.cat-tile{width:108px;min-height:98px;gap:11px;padding:16px 8px 14px}}.course-detail{max-width:1140px;margin:0 auto}.back-chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg1);border:1px solid var(--border);color:var(--muted);padding:8px 14px 8px 11px;border-radius:10px;font-size:13.5px;font-weight:500;margin-bottom:20px}.back-chip:hover{background:var(--bg2)}.back-chip svg{width:17px;height:17px}.course-grid{display:grid;grid-template-columns:1fr;gap:28px;align-items:start}.course-rail{display:flex;flex-direction:column;max-width:420px}.rail-art{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;background:var(--bg2);box-shadow:var(--lift-shadow)}.rail-art img{width:100%;height:100%;object-fit:cover}.rail-art .scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(160deg,#ffffff14,#0006)}.rail-art .cat-badge{position:absolute;top:16px;left:16px;font-family:var(--fmono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#ffffffd9;background:#00000057;padding:4px 10px;border-radius:7px}.course-rail h1{margin:22px 0 4px;font-weight:700;font-size:25px;line-height:1.15}.course-rail .instructor{color:var(--accent);font-weight:600;font-size:15px;margin:0 0 10px}.course-rail .stats{display:flex;align-items:center;gap:12px;font-family:var(--fmono);font-size:13px;color:var(--muted)}.course-rail .stats .sep{color:var(--faint)}.course-rail .prog-track{margin:18px 0 4px;height:6px;border-radius:6px;background:var(--bg2);overflow:hidden}.course-rail .prog-track>span{display:block;height:100%;background:var(--accent);border-radius:6px}.course-rail .prog-label{font-family:var(--fmono);font-size:12.5px;color:var(--faint);margin-bottom:18px}.course-rail .cta{margin-top:16px}.resource-btn{display:flex;align-items:center;gap:13px;width:100%;margin-top:11px;padding:13px 15px;border-radius:13px;border:1px solid var(--border);background:var(--bg1);color:var(--text);font-size:14.5px;font-weight:600;text-align:left}.resource-btn:hover{background:var(--bg2)}.resource-btn .ic{width:36px;height:36px;flex-shrink:0;border-radius:9px;background:var(--accent-soft);display:grid;place-items:center;color:var(--accent-2)}.resource-btn .ic svg{width:18px;height:18px}.resource-btn .rb-main{flex:1}.resource-btn .rb-sub{display:block;font-size:12px;color:var(--faint);font-weight:500}.resource-btn .chev{width:17px;height:17px;color:var(--faint)}.rail-actions{display:flex;gap:10px;margin-top:11px}.rail-actions .btn{flex:1}.course-main{max-width:700px}.about h2{font-size:18px;font-weight:600;margin:0 0 12px}.about p{margin:0;font-size:15.5px;line-height:1.7;color:var(--muted)}.about .released{margin-top:14px;font-family:var(--fmono);font-size:12.5px;color:var(--faint)}.lessons-head{display:flex;align-items:baseline;justify-content:space-between;margin:30px 0 6px}.lessons-head h2{font-size:18px;font-weight:600;margin:0}.lessons-head .meta{font-family:var(--fmono);font-size:12.5px;color:var(--faint)}.lesson{display:flex;align-items:center;gap:15px;width:100%;text-align:left;padding:13px 14px;border-radius:13px;border:1px solid transparent;background:transparent;color:var(--text)}.lesson:hover{background:var(--bg1)}.lesson.current{background:var(--accent-soft)}.l-status{width:34px;height:34px;flex-shrink:0;border-radius:50%;display:grid;place-items:center}.l-status.todo{border:1px solid var(--border);font-family:var(--fmono);font-size:13px;color:var(--faint)}.l-status.done{background:var(--accent-soft);color:var(--accent-2)}.l-status.current{background:var(--accent);color:var(--on-accent)}.l-status svg{width:17px;height:17px}.l-body{flex:1;min-width:0}.l-body .lt{font-weight:600;font-size:15px;line-height:1.3}.l-body .ls{display:flex;align-items:center;gap:7px;margin-top:4px;font-family:var(--fmono);font-size:12.5px;color:var(--faint)}.l-body .ls svg{width:13px;height:13px}.l-body .mini-prog{height:3px;background:var(--bg2);border-radius:2px;margin-top:7px;overflow:hidden;max-width:220px}.l-body .mini-prog>span{display:block;height:100%;background:var(--accent)}.lesson .chev{width:18px;height:18px;color:var(--faint);flex-shrink:0}.empty{text-align:center;padding:60px 20px;color:var(--muted)}.empty svg{width:54px;height:54px;color:var(--faint);margin-bottom:14px}.empty h3{font-size:18px;margin:0 0 6px;color:var(--text)}.skeleton{background:linear-gradient(90deg,var(--bg1) 25%,var(--bg2) 50%,var(--bg1) 75%);background-size:200% 100%;animation:shimmer 1.3s infinite;border-radius:var(--radius)}@keyframes shimmer{to{background-position:-200% 0}}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}.stat-card{background:var(--bg1);border:1px solid var(--border);border-radius:14px;padding:16px 18px}.stat-card .sc-n{font-family:var(--fdisp);font-weight:700;font-size:26px;line-height:1.1}.stat-card .sc-l{font-family:var(--fmono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin-top:5px}.cat-stat{display:flex;align-items:center;gap:14px;padding:9px 0}.cat-stat .cs-name{flex:0 0 auto;width:150px;font-size:13.5px;font-weight:600;line-height:1.2}.cat-stat .cs-bar{flex:1;height:8px;border-radius:6px;background:var(--bg2);overflow:hidden}.cat-stat .cs-bar>span{display:block;height:100%;background:var(--accent);border-radius:6px}.cat-stat .cs-count{flex:0 0 auto;width:44px;text-align:right;font-family:var(--fmono);font-size:13px;color:var(--muted)}@media (max-width: 560px){.cat-stat .cs-name{width:110px;font-size:12.5px}}.tabs{display:flex;gap:6px;margin-bottom:18px;border-bottom:1px solid var(--border)}.tabs button{background:none;border:none;color:var(--muted);font-weight:700;font-size:14px;padding:11px 14px;border-bottom:2px solid transparent}.tabs button.active{color:var(--text);border-bottom-color:var(--accent)}.tabs svg{width:18px;height:18px;vertical-align:-3px}.list-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border)}.list-row .grow{flex:1;min-width:0}.list-row .sub{font-family:var(--fmono);font-size:12px;color:var(--faint)}.badge{font-family:var(--fmono);font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;background:var(--bg2);color:var(--muted)}.badge.admin{background:var(--accent-soft);color:var(--accent-2)}.badge.used{background:#ff6b8124;color:#ffb3bf}.badge.active2{background:#5fcf9e29;color:#aef0d2}.invite-link{font-family:var(--fmono);font-size:12px;background:var(--bg);border:1px solid var(--border);padding:8px 10px;border-radius:8px;word-break:break-all}.section-head h2 svg,h2 svg,h3 svg{width:19px;height:19px;vertical-align:-3px}.search-bar{position:relative;margin-bottom:18px}.search-bar input{padding-left:44px}.search-bar>svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--faint)}.player-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;flex-direction:column;background:#08080a;overflow:hidden}.player-root:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 50% 38%,#1b1b22,#0c0c0f 55%,#050506);z-index:0}.player-stage{position:relative;z-index:1;flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.player-stage video{width:100%;height:100%;object-fit:contain}.audio-art{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center}.audio-art .art-inner{text-align:center;padding:20px}.audio-art img{width:210px;max-width:58vw;aspect-ratio:4/5;object-fit:cover;border-radius:16px;box-shadow:var(--lift-shadow);margin:0 auto 18px}.audio-art .pulse{font-family:var(--fmono);font-size:12px;color:var(--accent-2);letter-spacing:.08em;text-transform:uppercase}.controls-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;flex-direction:column;justify-content:space-between;opacity:1;transition:opacity .3s}.controls-overlay.hidden-controls{opacity:0;pointer-events:none}.ctrl-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:calc(16px + var(--safe-top)) 18px 14px;background:linear-gradient(180deg,#0009,#0000)}.ctrl-top .glass{width:40px;height:40px;flex-shrink:0;border-radius:11px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#fff;display:grid;place-items:center}.ctrl-top .glass:hover{background:#ffffff24}.ctrl-top .glass svg{width:20px;height:20px}.ctrl-top .titles{min-width:0;flex:1}.ctrl-top .titles .l1{font-family:var(--fmono);font-size:12px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctrl-top .titles .l2{font-family:var(--fdisp);font-weight:600;font-size:18px;color:#fff;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ctrl-top .top-actions{display:flex;align-items:center;gap:10px}.player-root button:focus{outline:none}.player-root button:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.player-root .ctrl-tap,.player-root .ctrl-tap:focus,.player-root .ctrl-tap:focus-visible{outline:none}.ctrl-tap{flex:1;width:100%;background:none;border:none;display:grid;place-items:center;cursor:pointer}.ctrl-tap .tap-play{width:84px;height:84px;border-radius:50%;background:#0a0a0c8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.22);color:#fff;display:grid;place-items:center}.ctrl-tap .tap-play svg{width:38px;height:38px;margin-left:4px}.ctrl-bottom{padding:12px 22px calc(20px + var(--safe-bottom));background:linear-gradient(0deg,#000000a8,#0000)}.scrub-row{display:flex;align-items:center;gap:14px;margin-bottom:12px}.scrub-row .t{font-family:var(--fmono);font-size:12.5px;color:#ffffffc7;min-width:44px}.scrub-row .t.end{text-align:right}.seek{-webkit-appearance:none;-moz-appearance:none;appearance:none;flex:1;height:16px;background:transparent;cursor:pointer}.seek::-webkit-slider-runnable-track{height:5px;border-radius:4px;background:linear-gradient(to right,var(--accent) var(--p,0%),rgba(255,255,255,.2) var(--p,0%))}.seek::-moz-range-track{height:5px;border-radius:4px;background:#fff3}.seek::-moz-range-progress{height:5px;border-radius:4px;background:var(--accent)}.seek::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;margin-top:-4.5px;box-shadow:0 1px 6px #00000080}.seek::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:none}.ctrl-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;overflow-x:auto;scrollbar-width:none}.ctrl-bar::-webkit-scrollbar{display:none}.ctrl-bar .grp{display:flex;align-items:center;flex:0 0 auto}.ctrl-bar .grp.left{gap:6px}.ctrl-bar .grp.right{gap:8px}.cbtn{width:40px;height:40px;flex-shrink:0;border-radius:11px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#fff;display:grid;place-items:center;position:relative}.cbtn:hover{background:#ffffff29}.cbtn:disabled{opacity:.34}.cbtn svg{width:22px;height:22px}.cbtn.skip{width:46px}.cbtn.skip svg{width:30px;height:30px;stroke-width:1.9}.cbtn.skip span{position:absolute;font-family:var(--fmono);font-size:9.5px;font-weight:700;top:55%;left:0;right:0;transform:translateY(-50%);text-align:center}.cbtn.active{color:var(--accent-2)}.cbtn.play{width:48px;height:48px;border-radius:50%;background:#fff;border:none;color:#111}.cbtn.play svg{width:24px;height:24px}.vol{display:flex;align-items:center;gap:9px}.vol .vbar{width:84px;height:5px;border-radius:4px;background:#ffffff38;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.vol .vbar::-webkit-slider-runnable-track{height:5px;border-radius:4px;background:linear-gradient(to right,rgba(255,255,255,.85) var(--p,100%),rgba(255,255,255,.22) var(--p,100%))}.vol .vbar::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;margin-top:-3.5px}.vol .vbar::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#fff;border:none}.rate-pill{padding:8px 12px;border-radius:9px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#fff;font-family:var(--fmono);font-size:13px;font-weight:700}.rate-pill:hover{background:#ffffff29}.pop{position:absolute;bottom:calc(78px + var(--safe-bottom));right:18px;z-index:8;background:#1c1c22f7;border:1px solid var(--border);border-radius:12px;padding:6px;min-width:156px;box-shadow:var(--lift-shadow)}.pop .pop-head{font-family:var(--fmono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);padding:6px 12px}.pop .pop-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;font-size:14px;color:#fff;background:none;border:none;width:100%;text-align:left}.pop .pop-item:hover{background:#ffffff14}.pop .pop-item.sel{color:var(--accent-2);font-weight:700}.center-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9;background:#0000009e;color:#fff;padding:10px 16px;border-radius:999px;font-family:var(--fmono);font-weight:700;font-size:14px;pointer-events:none;animation:fadeout .7s forwards}@keyframes fadeout{0%{opacity:1}70%{opacity:1}to{opacity:0}}.ldrawer-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;background:#0000006b}.ldrawer{position:absolute;top:0;right:0;bottom:0;z-index:9;width:min(392px,88vw);background:var(--bg1);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;box-shadow:-20px 0 50px #0006;animation:drawerIn .22s ease}@keyframes drawerIn{0%{transform:translate(102%)}to{transform:translate(0)}}.ldrawer .dh{padding:calc(20px + var(--safe-top)) 20px 16px;border-bottom:1px solid var(--border)}.ldrawer .dh .row{justify-content:space-between;align-items:flex-start}.ldrawer .dh .eyebrow{margin-bottom:4px}.ldrawer .dh .dt{font-family:var(--fdisp);font-weight:600;font-size:18px}.ldrawer .dh .close{width:34px;height:34px;flex-shrink:0;border-radius:9px;background:var(--bg2);border:1px solid var(--border);color:var(--muted);display:grid;place-items:center}.ldrawer .dlist{flex:1;overflow-y:auto;padding:10px}.ldrawer .dlist .lesson{padding:11px 12px}@media (max-width: 899px){.rail-art{max-width:230px}.course-rail h1{font-size:23px}}@media (max-width: 560px){.vol .vbar{display:none}.ctrl-bottom{padding-left:14px;padding-right:14px}.ctrl-bar .grp.left,.ctrl-bar .grp.right{gap:3px}.cbtn{width:37px;height:37px}.cbtn.skip{width:42px}.cbtn.skip svg{width:28px;height:28px}.cbtn.play{width:46px;height:46px}.rate-pill{padding:7px 9px}}@media (min-width: 900px){.bottom-nav,.topbar{display:none}.shell{padding-bottom:0;padding-left:244px}.side-nav{display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;width:244px;background:var(--bg);border-right:1px solid var(--border);padding:22px 14px;z-index:50}.side-nav .brand{padding:4px 8px 26px;font-size:20px}.side-nav .brand .mark{width:34px;height:34px;border-radius:9px}.side-nav .brand .mark svg{width:17px;height:17px}.side-nav nav{display:flex;flex-direction:column;gap:3px}.side-nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--muted);font-weight:500;font-size:15px}.side-nav a:hover{background:var(--bg1);color:var(--text)}.side-nav a.active{background:var(--accent-soft);color:var(--accent-2);font-weight:600}.side-nav a svg{width:21px;height:21px}.side-nav .bottom{margin-top:auto;display:flex;flex-direction:column;gap:3px;padding-top:16px;border-top:1px solid var(--border)}.side-nav .acct{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;color:var(--text)}.side-nav .acct:hover{background:var(--bg1)}.side-nav .acct .av{width:30px;height:30px;border-radius:50%;background:var(--bg3);display:grid;place-items:center;font-family:var(--fmono);font-size:12px;font-weight:700;color:var(--muted)}.side-nav .acct .who{line-height:1.25;text-align:left}.side-nav .acct .who .n{display:block;font-size:13.5px;font-weight:600}.side-nav .acct .who .s{display:block;font-size:11.5px;color:var(--faint)}.content{padding:30px 34px 90px}.home-head h1{font-size:30px}.search-pill{display:flex;align-items:center;gap:12px;min-width:300px;max-width:380px;flex:1;padding:11px 16px;border-radius:12px;background:var(--bg1);border:1px solid var(--border);color:var(--faint);font-size:14.5px;cursor:pointer}.search-pill svg{width:18px;height:18px}.poster-card{width:186px}.cw-card{width:360px}.grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:26px 22px}.course-grid{grid-template-columns:360px minmax(0,720px);gap:60px}.course-rail{position:sticky;top:26px;max-width:none}.course-rail h1{font-size:26px}.content:has(.course-detail){height:100vh;overflow:hidden;padding-bottom:30px;display:flex;flex-direction:column}.content:has(.course-detail) .course-detail{flex:1;min-height:0;display:flex;flex-direction:column;margin:0 auto;width:100%}.content:has(.course-detail) .back-chip{align-self:flex-start;flex:0 0 auto}.content:has(.course-detail) .course-grid{flex:1;min-height:0;align-items:stretch}.content:has(.course-detail) .course-rail{position:static;overflow-y:auto;min-height:0;padding-right:4px}.content:has(.course-detail) .course-main{height:100%;min-height:0;display:flex;flex-direction:column}.content:has(.course-detail) .course-main .about{flex:0 0 auto}.content:has(.course-detail) .lessons-section{flex:1;min-height:0;display:flex;flex-direction:column}.content:has(.course-detail) .lessons-head{flex:0 0 auto;margin-top:26px}.content:has(.course-detail) .lessons-list{flex:1;min-height:0;overflow-y:auto;padding-right:6px}}@media (min-width: 1280px){.content{padding:32px 44px 90px}}
