@import url('https://fonts.googleapis.com/css2?family=Lexend:wght@300;400;500;600;700;800&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
:root{--accent:#E50914;--bg:#000;--panel:#141414;--panel2:#1e1e1e;--border:rgba(255,255,255,0.1);--text:#fff;--muted:rgba(255,255,255,0.5);--tab-active:#fff;--tab-inactive:rgba(255,255,255,0.55)}
html,body{width:100%;height:100%;background:#000;overflow:hidden;font-family:'Lexend','Segoe UI',system-ui,-apple-system,sans-serif;color:#fff;user-select:none;-webkit-user-select:none}

/* ── SHELL ── */
#shell{position:relative;width:100vw;height:100vh;background:#000;display:flex;align-items:center;justify-content:center;cursor:none}
#shell.show-cursor{cursor:default}
video{width:100%;height:100%;object-fit:contain;display:block}
video::cue{color:var(--sub-color,#fff);font-size:var(--sub-size,30px);background:var(--sub-bg,transparent)}

/* ── POSTER ── */
#poster{position:absolute;inset:0;background-size:cover;background-position:center;z-index:5;cursor:pointer;display:none}
#poster-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 60%,rgba(0,0,0,.1) 100%)}
#poster-grad2{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.7) 0%,transparent 60%)}
#poster-info{position:absolute;bottom:90px;left:40px;right:40px;pointer-events:none}
#poster-brand{font-size:11px;font-weight:700;letter-spacing:5px;color:var(--accent);margin-bottom:10px}
#poster-title{font-size:34px;font-weight:700;line-height:1.1;margin-bottom:10px;text-shadow:0 2px 12px rgba(0,0,0,.7)}
#poster-sub{font-size:13px;color:var(--muted)}
#poster-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70px;height:70px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s;box-shadow:0 4px 24px rgba(0,0,0,.5)}
#poster-btn:hover{transform:translate(-50%,-50%) scale(1.08)}
#poster-btn svg{margin-left:5px}

/* ── LOADER ── */
#loader{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:#000;z-index:30}
.spinner{width:38px;height:38px;border:3px solid rgba(255,255,255,.12);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#loader-brand{position:absolute;top:18px;left:22px;font-size:11px;font-weight:700;letter-spacing:5px;color:var(--accent)}
#loader-msg{font-size:12px;color:var(--muted)}

/* ── ERROR ── */
#error-screen{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#000;z-index:30}
#error-screen .brand{position:absolute;top:18px;left:22px;font-size:11px;font-weight:700;letter-spacing:5px;color:var(--accent)}
#error-screen .title{font-size:16px;font-weight:600}
#error-screen .desc{font-size:13px;color:var(--muted);text-align:center;max-width:280px;line-height:1.5}
.btn-retry{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:10px 26px;font-size:13px;font-weight:600;cursor:pointer;margin-top:4px}

/* ── WATERMARK ── */
#watermark{position:absolute;top:16px;left:20px;z-index:10;font-size:11px;font-weight:700;letter-spacing:5px;color:var(--accent);opacity:.9;pointer-events:none}

/* ── CENTER FLASH ── */
#cflash{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:66px;height:66px;background:rgba(0,0,0,.55);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;z-index:8}
#cflash.go{animation:cfa .45s ease forwards}
@keyframes cfa{0%{opacity:1;transform:translate(-50%,-50%) scale(.75)}60%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.15)}}

/* ── SUBTITLE DISPLAY ── */
#sub-text{position:absolute;bottom:78px;left:50%;transform:translateX(-50%);z-index:12;font-size:var(--sub-size,30px);font-weight:500;color:var(--sub-color,#fff);background:var(--sub-bg,transparent);text-shadow:0 1px 5px #000,0 0 16px rgba(0,0,0,.9);text-align:center;max-width:82%;line-height:1.4;pointer-events:none;display:none}

/* ── SKIP INTRO ── */
#skip-intro{position:absolute;bottom:86px;right:20px;z-index:18;background:rgba(10,10,10,.9);border:1.5px solid rgba(255,255,255,.28);color:#fff;font-size:13px;font-weight:600;padding:10px 22px;border-radius:7px;cursor:pointer;display:none;letter-spacing:.3px;transition:border-color .2s}
#skip-intro:hover{border-color:rgba(255,255,255,.7)}

/* ── NEXT EP CARD ── */
#nep-card{position:absolute;bottom:86px;right:20px;z-index:18;background:rgba(12,12,12,.96);border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:14px 16px;min-width:220px;display:none;flex-direction:column;gap:9px;cursor:pointer;transition:border-color .2s}
#nep-card:hover{border-color:rgba(255,255,255,.35)}
.nep-label{font-size:10px;letter-spacing:1.8px;color:var(--muted);text-transform:uppercase}
.nep-name{font-size:14px;font-weight:600}
.nep-prog{height:3px;background:rgba(255,255,255,.14);border-radius:2px}
.nep-prog-fill{height:100%;background:var(--accent);width:0%;border-radius:2px}
.nep-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}

/* ══════════════════════════════════════════
   CONTROLS
══════════════════════════════════════════ */
#controls{position:absolute;bottom:0;left:0;right:0;z-index:15;background:linear-gradient(transparent,rgba(0,0,0,.8) 35%,rgba(0,0,0,.97) 100%);padding-bottom:14px;opacity:0;transition:opacity .3s;pointer-events:none}
#controls.vis{opacity:1;pointer-events:all}

/* progress */
#prog-wrap{padding:0 16px;height:22px;display:flex;align-items:center;cursor:pointer;position:relative}
#prog-bg{width:100%;height:3px;background:rgba(255,255,255,.2);border-radius:2px;position:relative;transition:height .15s}
#prog-wrap:hover #prog-bg{height:5px}
#prog-buf{position:absolute;left:0;height:100%;background:rgba(255,255,255,.28);border-radius:2px;width:0%}
#prog-fill{position:absolute;left:0;height:100%;background:var(--accent);border-radius:2px;width:0%}
#prog-thumb{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:13px;height:13px;background:#fff;border-radius:50%;opacity:0;transition:opacity .15s;box-shadow:0 1px 6px rgba(0,0,0,.6)}
#prog-wrap:hover #prog-thumb{opacity:1}
#prog-tip{position:absolute;bottom:22px;background:rgba(0,0,0,.85);color:#fff;font-size:11px;padding:3px 7px;border-radius:5px;display:none;transform:translateX(-50%);pointer-events:none;white-space:nowrap}

/* bottom bar */
#bar{display:flex;align-items:center;padding:0 12px;gap:4px}
.cbtn{background:none;border:none;color:#fff;cursor:pointer;width:36px;height:36px;border-radius:7px;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.cbtn:hover{background:rgba(255,255,255,.1)}
.cbtn svg{width:20px;height:20px;fill:currentColor}
#time-disp{font-size:12px;color:rgba(255,255,255,.75);padding:0 6px;white-space:nowrap;letter-spacing:.3px}
#bar-right{margin-left:auto;display:flex;align-items:center;gap:2px}

/* volume */
#vol-area{display:flex;align-items:center;gap:6px}
#vol-range{-webkit-appearance:none;width:68px;height:3px;border-radius:2px;background:rgba(255,255,255,.3);outline:none;cursor:pointer}
#vol-range::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}

/* ══════════════════════════════════════════
   SETTINGS PANEL — tabbed overlay
══════════════════════════════════════════ */
#panel-overlay{position:absolute;inset:0;z-index:40;display:none;align-items:center;justify-content:flex-end;padding:44px 26px 76px 26px;pointer-events:none}
#panel-overlay.open{display:flex}

#panel{background:rgba(7,9,9,.94);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.09);border-radius:14px;width:min(430px,calc(100vw - 52px));height:min(78vh,690px);display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 18px 60px rgba(0,0,0,.65);pointer-events:all}

/* tab bar */
#tab-bar{position:absolute;right:0;top:-54px;display:flex;align-items:center;justify-content:center;gap:4px;padding:4px;background:rgba(8,8,8,.82);border:1px solid rgba(255,255,255,.12);border-radius:22px;flex-shrink:0}
.tab-btn{background:none;border:none;color:var(--tab-inactive);font-size:13px;font-weight:500;padding:8px 14px;border-radius:18px;cursor:pointer;transition:background .2s,color .2s;letter-spacing:.2px}
.tab-btn.active{background:rgba(255,255,255,.12);color:var(--tab-active);font-weight:600}
#panel-close{margin-left:8px;background:rgba(255,255,255,.1);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#panel-close svg{width:14px;height:14px;fill:currentColor}

/* tab content */
.tab-pane{display:none;flex-direction:column;overflow-y:auto;flex:1;padding:14px 16px}
.tab-pane.active{display:flex}
.tab-pane::-webkit-scrollbar{width:3px}
.tab-pane::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

/* list items shared */
.panel-item{display:flex;align-items:center;gap:12px;padding:13px 14px;cursor:pointer;border-radius:8px;transition:background .15s,border-color .15s;position:relative;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);margin:4px 0}
.panel-item:hover{background:rgba(255,255,255,.07)}
.panel-item.selected{background:rgba(229,9,20,.2);border-color:rgba(229,9,20,.55)}
.panel-item.selected .item-name{color:var(--accent)}
.item-flag{width:24px;height:18px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.flag-img{width:24px;height:18px;object-fit:cover;border-radius:2px;display:block}
.flag-fallback{font-size:18px;line-height:1}
.item-body{flex:1;min-width:0}
.item-name{font-size:14px;font-weight:500;color:#fff}
.item-desc{font-size:12px;color:var(--muted);margin-top:1px}
.item-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.item-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;letter-spacing:.5px}
.badge-hd{background:rgba(255,255,255,.12);color:rgba(255,255,255,.7)}
.badge-fhd{background:rgba(229,9,20,.2);color:var(--accent)}
.badge-builtin{background:rgba(229,9,20,.2);color:var(--accent);font-size:10px;font-weight:600;padding:3px 8px;border-radius:5px}
.heart-btn{background:none;border:none;color:rgba(255,255,255,.35);cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s}
.heart-btn:hover,.heart-btn.loved{color:var(--accent)}
.heart-btn svg{width:16px;height:16px;fill:currentColor}
.check-icon{color:var(--accent);display:flex;align-items:center}
.check-icon svg{width:16px;height:16px;fill:currentColor}

/* quality items */
.q-item{display:flex;align-items:center;justify-content:space-between;padding:14px 14px;cursor:pointer;border-radius:8px;margin:4px 0;transition:background .15s,border-color .15s;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035)}
.q-item:hover{background:rgba(255,255,255,.06)}
.q-item.selected{background:rgba(229,9,20,.2);border-color:rgba(229,9,20,.55)}
.q-item.selected .q-name{color:var(--accent)}
.q-name{font-size:14px;font-weight:500}

/* speed items */
.sp-item{display:flex;align-items:center;justify-content:space-between;padding:14px 14px;cursor:pointer;border-radius:8px;margin:4px 0;transition:background .15s,border-color .15s;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035)}
.sp-item:hover{background:rgba(255,255,255,.06)}
.sp-item.selected{background:rgba(229,9,20,.2);border-color:rgba(229,9,20,.55)}
.sp-item.selected .sp-name{color:var(--accent)}
.sp-name{font-size:14px;font-weight:500}
.sp-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

/* subs special */
.sub-upload{display:flex;align-items:center;gap:10px;padding:13px 14px;cursor:pointer;color:rgba(255,255,255,.75);font-size:13px;transition:background .15s;border-radius:8px;margin:4px 0}
.sub-upload:hover{background:rgba(255,255,255,.06)}
.sub-upload svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}
.sub-action{display:flex;align-items:center;justify-content:space-between;padding:13px 14px;cursor:pointer;font-size:13px;color:rgba(255,255,255,.75);transition:background .15s;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);border-radius:8px;margin:6px 0}
.sub-action:hover{background:rgba(255,255,255,.06)}
.sub-action svg{width:14px;height:14px;fill:currentColor;opacity:.5}
.sub-section-label{font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:10px 18px 4px}

.subs-view{display:flex;flex-direction:column;min-height:100%}
.subs-view.hidden{display:none}
.appearance-back{display:flex;align-items:center;gap:8px;background:none;border:none;color:rgba(255,255,255,.72);font-size:13px;padding:8px 2px 14px;cursor:pointer}
.appearance-card{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.035);border-radius:8px;padding:14px;margin:8px 0}
.appearance-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:700;margin-bottom:12px}
.appearance-value{color:var(--accent);font-weight:500}
.appearance-range{width:100%;accent-color:#4b8cff}
.color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.color-swatch{height:40px;border:none;border-radius:6px;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.22)}
.latency-row{display:grid;grid-template-columns:62px 1fr 62px;gap:8px;align-items:center}
.latency-btn,.latency-value,.appearance-reset{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:#fff;border-radius:8px;padding:10px;font:inherit;text-align:center}
.latency-btn{cursor:pointer}
.appearance-reset{width:100%;margin-top:8px;font-weight:700;cursor:pointer}

@media (max-width:700px){
  #panel-overlay{justify-content:center;padding:82px 10px 22px}
  #panel{width:min(430px,calc(100vw - 20px));height:min(82vh,700px)}
  #tab-bar{right:50%;transform:translateX(50%);top:-52px}
}
