: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}
.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}
  #prerollWrap{width:100% !important;height:auto !important;aspect-ratio:16/9}
  #prerollVideo{width:100% !important;height:auto !important;aspect-ratio:16/9;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}
