:root{color-scheme:light;--bg:#F5F7FA;--panel:#F3F5F8;--panel-light:#F6F8FC;--panel-dark:rgba(255,255,255,.92);--rail:rgba(255,255,255,.85);--text:#111111;--text-dim:#444444;--muted:#6B7280;--accent:#0A84FF;--accent-soft:rgba(10,132,255,.18);--accent-glow:rgba(10,132,255,.35);--chip-bg:rgba(0,0,0,.04);--chip-on-bg:rgba(10,132,255,.2);--chip-on-border:rgba(10,132,255,.65);--blue:var(--accent);--glass: rgba(255,255,255,.85);--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.12);--focus-ring:0 0 0 2px rgba(10,132,255,.35);--shadow-pop:0 16px 32px rgba(0,0,0,.18);--radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--font-xs:clamp(11px, .73vw, 12px);--font-sm:clamp(12px, .82vw, 13px);--font-md:clamp(14px, .9vw, 15px);--font-lg:clamp(18px, 1.15vw, 20px);--font-xl:clamp(22px, 1.6vw, 26px);--font-display:clamp(28px, 2.4vw, 36px)}:root[data-layout-density=compact]{--space-1:3px;--space-2:6px;--space-3:10px;--space-4:14px;--space-5:18px;--space-6:22px;--font-xs:clamp(10px, .7vw, 11px);--font-sm:clamp(11px, .78vw, 12px);--font-md:clamp(13px, .86vw, 14px);--font-lg:clamp(16px, 1.05vw, 18px);--font-xl:clamp(20px, 1.45vw, 24px);--font-display:clamp(24px, 2.1vw, 32px)}:root[data-theme=dark]{color-scheme:dark;--bg:#0b0e12;--panel:#0e131a;--panel-light:#1a2330;--panel-dark:#0a1018;--rail:#070c12;--text:#e5e7eb;--text-dim:rgba(229,231,235,.72);--muted:#aab3bf;--accent:#4da3ff;--accent-soft:rgba(77,163,255,.18);--accent-glow:rgba(77,163,255,.5);--chip-bg:rgba(255,255,255,.08);--chip-on-bg:rgba(77,163,255,.25);--chip-on-border:rgba(77,163,255,.65);--blue:var(--accent);--glass: rgba(255,255,255,.06);--border: rgba(255,255,255,.08);--border-strong: rgba(255,255,255,.14)}:root[data-theme=light]{color-scheme:light;--bg:#F5F7FA;--panel:#F3F5F8;--panel-light:#F6F8FC;--panel-dark:rgba(255,255,255,.92);--rail:rgba(255,255,255,.85);--text:#111111;--text-dim:#444444;--muted:#6B7280;--accent:#0A84FF;--accent-soft:rgba(10,132,255,.18);--accent-glow:rgba(10,132,255,.35);--chip-bg:rgba(0,0,0,.04);--chip-on-bg:rgba(10,132,255,.2);--chip-on-border:rgba(10,132,255,.65);--blue:var(--accent);--glass: rgba(255,255,255,.85);--border: rgba(0,0,0,.08);--border-strong: rgba(0,0,0,.12);--focus-ring:0 0 0 2px rgba(10,132,255,.35);--shadow-pop:0 16px 32px rgba(0,0,0,.18)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;transition:background-color .24s ease,color .24s ease;letter-spacing:.01em;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;overscroll-behavior:none;text-rendering:optimizeLegibility;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}:root[data-pwa=true] body{touch-action:manipulation}@supports (-webkit-touch-callout: none){:root[data-pwa=true] body{-webkit-touch-callout:none;-webkit-user-select:none}:root[data-pwa=true] input,:root[data-pwa=true] textarea{-webkit-user-select:text}}:root[data-motion=reduced] *,:root[data-motion=reduced] *:before,:root[data-motion=reduced] *:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}[data-input-method=pointer] :focus-visible{box-shadow:none}[data-input-method=keyboard] .focus-ring{box-shadow:var(--focus-ring)}[data-input-method=remote]{cursor:none}[data-input-method=remote] *{cursor:none!important;pointer-events:none!important}[data-input-method=remote] .allow-pointer{cursor:auto!important;pointer-events:auto!important}.surface{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md)}.surface--light{background:var(--panel-light)}.surface--dark{background:var(--panel-dark)}.text-dim{color:var(--text-dim)}.text-muted{color:var(--muted)}.topbar{position:sticky;top:0;z-index:12;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:color-mix(in srgb,var(--panel) 82%,transparent);border-bottom:1px solid var(--border);padding:var(--space-2) var(--space-3);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.badge-theme{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em}.shell{display:grid;grid-template-columns:260px 1fr 420px;gap:16px;height:100dvh;padding:16px}.col{background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}.col .header{padding:12px 14px;border-bottom:1px solid var(--border);font-weight:700;letter-spacing:.3px}.scroll{flex:1;overflow:auto;padding:8px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.vrow{padding:6px}.vrow-inner{display:flex;align-items:center;gap:12px;padding:10px;border-radius:10px;border:1px solid var(--border);background:#ffffff08;cursor:pointer}.vrow-inner:hover{background:#ffffff0f}.vrow-inner.focus{box-shadow:0 0 0 2px #fff3,0 0 20px #4da3ff40}.tv-logo{width:48px;height:48px;border-radius:8px;overflow:hidden;background:#ffffff14;display:grid;place-items:center}.tv-logo img{width:100%;height:100%;object-fit:cover}.tv-name{font-weight:700}.tv-desc{font-size:12px;color:var(--muted)}.actions{margin-left:auto;display:flex;gap:8px}button{background:var(--glass);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;cursor:pointer}button.play{background:var(--blue);border-color:transparent;color:#111;font-weight:800}.update-banner{position:fixed;left:16px;right:16px;bottom:calc(16px + env(safe-area-inset-bottom));background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;box-shadow:var(--shadow-pop);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);z-index:1000}.update-banner__actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.update-banner__primary{background:var(--blue);border-color:transparent;color:#111;font-weight:700}.install-guide{position:relative;margin:8px 0 12px;padding:10px 12px;border-radius:12px;background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-pop)}.install-guide__title{font-weight:800;font-size:14px;margin-bottom:4px}.install-guide__body{font-size:12.5px;color:var(--text-dim)}.install-guide__close{position:absolute;top:8px;right:8px;padding:4px 6px;border-radius:8px}.miniplayer{position:relative}.miniplayer video{width:100%;aspect-ratio:16/9;background:#000;display:block}.card{padding:12px}.epg-list{display:flex;flex-direction:column;gap:8px}.epg-item{padding:10px;border-radius:10px;border:1px solid var(--border);background:#ffffff08;display:flex;gap:12px}.epg-time{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:var(--muted);min-width:64px}.fs-stage{position:relative;width:100%;height:100%;background:#000}.fs-video{position:absolute;top:0;right:0;bottom:0;left:0;background:#000}.fs-video video{width:100%;height:100%;object-fit:contain;background:#000}.drawer{position:absolute;top:0;left:0;width:520px;max-width:33vw;height:100%;background:#0a0d12f5;border-right:1px solid var(--border);transform:translate(-24px);opacity:0;pointer-events:none;transition:transform .18s ease,opacity .18s ease;display:grid;grid-template-rows:auto 1fr;z-index:8}.drawer.open{transform:translate(0);opacity:1;pointer-events:auto}.drawer .d-header{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;gap:8px;align-items:center}.search{flex:1;background:#ffffff0f;border:1px solid var(--border);padding:8px 10px;border-radius:8px;color:var(--text)}.d-list{overflow:auto;padding:8px}.d-item{border:1px solid var(--border);background:#ffffff08;border-radius:10px;padding:10px;margin-bottom:8px}.d-top{display:flex;gap:10px;align-items:center;margin-bottom:6px}.d-meta{display:grid;flex:1;min-width:0}.d-tags{display:flex;gap:6px;align-items:center}.d-tag{font-size:10px;padding:2px 6px;border-radius:6px;background:#ffffff14;color:#c9d2de}.now{display:flex;gap:8px;font-size:12px;align-items:center;color:#cfe3ff}.next{display:flex;gap:8px;font-size:12px;align-items:center;color:#cfd6e2}.badge{font-size:10px;padding:2px 6px;border-radius:5px;font-weight:800}.badge.now{background:var(--blue);color:#111}.badge.next{background:#ffffff1f}.progress{height:6px;border-radius:6px;background:#ffffff14;overflow:hidden;margin-top:4px}.fill{height:100%;background:var(--blue)}.d-item.focus{box-shadow:0 0 0 2px #ffffff4d,0 0 20px #4da3ff4d;transform:translateZ(0)}.timeline{padding:8px;border-top:1px solid var(--border);display:grid;gap:6px}.t-hours{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;font-size:11px;color:var(--muted)}.t-row{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:2px}.t-block{background:#ffffff0f;border:1px solid var(--border);padding:4px 6px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}.osd{position:absolute;left:0;right:0;bottom:0;z-index:6;padding:12px}.osd-card{background:#0000008c;border:1px solid var(--border);border-radius:12px;padding:12px;display:grid;grid-template-columns:auto 1fr auto;gap:12px}.osd-logo{width:56px;height:56px;border-radius:10px;overflow:hidden;background:#ffffff17}.osd-logo img{width:100%;height:100%;object-fit:cover}.osd-txt h4{margin:0 0 6px}.osd-line{font-size:12px;color:var(--muted)}.osd-expanded{margin-top:8px;font-size:13px;color:#cfd6e2}.num{position:absolute;right:20px;top:20px;z-index:7;display:flex;align-items:center;gap:10px;background:#0000008c;border:1px solid var(--border);border-radius:12px;padding:10px 12px}.num .digits{font-size:28px;font-weight:800;letter-spacing:1px}.num .ring{width:28px;height:28px;border-radius:50%;background:conic-gradient(var(--blue) calc(var(--pct)*1%),rgba(255,255,255,.15) 0)}.center{min-height:100dvh;display:grid;place-items:center}.login-shell{min-height:100dvh;display:grid;grid-template-columns:minmax(280px,1.1fr) minmax(320px,440px);align-items:center;gap:clamp(24px,5vw,64px);padding:clamp(20px,6vw,60px);background:radial-gradient(circle at 10% 10%,rgba(77,163,255,.25),transparent 55%),radial-gradient(circle at 90% 20%,rgba(22,163,74,.18),transparent 50%),linear-gradient(160deg,#080c12f2,#0e1420fa)}:root[data-theme=light] .login-shell{background:radial-gradient(circle at 10% 10%,rgba(10,132,255,.18),transparent 60%),radial-gradient(circle at 90% 20%,rgba(56,189,248,.18),transparent 55%),linear-gradient(160deg,#f5f7fa,#eef2f7)}.login-hero{position:relative;padding:clamp(20px,5vw,40px);border-radius:24px;background:color-mix(in srgb,var(--panel) 75%,transparent);border:1px solid color-mix(in srgb,var(--border) 70%,transparent);box-shadow:0 30px 80px #00000059;overflow:hidden}.login-brand h1{margin:12px 0 10px;font-size:clamp(24px,3.2vw,40px);line-height:1.1;letter-spacing:.2px}.login-brand p{margin:0 0 18px;font-size:clamp(13px,1.2vw,16px);color:var(--text-dim);max-width:46ch}.login-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}.login-highlights{display:flex;flex-wrap:wrap;gap:10px}.login-chip{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent-soft) 70%,transparent);color:var(--text);font-size:12px;font-weight:600}.login{width:min(440px,94vw);background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:24px;box-shadow:0 24px 60px #00000047;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.login-card{position:relative;overflow:hidden}.login-install{display:flex;justify-content:flex-start;margin-bottom:12px}.install-button{border-radius:12px;padding:8px 14px;border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent-soft) 65%,transparent);color:var(--accent);font-weight:700;font-size:12px;letter-spacing:.02em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.install-button:hover{transform:translateY(-1px);box-shadow:0 10px 24px #4da3ff40;background:color-mix(in srgb,var(--accent-soft) 85%,transparent)}.login-card:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:20px;padding:1px;background:linear-gradient(140deg,rgba(77,163,255,.6),transparent 55%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.login-title{font-weight:800;font-size:20px;margin-bottom:10px}.login .row{display:grid;gap:8px;margin-bottom:10px}.login input,.login select{background:#ffffff0f;border:1px solid var(--border);color:var(--text);padding:12px;border-radius:12px;outline:none;width:100%;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.login input:focus,.login select:focus{border-color:color-mix(in srgb,var(--accent) 60%,transparent);box-shadow:0 0 0 3px var(--accent-soft);background:color-mix(in srgb,var(--panel-light) 70%,transparent)}.login .input-wrap{position:relative;display:flex;align-items:center}.login .toggle-pass{position:absolute;right:8px;border-radius:8px;padding:6px 8px;border:1px solid var(--border);background:#ffffff0f;color:var(--text);font-size:14px}.login .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.login .actions .play{background:linear-gradient(135deg,#4da3fff2,#4da3ff99);color:#07131f;border:none;box-shadow:0 10px 26px #4da3ff59}.login-footer{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px;font-size:11.5px;color:var(--text-dim)}.login-footer span{padding:4px 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--border) 70%,transparent);background:color-mix(in srgb,var(--panel-light) 60%,transparent)}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#ffffff0d;border:1px solid var(--border);font-size:12px;margin-bottom:10px}.status-dot{width:8px;height:8px;border-radius:50%;background:#fff6}.status-dot--on{background:#4ade80}.status-dot--off{background:#f97316}.offline-hint{margin:0 0 10px;font-size:12px;color:var(--text-dim)}.caps-hint{font-size:12px;color:var(--text-dim);display:flex;align-items:center;gap:6px}.caps-hint:before{content:"⬆";font-size:12px}@media (max-width: 900px){.login-shell{grid-template-columns:1fr;padding:24px 18px 40px}.login-hero{order:1}.login{order:2}}.toast-wrap{position:fixed;right:16px;bottom:16px;display:grid;gap:8px;z-index:9999}.toast{display:flex;align-items:center;gap:10px;background:#000000b3;border:1px solid var(--border);padding:10px 12px;border-radius:10px;box-shadow:0 8px 20px #00000059;font-weight:500}.toast-icon{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;background:#ffffff1f}.toast.toast-ok{background:#16a34a2e;border-color:#22c55e59;color:#bbf7d0}.toast.toast-ok .toast-icon{background:#22c55e33;color:#22c55e}.toast.toast-info{background:#2563eb29;border-color:#3b82f659;color:#dbeafe}.toast.toast-info .toast-icon{background:#3b82f633;color:#3b82f6}.toast.toast-warn{background:#ca8a042e;border-color:#eab30859;color:#fef08a}.toast.toast-warn .toast-icon{background:#facc1538;color:#facc15}.toast.toast-err{background:#dc26262e;border-color:#f8717159;color:#fecaca}.toast.toast-err .toast-icon{background:#f8717138;color:#ef4444}.tv-wrap{display:grid;grid-template-columns:280px 1fr 420px;gap:12px;height:100dvh;padding:12px;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif}.col{background:var(--panel);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;min-height:0}.title{padding:10px 12px;border-bottom:1px solid var(--border);font-weight:700}.list{flex:1;min-height:0;overflow:auto}.row.grp{padding:10px 12px}.row.grp.focus{background:var(--accent-soft);box-shadow:inset 0 0 0 2px var(--accent-glow)}.row.chan{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--border)}.row.chan .logo img,.drow .logo img{width:46px;height:46px;border-radius:8px;object-fit:cover;background:var(--glass)}.row.chan .logo .stub,.drow .logo .stub{width:46px;height:46px;border-radius:8px;background:var(--glass)}.row.chan .meta{flex:1;min-width:0}.row.chan .name{font-weight:600;font-size:14px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row.chan .now,.row.chan .next{display:flex;gap:8px;font-size:12px;color:var(--text-dim)}.badge{font-size:10px;font-weight:700;color:#111;background:var(--accent);border-radius:4px;padding:2px 6px}.badge.dim{background:var(--accent-soft);color:var(--accent)}.row.chan.focus{background:var(--glass);outline:2px solid var(--accent-glow)}.col.right .mini{padding:10px}.col.right .stage{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000;height:240px}.col.right .stage.mini{width:100%;height:240px}.col.right video{width:100%;height:100%;display:block;background:#000}.col.right .osd{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0000,#000000a6);padding:10px 12px}.col.right .osd .cname{font-weight:700;margin-bottom:2px}.col.right .help{padding:8px 12px;font-size:12px;color:var(--text-dim);border-top:1px solid var(--border)}.drawer{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex}.drawer .drawer-head{width:560px;max-width:36vw;background:var(--panel);border-right:1px solid var(--border);padding:10px 12px;display:flex;align-items:center;justify-content:space-between}.drawer .drawer-body{flex:1;display:flex}.drawer .drawer-list{width:560px;max-width:36vw;background:var(--panel);border-right:1px solid var(--border)}.drawer .drawer-list.narrow{width:520px}.drow{display:flex;gap:10px;padding:8px 10px;border-bottom:1px solid var(--border)}.drow.focus{background:var(--accent-soft);outline:2px solid var(--accent-glow)}.drow .meta{display:flex;flex-direction:column;gap:4px;min-width:0}.drow .meta .name{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drow .meta .now,.drow .meta .next{display:flex;gap:8px;font-size:12px;color:var(--text-dim)}.timeline{flex:1;padding:10px 14px;display:none}.timeline.open{display:block}.tl .tl-row{display:grid;grid-template-columns:60px 1fr;gap:10px;padding:6px 0;border-bottom:1px dashed var(--border)}.tl .tl-empty{opacity:.7;font-size:13px;padding:10px 0}@keyframes loaderOverlaySpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
