:root{
  --bg:#0b0c10;--panel:#12141a;--panel2:#0f1116;--text:#e7e8ee;--muted:#a9adbb;
  --line:#272a36;--accent2:#cfd2dc;--danger:#fb7185;
  --shadow:0 4px 20px rgba(0,0,0,.4);--radius:12px
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;padding:0;overflow:hidden}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#0b0c10;color:var(--text);display:flex;flex-direction:column}
a{color:var(--text);text-decoration:none}a:hover{opacity:.85}
.container{display:flex;flex-direction:column;width:100%;height:100vh;padding:8px 10px;gap:8px;overflow:hidden}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0;min-height:0}
.brand{display:flex;flex-direction:column;gap:1px;white-space:nowrap}
.brand .brand-title{font-weight:700;font-size:16px;letter-spacing:.1px}
.brand .subtitle{color:var(--muted);font-size:11px}
.controls{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}
.btn{background:linear-gradient(180deg,#1e2130,#13151e);border:1px solid var(--line);color:var(--text);padding:7px 12px;border-radius:9px;cursor:pointer;font-size:13px;white-space:nowrap;line-height:1}
.btn:hover{border-color:#3a3f55}.btn:active{transform:translateY(1px)}
.btn.primary{border-color:#3b3f55;background:linear-gradient(180deg,#202437,#131726)}
.btn.small{padding:5px 10px;font-size:12px}
.btn.danger{border-color:#7f1d1d;background:linear-gradient(180deg,#2d0e0e,#1a0808);color:var(--danger)}
.input{background:#0f1116;border:1px solid var(--line);color:var(--text);padding:7px 10px;border-radius:9px;outline:none;font-size:13px;width:auto}
.input:focus{border-color:#3a3f55}textarea.input{resize:vertical;width:100%}
.grid{display:grid;grid-template-columns:62% 38%;gap:8px;flex:1;min-height:0;overflow:hidden}
.card{background:#0f1116;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;min-height:0}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 12px 8px;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}
.card-head h2{margin:0;font-size:12px;letter-spacing:.3px;color:var(--accent2);font-weight:600;text-transform:uppercase}
.badge{font-size:11px;color:var(--muted);border:1px solid rgba(255,255,255,.07);padding:4px 9px;border-radius:999px;background:rgba(0,0,0,.3);white-space:nowrap}
.player-wrap{flex:1;min-height:0;padding:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
video{display:block;width:100%;height:100%;max-width:100%;border-radius:10px;background:#000;border:1px solid rgba(255,255,255,.07);object-fit:contain;max-height:100%;aspect-ratio:16/9}
.nowplaying{padding:8px 12px;border-top:1px solid rgba(255,255,255,.05);background:rgba(0,0,0,.25);flex-shrink:0}
.nowplaying .np-title{font-weight:700;margin:0 0 2px 0;font-size:13px}
.nowplaying .np-meta{color:var(--muted);font-size:11px;display:flex;gap:10px;flex-wrap:wrap}
.epg-wrap{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}
.epg-scroll{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;padding:8px 10px;scroll-behavior:smooth;position:relative}
.epg-row{display:flex;gap:8px;align-items:stretch;min-width:max-content;height:100%}
.slot{width:200px;border-radius:10px;border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.03);padding:0;display:flex;flex-direction:column;cursor:default;user-select:none;position:relative;overflow:hidden}
.slot:hover{border-color:rgba(255,255,255,.2)}
.slot-img{width:100%;height:110px;object-fit:cover;display:block;flex-shrink:0}
.slot-img-placeholder{width:100%;height:110px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.06)}
.slot-img-placeholder svg{width:32px;height:32px;opacity:.18}
.slot-body{padding:8px 10px;display:flex;flex-direction:column;flex:1;min-height:0}
.slot .time{color:var(--muted);font-size:11px;margin-bottom:4px;display:flex;justify-content:space-between;gap:8px;flex-shrink:0}
.slot .stitle{font-weight:700;font-size:13px;margin:0 0 3px;line-height:1.25;flex-shrink:0}
.slot .by{color:var(--muted);font-size:11px;margin-bottom:5px;flex-shrink:0}
.slot .info{color:var(--text);font-size:11px;line-height:1.35;opacity:.88;flex:1;min-height:0;overflow:hidden;margin-bottom:7px}
.slot .links{display:flex;gap:6px;align-items:center;flex-wrap:wrap;flex-shrink:0;margin-top:auto}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;border:1px solid rgba(255,255,255,.09);background:rgba(0,0,0,.25)}
.iconbtn:hover{border-color:rgba(255,255,255,.2)}.iconbtn svg{width:14px;height:14px;opacity:.85}
.slot .website{margin-left:auto;font-size:11px;color:var(--accent2);border:1px solid rgba(255,255,255,.09);padding:5px 9px;border-radius:9px;background:rgba(0,0,0,.2)}
.nowline{position:absolute;top:0;bottom:0;width:2px;background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.85),rgba(255,255,255,0));z-index:2;pointer-events:none}
.nowlabel{position:absolute;top:8px;transform:translateX(-50%);z-index:4;font-size:10px;color:#0b0c10;background:rgba(255,255,255,.92);padding:4px 8px;border-radius:999px;pointer-events:none;font-weight:700}
/* ─── Live badge — red dot + red text ─────────────────────────────────────── */
.live-badge{color:#f87171;border-color:rgba(248,113,113,.25);background:rgba(248,113,113,.08);display:flex;align-items:center;gap:5px;font-weight:600}
.live-badge::before{content:'';display:inline-block;width:7px;height:7px;border-radius:50%;background:#f87171;flex-shrink:0;animation:live-pulse 2s ease-in-out infinite}
@keyframes live-pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(248,113,113,.6)}50%{opacity:.7;box-shadow:0 0 0 4px rgba(248,113,113,0)}}
/* ─── Viewer count badge ───────────────────────────────────────────────────── */
.viewer-count{color:var(--accent2);border-color:rgba(255,255,255,.1);font-size:11px}
.notice{padding:6px 12px;color:var(--muted);font-size:11px;flex-shrink:0;border-top:1px solid rgba(255,255,255,.04)}
.admin-body{overflow:auto}.admin-body .container{height:auto;min-height:100vh;overflow:visible}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%}
.admin-slot-list{display:flex;flex-direction:column;gap:10px;width:100%}
.admin-slot-list .slot{width:100%}.admin-form-wrap{display:flex;flex-direction:column;gap:10px;padding:14px}
label.field-label{color:var(--muted);font-size:11px;display:block;margin-bottom:3px}
@media(max-width:900px){.grid{grid-template-columns:55% 45%}}
@media(max-width:700px){
  html,body{height:auto !important;overflow:auto !important}
  .container{height:auto !important;min-height:unset;overflow:visible !important;padding:6px;gap:6px}
  .topbar{flex-wrap:wrap;gap:6px}.controls{flex-wrap:wrap;gap:6px}
  .brand .brand-title{font-size:14px}.brand .subtitle{font-size:10px}
  .btn{padding:6px 10px;font-size:12px}.btn.small{padding:4px 8px;font-size:11px}
  .grid{display:flex !important;flex-direction:column !important;gap:6px;flex:none !important;overflow:visible !important;min-height:unset !important}
  .card{overflow:hidden;flex:none !important;min-height:unset !important}
  .player-wrap{display:flex !important;flex:none !important;height:auto !important;min-height:unset !important;padding:6px;overflow:visible;align-items:stretch;justify-content:center}
  #prerollVideo{width:100% !important;height:100% !important;max-height:none !important}
  #transitionWrap{border-radius:8px}
  #transitionImg{object-fit:contain !important}
  video#video{width:100% !important;height:auto !important;max-height:none !important;aspect-ratio:16/9}
  .epg-wrap{flex:none !important;height:auto !important;min-height:unset !important}
  .epg-scroll{flex:none !important;height:280px !important;overflow-x:auto;overflow-y:hidden}
  .admin-grid{grid-template-columns:1fr}
  .nowplaying{padding:6px 10px}
  .nowplaying .np-title{font-size:12px}
}
/* ─── Modals ───────────────────────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}
.modal-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:520px;display:flex;flex-direction:column;overflow:hidden}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px;flex-shrink:0}
.modal-close{background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;line-height:1;padding:0 4px}
.modal-close:hover{color:var(--text)}
.modal-body{padding:18px;display:flex;flex-direction:column;gap:10px}
.copy-row{display:flex;gap:8px;align-items:stretch}
/* ─── Now-Playing fullscreen page ───────────────────────────────────────────── */
.np-page{display:flex;flex-direction:row;align-items:center;justify-content:center;width:100vw;height:100vh;background:#0b0c10;gap:0;overflow:hidden}
.np-main{flex:1;display:flex;align-items:center;justify-content:center;height:100%;padding:24px 12px 24px 24px}
.np-main img,.np-main .np-placeholder{width:100%;height:100%;object-fit:contain;border-radius:12px;max-height:100vh}
.np-next-col{width:220px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:24px 24px 24px 12px}
.np-next-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.np-next img,.np-next .np-placeholder{width:200px;height:130px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.np-placeholder{background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center}
.np-placeholder svg{width:40px;height:40px;opacity:.18}

/* ─── VOD-style player shell (used in EPG live player card) ─────────────────── */
.video-inner{position:relative;width:100%;aspect-ratio:16/9;max-height:100%;border-radius:10px;overflow:hidden;background:#000;border:1px solid rgba(255,255,255,.07)}
.video-poster{position:absolute;inset:0;width:100%;height:100%;border-radius:10px;object-fit:contain;background:#000;z-index:1;transition:opacity .4s ease}
.video-poster.hidden{opacity:0;pointer-events:none}
.play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;pointer-events:none;transition:opacity .4s ease}
.play-overlay.hidden{opacity:0}
.play-overlay-btn{width:64px;height:64px;border-radius:50%;background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;pointer-events:auto;cursor:pointer}
.play-overlay-btn:hover{background:rgba(0,0,0,.75);border-color:rgba(255,255,255,.35)}
.play-overlay-btn svg{width:28px;height:28px;fill:#fff}
.vod-fullscreen-btn{position:absolute;bottom:12px;right:12px;z-index:5;width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;cursor:pointer}
.vod-fullscreen-btn:hover{border-color:rgba(255,255,255,.28)}
.vod-fullscreen-btn svg{width:15px;height:15px;fill:#fff;opacity:.85}
.vod-loading{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:6;border-radius:10px;opacity:0;pointer-events:none;transition:opacity .3s}
.vod-loading.show{opacity:1;pointer-events:auto}
.vod-spinner{width:34px;height:34px;border:3px solid rgba(255,255,255,.18);border-top-color:rgba(255,255,255,.85);border-radius:50%;animation:vod-spin .85s linear infinite}
@keyframes vod-spin{to{transform:rotate(360deg)}}
.player-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px;padding:5px 10px 0;flex-shrink:0}
.action-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}
.action-btn i{font-size:12px}
.action-btn:hover{border-color:var(--accent2);color:var(--text)}
.vod-controls-bar{display:flex;align-items:center;gap:8px;padding:5px 10px 7px;border-top:1px solid rgba(255,255,255,.05);flex-shrink:0}
.ctrl-btn{background:none;border:none;cursor:pointer;padding:3px;display:flex;align-items:center;flex-shrink:0}
.ctrl-btn svg{width:19px;height:19px;fill:var(--text);opacity:.82}
.ctrl-btn:hover svg{opacity:1}
.vod-progress-track{flex:1;height:4px;background:rgba(255,255,255,.12);border-radius:4px;cursor:pointer;overflow:hidden}
.vod-progress-fill{height:100%;background:var(--accent2);width:0;border-radius:4px;transition:width .1s linear}
.vod-time-label{font-size:11px;color:var(--muted);white-space:nowrap;min-width:90px;text-align:right}
.vod-vol-wrap{display:flex;align-items:center;gap:4px;flex-shrink:0}
.vod-vol-track{width:58px;height:4px;background:rgba(255,255,255,.12);border-radius:4px;cursor:pointer;overflow:hidden}
.vod-vol-fill{height:100%;background:var(--accent2);width:75%;border-radius:4px}
