:root{--bg:#08111f;--panel:#101b2e;--panel2:#0c1628;--text:#e6edf7;--muted:#93a4ba;--line:#26354d;--primary:#2563eb;--danger:#dc2626;--warn:#f97316;--ok:#16a34a}
*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#122545,#08111f 40%);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif}a{color:inherit;text-decoration:none}.topbar{height:64px;border-bottom:1px solid var(--line);background:rgba(8,17,31,.88);display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:10;backdrop-filter:blur(10px)}.brand{font-weight:800;letter-spacing:.3px;display:flex;gap:10px;align-items:center}.dot{width:12px;height:12px;background:#ef4444;border-radius:999px;box-shadow:0 0 18px #ef4444}.topbar nav{display:flex;gap:14px;color:var(--muted);font-size:14px}.topbar nav a:hover{color:#fff}.container{max-width:1500px;margin:0 auto;padding:18px}.login-card{max-width:420px;margin:70px auto;background:var(--panel);padding:30px;border:1px solid var(--line);border-radius:18px;box-shadow:0 20px 80px #0008}.muted{color:var(--muted)}label{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:14px}input,select,textarea{background:#07101e;border:1px solid var(--line);color:var(--text);border-radius:10px;padding:11px;outline:none}textarea{min-height:92px}.btn{border:1px solid var(--line);background:#14213a;color:#fff;border-radius:10px;padding:10px 13px;cursor:pointer;font-weight:700}.btn:hover,.mini-btn:hover{filter:brightness(1.15)}.btn.primary{background:var(--primary);border-color:#3b82f6}.btn.danger{background:var(--danger);border-color:#ef4444}.btn.warn{background:#7c2d12;border-color:var(--warn)}.btn.success{background:#16a34a;color:#fff;border-color:#16a34a}.alert{padding:12px;border-radius:10px;margin:12px 0}.alert.error{background:#3b0b0b;color:#fecaca;border:1px solid #7f1d1d}
.status-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:14px}.status-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px}.status-card.small{min-height:74px;padding:10px 12px;position:relative}.status-card span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.status-card strong{font-size:20px;line-height:1.2;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-card.ok{border-color:#166534;background:linear-gradient(180deg,#0f2c1b,#0b1f16)}.status-card.fail{border-color:#7f1d1d;background:linear-gradient(180deg,#351111,#1f0b0b)}.status-card.on{border-color:#166534;background:linear-gradient(180deg,#0f2c1b,#0b1f16)}.status-card.off{border-color:#7f1d1d;background:linear-gradient(180deg,#351111,#1f0b0b)}.status-card.with-action strong{padding-right:70px}.mini-btn{position:absolute;right:9px;bottom:9px;border:1px solid #385173;background:#172033;color:#fff;border-radius:9px;padding:6px 9px;font-size:12px;font-weight:800;cursor:pointer}.mini-btn.on{background:#14532d;border-color:#16a34a}.mini-btn.off{background:#7f1d1d;border-color:#ef4444}
.monitor-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}.monitor{background:#020617;border:2px solid #b91c1c;border-radius:18px;overflow:hidden;box-shadow:0 0 0 1px #000}.monitor.preview{border-color:#16a34a}.monitor.program{border-color:#b91c1c}.monitor-title{height:42px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:#070b12}.monitor iframe{display:block;width:100%;aspect-ratio:16/9;border:0;background:#000}.pill{font-size:12px;color:#cbd5e1;background:#172033;border:1px solid var(--line);border-radius:999px;padding:4px 8px}.toolbar{display:flex;gap:10px;margin:14px 0 20px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.backpack{background:linear-gradient(180deg,#111f35,#0b1628);border:1px solid var(--line);border-radius:18px;padding:16px}.bp-head{display:flex;align-items:center;gap:10px}.bp-head h3{margin:0;flex:1}.color{width:12px;height:30px;border-radius:6px}.port{font-weight:800;color:#cbd5e1;background:#0b1220;border:1px solid var(--line);padding:5px 8px;border-radius:10px}.bp-meta{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:13px}.state{display:inline-flex;align-items:center;gap:7px;font-weight:900}.state:before{content:"";width:9px;height:9px;border-radius:999px;background:#64748b;display:inline-block}.state.connected{color:#86efac}.state.connected:before{background:#22c55e;box-shadow:0 0 12px #22c55e}.state.disconnected{color:#fecaca}.state.disconnected:before{background:#ef4444;box-shadow:0 0 12px #ef4444}.state.previewing{color:#bfdbfe}.state.previewing:before{background:#3b82f6}.state.programming{color:#fde68a}.state.programming:before{background:#f59e0b}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.table-wrap{overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:14px}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--line);padding:11px;text-align:left}th{color:#cbd5e1;background:#0b1628}.grid-form{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;margin-top:12px}.grid-form .wide{grid-column:1/-1}.check{justify-content:end}.note{margin-top:18px;background:#10203a;border:1px solid var(--line);border-radius:14px;padding:14px;color:#cbd5e1}.badge.ok{color:#86efac}.badge.error{color:#fecaca}
.modal-backdrop{display:none;position:fixed;inset:0;background:#0009;z-index:100;align-items:center;justify-content:center;padding:20px}.modal-backdrop.show{display:flex}.modal{width:min(520px,100%);background:#101b2e;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:0 24px 90px #000}.modal h2{margin:0 0 10px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
@media(max-width:1050px){.status-row{grid-template-columns:repeat(2,1fr)}.monitor-grid,.grid-form{grid-template-columns:1fr}.topbar{height:auto;align-items:flex-start;gap:12px;flex-direction:column;padding:14px}.topbar nav{flex-wrap:wrap}.container{padding:14px}}@media(max-width:520px){.status-row{grid-template-columns:1fr}.cards{grid-template-columns:1fr}}
