:root{
  --bg:#0C1212; --surface:#121A19; --hairline:#25302E;
  --ink:#ECF1EF; --muted:#6F827C; --accent:#FFB23E; --live:#FF4D4D;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif; line-height:1.5;
}
.dot{width:8px;height:8px;border-radius:50%;background:var(--live);
  box-shadow:0 0 0 0 rgba(255,77,77,.6);animation:pulse 1.8s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 7px rgba(255,77,77,0)}100%{box-shadow:0 0 0 0 rgba(255,77,77,0)}}
@media (prefers-reduced-motion:reduce){.dot{animation:none}}

/* ---------- gate (index) ---------- */
.gate-body{display:grid;place-items:center;padding:24px;
  background-image:radial-gradient(120% 80% at 50% -10%, rgba(255,178,62,.10), transparent 60%)}
.gate{width:100%;max-width:380px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:"Oswald",sans-serif;
  font-weight:600;letter-spacing:.28em;font-size:12px;text-transform:uppercase;color:var(--muted);margin:0 0 28px}
h1{font-family:"Oswald",sans-serif;font-weight:300;font-size:26px;line-height:1.2;margin:0 0 22px}
.slots{display:flex;gap:8px;justify-content:center;margin-bottom:18px}
.slot{width:46px;height:60px;text-align:center;padding:0;background:var(--surface);
  border:1px solid var(--hairline);border-radius:10px;color:var(--ink);font-family:"Space Mono",monospace;
  font-weight:700;font-size:26px;text-transform:uppercase;caret-color:var(--accent);
  transition:border-color .15s,box-shadow .15s,background .15s}
.slot:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,178,62,.18)}
.slot.filled{border-color:var(--accent);background:#15201c}
.slots.shake{animation:shake .35s}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
@media (prefers-reduced-motion:reduce){.slots.shake{animation:none}}
.btn{width:100%;height:50px;margin-top:6px;cursor:pointer;background:var(--accent);color:#1b1300;
  border:none;border-radius:10px;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.14em;
  font-size:14px;text-transform:uppercase;transition:filter .15s,opacity .15s}
.btn:hover{filter:brightness(1.06)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.error{min-height:18px;margin:14px 0 0;font-size:13px;color:var(--live);opacity:0;transition:opacity .15s}
.error.show{opacity:1}

/* ---------- player (watch) ---------- */
.player-body{background:#000;overflow:hidden}
#video{position:fixed;inset:0;width:100%;height:100%;background:#000;object-fit:contain}
.bar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;z-index:3;background:linear-gradient(to bottom,rgba(0,0,0,.55),transparent);pointer-events:none}
.bar>*{pointer-events:auto}
.live{display:inline-flex;align-items:center;gap:8px;font-family:"Oswald",sans-serif;font-weight:600;
  letter-spacing:.22em;font-size:12px;text-transform:uppercase}
.exit{appearance:none;border:none;background:rgba(0,0,0,.35);color:var(--ink);width:34px;height:34px;
  border-radius:50%;font-size:18px;line-height:1;cursor:pointer;text-decoration:none;display:grid;place-items:center}
.exit:hover{background:rgba(0,0,0,.6)}
.overlay{position:fixed;inset:0;z-index:4;display:none;place-items:center;background:rgba(0,0,0,.35);cursor:pointer}
.overlay.show{display:grid}
.pill{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;background:var(--accent);color:#1b1300;
  border-radius:999px;font-family:"Oswald",sans-serif;font-weight:600;letter-spacing:.12em;font-size:14px;text-transform:uppercase}
.status{position:fixed;left:0;right:0;bottom:18px;text-align:center;z-index:2;font-size:13px;color:#9fb0aa;pointer-events:none}

/* ---------- admin ---------- */
.admin-body{padding:32px 20px}
.wrap{max-width:720px;margin:0 auto}
.card{background:var(--surface);border:1px solid var(--hairline);border-radius:12px;padding:20px;margin-bottom:20px}
.card h2{font-family:"Oswald",sans-serif;font-weight:500;font-size:18px;margin:0 0 16px}
label{display:block;font-size:13px;color:var(--muted);margin:0 0 8px}
input[type=text],input[type=password],input[type=number],input[type=datetime-local]{
  width:100%;height:44px;padding:0 14px;color:var(--ink);background:var(--bg);border:1px solid var(--hairline);
  border-radius:10px;font-family:"Space Mono",monospace;font-size:14px}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,178,62,.16)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--hairline);vertical-align:middle}
th{color:var(--muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
td.code{font-family:"Space Mono",monospace;font-weight:700;letter-spacing:.05em}
.tag{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;letter-spacing:.04em}
.tag.on{background:rgba(54,226,123,.14);color:#5fe39b}
.tag.off{background:rgba(255,77,77,.14);color:#ff8a8a}
.tag.live{background:rgba(255,178,62,.16);color:var(--accent)}
.mini{height:34px;padding:0 12px;border-radius:8px;border:1px solid var(--hairline);background:var(--bg);
  color:var(--ink);font-size:12.5px;cursor:pointer}
.mini:hover{border-color:var(--accent);color:var(--accent)}
.mini.danger:hover{border-color:var(--live);color:var(--live)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:end}
.row>div{flex:1;min-width:120px}
.note{font-size:12.5px;color:var(--muted)}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.flash{padding:12px 14px;border-radius:10px;margin-bottom:18px;font-size:13.5px;
  background:rgba(255,178,62,.12);border:1px solid rgba(255,178,62,.3);color:var(--accent)}
a.link{color:var(--muted);text-decoration:none;font-size:13px}
a.link:hover{color:var(--ink)}
