/* Radio Broadcaster — WRZF control plane UI */
:root{
  --bg:#0e1116; --panel:#171c24; --panel2:#1e242e; --line:#2a323d;
  --txt:#e6e9ee; --dim:#8b97a6; --accent:#f5a623; --accent2:#ff6b4a;
  --ok:#3ddc84; --warn:#ffc857; --bad:#ff5c5c; --blue:#4aa3ff;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font:14px/1.5 -apple-system,Segoe UI,Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* layout */
.rb-wrap{display:flex;min-height:100vh}
.rb-side{width:230px;background:var(--panel);border-right:1px solid var(--line);
  position:fixed;top:0;bottom:0;display:flex;flex-direction:column}
.rb-main{margin-left:230px;flex:1;display:flex;flex-direction:column;min-width:0}
.rb-brand{padding:18px 20px;border-bottom:1px solid var(--line)}
.rb-brand b{font-size:17px;letter-spacing:.5px}
.rb-brand .on{color:var(--accent)}
.rb-brand small{display:block;color:var(--dim);font-size:11px;margin-top:2px}
.rb-nav{padding:10px 0;flex:1;overflow-y:auto}
.rb-nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--dim);
  font-weight:500;border-left:3px solid transparent}
.rb-nav a:hover{color:var(--txt);background:var(--panel2);text-decoration:none}
.rb-nav a.active{color:var(--accent);background:var(--panel2);border-left-color:var(--accent)}
.rb-nav .ic{width:18px;text-align:center;font-size:15px}
.rb-side-foot{padding:14px 20px;border-top:1px solid var(--line);color:var(--dim);font-size:11px}

/* topbar */
.rb-top{display:flex;align-items:center;justify-content:space-between;
  padding:14px 26px;border-bottom:1px solid var(--line);background:var(--panel)}
.rb-top h1{font-size:18px;font-weight:600}
.rb-top .meta{display:flex;align-items:center;gap:18px;color:var(--dim);font-size:12px}
.rb-content{padding:24px 26px;flex:1}

/* status pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;
  font-size:11px;font-weight:600;background:var(--panel2);border:1px solid var(--line)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--dim)}
.pill.ok .dot{background:var(--ok)} .pill.ok{color:var(--ok)}
.pill.bad .dot{background:var(--bad)} .pill.bad{color:var(--bad)}
.pill.warn .dot{background:var(--warn)} .pill.warn{color:var(--warn)}

/* cards */
.grid{display:grid;gap:16px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1100px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px}
.card h3{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--dim);
  margin-bottom:12px;font-weight:600}
.stat .num{font-size:30px;font-weight:700;line-height:1}
.stat .lbl{color:var(--dim);font-size:12px;margin-top:6px}
.stat .num.accent{color:var(--accent)}

/* tables */
table.rb{width:100%;border-collapse:collapse;font-size:13px}
table.rb th{text-align:left;color:var(--dim);font-size:11px;text-transform:uppercase;
  letter-spacing:.5px;padding:9px 10px;border-bottom:1px solid var(--line)}
table.rb td{padding:9px 10px;border-bottom:1px solid var(--panel2)}
table.rb tr:hover td{background:var(--panel2)}
.muted{color:var(--dim)}
.nowrap{white-space:nowrap}

/* buttons */
.btn{display:inline-block;background:var(--accent);color:#1a1205;font-weight:600;
  padding:8px 16px;border-radius:7px;border:0;cursor:pointer;font-size:13px}
.btn:hover{filter:brightness(1.08);text-decoration:none}
.btn.ghost{background:transparent;color:var(--txt);border:1px solid var(--line)}
.btn.sm{padding:5px 11px;font-size:12px}
.btn[disabled]{opacity:.45;cursor:not-allowed}

/* misc */
.section-title{font-size:13px;font-weight:600;color:var(--dim);text-transform:uppercase;
  letter-spacing:.6px;margin:26px 0 12px}
.banner{background:linear-gradient(90deg,#2a1c08,#1e242e);border:1px solid var(--accent);
  border-radius:9px;padding:12px 16px;margin-bottom:20px;font-size:13px}
.banner b{color:var(--accent)}
.bar{height:8px;background:var(--panel2);border-radius:5px;overflow:hidden}
.bar i{display:block;height:100%;background:var(--accent)}
.kv{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--panel2)}
.kv span:first-child{color:var(--dim)}
.tag{display:inline-block;background:var(--panel2);border:1px solid var(--line);
  border-radius:5px;padding:1px 8px;font-size:11px;color:var(--dim)}

/* login */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-box{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:36px;width:340px}
.login-box h1{font-size:22px;margin-bottom:4px}
.login-box h1 .on{color:var(--accent)}
.login-box p{color:var(--dim);font-size:12px;margin-bottom:22px}
.login-box label{display:block;font-size:12px;color:var(--dim);margin:12px 0 5px}
.login-box input{width:100%;background:var(--bg);border:1px solid var(--line);
  border-radius:7px;padding:10px;color:var(--txt);font-size:14px}
.login-box .btn{width:100%;margin-top:20px;padding:11px}
.err{background:#3a1717;border:1px solid var(--bad);color:#ffb4b4;
  padding:9px 12px;border-radius:7px;font-size:12px;margin-bottom:14px}
