:root{
  --bg:#0d1117; --panel:#161b22; --panel-2:#1c2230;
  --line:#2a3140; --text:#e6edf3; --muted:#8b949e;
  --accent:#58a6ff; --good:#3fb950; --warn:#d29922; --bad:#f85149;
  --jf:#aa5cc3; --rad:#fbb040; --son:#3498db; --sab:#36c692; --js:#ec407a;
  --radius:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:14px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
header{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:10}
.brand{display:flex;align-items:center;gap:10px}
.brand h1{font-size:18px;margin:0;letter-spacing:.3px}
.brand .sub{color:var(--muted);font-size:12px}
.dot{width:10px;height:10px;border-radius:50%;background:var(--good);box-shadow:0 0 8px var(--good)}
.dot.stale{background:var(--warn);box-shadow:0 0 8px var(--warn)}
.dot.dead{background:var(--bad);box-shadow:0 0 8px var(--bad)}
.meta{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:12px}
#refresh-btn{background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:6px;width:28px;height:28px;cursor:pointer;font-size:16px}
#refresh-btn:hover{background:var(--line)}

main{display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:14px;padding:14px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;overflow:hidden;display:flex;flex-direction:column}
.card>header{padding:0 0 10px 0;border-bottom:1px solid var(--line);position:static;background:transparent;display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
.card h2{margin:0;font-size:15px;letter-spacing:.4px;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.card h2::before{content:"";display:inline-block;width:8px;height:8px;border-radius:2px;background:var(--accent)}
.card.jellyfin h2::before{background:var(--jf)}
.card.radarr h2::before{background:var(--rad)}
.card.sonarr h2::before{background:var(--son)}
.card.sabnzbd h2::before{background:var(--sab)}
.card.jellyseerr h2::before{background:var(--js)}
.card.host h2::before{background:var(--accent)}
.badge{font-size:11px;color:var(--muted);background:var(--panel-2);padding:2px 8px;border-radius:999px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}
.stat{background:var(--panel-2);border-radius:8px;padding:10px 12px}
.stat label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.stat .val{font-size:22px;font-weight:600;font-variant-numeric:tabular-nums}
.stat .val.big{font-size:24px}
.stat .val.good{color:var(--good)}
.stat .val.warn-on-nonzero[data-nz="1"]{color:var(--warn)}
.bar{height:4px;background:var(--line);border-radius:2px;margin-top:6px;overflow:hidden}
.bar span{display:block;height:100%;background:var(--accent);width:0%}
.bar span[data-pct-high="1"]{background:var(--bad)}
.bar span[data-pct-mid="1"]{background:var(--warn)}

.card h3{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:14px 0 6px 0}

table{width:100%;border-collapse:collapse;font-size:12.5px}
th,td{text-align:left;padding:6px 8px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.4px}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--panel-2)}
td.num{font-variant-numeric:tabular-nums;text-align:right}
td.trunc{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.empty{color:var(--muted);font-style:italic;padding:8px 0;font-size:12px}

.subgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
@media(max-width:700px){.subgrid{grid-template-columns:1fr}}

.sessions{display:flex;flex-direction:column;gap:8px}
.session{background:var(--panel-2);border-radius:8px;padding:10px 12px;border-left:3px solid var(--good)}
.session.transcode{border-left-color:var(--warn)}
.session .title{font-weight:600}
.session .meta{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;flex-wrap:wrap;gap:10px}
.session .progress{height:3px;background:var(--line);border-radius:2px;margin-top:8px;overflow:hidden}
.session .progress span{display:block;height:100%;background:var(--accent)}
.session .reasons{margin-top:6px;display:flex;flex-wrap:wrap;gap:4px}
.session .reasons span{background:#3a2a1a;color:var(--warn);font-size:10.5px;padding:1px 6px;border-radius:999px;border:1px solid #54391d}

.status-pill{display:inline-block;padding:1px 8px;border-radius:999px;font-size:11px;background:var(--panel-2);color:var(--muted)}
.status-pill.ok,.status-pill.completed,.status-pill.available{background:#0e2e1a;color:var(--good)}
.status-pill.failed,.status-pill.declined{background:#3a1414;color:var(--bad)}
.status-pill.pending,.status-pill.warning,.status-pill.queued{background:#3a2a1a;color:var(--warn)}
.status-pill.downloading,.status-pill.processing{background:#142a3d;color:var(--accent)}
.status-pill.approved{background:#1a2a3d;color:var(--son)}

.health{list-style:none;margin:0;padding:0;font-size:12px}
.health li{padding:6px 8px;border-left:3px solid var(--warn);background:var(--panel-2);border-radius:4px;margin-bottom:4px}
.health li.error{border-left-color:var(--bad)}
.health-title{margin-top:14px}
.card.transcoder h2::before{background:#fb8c00}
.log{background:#0a0d12;border:1px solid var(--line);border-radius:6px;padding:8px 10px;font-size:11.5px;line-height:1.35;color:var(--muted);max-height:180px;overflow:auto;white-space:pre-wrap;margin:0}
.active-job{background:var(--panel-2);border-radius:8px;padding:10px 12px;border-left:3px solid var(--warn)}
.active-job .title{font-weight:600;font-size:13px}
.active-job .meta{font-size:11.5px;color:var(--muted);margin-top:2px}

.err{color:var(--bad);font-size:12px;padding:8px;background:#2a1414;border-radius:6px}
