:root{
  --bg:#FBFBFC; --surface:#FFFFFF; --surface-2:#F5F6F7; --surface-3:#EEF0F2;
  --border:#E6E8EB; --border-strong:#D7DAE0;
  --text:#0B0E14; --text-2:#5B6270; --text-3:#8A909C;
  --primary:#5B5BD6; --primary-fg:#FFFFFF; --primary-soft:#EEEEFB; --primary-border:#D9D9F7;
  --onair:#E5484D; --onair-soft:#FDECEC;
  --success:#30A46C; --success-soft:#E7F6EE;
  --warn:#BB7A12; --warn-soft:#FBF1E0;
  --shadow:0 1px 2px rgba(11,14,20,.04), 0 1px 3px rgba(11,14,20,.03);
  --font-ui:'Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --r:6px; --r-sm:4px; --r-lg:9px;
}
[data-theme="dark"]{
  --bg:#0B0E14; --surface:#11151D; --surface-2:#161B24; --surface-3:#1C2230;
  --border:rgba(255,255,255,.08); --border-strong:rgba(255,255,255,.14);
  --text:#E8EAED; --text-2:#9AA1AD; --text-3:#646B78;
  --primary:#6E6AF0; --primary-fg:#FFFFFF; --primary-soft:rgba(110,106,240,.16); --primary-border:rgba(110,106,240,.35);
  --onair:#FF5A5F; --onair-soft:rgba(229,72,77,.16);
  --success:#3DD68C; --success-soft:rgba(48,164,108,.16);
  --warn:#E9A23B; --warn-soft:rgba(233,162,59,.14);
  --shadow:0 1px 2px rgba(0,0,0,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-ui);background:var(--bg);color:var(--text);font-size:13.5px;line-height:1.45;-webkit-font-smoothing:antialiased;letter-spacing:-.005em}
.mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1;letter-spacing:-.01em}
::selection{background:var(--primary-soft)}
.app{display:grid;grid-template-columns:212px 1fr;height:100vh;overflow:hidden}
.side{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}
.brand{display:flex;align-items:center;gap:9px;padding:14px 16px;border-bottom:1px solid var(--border)}
.brand .logo{width:22px;height:22px;border-radius:5px;background:linear-gradient(135deg,var(--primary),#8B5BD6);display:grid;place-items:center;flex:none}
.brand .logo svg{width:13px;height:13px}
.brand b{font-weight:600;font-size:14px;letter-spacing:-.02em}
.brand .env{margin-left:auto;font-size:10px;color:var(--text-3);border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-weight:500}
.nav{padding:8px;overflow-y:auto;flex:1}
.nav .grp{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-weight:600;padding:12px 8px 5px}
.nav a{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:var(--r-sm);color:var(--text-2);text-decoration:none;font-weight:500;font-size:13px;margin-bottom:1px;cursor:pointer}
.nav a svg{width:15px;height:15px;flex:none;opacity:.85}
.nav a:hover{background:var(--surface-2);color:var(--text)}
.nav a.on{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav a .badge{margin-left:auto;font-size:10px;background:var(--onair-soft);color:var(--onair);border-radius:20px;padding:0 6px;font-weight:600;font-family:var(--font-mono)}
.side .me{border-top:1px solid var(--border);padding:10px 12px;display:flex;align-items:center;gap:9px}
.av{width:24px;height:24px;border-radius:5px;background:var(--surface-3);display:grid;place-items:center;font-size:11px;font-weight:600;color:var(--text-2);flex:none}
.me .nm{font-size:12.5px;font-weight:500;line-height:1.2}
.me .nm small{display:block;color:var(--text-3);font-weight:400;font-size:11px}
.main{display:flex;flex-direction:column;min-width:0;min-height:0}
.top{height:52px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;gap:14px;padding:0 18px;flex:none}
.top .sp{flex:1}
.icon-btn{width:30px;height:30px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg);display:grid;place-items:center;cursor:pointer;color:var(--text-2)}
.icon-btn:hover{border-color:var(--border-strong);color:var(--text)}
.icon-btn svg{width:15px;height:15px}
.content{overflow-y:auto;padding:20px 22px 40px;flex:1;min-height:0}
.pagehdr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px;gap:12px}
.pagehdr h1{font-size:19px;font-weight:600;letter-spacing:-.02em}
.pagehdr p{color:var(--text-3);font-size:12.5px;margin-top:2px}
.btn{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 11px;border-radius:var(--r);font-weight:600;font-size:12.5px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text)}
.btn:hover{border-color:var(--border-strong)}
.btn.pri{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}
.btn.pri:hover{filter:brightness(1.06)}
.btn.danger{color:var(--onair);border-color:var(--onair-soft)}
.btn.danger:hover{background:var(--onair-soft)}
.btn.sm{height:25px;padding:0 8px;font-size:11.5px}
.btn svg{width:14px;height:14px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.stat{padding:13px 14px}
.stat .k{display:flex;align-items:center;gap:6px;color:var(--text-3);font-size:11.5px;font-weight:500;margin-bottom:9px}
.stat .k svg{width:13px;height:13px}
.stat .v{font-size:25px;font-weight:600;letter-spacing:-.03em;line-height:1}
.stat .v small{font-size:13px;color:var(--text-3);font-weight:500;letter-spacing:0}
.stat .sub{margin-top:7px;font-size:11.5px;color:var(--text-2);display:flex;align-items:center;gap:5px}
.ch{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid var(--border);gap:10px}
.ch h3{font-size:13px;font-weight:600}
.ch .tag{font-size:10.5px;font-weight:600;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);border-radius:4px;padding:1px 7px}
.pad{padding:14px}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;padding:8px 14px;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:9px 14px;border-bottom:1px solid var(--border);font-size:12.5px;color:var(--text-2);vertical-align:middle}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--surface-2)}
td b{color:var(--text);font-weight:600}
td .who{display:inline-flex;align-items:center;gap:7px;color:var(--text)}
td .acts{display:flex;gap:5px;justify-content:flex-end}
.pill{font-size:10.5px;font-weight:600;padding:1px 8px;border-radius:20px;white-space:nowrap;display:inline-block}
.pill.agent{background:var(--primary-soft);color:var(--primary)}
.pill.you{background:var(--surface-3);color:var(--text-2)}
.s-active,.s-running{background:var(--success-soft);color:var(--success)}
.s-suspended,.s-disabled,.s-stopped{background:var(--surface-3);color:var(--text-2)}
.s-pending{background:var(--warn-soft);color:var(--warn)}
.s-admin{background:var(--onair-soft);color:var(--onair)}
.dot-run{width:7px;height:7px;border-radius:50%;display:inline-block;background:var(--success)}
.dot-off{width:7px;height:7px;border-radius:50%;display:inline-block;background:var(--text-3)}
.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.search{flex:1;max-width:320px;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:7px 11px;font-family:var(--font-ui);font-size:13px;color:var(--text)}
.search:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.pager{display:flex;align-items:center;gap:8px;justify-content:flex-end;padding:11px 14px;color:var(--text-3);font-size:12px}
.empty{padding:34px;text-align:center;color:var(--text-3);font-size:12.5px}
a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--primary);outline-offset:1px}
.login{height:100vh;display:grid;place-items:center;background:var(--bg);padding:20px}
.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:26px 24px}
.login-card .lb{display:flex;align-items:center;gap:9px;margin-bottom:18px}
.login-card .lb .logo{width:26px;height:26px;border-radius:6px;background:linear-gradient(135deg,var(--primary),#8B5BD6);display:grid;place-items:center;flex:none}
.login-card .lb .logo svg{width:15px;height:15px}
.login-card .lb b{font-size:15px;font-weight:600}
.login-card .lb .env{margin-left:auto;font-size:10px;color:var(--text-3);border:1px solid var(--border);border-radius:4px;padding:1px 5px}
.login-card h1{font-size:16px;font-weight:600;margin-bottom:3px}
.login-card .hint{color:var(--text-3);font-size:12px;margin-bottom:18px}
.field{margin-bottom:12px}
.field label{display:block;font-size:11.5px;font-weight:600;color:var(--text-2);margin-bottom:5px}
.field input{width:100%;border:1px solid var(--border);border-radius:var(--r);background:var(--bg);padding:9px 11px;font-family:var(--font-ui);font-size:13.5px;color:var(--text)}
.field input.code{font-family:var(--font-mono);letter-spacing:.3em;text-align:center}
.field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.login-card .btn{width:100%;justify-content:center;height:36px;margin-top:6px}
.login-err{background:var(--onair-soft);color:var(--onair);font-size:12px;font-weight:500;border-radius:var(--r);padding:8px 11px;margin-bottom:12px}
.gate{height:100vh;display:grid;place-items:center;text-align:center;padding:20px}
.gate .card{max-width:380px;padding:26px}
.gate h2{font-size:16px;margin-bottom:8px}
.gate p{color:var(--text-2);font-size:13px;margin-bottom:16px}
.modal-wrap{position:fixed;inset:0;background:rgba(11,14,20,.45);display:grid;place-items:center;z-index:50;padding:20px}
.modal{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:0 12px 40px rgba(0,0,0,.28);max-height:86vh;overflow:auto}
.modal .mh{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.modal .mh h3{font-size:14px;font-weight:600}
.modal .mb{padding:16px}
.modal .mb .lab{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;margin:12px 0 5px}
.modal .mb .lab:first-child{margin-top:0}
.tok{font-family:var(--font-mono);font-size:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:9px 10px;word-break:break-all;color:var(--text-2)}
.mf{display:flex;gap:8px;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--border)}
select.inp{border:1px solid var(--border);border-radius:var(--r);background:var(--bg);padding:8px 10px;font-family:var(--font-ui);font-size:13px;color:var(--text);width:100%}
.toast-wrap{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:60}
.toast{background:var(--surface);border:1px solid var(--border-strong);border-left:3px solid var(--primary);border-radius:var(--r);box-shadow:0 6px 20px rgba(0,0,0,.18);padding:10px 13px;font-size:12.5px;font-weight:500;min-width:200px;max-width:340px}
.toast.ok{border-left-color:var(--success)}
.toast.err{border-left-color:var(--onair)}
[hidden]{display:none!important}
@media (max-width:1080px){.stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:720px){.app{grid-template-columns:1fr}.side{display:none}}
