:root{--bg:#0a0a0a;--bg-elev:#0e0e0e;--surface-1:#111;--surface-2:#161616;--surface-3:#1c1c1c;--surface-hover:#1a1a1a;--border:#1f1f1f;--border-strong:#2a2a2a;--border-input:#262626;--text:#fafafa;--text-dim:#a3a3a3;--text-mute:#6b6b6b;--accent:#0ea5e9;--accent-hover:#38bdf8;--accent-soft:#0ea5e91f;--accent-soft-2:#0ea5e938;--accent-glow:#0ea5e966;--accent-text:#38bdf8;--success:#22c55e;--danger:#ef4444;--warning:#eab308;--radius-sm:6px;--radius:10px;--radius-lg:14px;--shadow-1:0 1px 2px #0006;--shadow-2:0 6px 24px #00000080;--shadow-pop:0 16px 40px #000000b3;--sidebar-w:260px;--sidebar-w-narrow:220px;--secondary-sidebar-w:300px;--topbar-h:60px;--titlebar-h:38px;--bottombar-h:60px;--font-sans:"Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;--font-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace}*{box-sizing:border-box}[x-cloak]{display:none!important}html,body{background:var(--bg);height:100%;color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;touch-action:pan-x pan-y;overscroll-behavior:none;margin:0;padding:0;font-size:14px;line-height:1.45;overflow:hidden}img{max-width:100%;display:block}button{color:inherit;font:inherit;cursor:pointer;background:0 0;border:none;padding:0}button:disabled,button[aria-disabled=true]{opacity:.45;cursor:not-allowed;pointer-events:none}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,select,textarea{color:inherit;font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-3);border:2px solid var(--bg);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.scrollbar-thin::-webkit-scrollbar{width:6px}.scrollbar-thin::-webkit-scrollbar-thumb{border:none}.app{grid-template-columns:var(--sidebar-w) 1fr;background:var(--bg);grid-template-rows:1fr;height:100vh;display:grid;position:relative}.app.in-player{grid-template-columns:var(--sidebar-w) var(--secondary-sidebar-w) 1fr}.app.fullwindow{grid-template-rows:1fr;grid-template-columns:1fr}.app.fullwindow .sidebar,.app.fullwindow .secondary-sidebar{display:none}@media (max-width:1279px) and (min-width:1024px){.app{grid-template-columns:var(--sidebar-w-narrow) 1fr}.app.in-player{grid-template-columns:var(--sidebar-w-narrow) var(--secondary-sidebar-w) 1fr}}@media (max-width:1023px){.app,.app.in-player{grid-template-columns:1fr}.app.fullwindow{grid-template-rows:1fr;grid-template-columns:1fr}.sidebar,.secondary-sidebar{display:none!important}}.sidebar{background:var(--surface-1);border-right:1px solid var(--border);flex-direction:column;grid-row:1;min-width:0;display:flex;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);height:var(--topbar-h);align-items:center;gap:10px;padding:14px 16px 12px;display:flex}.sidebar-brand img{border-radius:8px;width:30px;height:30px;box-shadow:0 4px 12px #0ea5e940}.sidebar-brand .name{letter-spacing:-.01em;font-size:15px;font-weight:600}.sidebar-brand .tag{font-size:10px;font-family:var(--font-mono);color:var(--text-mute);text-transform:uppercase;letter-spacing:.08em;background:var(--surface-3);border-radius:4px;flex-shrink:0;align-items:center;margin-left:auto;padding:2px 6px;transition:background .12s,color .12s;display:flex;position:relative}.sidebar-brand .tag:hover{background:var(--border-strong);color:var(--text)}.version-update-dot{background:var(--danger);border:1.5px solid var(--surface-1);border-radius:50%;width:6px;height:6px;position:absolute;top:-3px;right:-3px}.sidebar-search{padding:10px 12px 8px}.search-wrap{position:relative}.search-wrap .icon-l{color:var(--text-mute);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-wrap kbd{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-mute);border:1px solid var(--border);border-radius:4px;padding:2px 5px;font-size:10px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-input{background:var(--surface-2);border:1px solid var(--border-input);width:100%;color:var(--text);border-radius:8px;padding:8px 32px;font-size:13px;transition:border-color .15s,background .15s}.search-input:focus{border-color:var(--accent);background:var(--surface-1);outline:none}.search-clear{background:var(--surface-3);width:18px;height:18px;color:var(--text-mute);border-radius:50%;flex-shrink:0;place-items:center;transition:background .12s,color .12s;display:grid;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-clear:hover{background:var(--border-strong);color:var(--text)}.sidebar-nav-fixed{border-bottom:1px solid var(--border);flex-shrink:0;padding:4px 8px 8px}.sidebar-nav-cats{flex:1;padding:4px 8px 8px;overflow-y:auto}.nav-section{margin-top:10px}.nav-separator{border-top:1px solid var(--border);margin:8px 10px}.nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);justify-content:space-between;align-items:center;gap:6px;padding:8px 10px 4px;font-size:10px;font-weight:600;display:flex}.nav-item{width:100%;color:var(--text-dim);text-align:left;border-radius:8px;align-items:center;gap:10px;padding:7px 10px;font-size:13px;transition:background .12s,color .12s;display:flex;position:relative}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item .icon{color:currentColor;opacity:.85;flex-shrink:0}.nav-item .label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.nav-item.active{background:var(--accent-soft);color:var(--accent-text)}.nav-item.active:before{content:"";background:var(--accent);border-radius:2px;width:2.5px;position:absolute;top:8px;bottom:8px;left:0}.category-list .nav-item .cat-icon{background:var(--surface-3);border-radius:6px;flex-shrink:0;place-items:center;width:22px;height:22px;font-size:12px;display:grid}.miniplayer{background:linear-gradient(180deg, var(--surface-2), var(--surface-1));border:1px solid var(--border);box-shadow:var(--shadow-2);border-radius:12px;margin:0 8px 8px;transition:transform .18s,border-color .18s;overflow:hidden}.miniplayer:hover{border-color:var(--border-strong);transform:translateY(-1px)}.miniplayer-thumb{aspect-ratio:16/9;cursor:pointer;background:#000;position:relative;overflow:hidden}.miniplayer-live{color:#fff;letter-spacing:.06em;background:#dc2626f2;border-radius:4px;align-items:center;gap:4px;padding:3px 6px;font-size:10px;font-weight:700;display:flex;position:absolute;top:8px;left:8px}.miniplayer-live:before{content:"";background:#fff;border-radius:50%;width:6px;height:6px;animation:1.6s ease-in-out infinite livePulse}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.4}}.miniplayer-expand{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;opacity:0;background:#0000008c;border-radius:6px;padding:4px;transition:opacity .15s;position:absolute;top:6px;right:6px}.miniplayer:hover .miniplayer-expand{opacity:1}.miniplayer-info{align-items:center;gap:8px;padding:8px 10px 10px;display:flex}.miniplayer-info .meta{flex:1;min-width:0}.miniplayer-info .title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.miniplayer-info .sub{color:var(--text-mute);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.icon-btn{background:var(--surface-3);width:28px;height:28px;color:var(--text);border-radius:6px;flex-shrink:0;place-items:center;transition:background .12s,color .12s;display:grid}.icon-btn:hover{background:var(--border-strong)}.icon-btn.danger:hover{color:var(--danger);background:#ef444433}.account-chip{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;text-align:left;border-radius:10px;align-items:center;gap:10px;margin:0 8px 12px;padding:8px 10px;transition:border-color .15s,background .15s;display:flex;position:relative}.account-chip:hover{border-color:var(--border-strong);background:var(--surface-hover)}.avatar{background:linear-gradient(135deg, var(--accent), #38bdf8);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:13px;font-weight:600;display:grid}.account-chip .meta{flex:1;min-width:0}.account-chip .alias{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.account-chip .status{color:var(--text-mute);align-items:center;gap:5px;font-size:11px;display:flex}.dot{background:var(--success);border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 2px #22c55e2e}.secondary-sidebar{background:var(--surface-1);border-right:1px solid var(--border);flex-direction:column;grid-row:1;min-width:0;display:flex;overflow:hidden}.sec-header{border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 14px 10px}.sec-header-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);margin-bottom:6px;font-size:10px;font-weight:600}.sec-header-title{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex;overflow:hidden}.season-tabs{border-bottom:1px solid var(--border);flex-shrink:0;gap:4px;padding:10px 14px;display:flex;overflow-x:auto}.season-tab{background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);white-space:nowrap;border-radius:6px;padding:5px 10px;font-size:12px;font-weight:500;transition:all .12s}.season-tab:hover{color:var(--text);border-color:var(--border-strong)}.season-tab.active{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-text)}.sec-list{flex:1;padding:6px;overflow-y:auto}.episode-row{cursor:pointer;text-align:left;border-radius:8px;gap:10px;width:100%;padding:10px;transition:background .12s;display:flex}.episode-row:hover{background:var(--surface-hover)}.episode-row.playing{background:var(--accent-soft)}.episode-row.playing .ep-num{background:var(--accent);color:#fff}.ep-num{background:var(--surface-3);width:32px;height:32px;color:var(--text-dim);font-family:var(--font-mono);border-radius:6px;flex-shrink:0;place-items:center;font-size:12px;font-weight:600;display:grid}.episode-row .meta{flex:1;min-width:0}.episode-row .title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex;overflow:hidden}.episode-row.playing .title{color:var(--accent-text)}.episode-row .meta-line{color:var(--text-mute);font-size:11px;font-family:var(--font-mono);margin-top:2px}.sec-channel-row{cursor:pointer;text-align:left;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .12s;display:flex}.sec-channel-row:hover{background:var(--surface-hover)}.sec-channel-row.playing{background:var(--accent-soft)}.sec-channel-row.playing .name{color:var(--accent-text)}.sec-channel-row .channel-logo{background:var(--surface-3);border-radius:6px;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid;overflow:hidden}.sec-channel-row .meta{flex:1;min-width:0}.sec-channel-row .name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sec-movie-row{cursor:pointer;text-align:left;border-radius:8px;gap:10px;width:100%;padding:8px;transition:background .12s;display:flex}.sec-movie-row:hover{background:var(--surface-hover)}.sec-movie-row.playing{background:var(--accent-soft)}.sec-movie-row.playing .title{color:var(--accent-text)}.sec-movie-row .mini-poster{background:var(--surface-3);border-radius:6px;flex-shrink:0;place-items:center;width:48px;height:72px;display:grid;overflow:hidden}.sec-movie-row .mini-poster img{object-fit:cover;width:100%;height:100%}.sec-movie-row .meta{flex:1;min-width:0}.sec-movie-row .title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.sec-movie-row .sub{color:var(--text-mute);font-size:11px;font-family:var(--font-mono);margin-top:4px}.main{background:var(--bg);flex-direction:column;grid-row:1;min-width:0;display:flex;position:relative;overflow:hidden}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);z-index:10;background:#0a0a0ad9;flex-shrink:0;align-items:center;gap:14px;padding:0 20px;display:flex}.topbar-mobile-brand{align-items:center;gap:8px;display:none}.topbar-mobile-brand img{border-radius:6px;width:26px;height:26px}.topbar-mobile-brand .name{font-size:14px;font-weight:600}.crumbs{align-items:center;gap:8px;min-width:0;display:flex}.crumb{color:var(--text-mute);white-space:nowrap;font-size:13px}.crumb.current{color:var(--text);font-weight:500}.crumb-sep{color:var(--text-mute);opacity:.5}.crumb-back{color:var(--text-mute);align-items:center;gap:4px;transition:color .12s;display:flex}.crumb-back:hover{color:var(--text)}.mobile-back-btn{display:none}@media (max-width:1023px){.mobile-back-btn{display:flex}}.topbar .spacer{flex:1}.topbar .actions{align-items:center;gap:8px;display:flex}.topbar-btn{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:7px 10px;font-size:12.5px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.topbar-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--border-strong)}.topbar-btn.icon-only{padding:7px}.topbar-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.topbar-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.topbar-btn.now-playing{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-text)}.mobile-fab{bottom:calc(var(--bottombar-h) + 12px);z-index:50;background:var(--surface-2);border:1px solid var(--border-strong);width:44px;height:44px;color:var(--text-dim);box-shadow:var(--shadow-pop);border-radius:12px;justify-content:center;align-items:center;line-height:0;transition:color .12s,background .12s;display:none;position:fixed;left:12px}.mobile-fab:hover{color:var(--text);background:var(--surface-3)}.sidebar-backdrop{z-index:99;background:#0009;display:none;position:fixed;inset:0}@media (max-width:1023px){.mobile-fab{display:flex}.sidebar-backdrop{display:block}.sidebar.mobile-open,.sidebar.mobile-closing{z-index:100;width:280px;position:fixed;top:0;bottom:0;left:0;box-shadow:4px 0 24px #00000080;display:flex!important}.sidebar.mobile-open{animation:.22s slideInLeft}.sidebar.mobile-closing{animation:.22s forwards slideOutLeft}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideOutLeft{0%{transform:translate(0)}to{transform:translate(-100%)}}.mobile-search-overlay{top:var(--topbar-h);background:var(--surface-1);border-bottom:1px solid var(--border);z-index:9;padding:12px 16px;position:absolute;left:0;right:0}.content{flex:1;padding:22px 28px 60px;overflow-y:auto}.section-head{flex-wrap:wrap;align-items:flex-end;gap:14px;margin-bottom:18px;display:flex}.section-head h2{letter-spacing:-.015em;margin:0;font-size:22px;font-weight:600}.section-head .count{color:var(--text-mute);font-family:var(--font-mono);padding-bottom:4px;font-size:12px}.section-head .right{align-items:center;gap:8px;margin-left:auto;display:flex}.grid-posters{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:18px;display:grid}.card-poster{cursor:pointer;border-radius:10px;transition:transform .18s;position:relative}.card-poster:hover{transform:translateY(-4px)}.card-poster .poster{aspect-ratio:2/3;background:var(--surface-2);border-radius:10px;position:relative;overflow:hidden;box-shadow:0 4px 14px #0006}.poster-fallback{color:#fffffff2;letter-spacing:-.02em;place-items:center;font-size:36px;font-weight:700;display:grid;position:absolute;inset:0}.play-overlay-btn{background:var(--accent);color:#fff;opacity:0;width:50px;height:50px;box-shadow:0 8px 30px var(--accent-glow);z-index:3;border-radius:50%;place-items:center;transition:opacity .18s,transform .18s;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.9)}.card-poster:hover .play-overlay-btn{opacity:1;transform:translate(-50%,-50%)scale(1)}.fav-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;opacity:0;z-index:2;background:#0009;border-radius:8px;place-items:center;width:30px;height:30px;transition:opacity .15s;display:grid;position:absolute;top:8px;right:8px}.fav-btn.active,.card-poster:hover .fav-btn{opacity:1}.fav-btn.active{color:var(--accent-text)}.card-meta{margin-top:8px;padding:0 2px}.card-actions{gap:4px;margin-top:6px;display:flex}.card-btn{height:26px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:5px;flex:1;place-items:center;font-size:11px;font-weight:600;transition:background .12s,color .12s;display:grid}.card-btn:hover{background:var(--surface-3);color:var(--text)}.card-btn.active{color:var(--accent-text)}.card-meta .title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.card-meta .sub{color:var(--text-mute);align-items:center;gap:8px;margin-top:2px;font-size:11.5px;display:flex}.rating{color:#fcd34d;font-family:var(--font-mono);align-items:center;gap:2px;font-weight:500;display:inline-flex}.badge-new{background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.06em;z-index:2;border-radius:4px;padding:3px 6px;font-size:10px;font-weight:700;position:absolute;top:8px;left:8px}.channel-row{background:var(--surface-1);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:10px;transition:background .12s,border-color .12s;display:flex}.channel-row:hover{background:var(--surface-2);border-color:var(--border-strong)}.channel-row.playing{border-color:var(--accent);background:var(--accent-soft)}.channel-logo{color:#fff;background:var(--surface-3);border-radius:8px;flex-shrink:0;place-items:center;width:44px;height:44px;font-size:16px;font-weight:700;display:grid;position:relative;overflow:hidden}.channel-row .meta{flex:1;min-width:0}.channel-row .name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:13.5px;font-weight:600;display:flex;overflow:hidden}.channel-row .epg{color:var(--text-mute);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:12px;overflow:hidden}.live-pill{color:#fecaca;letter-spacing:.05em;background:#dc262638;border-radius:3px;flex-shrink:0;align-items:center;gap:3px;padding:2px 5px;font-size:9.5px;font-weight:700;display:inline-flex}.live-pill:before{content:"";background:var(--danger);border-radius:50%;width:5px;height:5px;animation:1.6s ease-in-out infinite livePulse}.channel-row .actions{opacity:0;align-items:center;gap:4px;transition:opacity .12s;display:flex}.channel-row:hover .actions,.channel-row.playing .actions,.channel-row.is-focused .actions{opacity:1}.row-btn{width:32px;height:32px;color:var(--text-dim);border-radius:6px;place-items:center;transition:background .12s,color .12s;display:grid}.row-btn:hover{background:var(--surface-3);color:var(--text)}.row-btn.play{background:var(--accent);color:#fff}.row-btn.play:hover{background:var(--accent-hover);color:#fff}.row-btn.active{color:var(--accent-text)}.channels-list{flex-direction:column;gap:6px;display:flex}.series-detail{grid-template-columns:280px 1fr;align-items:start;gap:32px;display:grid}.series-cover-col{position:sticky;top:0}.series-cover{aspect-ratio:2/3;background:var(--surface-2);border-radius:14px;width:100%;margin-bottom:18px;position:relative;overflow:hidden;box-shadow:0 8px 40px #0009}.series-cover img{object-fit:cover;width:100%;height:100%}.series-title{letter-spacing:-.02em;overflow-wrap:break-word;margin:0 0 6px;font-size:22px;font-weight:700}.series-meta-line{color:var(--text-mute);font-size:13px;font-family:var(--font-mono);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.series-actions{gap:8px;margin-bottom:18px;display:flex}.series-actions .btn-play{background:var(--accent);color:#fff;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-size:13px;font-weight:600;transition:background .12s;display:inline-flex}.series-actions .btn-play:hover{background:var(--accent-hover)}.series-actions .btn-secondary{background:var(--surface-2);border:1px solid var(--border);width:40px;color:var(--text-dim);border-radius:8px;place-items:center;transition:all .12s;display:grid}.series-actions .btn-secondary:hover{background:var(--surface-3);color:var(--text);border-color:var(--border-strong)}.series-actions .btn-secondary.active{color:var(--accent-text);border-color:var(--accent-soft-2);background:var(--accent-soft)}.series-synopsis{color:var(--text-dim);font-size:13.5px;line-height:1.6}.episodes-panel{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;overflow:hidden}.episodes-panel-head{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding:14px 18px;display:flex}.episodes-panel-head h3{margin:0;font-size:15px;font-weight:600}.episodes-panel-head .count{color:var(--text-mute);font-family:var(--font-mono);font-size:12px}.season-tabs-panel{border-bottom:1px solid var(--border);gap:4px;padding:12px 18px;display:flex;overflow-x:auto}.episodes-list{max-height:600px;padding:6px;overflow-y:auto}.episode-row.big{gap:14px;padding:12px}.episode-row.big .ep-num{background:linear-gradient(135deg, var(--surface-3), var(--surface-2));border-radius:8px;width:52px;height:76px;font-size:14px}.episode-row.big .title{white-space:normal;font-size:14px;font-weight:600;overflow:visible}.episode-row.big .description{color:var(--text-mute);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.episode-row.big .actions{flex-shrink:0;gap:4px;display:flex}@media (max-width:1023px){.series-detail{grid-template-columns:1fr;gap:20px}.series-cover-col{position:relative}.series-cover{max-width:280px;margin:0 auto 18px}}@media (max-width:768px){.series-cover{max-width:200px;margin:0 auto 18px}}.player-wrap{background:#000;flex-direction:column;grid-area:1/3;display:flex;position:relative;overflow:hidden}.app.fullwindow .player-wrap{grid-area:1/1}@media (max-width:1023px){.player-wrap{grid-column:1}}.player-header{z-index:4;color:#fff;background:linear-gradient(#000000bf,#0000);align-items:center;gap:12px;padding:16px 22px;transition:opacity .3s;display:flex;position:absolute;top:0;left:0;right:0}.player-header .title{font-size:16px;font-weight:600}.player-header .sub{color:#ffffffb3;margin-top:2px;font-size:12px}.player-header .right{align-items:center;gap:8px;margin-left:auto;display:flex}.player-header .meta-block{align-items:center;gap:12px;min-width:0;display:flex}.player-header .meta-block>div{min-width:0}.player-header .title,.player-header .sub{white-space:nowrap;text-overflow:ellipsis;max-width:400px;overflow:hidden}.type-pill{text-transform:uppercase;letter-spacing:.08em;color:#fff;background:#ffffff24;border-radius:4px;padding:4px 8px;font-size:10px;font-weight:700}.player-stage{background:#000;flex:1;min-height:0;position:relative;overflow:hidden}.player-stage video{object-fit:contain;width:100%;height:100%}.player-buffering-indicator{z-index:5;color:#ffffffd9;background:#000000b3;border-radius:8px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;display:flex;position:absolute;top:16px;left:16px}.player-loading-overlay{z-index:20;pointer-events:none;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.player-error-overlay{text-align:center;z-index:20;pointer-events:auto;background:#000000f2;flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex;position:absolute;inset:0}.subtitle-overlay{text-align:center;pointer-events:none;z-index:10;padding:0 20px;display:none;position:absolute;bottom:60px;left:0;right:0}.subtitle-overlay span{color:#fff;white-space:pre-wrap;background:#000c;border-radius:4px;padding:4px 12px;font-size:18px;line-height:1.5}.subtitle-dialog{z-index:99999;background:var(--surface-2);border:1px solid var(--border-strong);box-shadow:var(--shadow-pop);border-radius:10px;flex-direction:column;min-width:260px;max-width:320px;display:flex;position:fixed;overflow:hidden}.plyr{width:100%;height:100%}.plyr--video{background:#000;height:100%}.plyr__video-wrapper{height:100%}.plyr__controls{background:linear-gradient(#0000,#000c)!important}.plyr--full-ui input[type=range]{color:var(--accent)}.plyr__control--overlaid{background:var(--accent)!important}.plyr__control--overlaid:hover{background:var(--accent-hover)!important}.bottom-bar{height:var(--bottombar-h);border-top:1px solid var(--border);background:var(--surface-1);z-index:30;flex-shrink:0;display:none}.bottom-bar-btn{color:var(--text-mute);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:10.5px;font-weight:500;transition:color .12s;display:flex}.bottom-bar-btn.active{color:var(--accent-text)}.mobile-mini-player{background:var(--surface-2);border-top:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:8px 12px;display:none;position:relative}.mobile-mini-player .thumb{background:#000;border-radius:6px;flex-shrink:0;width:44px;height:44px;overflow:hidden}.mobile-mini-player .meta{flex:1;min-width:0}.mobile-mini-player .title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.mobile-mini-player .sub{color:var(--text-mute);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}@media (max-width:1023px){.bottom-bar,.topbar-mobile-brand{display:flex}.topbar .crumbs{display:none}.mobile-only{display:flex!important}.desktop-only{display:none!important}}@media (min-width:1024px){.mobile-only{display:none!important}}.login-screen{background:radial-gradient(ellipse at top, #0ea5e912 0%, transparent 60%), var(--bg);z-index:100;grid-column:1/-1;place-items:center;padding:40px 16px;display:grid;position:fixed;inset:0;overflow-y:auto}.login-card{background:var(--surface-1);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow-pop);border-radius:16px;padding:28px;position:relative}.login-settings-btn{width:32px;height:32px;color:var(--text-mute);border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;top:12px;right:12px}.login-settings-btn:hover{background:var(--surface-2);color:var(--text)}.login-brand{text-align:center;margin-bottom:22px}.login-brand img{border-radius:14px;width:60px;height:60px;margin:0 auto 12px;box-shadow:0 8px 30px #0ea5e94d}.login-brand h1{letter-spacing:-.02em;margin:0 0 4px;font-size:22px;font-weight:600}.login-brand p{color:var(--text-mute);margin:0;font-size:12.5px}.field{margin-bottom:12px}.field label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.input,.select{background:var(--surface-2);border:1px solid var(--border-input);width:100%;color:var(--text);border-radius:8px;padding:9px 12px;font-size:13px}.input:focus,.select:focus{border-color:var(--accent);background:var(--surface-1);outline:none}.btn-primary{background:var(--accent);color:#fff;border-radius:8px;width:100%;padding:10px;font-size:13.5px;font-weight:600;transition:background .12s}.btn-primary:hover{background:var(--accent-hover)}.btn-inline{background:var(--accent);color:#fff;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:12.5px;font-weight:600;line-height:1;transition:background .12s,transform .12s;display:inline-flex}.btn-inline:hover{background:var(--accent-hover);transform:translateY(-1px)}.divider{color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:10px;margin:16px 0;font-size:11px;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.saved-account-row{margin-bottom:8px;position:relative}.saved-account{background:var(--surface-2);border:1px solid var(--border);text-align:left;border-radius:10px;align-items:center;gap:10px;width:100%;margin-bottom:0;padding:10px;transition:border-color .12s,background .12s;display:flex}.saved-account:hover{border-color:var(--accent);background:var(--surface-hover)}.saved-account-row:hover .kbd-chip{opacity:0}.saved-account .meta{flex:1;min-width:0}.saved-account .alias{font-size:13px;font-weight:600}.saved-account .username{color:var(--text-mute);font-size:11px;font-family:var(--font-mono)}.saved-account-delete{opacity:0;pointer-events:none;color:var(--text-mute);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;line-height:1;transition:opacity .12s,color .12s,background .12s;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.saved-account-row:hover .saved-account-delete{opacity:1;pointer-events:auto}.saved-account-delete:hover:not(.confirming){color:var(--text);background:var(--surface-3)}.saved-account-delete.confirming{opacity:1;pointer-events:auto;color:#ef4444;background:#ef44441a}.popover{z-index:100;background:var(--surface-2);border:1px solid var(--border-strong);box-shadow:var(--shadow-pop);border-radius:12px;min-width:0;padding:6px;position:absolute;overflow:hidden}.popover-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:6px;padding:10px 12px;display:flex}.popover-header .meta{flex:1;min-width:0}.popover-header .alias{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.popover-header .username{color:var(--text-mute);font-size:11.5px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;overflow:hidden}.popover-section{border-bottom:1px solid var(--border);padding:8px 10px}.popover-section:last-child{border-bottom:none}.popover-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute);margin-bottom:6px;font-size:10px;font-weight:600}.popover-item{width:100%;color:var(--text-dim);text-align:left;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;transition:background .12s,color .12s;display:flex}.popover-item:hover{background:var(--surface-hover);color:var(--text)}.popover-item.danger{color:var(--danger)}.popover-item.danger:hover{background:#ef44441f}.popover-radio{text-align:left;cursor:pointer;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .12s;display:flex}.popover-radio:hover{background:var(--surface-hover)}.popover-radio .radio-dot{border:1.5px solid var(--border-strong);border-radius:50%;flex-shrink:0;place-items:center;width:16px;height:16px;transition:border-color .12s;display:grid}.popover-radio.active .radio-dot{border-color:var(--accent)}.popover-radio.active .radio-dot:after{content:"";background:var(--accent);border-radius:50%;width:8px;height:8px}.popover-radio .label-text{flex:1;min-width:0;font-size:13px}.popover-radio .label-sub{color:var(--text-mute);font-size:11px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;overflow:hidden}.kbd-chip{font-family:var(--font-mono);background:var(--surface-3);color:var(--text-mute);border-radius:4px;margin-left:auto;padding:2px 5px;font-size:10px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#000000bf;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--surface-1);border:1px solid var(--border-strong);box-shadow:var(--shadow-pop);border-radius:16px;flex-direction:column;width:100%;max-width:880px;height:min(82vh,720px);display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:16px 22px;display:flex}.modal-header h2{letter-spacing:-.01em;margin:0;font-size:16px;font-weight:600}.modal-header .close-btn{width:32px;height:32px;color:var(--text-mute);border-radius:8px;place-items:center;margin-left:auto;transition:all .12s;display:grid}.modal-header .close-btn:hover{background:var(--surface-hover);color:var(--text)}.modal-body{flex:1;grid-template-columns:220px 1fr;min-height:0;display:grid;overflow:hidden}.update-modal{max-width:480px;height:auto;max-height:82vh}.update-modal .settings-content{max-height:calc(82vh - 65px);padding:20px 24px 24px}.settings-tabs{border-right:1px solid var(--border);background:var(--surface-1);padding:12px;overflow-y:auto}.settings-nav-toggle{display:none}.settings-nav-pills{display:contents}.settings-nav-chevron{color:var(--text-mute);margin-left:auto;transition:transform .18s}.settings-nav-chevron.open{transform:rotate(180deg)}.settings-tab{width:100%;color:var(--text-dim);text-align:left;border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;font-size:13px;transition:all .12s;display:flex}.settings-tab:hover{background:var(--surface-hover);color:var(--text)}.settings-tab.active{background:var(--accent-soft);color:var(--accent-text)}.settings-content{padding:24px 28px 32px;overflow-y:auto}.settings-section{margin-bottom:30px}.settings-section:last-child{margin-bottom:0}.settings-section h3{letter-spacing:-.01em;margin:0 0 4px;font-size:15px;font-weight:600}.settings-section .section-desc{color:var(--text-mute);margin:0 0 16px;font-size:12.5px}.form-row{border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:12px 0;display:flex}.form-row:last-child{border-bottom:none}.form-row .field-info{flex:1;min-width:0}.form-row .field-info label{color:var(--text);margin-bottom:2px;font-size:13px;font-weight:500;display:block}.form-row .field-info .hint{color:var(--text-mute);font-size:12px}.form-row .field-control{flex-shrink:0;min-width:200px}.form-row.stacked{flex-direction:column;align-items:stretch;gap:8px}.form-row.stacked .field-control{width:100%;min-width:0}.switch{background:var(--surface-3);border:1px solid var(--border-strong);cursor:pointer;border-radius:999px;flex-shrink:0;width:36px;height:20px;transition:background .18s,border-color .18s;position:relative}.switch:after{content:"";background:var(--text-mute);border-radius:50%;width:14px;height:14px;transition:transform .18s,background .18s;position:absolute;top:2px;left:2px}.switch.on{background:var(--accent-soft);border-color:var(--accent)}.switch.on:after{background:var(--accent);transform:translate(16px)}.form-row.row-disabled{opacity:.4;pointer-events:none}.pill-group{flex-wrap:wrap;gap:6px;display:flex}.pill{background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:999px;padding:5px 10px;font-size:12px;transition:all .12s}.pill:hover{color:var(--text);border-color:var(--border-strong)}.pill.active{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-text)}.url-list{border:1px solid var(--border);background:var(--surface-2);border-radius:10px;overflow:hidden}.url-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 12px;transition:background .12s;display:flex}.url-item:last-child{border-bottom:none}.url-item:hover{background:var(--surface-hover)}.url-item.selected{background:var(--accent-soft)}.url-item.selected .url-label{color:var(--accent-text)}.url-item .url-radio-wrap{cursor:pointer;flex:1;align-items:center;gap:12px;min-width:0;display:flex}.url-item .url-meta{flex:1;min-width:0}.url-item .url-label{font-size:13px;font-weight:500}.url-item .url-url{color:var(--text-mute);font-size:11px;font-family:var(--font-mono);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.url-item .url-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-add-url{background:var(--surface-2);border:1px dashed var(--border-strong);width:100%;color:var(--text-dim);border-radius:8px;justify-content:center;align-items:center;gap:6px;margin-top:8px;padding:9px;font-size:12.5px;transition:all .12s;display:flex}.btn-add-url:hover{background:var(--surface-hover);color:var(--text);border-color:var(--accent)}.about-card{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;align-items:center;gap:16px;padding:18px;display:flex}.about-card img{border-radius:12px;flex-shrink:0;width:56px;height:56px;box-shadow:0 4px 14px #0ea5e940}.about-card .meta h4{margin:0 0 4px;font-size:16px;font-weight:600}.about-card .meta p{color:var(--text-mute);font-size:12.5px;font-family:var(--font-mono);margin:0}.empty-state{text-align:center;color:var(--text-mute);flex-direction:column;justify-content:center;align-items:center;padding:80px 20px;display:flex}.empty-state .icon-wrap{background:var(--surface-2);border:1px solid var(--border);border-radius:14px;place-items:center;width:64px;height:64px;margin-bottom:14px;display:grid}.empty-state h3{color:var(--text);margin:0 0 4px;font-size:16px;font-weight:600}.empty-state p{margin:0;font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes marquee{0%{transform:translate(0)}40%{transform:translateX(calc(-1 * var(--marquee-distance,0px)))}50%{transform:translateX(calc(-1 * var(--marquee-distance,0px)))}90%{transform:translate(0)}to{transform:translate(0)}}.spinner{border:2px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.mini-spinner{border:2px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}.loading-overlay{color:var(--text-mute);flex-direction:column;align-items:center;gap:12px;padding:60px 20px;font-size:13px;display:flex}.hover-scroll{position:relative;overflow:hidden}.hover-scroll>*{white-space:nowrap;display:inline-block}.hover-scroll:hover>*,.card-poster:hover .hover-scroll>*{animation:marquee var(--marquee-duration,4s) linear infinite}.channel-row.is-focused .hover-scroll>*,.card-poster.is-focused .hover-scroll>*{animation:marquee var(--marquee-duration,5s) linear infinite}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--surface-2);border:1px solid var(--border-strong);box-shadow:var(--shadow-pop);pointer-events:all;border-radius:10px;align-items:center;gap:10px;max-width:320px;padding:12px 14px;font-size:13px;animation:.18s ease-out fadeIn;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.warning{border-left:3px solid var(--warning)}.toast.info{border-left:3px solid var(--accent)}.update-notes{color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;max-height:220px;padding:10px 12px;font-size:13px;overflow:auto}.update-notes h3,.update-notes h4,.update-notes h5{color:var(--text);margin:0 0 8px;font-size:13px;font-weight:700}.update-notes h4,.update-notes h5{color:var(--text-dim);margin-top:12px}.update-notes p,.update-notes ul{margin:0 0 10px}.update-notes>:last-child{margin-bottom:0}.update-notes ul{padding-left:18px}.update-notes li{margin-bottom:5px}.update-notes code{font-family:var(--font-mono);color:var(--accent-text);background:var(--surface-3);border-radius:4px;padding:1px 4px;font-size:12px}.update-notes strong{color:var(--text)}.update-dot{background:var(--danger);border:2px solid var(--surface-1);border-radius:50%;width:8px;height:8px;position:absolute;top:-3px;right:-3px}.fade-in{animation:.18s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.animate-spin{animation:.8s linear infinite spin}.animate-spin>*{display:block}@media (max-width:1023px){.content{padding:18px 16px 80px;overflow-x:hidden}.section-head h2{font-size:19px}.grid-posters{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px}.live-pill{display:none}.channel-row{flex-wrap:wrap}.channel-row .actions{opacity:1;pointer-events:none;justify-content:flex-start;width:100%;max-height:0;padding-left:56px;transition:max-height .18s;overflow:hidden}.channel-row:hover .actions,.channel-row.playing .actions,.channel-row.is-focused .actions{pointer-events:auto;max-height:44px}.channel-row .row-btn.play{min-width:44px}.card-poster,.card-poster .poster{touch-action:manipulation}.card-poster:hover{transform:none}.card-poster:hover .play-overlay-btn,.card-poster:hover .fav-btn{opacity:0}.card-poster .play-overlay-btn,.card-poster .fav-btn:not(.active){pointer-events:none}.card-poster.is-focused .fav-btn{opacity:1;pointer-events:auto}.card-poster.is-focused .play-overlay-btn{opacity:1;transform:translate(-50%,-50%)scale(1)}.player-header{padding:12px 14px}.modal-body{grid-template-rows:auto 1fr;grid-template-columns:1fr}.settings-tabs{border-right:none;border-bottom:1px solid var(--border);overflow-x:unset;flex-direction:column;gap:4px;padding:10px 14px;display:flex}.settings-tab{width:100%;padding:8px 12px}.settings-nav-toggle{width:100%;color:var(--accent-text);background:var(--accent-soft);border-radius:8px;align-items:center;gap:10px;margin-bottom:4px;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.settings-nav-pills{opacity:1;flex-direction:column;gap:4px;max-height:300px;transition:max-height .22s,opacity .18s;display:flex;overflow:hidden}.settings-nav-pills.collapsed{opacity:0;pointer-events:none;max-height:0}.form-row{flex-direction:column;align-items:stretch;gap:8px}.form-row .field-control{width:100%;min-width:0}.modal{max-height:95vh}.modal-backdrop{padding:8px}.toast-container{bottom:80px;right:12px}}
