:root,:root[data-theme=dark]{--bg: #0a0a0f;--bg-2: #11111a;--bg-3: #1a1a26;--bg-4: #232333;--border: #2a2a3c;--text: #ecedf3;--text-dim: #9396a8;--text-dim-2:#6c6e80;--accent: #f59e0b;--accent-2: #fbbf24;--accent-dim:rgba(245,158,11,.15);--green: #10b981;--red: #ef4444;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-track: transparent;--scrollbar-thumb: rgba(255,255,255,.1);--scrollbar-thumb-hover: rgba(255,255,255,.2);color-scheme:dark}:root[data-theme=light]{--bg: #ffffff;--bg-2: #f7f7fa;--bg-3: #eeeef3;--bg-4: #e3e3eb;--border: #d8d8e0;--text: #11111a;--text-dim: #4a4a58;--text-dim-2:#7a7a85;--accent: #d97706;--accent-2: #f59e0b;--accent-dim:rgba(217,119,6,.12);--green: #059669;--red: #dc2626;--shadow: 0 10px 40px -12px rgba(0,0,0,.18);--scrollbar-thumb: rgba(0,0,0,.18);--scrollbar-thumb-hover: rgba(0,0,0,.35);color-scheme:light}:root[data-theme=sand]{--bg: #f4e8d4;--bg-2: #ecdfc6;--bg-3: #e2d2b1;--bg-4: #d4c198;--border: #c7b48a;--text: #3a2e1c;--text-dim: #6a5a3e;--text-dim-2:#8e7d5e;--accent: #b45309;--accent-2: #d97706;--accent-dim:rgba(180,83,9,.14);--green: #166534;--red: #991b1b;--shadow: 0 10px 40px -12px rgba(80,60,20,.2);--scrollbar-thumb: rgba(80,60,20,.22);--scrollbar-thumb-hover: rgba(80,60,20,.4);color-scheme:light}:root[data-theme=catppuccin-mocha]{--bg: #1e1e2e;--bg-2: #181825;--bg-3: #313244;--bg-4: #45475a;--border: #45475a;--text: #cdd6f4;--text-dim: #a6adc8;--text-dim-2:#7f849c;--accent: #fab387;--accent-2: #f9e2af;--accent-dim:rgba(250,179,135,.15);--green: #a6e3a1;--red: #f38ba8;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-thumb: rgba(205,214,244,.1);--scrollbar-thumb-hover: rgba(205,214,244,.22);color-scheme:dark}:root[data-theme=catppuccin-latte]{--bg: #eff1f5;--bg-2: #e6e9ef;--bg-3: #dce0e8;--bg-4: #ccd0da;--border: #bcc0cc;--text: #4c4f69;--text-dim: #5c5f77;--text-dim-2:#7c7f93;--accent: #fe640b;--accent-2: #df8e1d;--accent-dim:rgba(254,100,11,.12);--green: #40a02b;--red: #d20f39;--shadow: 0 10px 40px -12px rgba(0,0,0,.18);--scrollbar-thumb: rgba(76,79,105,.18);--scrollbar-thumb-hover: rgba(76,79,105,.35);color-scheme:light}:root[data-theme=rose-pine]{--bg: #191724;--bg-2: #1f1d2e;--bg-3: #26233a;--bg-4: #2a283e;--border: #403d52;--text: #e0def4;--text-dim: #908caa;--text-dim-2:#6e6a86;--accent: #ebbcba;--accent-2: #f6c177;--accent-dim:rgba(235,188,186,.14);--green: #9ccfd8;--red: #eb6f92;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-thumb: rgba(224,222,244,.1);--scrollbar-thumb-hover: rgba(224,222,244,.22);color-scheme:dark}:root[data-theme=nord]{--bg: #2e3440;--bg-2: #3b4252;--bg-3: #434c5e;--bg-4: #4c566a;--border: #4c566a;--text: #eceff4;--text-dim: #d8dee9;--text-dim-2:#a0a9bb;--accent: #88c0d0;--accent-2: #8fbcbb;--accent-dim:rgba(136,192,208,.15);--green: #a3be8c;--red: #bf616a;--shadow: 0 10px 40px -12px rgba(0,0,0,.5);--scrollbar-thumb: rgba(236,239,244,.12);--scrollbar-thumb-hover: rgba(236,239,244,.25);color-scheme:dark}:root[data-theme=solarized-dark]{--bg: #002b36;--bg-2: #073642;--bg-3: #0d4654;--bg-4: #1a5263;--border: #1a5263;--text: #fdf6e3;--text-dim: #93a1a1;--text-dim-2:#657b83;--accent: #b58900;--accent-2: #cb4b16;--accent-dim:rgba(181,137,0,.18);--green: #859900;--red: #dc322f;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-thumb: rgba(253,246,227,.1);--scrollbar-thumb-hover: rgba(253,246,227,.22);color-scheme:dark}:root[data-theme=gruvbox-dark]{--bg: #282828;--bg-2: #32302f;--bg-3: #3c3836;--bg-4: #504945;--border: #504945;--text: #ebdbb2;--text-dim: #bdae93;--text-dim-2:#928374;--accent: #fabd2f;--accent-2: #fe8019;--accent-dim:rgba(250,189,47,.18);--green: #b8bb26;--red: #fb4934;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-thumb: rgba(235,219,178,.12);--scrollbar-thumb-hover: rgba(235,219,178,.25);color-scheme:dark}:root[data-theme=tokyo-night]{--bg: #1a1b26;--bg-2: #16161e;--bg-3: #232336;--bg-4: #2a2b3d;--border: #292e42;--text: #c0caf5;--text-dim: #a9b1d6;--text-dim-2:#565f89;--accent: #e0af68;--accent-2: #ff9e64;--accent-dim:rgba(224,175,104,.16);--green: #9ece6a;--red: #f7768e;--shadow: 0 10px 40px -12px rgba(0,0,0,.6);--scrollbar-thumb: rgba(192,202,245,.1);--scrollbar-thumb-hover: rgba(192,202,245,.22);color-scheme:dark}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track, transparent)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:var(--scrollbar-track, transparent)}*::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:6px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover);background-clip:padding-box;border:2px solid transparent}*::-webkit-scrollbar-corner{background:transparent}:root{--radius: 12px;--radius-sm: 8px;--transition: .18s cubic-bezier(.2,.7,.3,1)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}html{-webkit-text-size-adjust:100%;touch-action:manipulation}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-webkit-touch-callout:none}body:has(#app){overflow:hidden}#app{display:grid;grid-template-columns:var(--cst-sb-width, 340px) 1fr;height:100vh;transition:grid-template-columns var(--transition)}.sidebar-open{position:fixed;top:12px;left:12px;z-index:120;width:38px;height:38px;display:none;place-items:center;background:var(--bg-3);border:1px solid var(--border);color:var(--text-dim);border-radius:9px;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sidebar-open:hover{background:var(--bg-4);color:var(--text);border-color:var(--accent)}.sidebar-open:active{transform:scale(.94)}html.sidebar-collapsed .sidebar-open{display:grid}.sidebar-close{flex:none;width:30px;height:30px;display:grid;place-items:center;background:transparent;border:1px solid transparent;color:var(--text-dim);border-radius:8px;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.sidebar-close:hover{background:var(--bg-3);color:var(--text);border-color:var(--border)}.sidebar-close:active{transform:scale(.94)}.sidebar-backdrop{display:none}@media(max-width:900px){body{overflow-x:hidden}#app{grid-template-columns:1fr!important}.sidebar{position:fixed;top:0;left:0;bottom:0;width:86vw;max-width:340px;z-index:200;transform:translate(-100%);transition:transform var(--transition);box-shadow:0 10px 40px -10px #00000080}html:not(.sidebar-collapsed) .sidebar{transform:translate(0)}html:not(.sidebar-collapsed) .sidebar-backdrop{display:block;position:fixed;inset:0;background:#0000008c;z-index:150}.content{grid-column:1 / -1;width:100%;max-width:100vw;overflow-x:hidden}}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 14px;border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:38px;height:38px;background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:10px;display:grid;place-items:center;color:var(--bg);font-weight:800;font-size:13px;letter-spacing:.5px}.brand-text{min-width:0}.brand-title{font-weight:700;font-size:15px;letter-spacing:-.01em}.brand-sub{font-size:11.5px;color:var(--text-dim);margin-top:1px}html.sidebar-collapsed .home,html.sidebar-collapsed .course-page,html.sidebar-collapsed .lesson-topbar{padding-left:62px}.sidebar-stats{padding:12px 16px;font-size:12px;color:var(--text-dim);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat{display:flex;flex-direction:column;gap:2px}.stat-value{color:var(--text);font-weight:600;font-size:13px}.sidebar-search{padding:10px 12px;border-bottom:1px solid var(--border)}.sidebar-search input{width:100%;background:var(--bg-3);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px;outline:none;transition:var(--transition)}.sidebar-search input::placeholder{color:var(--text-dim-2)}.sidebar-search input:focus{border-color:var(--accent);background:var(--bg-2)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.sidebar-nav::-webkit-scrollbar{width:8px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:4px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--border)}.course-group{margin-bottom:4px}.course-header{display:flex;align-items:center;gap:10px;padding:10px 14px 10px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text);font-weight:600;font-size:13px;transition:var(--transition)}.course-header:hover{background:var(--bg-3)}.course-header .chev{font-size:10px;color:var(--text-dim-2);transition:var(--transition);width:12px;display:inline-block}.course-group.open .course-header .chev{transform:rotate(90deg)}.course-header .title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-header .badge{font-size:10.5px;color:var(--text-dim);background:var(--bg-3);padding:1px 7px;border-radius:999px;font-weight:500}.course-progress{height:2px;background:var(--bg-3);margin:0 14px 4px 28px;border-radius:1px;overflow:hidden}.course-progress-bar{height:100%;background:var(--accent);transition:width .3s}.modules{display:none;padding:2px 0 8px}.course-group.open .modules{display:block}.module-header{display:flex;align-items:center;gap:8px;padding:7px 14px 7px 28px;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-dim);font-size:12.5px;font-weight:500;transition:var(--transition)}.module-header:hover{color:var(--text);background:var(--bg-3)}.module-header .chev{font-size:9px;color:var(--text-dim-2);width:10px;transition:var(--transition)}.module-group.open .module-header .chev{transform:rotate(90deg)}.module-header .title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-header .badge{font-size:10px;color:var(--text-dim-2)}.lessons{display:none;padding:2px 0 6px}.module-group.open .lessons{display:block}.lesson-item{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 44px;font-size:12.5px;color:var(--text-dim);cursor:pointer;border-left:2px solid transparent;transition:var(--transition)}.lesson-item:hover{color:var(--text);background:var(--bg-3)}.lesson-item.active{color:var(--accent);background:var(--accent-dim);border-left-color:var(--accent)}.lesson-item.watched .ftag{color:var(--green)}.lesson-item .ftag{font-size:10.5px;font-family:SF Mono,Menlo,monospace;color:var(--text-dim-2);font-weight:600;letter-spacing:.3px;min-width:32px}.lesson-item .title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lesson-item .dur{font-size:10.5px;color:var(--text-dim-2);font-variant-numeric:tabular-nums}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.btn-text{background:transparent;border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:var(--transition);width:100%}.btn-text:hover{color:var(--text);background:var(--bg-3)}.theme-switcher{position:relative}.theme-btn{width:100%;background:var(--bg-3);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:10px}.theme-btn:hover{background:var(--bg-4);border-color:var(--accent)}.theme-btn .theme-dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--border);flex-shrink:0}.theme-btn .theme-name{flex:1;text-align:left}.theme-btn .theme-chev{color:var(--text-dim-2);font-size:10px;transition:transform var(--transition)}.theme-btn[aria-expanded=true] .theme-chev{transform:rotate(180deg)}.theme-menu{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:6px;z-index:50;display:flex;flex-direction:column;gap:1px;max-height:50vh;overflow-y:auto}.theme-menu[hidden]{display:none}.theme-option{appearance:none;background:transparent;border:none;color:var(--text);font-size:12.5px;padding:8px 10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background var(--transition);text-align:left}.theme-option:hover{background:var(--bg-3)}.theme-option .dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--border);flex-shrink:0}.theme-option .label{flex:1}.theme-option .check{color:var(--accent);opacity:0;font-weight:700}.theme-option.active{background:var(--accent-dim)}.theme-option.active .check{opacity:1}.content{overflow-y:auto;padding:0;min-width:0}.loading{padding:60px;text-align:center;color:var(--text-dim)}.home{padding:48px 48px 64px;max-width:1200px;margin:0 auto}.home-hero{margin-bottom:36px;padding:28px;background:linear-gradient(135deg,var(--bg-2),var(--bg-3));border-radius:var(--radius);border:1px solid var(--border);position:relative;overflow:hidden}.home-hero:after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;background:radial-gradient(circle,var(--accent-dim),transparent 70%);pointer-events:none}.home-hero h1{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px}.home-hero p{color:var(--text-dim);max-width:720px;font-size:14px}.home-hero .meta{display:flex;gap:24px;margin-top:18px;font-size:13px;color:var(--text-dim)}.home-hero .meta strong{color:var(--text);font-weight:600;font-size:14px}.home-courses{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.course-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:22px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.course-card:hover{background:var(--bg-3);transform:translateY(-2px);box-shadow:var(--shadow)}.course-card .number{font-size:11px;color:var(--text-dim-2);letter-spacing:.15em;text-transform:uppercase;font-weight:600}.course-card h3{font-size:18px;margin:6px 0 12px;letter-spacing:-.01em;font-weight:700}.course-card .summary{color:var(--text-dim);font-size:13px;min-height:38px}.course-card .stats{display:flex;gap:16px;margin-top:18px;font-size:12px;color:var(--text-dim)}.course-card .stats strong{color:var(--text);font-weight:600}.course-card .progress{height:3px;background:var(--bg-3);border-radius:2px;margin-top:14px;overflow:hidden}.course-card .progress-bar{height:100%;background:var(--accent);transition:width .3s}.course-page{padding:32px 48px 64px;max-width:1200px;margin:0 auto}.crumbs{color:var(--text-dim);font-size:12.5px;margin-bottom:14px}.crumbs a{color:var(--text-dim);text-decoration:none}.crumbs a:hover{color:var(--accent)}.crumbs .sep{margin:0 6px;color:var(--text-dim-2)}.course-title{font-size:26px;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}.course-meta{color:var(--text-dim);font-size:13.5px;margin-bottom:30px}.course-meta span+span{margin-left:18px}.modules-list{display:flex;flex-direction:column;gap:12px}.module-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;cursor:pointer;transition:var(--transition);display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center}.module-card:hover{background:var(--bg-3)}.module-card .num{width:38px;height:38px;background:var(--bg-3);border-radius:8px;display:grid;place-items:center;font-weight:700;font-size:14px;color:var(--accent);border:1px solid var(--border)}.module-card h4{font-size:15px;font-weight:600;margin-bottom:2px;letter-spacing:-.01em}.module-card .info{font-size:12.5px;color:var(--text-dim)}.module-card .info span+span{margin-left:14px}.module-card .progress-mini{width:80px;height:4px;background:var(--bg-3);border-radius:2px;overflow:hidden;margin-top:6px}.module-card .progress-mini-bar{height:100%;background:var(--green);transition:width .3s}.module-card .arrow{color:var(--text-dim);font-size:18px}.lesson-page{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden;position:relative;--grid-top-gap: 18px}.lesson-topbar{position:absolute;top:0;left:0;right:0;z-index:30;padding:14px 28px;border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;background:var(--bg-2);transition:transform .28s ease}.lesson-page.header-hidden .lesson-topbar{transform:translateY(-100%)}.lesson-topbar .crumbs{margin-bottom:4px}.lesson-topbar h2{font-size:17px;font-weight:600;letter-spacing:-.01em}.lesson-topbar h2 .ftag{font-family:SF Mono,Menlo,monospace;color:var(--accent);font-size:13px;margin-right:10px}.lesson-nav-btns{display:flex;gap:8px}.btn-nav{background:var(--bg-3);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-nav:hover{background:var(--bg-4)}.btn-nav:disabled{opacity:.4;cursor:not-allowed}.btn-nav .btn-arrow{font-size:14px;line-height:1}@media(max-width:700px){.lesson-topbar{padding:10px 14px;grid-template-columns:minmax(0,1fr) auto;gap:10px;max-width:100vw;overflow:hidden;box-sizing:border-box}.lesson-topbar>*{min-width:0}.lesson-topbar .crumbs{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.lesson-topbar h2{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lesson-topbar h2 .ftag{font-size:11px;margin-right:6px}.lesson-nav-btns{grid-column:2}.btn-nav{padding:8px 10px;min-width:38px;justify-content:center}.btn-nav .btn-label{display:none}.btn-nav .btn-arrow{font-size:18px;font-weight:700}}.btn-primary{background:var(--accent);border:1px solid var(--accent);color:var(--bg);padding:8px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-primary:hover{background:var(--accent-2)}.lesson-grid{display:grid;grid-template-columns:minmax(0,1fr) clamp(320px,28vw,440px);grid-template-areas:"player trans" "info   trans" "info   side";grid-template-rows:auto 1fr auto;gap:16px;padding:18px 28px 32px;overflow-y:auto;overflow-x:hidden;align-content:start;min-height:0;background:var(--bg)}.zone-player{grid-area:player;min-width:0}.zone-trans{grid-area:trans;min-width:0;align-self:stretch}.zone-info{grid-area:info;min-width:0}.zone-side{grid-area:side;min-width:0;display:flex;flex-direction:column;gap:12px}.lesson-grid.expanded{grid-template-areas:"player player" "info   trans" ".      side";grid-template-rows:auto 1fr auto}.lesson-grid.expanded .zone-trans{min-height:45vh}.lesson-grid.expanded .zone-info{min-height:45vh;overflow-y:auto}.lesson-grid.is-animating,.lesson-grid.is-animating *{pointer-events:none!important}@media(max-width:1100px){.lesson-page{max-width:100vw;overflow-x:hidden;--grid-top-gap: 0px}.lesson-grid,.lesson-grid.expanded{grid-template-columns:1fr;grid-template-areas:"player" "trans" "info" "side";padding:0 0 24px;max-width:100vw;width:100%;overflow-x:hidden;box-sizing:border-box}.lesson-grid>*{min-width:0;max-width:100%;box-sizing:border-box}.zone-info{padding:16px;margin:0 12px;max-width:calc(100vw - 24px)}.zone-side{padding:0 12px;max-width:100vw}.zone-trans{margin:12px 12px 0;max-width:calc(100vw - 24px)}.lesson-grid .transcript-aside,.lesson-grid.expanded .transcript-aside{height:320px!important;min-height:320px!important;max-height:320px!important;border-radius:var(--radius);width:100%;max-width:100%}.lesson-grid.expanded .zone-trans,.lesson-grid.expanded .zone-info{min-height:unset}}.lesson-grid,.lesson-grid.expanded{padding-top:calc(var(--topbar-h, 56px) + var(--grid-top-gap, 18px));transition:padding-top .28s ease}.lesson-page.header-hidden .lesson-grid,.lesson-page.header-hidden .lesson-grid.expanded{padding-top:var(--grid-top-gap, 18px)}.player-wrap{position:relative;aspect-ratio:16 / 9;width:100%;max-height:65vh;max-width:calc(65vh * 16 / 9);margin:0 auto;background:#000;border-radius:var(--radius);overflow:hidden;align-self:start}.lesson-grid.expanded .player-wrap{max-height:78vh;max-width:calc(78vh * 16 / 9)}@media(max-width:1100px){.player-wrap{border-radius:0;max-width:100%;max-height:56vh}}.player-wrap video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;cursor:pointer}.player-wrap:fullscreen{max-width:none;max-height:none;width:100%;height:100%;margin:0;border-radius:0;aspect-ratio:auto}.player-wrap:-webkit-full-screen{max-width:none;max-height:none;width:100%;height:100%;margin:0;border-radius:0;aspect-ratio:auto}.player-wrap:fullscreen video{object-fit:contain}.player-wrap:-webkit-full-screen video{object-fit:contain}.transcript-aside{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;min-height:0;height:100%}@media(max-width:1100px){.transcript-aside{border-radius:var(--radius);max-height:350px;height:auto}}.transcript-aside-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.transcript-aside-header h4{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.15em}.transcript-follow-btn{background:var(--bg-3);border:1px solid var(--border);color:var(--text-dim);font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.08em}.transcript-follow-btn:hover{color:var(--text);background:var(--bg-4)}.transcript-follow-btn.active{background:var(--accent-dim);color:var(--accent);border-color:transparent}.transcript-list{flex:1;overflow-y:auto;padding:6px 0}.transcript-empty{padding:24px 16px;color:var(--text-dim-2);font-size:13px;text-align:center}.transcript-row{padding:8px 16px;display:grid;grid-template-columns:48px 1fr;gap:10px;cursor:pointer;border-left:2px solid transparent;transition:background .14s ease}.transcript-row:hover{background:var(--bg-3)}.transcript-row.active{background:var(--accent-dim);border-left-color:var(--accent)}.transcript-ts{font-family:SF Mono,Menlo,monospace;font-size:11px;color:var(--text-dim-2);font-variant-numeric:tabular-nums;padding-top:1px}.transcript-row.active .transcript-ts{color:var(--accent);font-weight:600}.transcript-text{font-size:13px;color:var(--text);line-height:1.5}.transcript-row.active .transcript-text{color:var(--text)}.player-overlay{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,#0000 0% 60%,#000000b3);opacity:1;transition:opacity .22s ease}.player-overlay.hidden{opacity:0;pointer-events:none}.player-overlay.hidden>*{pointer-events:none!important}.player-overlay>*{pointer-events:auto}.player-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:60px;pointer-events:none}.player-center>*{pointer-events:auto}.center-btn{background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:none;color:#fff;width:64px;height:64px;border-radius:50%;cursor:pointer;display:grid;place-items:center;transition:transform .14s ease,background .14s ease;position:relative}.center-btn:hover{background:#000000bf;transform:scale(1.08)}.center-btn:active{transform:scale(.95)}.center-btn.big{width:84px;height:84px}.center-btn svg{width:32px;height:32px;fill:#fff}.center-btn.big svg{width:42px;height:42px}@media(max-width:700px){.center-btn{width:44px;height:44px}.center-btn.big{width:56px;height:56px}.center-btn svg{width:22px;height:22px}.center-btn.big svg{width:28px;height:28px}.player-center{gap:28px}}.center-btn .seek-label{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);font-size:10px;color:#ffffffb3;font-weight:600;letter-spacing:.05em;text-shadow:0 1px 2px rgba(0,0,0,.8);white-space:nowrap}.player-overlay.idle .center-btn:not(.play-pause){opacity:0;pointer-events:none;transition:opacity .22s}.player-overlay.idle .center-btn.play-pause{opacity:0;pointer-events:none}.player-overlay.show-center .center-btn{opacity:1}.player-bottom{position:absolute;left:0;right:0;bottom:0;padding:8px 18px 14px;display:flex;flex-direction:column;gap:6px;z-index:2}.player-progress{width:100%;height:6px;background:#ffffff2e;border-radius:3px;cursor:pointer;position:relative;transition:height .14s ease;touch-action:none}.player-progress:hover{height:8px}@media(max-width:700px){.player-progress,.player-progress:hover{height:10px}}.player-progress-buffered{position:absolute;inset:0;background:#ffffff4d;border-radius:3px;width:0%}.player-progress-played{position:absolute;inset:0;background:var(--accent);border-radius:3px;width:0%}.player-progress-thumb{position:absolute;width:12px;height:12px;background:var(--accent);border-radius:50%;top:50%;transform:translate(-50%,-50%) scale(0);left:0%;transition:transform .14s ease;box-shadow:0 0 8px #f59e0b80}.player-progress:hover .player-progress-thumb{transform:translate(-50%,-50%) scale(1)}.player-controls{display:flex;align-items:center;gap:10px;color:#fff}.player-btn{background:transparent;border:none;color:#fff;width:36px;height:36px;border-radius:6px;cursor:pointer;display:grid;place-items:center;transition:background .14s ease}.player-btn:hover{background:#ffffff26}.player-btn.active{background:var(--accent)}.player-btn.active:hover{background:var(--accent-2)}.player-btn.active svg{fill:#0c0c11}.player-btn svg{width:20px;height:20px;fill:#fff}.player-btn:disabled{opacity:.3;cursor:default}.player-btn:disabled:hover{background:transparent}.player-time{font-size:12px;font-variant-numeric:tabular-nums;color:#ffffffd9;margin-left:4px;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0}.player-spacer{flex:1}@media(max-width:900px){#expand-btn{display:none}}.player-volume{display:flex;align-items:center;gap:4px}.player-volume-slider{width:0;height:16px;overflow:hidden;transition:width .2s ease;display:flex;align-items:center}.player-volume:hover .player-volume-slider,.player-volume:focus-within .player-volume-slider{width:80px}.player-volume-slider input{width:76px;height:5px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#fff var(--vol, 100%),rgba(255,255,255,.28) var(--vol, 100%));border-radius:3px;outline:none;cursor:pointer}.player-volume-slider input::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #00000073}.player-volume-slider input::-moz-range-track{height:5px;background:#ffffff47;border-radius:3px}.player-volume-slider input::-moz-range-progress{height:5px;background:#fff;border-radius:3px}.player-volume-slider input::-moz-range-thumb{width:13px;height:13px;border:none;background:#fff;border-radius:50%;cursor:pointer}.player-volume-slider input:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.player-spinner{position:absolute;inset:0;display:none;align-items:center;justify-content:center;pointer-events:none}.player-overlay.buffering .player-spinner{display:flex}.player-spinner-dot{width:48px;height:48px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.player-wrap.idle,.player-wrap.idle video{cursor:none}.skip-next-btn{position:absolute;bottom:70px;right:24px;z-index:5;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:#fff;padding:10px 16px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;transition:opacity .22s ease,transform .22s ease,background .14s ease,border-color .14s ease;opacity:0;transform:translateY(8px)}.skip-next-btn[hidden]{display:none}.skip-next-btn.show{opacity:1;transform:translateY(0)}.skip-next-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.skip-next-btn .skip-next-icon{font-size:14px}.scrub-preview{position:fixed;transform:translate(-50%);pointer-events:none;z-index:9999;display:flex;flex-direction:column;align-items:center;gap:6px;animation:scrub-fade .12s ease}.scrub-preview[hidden]{display:none!important}.scrub-video{background:#000;border:2px solid rgba(255,255,255,.9);border-radius:8px;object-fit:cover;box-shadow:0 10px 30px #000000b3;display:block}.scrub-time{background:#000000eb;color:#fff;font-size:13px;font-variant-numeric:tabular-nums;padding:4px 10px;border-radius:5px;font-weight:700;letter-spacing:.02em}@keyframes scrub-fade{0%{opacity:0;transform:translate(-50%,6px)}to{opacity:1;transform:translate(-50%)}}.zone-info{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.lesson-info-head{margin-bottom:14px}.lesson-info-head h3{font-size:18px;font-weight:600;margin-bottom:6px;letter-spacing:-.01em}.lesson-info-head .meta{display:flex;gap:8px;align-items:center;color:var(--text-dim-2);font-size:12.5px}.zone-info .desc{color:var(--text-dim);font-size:13.5px}.zone-side .watched-toggle,.zone-side .side-card,.zone-side .download-card{width:100%}.side-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}.side-card .label{font-size:11px;color:var(--text-dim-2);text-transform:uppercase;letter-spacing:.15em;margin-bottom:6px;font-weight:600}.side-card .value{font-size:13px;color:var(--text)}.side-card a.value{color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px}.side-card a.value:hover{text-decoration:underline}.actions{display:flex;flex-direction:column;gap:8px}.download-card{position:relative;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 18px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--bg);border:none;cursor:pointer;font-family:Inter,-apple-system,system-ui,sans-serif;font-weight:700;font-size:14px;letter-spacing:.02em;overflow:hidden;transition:transform .14s ease,box-shadow .2s ease,filter .14s ease;box-shadow:0 6px 18px -8px #f59e0b99;width:100%}.download-card:hover{filter:brightness(1.05);transform:translateY(-1px);box-shadow:0 10px 24px -8px #f59e0bbf}.download-card:active{transform:translateY(0)}.download-card .download-icon{width:18px;height:18px;flex-shrink:0}.download-card .download-label{font-weight:700;font-size:14px;letter-spacing:.03em}.download-card.downloading{cursor:progress;background:var(--bg-3);color:var(--text);box-shadow:none}.download-card.downloading:hover{transform:none;filter:none}.download-card.done{background:linear-gradient(135deg,var(--green),#34d399);color:var(--bg)}.download-card.error{background:linear-gradient(135deg,var(--red),#f87171);color:#fff}.download-progress{position:absolute;inset:0;pointer-events:none;display:flex;align-items:stretch}.download-progress-bar{background:linear-gradient(135deg,var(--accent),var(--accent-2));width:0%;height:100%;transition:width .2s ease;opacity:.4}.download-status{position:relative;z-index:1;font-size:12.5px;font-weight:600;font-variant-numeric:tabular-nums}.download-warning{font-size:11px;line-height:1.45;color:var(--text-dim-2);display:flex;gap:6px;align-items:flex-start;padding:8px 4px 0;transition:color .18s ease}.download-warning .warn-icon{flex-shrink:0;line-height:1.45}.download-warning.active{color:var(--accent);font-weight:600}.watched-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 14px;border-radius:var(--radius-sm);background:var(--bg-3);border:1px solid var(--border);color:var(--text);font-size:13px;transition:var(--transition)}.watched-toggle:hover{background:var(--bg-4)}.watched-toggle.watched{background:#10b9811f;border-color:var(--green);color:var(--green)}.watched-toggle .dot{width:14px;height:14px;border-radius:50%;border:2px solid currentColor;display:inline-block;position:relative}.watched-toggle.watched .dot{background:var(--green)}.watched-toggle.watched .dot:after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;color:var(--bg);font-size:9px;font-weight:900}.ai-section{margin-bottom:22px}.ai-section:last-child{margin-bottom:0}.ai-heading{font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.15em;margin:0 0 10px}.ai-resumo{color:var(--text);font-size:14px;line-height:1.65;background:var(--bg-2);padding:14px 16px;border-radius:var(--radius-sm);border-left:3px solid var(--accent);margin-bottom:8px}.ai-resumo+.ai-resumo{border-left-color:var(--border)}.ai-list{list-style:none;display:flex;flex-direction:column;gap:6px}.ai-list li{padding:8px 12px 8px 30px;background:var(--bg-2);border-radius:6px;font-size:13px;position:relative;color:var(--text)}.ai-list li:before{content:"•";color:var(--accent);position:absolute;left:14px;font-weight:700}.ai-links{list-style:none;display:flex;flex-direction:column;gap:4px}.ai-links li{padding:8px 12px;background:var(--bg-2);border-radius:6px;font-size:13px}.ai-links a{color:var(--accent);text-decoration:none;font-weight:500}.ai-links a:hover{text-decoration:underline}.ai-link-ctx{color:var(--text-dim);font-size:12px}.ai-tags{display:flex;flex-wrap:wrap;gap:6px}.ai-tag{background:var(--bg-3);color:var(--text);padding:4px 10px;border-radius:999px;font-size:12px;border:1px solid var(--border)}.ai-transcript summary{cursor:pointer;padding:10px 12px;background:var(--bg-2);border-radius:var(--radius-sm);list-style:none;display:flex;align-items:center;gap:8px}.ai-transcript summary::-webkit-details-marker{display:none}.ai-transcript summary:before{content:"▶";font-size:9px;transition:transform .18s;color:var(--text-dim)}.ai-transcript[open] summary:before{transform:rotate(90deg)}.ai-hint{color:var(--text-dim-2);font-weight:400;font-size:11px;text-transform:none;letter-spacing:0}.ai-transcript-text{margin-top:8px;padding:14px 16px;background:var(--bg-2);border-radius:var(--radius-sm);font-size:13px;line-height:1.7;color:var(--text);white-space:pre-wrap;max-height:400px;overflow-y:auto}mark{background:var(--accent-dim);color:var(--accent-2);padding:0 2px;border-radius:2px}@media(max-width:900px){.lesson-info{grid-template-columns:1fr;padding:12px 16px 16px}.home,.course-page{padding:24px}.home-hero{padding:22px}.home-hero h1{font-size:22px}}.catalog-shell{height:100vh;overflow-y:auto;background:var(--bg)}a.course-card,a.course-card:hover{text-decoration:none;color:inherit}.catalog-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 28px;background:color-mix(in srgb,var(--bg) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.catalog-actions{display:flex;align-items:center;gap:14px}.catalog-admin-btn{padding:8px 16px;border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-ink, #0c0c11);font-weight:700;font-size:13px;text-decoration:none;transition:filter var(--transition)}.catalog-admin-btn:hover{filter:brightness(1.08)}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(1200px 600px at 10% -10%,rgba(245,158,11,.12),transparent 60%),radial-gradient(900px 500px at 110% 110%,rgba(245,158,11,.07),transparent 55%),var(--bg)}.login-card{width:min(420px,100%);background:var(--bg-2);border:1px solid var(--border);border-radius:18px;padding:34px 32px 26px;box-shadow:0 24px 70px -24px #000000a6}.login-brand{display:flex;align-items:center;gap:13px;margin-bottom:26px}.login-brand .brand-mark{width:46px;height:46px;background:var(--accent);color:#0c0c11;font-weight:800;font-size:18px;display:grid;place-items:center;border-radius:12px;flex-shrink:0}.login-brand .brand-title{font-weight:700;font-size:16px;color:var(--text)}.login-brand .brand-sub{font-size:12px;color:var(--text-dim);margin-top:2px}.login-card form{display:flex;flex-direction:column;gap:11px}.login-card input{width:100%;appearance:none;background:var(--bg-3);border:1px solid var(--border);color:var(--text);padding:13px 15px;border-radius:11px;font-size:14px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.login-card input::placeholder{color:var(--text-dim-2)}.login-card input:focus{border-color:var(--accent);background:var(--bg-4, var(--bg-3));box-shadow:0 0 0 3px #f59e0b29}.login-card #submit-btn{margin-top:6px;width:100%;background:var(--accent);color:#0c0c11;border:none;padding:14px 18px;font-weight:700;border-radius:11px;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:filter .15s,transform .1s}.login-card #submit-btn:hover{filter:brightness(1.07)}.login-card #submit-btn:active{transform:translateY(1px)}.login-card #submit-btn:disabled{opacity:.6;cursor:progress}.login-toggle{display:block;width:100%;margin-top:12px;text-align:center;background:none;border:none;color:var(--text-dim);font-size:13px;cursor:pointer;transition:color .15s}.login-toggle:hover{color:var(--accent)}.login-msg-error{margin-top:12px;padding:11px 13px;border-radius:10px;background:#ef44441f;border:1px solid rgba(239,68,68,.4);color:#fda4a4;font-size:13px}.login-foot{margin-top:22px;padding-top:16px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim-2);text-align:center}#app>.content{width:100%;min-width:0;justify-self:stretch}.lesson-page,.lesson-grid{width:100%;min-width:0}.lesson-topbar{position:sticky;top:0;transform:none!important}.lesson-page.header-hidden .lesson-topbar{transform:none!important}.lesson-grid{padding-top:20px}.admin-shell{height:100vh;overflow-y:auto;background:var(--bg)}.admin-shell .admin-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:var(--bg-2);border-bottom:1px solid var(--border)}.admin-shell .admin-back{color:var(--text-dim);text-decoration:none;font-size:13px}.admin-shell .admin-back:hover{color:var(--accent)}.admin-shell .admin-title{font-size:16px;font-weight:700;color:var(--text)}.admin-shell .admin-body{max-width:1100px;margin:0 auto;padding:28px;display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:800px){.admin-shell .admin-body{grid-template-columns:1fr}}.admin-shell .admin-col-title{font-size:13px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-dim);margin-bottom:12px}.admin-shell .admin-user{width:100%;text-align:left;padding:12px 14px;margin-bottom:8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-2);color:var(--text);cursor:pointer;transition:var(--transition);display:flex;justify-content:space-between;align-items:center}.admin-shell .admin-user:hover{background:var(--bg-3)}.admin-shell .admin-user.active{border-color:var(--accent);background:var(--bg-3)}.admin-shell .admin-user .role{font-size:11px;color:var(--text-dim-2);text-transform:uppercase}.admin-shell .admin-user .role.is-admin{color:var(--accent)}.admin-shell .admin-course-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;margin-bottom:8px;border-radius:var(--radius-sm);background:var(--bg-2);border:1px solid var(--border)}.admin-shell .admin-grant-btn{padding:7px 14px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:600;font-size:13px;transition:var(--transition)}.admin-shell .admin-grant-btn.grant{background:var(--accent);color:#0c0c11}.admin-shell .admin-grant-btn.revoke{background:var(--bg-4, #ffffff14);color:var(--text);border:1px solid var(--border)}.admin-shell .admin-empty{color:var(--text-dim-2);font-size:13px;padding:8px 0}.admin-shell .uploader{margin:0 24px 20px;padding:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius)}.admin-shell .uploader-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}.admin-shell .uploader-row input[type=text]{flex:1 1 200px;padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px}.admin-shell .uploader-row button,.admin-shell .uploader input[type=file]{padding:9px 14px;border-radius:10px;border:1px solid var(--border);background:var(--accent);color:#0c0c11;font-weight:600;font-size:14px;cursor:pointer}.admin-shell .uploader input[type=file]{background:var(--bg);color:var(--text);width:100%;margin-top:4px}.admin-shell .uploader-row button:disabled{opacity:.5;cursor:default}.admin-shell .uploader-active{font-size:13px;color:var(--text-dim-2);margin-bottom:8px}.admin-shell .uploader-hint{font-size:12px;color:var(--text-dim-2);margin:6px 0 0}.admin-shell .uploader-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}.admin-shell .uploader-item{display:grid;grid-template-columns:1fr 120px 90px;align-items:center;gap:10px;font-size:13px}.admin-shell .uploader-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-shell .uploader-item-bar{height:6px;background:var(--bg-4, #ffffff14);border-radius:999px;overflow:hidden}.admin-shell .uploader-item-fill{display:block;height:100%;background:var(--accent);transition:width .12s linear}.admin-shell .uploader-item.done .uploader-item-fill{background:var(--green, #38d39f)}.admin-shell .uploader-item.error .uploader-item-fill{background:var(--red, #ef4444)}.admin-shell .uploader-item-status{text-align:right;color:var(--text-dim-2);font-variant-numeric:tabular-nums}.admin-shell .admin-courses-manage{margin:0 24px 20px;padding:16px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius)}.admin-shell .admin-draft{color:var(--text-dim-2);font-size:12px}.cd-overlay{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:color-mix(in srgb,#000 56%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.cd-panel{width:100%;max-width:440px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius, 16px);box-shadow:var(--shadow, 0 30px 80px -20px rgba(0, 0, 0, .7));padding:26px 26px 22px;text-align:left;transform-origin:center}.cd-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:13px;margin-bottom:16px;color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,transparent)}.cd-panel.danger .cd-icon{color:var(--red);background:color-mix(in srgb,var(--red) 16%,transparent)}.cd-title{margin:0 0 8px;font-size:18px;font-weight:650;line-height:1.3;letter-spacing:-.01em;color:var(--text)}.cd-message{margin:0;font-size:14px;line-height:1.6;color:var(--text-dim)}.cd-message strong{color:var(--text);font-weight:600}.cd-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.cd-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:10px;border:1px solid var(--border);background:var(--bg-3);color:var(--text);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .16s,border-color .16s,filter .16s,box-shadow .16s}.cd-btn:hover{background:var(--bg-4)}.cd-confirm{background:var(--accent);color:#0c0c11;border-color:transparent}.cd-confirm:hover{background:var(--accent);filter:brightness(1.06)}.cd-danger{background:var(--red);color:#fff;border-color:transparent}.cd-danger:hover{background:var(--red);filter:brightness(1.08)}.cd-btn:focus-visible{outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 45%,transparent)}.cd-danger:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb,var(--red) 45%,transparent)}@media(max-width:480px){.cd-actions{flex-direction:column-reverse}.cd-btn{width:100%}}.nc-shell{min-height:100vh;background:var(--bg);color:var(--text)}.nc-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:14px 28px;background:color-mix(in srgb,var(--bg) 86%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.nc-back{color:var(--text-dim-2);text-decoration:none;font-size:14px;transition:color .18s}.nc-back:hover{color:var(--text)}.nc-topbar-title{font-weight:600;font-size:15px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nc-topbar-actions{display:flex;align-items:center;gap:14px}.nc-stat{color:var(--text-dim-2);font-size:13px}.nc-body{max-width:860px;margin:0 auto;padding:28px 24px 80px;display:flex;flex-direction:column;gap:20px}.nc-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:22px}.nc-card-title{display:flex;align-items:center;justify-content:space-between;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim-2);margin-bottom:18px}.nc-field{margin-bottom:14px}.nc-field label{display:block;font-size:13px;color:var(--text-dim-2);margin-bottom:6px}.nc-field input,.nc-field textarea{width:100%;padding:11px 13px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;font-family:inherit;transition:border-color .18s,box-shadow .18s}.nc-field input:focus,.nc-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 25%,transparent)}.nc-field input:disabled,.nc-field textarea:disabled{opacity:.6}.nc-field textarea{resize:vertical}.nc-field-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px}.nc-switch{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-dim-2);cursor:pointer}.nc-switch input{width:16px;height:16px;accent-color:var(--accent)}.nc-created-badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-dim-2)}.nc-dot{width:8px;height:8px;border-radius:50%;background:var(--green, #38d39f)}.nc-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;border-radius:10px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .18s,border-color .18s,opacity .18s}.nc-btn:hover{border-color:var(--accent)}.nc-btn:disabled{opacity:.5;cursor:default}.nc-btn-primary{background:var(--accent);color:#0c0c11;border-color:transparent}.nc-btn-primary:hover{filter:brightness(1.05)}.nc-btn-ghost{background:transparent;color:var(--text-dim-2);padding:6px 10px;font-size:13px}.nc-btn-ghost:hover{color:var(--text)}.nc-empty{padding:28px;text-align:center;color:var(--text-dim-2);font-size:14px;border:1px dashed var(--border);border-radius:12px}.nc-mods{list-style:none;display:flex;flex-direction:column;gap:12px;padding:0;margin:0}.nc-mod{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:12px}.nc-mod-head{display:flex;align-items:center;gap:8px}.nc-handle{color:var(--text-dim-2);cursor:grab;display:inline-flex;padding:4px;border-radius:6px}.nc-handle:active{cursor:grabbing}.nc-handle.sm{opacity:.6}.nc-mod-title{flex:1;background:transparent;border:1px solid transparent;border-radius:8px;padding:6px 8px;color:var(--text);font-size:15px;font-weight:600}.nc-mod-title:hover{border-color:var(--border)}.nc-mod-title:focus{outline:none;border-color:var(--accent);background:var(--bg-2)}.nc-mod-count{font-size:12px;color:var(--text-dim-2);white-space:nowrap}.nc-icon-btn{display:inline-flex;padding:7px;border-radius:8px;border:none;background:transparent;color:var(--text-dim-2);cursor:pointer;transition:background .16s,color .16s}.nc-icon-btn:hover{background:color-mix(in srgb,var(--red, #ef4444) 18%,transparent);color:var(--red, #ef4444)}.nc-lessons{list-style:none;display:flex;flex-direction:column;gap:6px;padding:8px 0 0;margin:6px 0 0}.nc-lesson{display:flex;align-items:center;gap:8px;padding:7px 8px;background:var(--bg-2);border:1px solid var(--border);border-radius:9px}.nc-lesson-ic{color:var(--accent);display:inline-flex}.nc-lesson-title{flex:1;background:transparent;border:1px solid transparent;border-radius:7px;padding:4px 6px;color:var(--text);font-size:14px}.nc-lesson-title:hover{border-color:var(--border)}.nc-lesson-title:focus{outline:none;border-color:var(--accent)}.nc-lesson-dur{font-size:12px;color:var(--text-dim-2);font-variant-numeric:tabular-nums}.nc-q{display:flex;align-items:center;gap:10px;padding:8px;margin-top:6px;background:var(--bg-2);border:1px solid var(--border);border-radius:9px;overflow:hidden}.nc-q-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nc-q-bar{width:120px;height:6px;background:color-mix(in srgb,var(--text) 12%,transparent);border-radius:999px;overflow:hidden}.nc-q-fill{display:block;height:100%;background:var(--accent);transition:width .12s linear}.nc-q.error .nc-q-fill{background:var(--red, #ef4444)}.nc-q-pct{font-size:12px;color:var(--text-dim-2);width:38px;text-align:right;font-variant-numeric:tabular-nums}.nc-q-act{background:none;border:none;color:var(--accent);font-size:12px;cursor:pointer}.nc-drop{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;padding:16px;border:1px dashed var(--border);border-radius:10px;color:var(--text-dim-2);font-size:13px;transition:border-color .16s,background .16s,color .16s}.nc-drop.over{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--text)}.nc-drop-ic{color:var(--accent);display:inline-flex}.nc-drop-pick{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-size:13px}@media(max-width:640px){.nc-body{padding:16px 12px 60px}.nc-card{padding:16px}.nc-q-bar{width:70px}}
