:root{--bg-0: #05070d;--bg-1: #0a0e1a;--bg-2: #0f1525;--surface: #111a2e;--surface-1: #0f1728;--surface-hi: #172341;--surface-2: #0c1322;--border: #1d2944;--border-hi: #2a3a60;--text: #e9eefb;--text-dim: #b1bdd5;--text-muted: #7d8aa8;--accent: #5eb0ff;--accent-2: #7c5cff;--accent-3: #3ddc97;--danger: #ff5d73;--warn: #f2c14e;--ok: #3ddc97;--accent-soft: color-mix(in srgb, var(--accent) 14%, transparent);--danger-soft: color-mix(in srgb, var(--danger) 15%, transparent);--warn-soft: color-mix(in srgb, var(--warn) 15%, transparent);--ok-soft: color-mix(in srgb, var(--ok) 14%, transparent);--grad-hero: linear-gradient(135deg, #5eb0ff 0%, #7c5cff 60%, #3ddc97 120%);--grad-card: linear-gradient(160deg, rgba(94,176,255,.07), rgba(124,92,255,.015));--glow-soft: 0 10px 40px -12px rgba(0,0,0,.6);--glow-accent: 0 12px 44px -18px color-mix(in srgb, var(--accent) 60%, transparent);--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--ease-out: cubic-bezier(.16, 1, .3, 1);--gap: 18px;--pad: 18px;--tile-pad: 20px;--sb-w: 252px;--topbar-h: 60px;--mono: "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace}[data-theme=light]{--bg-0: #eef1f7;--bg-1: #f4f6fb;--bg-2: #ffffff;--surface: #ffffff;--surface-1: #f6f8fc;--surface-hi: #f7f9fd;--surface-2: #eef2f9;--border: #dbe2ef;--border-hi: #c5d0e6;--text: #0e1626;--text-dim: #44516c;--text-muted: #76839e;--accent: #2f7ce0;--accent-2: #6b48e8;--accent-3: #16a96d;--danger: #e23a52;--warn: #d99412;--ok: #16a96d;--grad-card: linear-gradient(160deg, rgba(47,124,224,.05), rgba(107,72,232,.015));--glow-soft: 0 10px 30px -14px rgba(40,60,110,.28)}[data-density=compact]{--gap: 12px;--pad: 13px;--tile-pad: 14px}[data-density=comfy]{--gap: 24px;--pad: 24px;--tile-pad: 26px}*{box-sizing:border-box}html,body{margin:0;height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-0);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}#root{height:100vh}::selection{background:var(--accent);color:#04131f}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(50vw 50vw at 8% -5%,color-mix(in srgb,var(--accent) 12%,transparent),transparent 60%),radial-gradient(48vw 48vw at 100% 0%,color-mix(in srgb,var(--accent-2) 10%,transparent),transparent 60%);opacity:.9}.shell{position:relative;z-index:1;display:grid;grid-template-columns:var(--sb-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"side top" "side main";height:100vh}.shell[data-nav=top]{grid-template-columns:1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"top" "main"}.sidebar{grid-area:side;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.shell[data-nav=top] .sidebar{display:none}.brand{display:flex;align-items:center;gap:11px;padding:0 18px;height:var(--topbar-h);border-bottom:1px solid var(--border);flex-shrink:0}.brand img{width:30px;height:30px;object-fit:contain;filter:drop-shadow(0 0 14px color-mix(in srgb,var(--accent) 45%,transparent))}.brand .name{font-weight:600;font-size:18px;letter-spacing:.2px}.brand .name b{font-weight:600}.icon-btn.sb-close{display:none}.nav-section{padding:14px 12px 6px}.nav-label{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);padding:0 10px 8px;font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--text-dim);font-size:14px;font-weight:500;cursor:pointer;transition:all .16s var(--ease-out);border:1px solid transparent;position:relative}.nav-item:hover{background:color-mix(in srgb,var(--surface) 70%,transparent);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:var(--text);border-color:color-mix(in srgb,var(--accent) 30%,transparent)}.nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:3px;background:var(--accent)}.nav-item .ico{width:18px;height:18px;flex-shrink:0;opacity:.9}.nav-item .badge-count{margin-left:auto}.badge-count{font-size:11px;font-weight:700;font-family:var(--mono);background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);border-radius:999px;min-width:19px;height:19px;padding:0 6px;display:inline-flex;align-items:center;justify-content:center}.sidebar .spacer{flex:1}.sb-foot{border-top:1px solid var(--border);padding:12px;display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:9px;flex-shrink:0;background:var(--grad-hero);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#04131f}.sb-foot .who{font-size:13px;font-weight:600;line-height:1.2}.sb-foot .role{font-size:11px;color:var(--text-muted)}.topbar{grid-area:top;position:relative;z-index:40;background:color-mix(in srgb,var(--bg-1) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 22px;min-height:0}.topbar .page-title{font-size:17px;font-weight:600;letter-spacing:-.01em}.topbar .page-sub{font-size:12.5px;color:var(--text-muted);font-family:var(--mono)}.icon-btn.hamburger{display:none}.top-nav{display:none;gap:4px;margin-left:8px}.shell[data-nav=top] .top-nav,.shell[data-nav=top] .topbar .brand-inline{display:flex}.brand-inline{display:none;align-items:center;gap:10px;padding-right:14px;margin-right:6px;border-right:1px solid var(--border)}.brand-inline img{width:26px;height:26px;filter:drop-shadow(0 0 12px color-mix(in srgb,var(--accent) 45%,transparent))}.brand-inline .name{font-weight:600;font-size:16px}.top-nav .nav-item{padding:7px 13px}.top-nav .nav-item.active:before{display:none}.top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.live-pill{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-family:var(--mono);color:var(--text-dim);background:var(--surface);border:1px solid var(--border);padding:6px 12px;border-radius:999px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 color-mix(in srgb,var(--ok) 70%,transparent);animation:pulse 2.4s infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--ok) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}to{box-shadow:0 0 0 0 transparent}}.icon-btn{width:36px;height:36px;border-radius:10px;cursor:pointer;background:var(--surface);border:1px solid var(--border);color:var(--text-dim);display:inline-flex;align-items:center;justify-content:center;transition:all .16s var(--ease-out);position:relative}.icon-btn:hover{color:var(--text);border-color:var(--border-hi);background:var(--surface-hi)}.icon-btn .dot-flag{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--bg-1)}.main{grid-area:main;overflow-y:auto;overflow-x:hidden;min-height:0}.lic-banner{display:flex;align-items:center;gap:10px;padding:11px 16px;margin-bottom:16px;border-radius:12px;font-size:13.5px;font-weight:600;border:1px solid transparent}.lic-banner svg{flex:0 0 auto}.lic-banner.crit{background:var(--danger-soft);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,transparent)}.lic-banner.warn{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in srgb,var(--warn) 40%,transparent)}.lic-banner.info{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.main>*{max-width:1600px;margin-left:auto;margin-right:auto}.main{padding:var(--pad) clamp(16px,3vw,48px) 40px}.main::-webkit-scrollbar{width:10px}.main::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:999px;border:3px solid var(--bg-0)}.range-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:var(--gap)}.seg{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.seg button{border:none;background:transparent;color:var(--text-muted);font-family:var(--mono);font-size:12px;font-weight:500;padding:6px 12px;border-radius:7px;cursor:pointer;transition:all .14s}.seg button:hover{color:var(--text-dim)}.seg button.on{background:var(--accent-soft);color:var(--text);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent)}.seg.sm button{padding:4px 9px;font-size:11px}.chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 13px;font-size:12.5px;color:var(--text-dim);cursor:pointer;transition:all .14s;font-weight:500}.chip:hover{border-color:var(--border-hi);color:var(--text)}.chip .x{opacity:.55;font-size:14px}.chip.add{border-style:dashed;color:var(--text-muted)}.grid{display:grid;gap:var(--gap)}.section-title{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--text-dim);margin:6px 2px 2px;text-transform:uppercase;font-size:11.5px;letter-spacing:.12em}.section-title .count{color:var(--text-muted);font-family:var(--mono);font-weight:500;letter-spacing:0;text-transform:none}.section-title .line{flex:1;height:1px;background:var(--border)}.card{background:var(--surface);background-image:var(--grad-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--tile-pad);position:relative}.card.hover:hover{border-color:var(--border-hi)}.kpi{display:flex;flex-direction:column;gap:12px;min-height:124px}.kpi .kpi-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.kpi .kpi-label{font-size:12.5px;color:var(--text-muted);font-weight:500}.kpi .kpi-ico{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}.kpi .kpi-val{font-size:30px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}.kpi .kpi-val .unit{font-size:14px;color:var(--text-muted);font-weight:500;margin-left:4px}.kpi .kpi-foot{display:flex;align-items:center;gap:8px;font-size:12px;font-family:var(--mono)}.delta{display:inline-flex;align-items:center;gap:3px;font-weight:600}.delta.up{color:var(--ok)}.delta.down{color:var(--danger)}.delta.flat{color:var(--text-muted)}.kpi .spark{margin-top:auto}.spill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;font-family:var(--mono);letter-spacing:.01em}.spill .d{width:7px;height:7px;border-radius:50%}.spill.ok{background:var(--ok-soft);color:var(--ok)}.spill.ok .d{background:var(--ok)}.spill.warn{background:var(--warn-soft);color:var(--warn)}.spill.warn .d{background:var(--warn)}.spill.crit{background:var(--danger-soft);color:var(--danger)}.spill.crit .d{background:var(--danger)}.spill.info{background:var(--accent-soft);color:var(--accent)}.spill.info .d{background:var(--accent)}.spill.idle{background:color-mix(in srgb,var(--text-muted) 16%,transparent);color:var(--text-muted)}.spill.idle .d{background:var(--text-muted)}.alarm-row{display:grid;grid-template-columns:4px auto 1fr auto auto;align-items:center;gap:14px;padding:13px 16px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);transition:all .16s var(--ease-out)}.alarm-row+.alarm-row{margin-top:9px}.alarm-row:hover{border-color:var(--border-hi);transform:translate(1px)}.alarm-row .rail{width:4px;height:100%;min-height:36px;border-radius:3px}.alarm-row.crit .rail{background:var(--danger)}.alarm-row.warn .rail{background:var(--warn)}.alarm-row.info .rail{background:var(--accent)}.alarm-row .a-meta{min-width:0}.alarm-row .a-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:9px}.alarm-row .a-sub{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alarm-row .a-val{font-family:var(--mono);font-size:13px;text-align:right}.alarm-row .a-val .lim{color:var(--text-muted);font-size:11px}.alarm-row .a-time{font-family:var(--mono);font-size:12px;color:var(--text-muted);text-align:right;white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;padding:8px 15px;border-radius:9px;border:1px solid var(--border-hi);background:var(--surface-hi);color:var(--text);transition:all .15s var(--ease-out);white-space:nowrap}.btn:hover{border-color:var(--accent);color:var(--text)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#04131f}.btn.primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.btn.ghost{background:transparent}.btn.sm{padding:5px 11px;font-size:12px}.btn.ack{background:var(--ok-soft);border-color:color-mix(in srgb,var(--ok) 35%,transparent);color:var(--ok)}.btn.ack:hover{background:var(--ok);color:#04131f}.ack-flash{animation:ackf .5s var(--ease-out)}@keyframes ackf{0%{background:var(--ok-soft)}to{background:var(--surface-2)}}.dev-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px;cursor:pointer;transition:all .16s var(--ease-out);display:flex;flex-direction:column;gap:11px}.dev-card:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:var(--glow-soft)}.dev-card.sel{border-color:var(--accent);box-shadow:var(--glow-accent)}.dev-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.dev-name{font-size:14px;font-weight:600;line-height:1.25}.dev-code{font-size:11.5px;color:var(--text-muted);font-family:var(--mono);margin-top:2px}.dev-proto{font-size:10px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:2px 7px;border-radius:6px;font-weight:600}.dev-metrics{display:flex;gap:16px}.dev-metric .m-val{font-size:18px;font-weight:600;font-variant-numeric:tabular-nums}.dev-metric .m-lab{font-size:10.5px;color:var(--text-muted);font-family:var(--mono);margin-top:1px}.dev-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:2px}.chart-wrap{position:relative;width:100%}.chart-wrap canvas{display:block;width:100%}.chart-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.chart-head .ct{font-size:15px;font-weight:600}.chart-head .cs{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-top:3px}.legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}.legend .li{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--text-dim);cursor:pointer}.legend .li .sw{width:11px;height:3px;border-radius:2px}.legend .li.off{opacity:.4}.legend .li .lv{margin-left:4px;font-family:var(--mono);color:var(--text);font-weight:600}.chart-tip{position:absolute;pointer-events:none;z-index:5;background:var(--bg-0);border:1px solid var(--border-hi);border-radius:10px;padding:9px 11px;font-size:12px;box-shadow:var(--glow-soft);transform:translate(-50%,-115%);white-space:nowrap;transition:opacity .1s}.chart-tip .tt-t{font-family:var(--mono);color:var(--text-muted);font-size:11px;margin-bottom:5px}.chart-tip .tt-r{display:flex;align-items:center;gap:7px}.chart-tip .tt-r+.tt-r{margin-top:3px}.chart-tip .tt-r .sw{width:9px;height:9px;border-radius:3px}.chart-tip .tt-r .v{font-family:var(--mono);font-weight:600;margin-left:auto;padding-left:14px}.view-toggle{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:3px}.view-toggle button{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;padding:6px 16px;border-radius:7px;transition:all .14s}.view-toggle button.on{background:var(--accent-soft);color:var(--text);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent)}.muted{color:var(--text-muted)}.mono{font-family:var(--mono)}.empty{color:var(--text-muted);font-size:13px;padding:30px;text-align:center}.fade-up{animation:fadeUp .45s var(--ease-out) both}@keyframes fadeUp{0%{transform:translateY(8px)}to{transform:none}}.login-stage{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.login-card{position:relative;z-index:2;width:min(420px,92vw);background:var(--surface);background-image:var(--grad-card);border:1px solid var(--border-hi);border-radius:var(--radius-lg);padding:36px 36px 28px;box-shadow:var(--glow-soft)}.login-brand{display:flex;align-items:center;gap:11px;margin-bottom:26px}.login-brand img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 0 14px color-mix(in srgb,var(--accent) 45%,transparent))}.login-brand .name{font-weight:600;font-size:20px;letter-spacing:.2px}.login-h{font-size:24px;font-weight:600;letter-spacing:-.02em;margin:0}.login-sub{font-size:13px;color:var(--text-muted);margin:6px 0 0}.login-err{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:500;color:var(--danger);background:var(--danger-soft);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent);border-radius:9px;padding:9px 12px}.login-remember{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input{accent-color:var(--accent);width:15px;height:15px}.login-link{font-size:12.5px;color:var(--accent);cursor:pointer;text-decoration:none}.login-link:hover{text-decoration:underline}.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--text-muted)}.pw-toggle:hover{color:var(--text)}.login-demo{margin-top:22px;padding-top:18px;border-top:1px solid var(--border);font-size:11.5px;color:var(--text-muted);line-height:1.6;text-align:center}.login-demo b{color:var(--text-dim);font-family:var(--mono)}.login-foot{position:relative;z-index:2;margin-top:22px;font-size:11px;color:var(--text-muted)}.acct-menu{position:absolute;bottom:calc(100% + 8px);left:12px;right:12px;z-index:70;background:var(--bg-0);border:1px solid var(--border-hi);border-radius:12px;padding:6px;box-shadow:var(--glow-soft)}.acct-menu .mi{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;font-size:13.5px;color:var(--text-dim);cursor:pointer}.acct-menu .mi:hover{background:var(--surface-hi);color:var(--text)}.acct-menu .mi.danger:hover{background:var(--danger-soft);color:var(--danger)}.acct-menu .sep{height:1px;background:var(--border);margin:4px 2px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:var(--gap);overflow-x:auto}.tabs::-webkit-scrollbar{height:0}.tab{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;padding:11px 15px;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .14s,border-color .14s;display:inline-flex;align-items:center;gap:8px}.tab:hover{color:var(--text-dim)}.tab.on{color:var(--text);border-bottom-color:var(--accent)}.tab .tcount{font-family:var(--mono);font-size:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:1px 6px;font-weight:500}.subtabs{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px;margin-bottom:var(--gap);flex-wrap:wrap}.subtabs button{border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:7px;transition:all .14s}.subtabs button.on{background:var(--surface-hi);color:var(--text);box-shadow:0 1px 3px #0003}.tbl{width:100%;border-collapse:separate;border-spacing:0}.tbl th{text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:600;padding:0 14px 11px;white-space:nowrap}.tbl td{padding:13px 14px;border-top:1px solid var(--border);font-size:13.5px;vertical-align:middle}.tbl tr:hover td{background:color-mix(in srgb,var(--surface-hi) 50%,transparent)}.tbl td.mono,.tbl td .mono{font-family:var(--mono);font-size:12.5px}.tbl .row-actions{display:flex;gap:6px;justify-content:flex-end}.t-strong{font-weight:600}.field{display:flex;flex-direction:column;gap:6px}.field>label{font-size:12px;font-weight:600;color:var(--text-dim)}.field .hint{font-size:11px;color:var(--text-muted)}.inp,.sel,textarea.inp{background:var(--surface-2);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:inherit;font-size:13.5px;padding:9px 12px;width:100%;transition:border-color .14s,box-shadow .14s;outline:none}.inp:focus,.sel:focus,textarea.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.inp.mono{font-family:var(--mono);font-size:12.5px}.sel{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237d8aa8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:32px;cursor:pointer}.sel.sm{height:30px;font-size:12px;padding-top:4px;padding-bottom:4px}.form-grid{display:grid;gap:14px 16px}.switch{display:inline-flex;align-items:center;gap:9px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;color:var(--text-dim)}.switch .track{width:38px;height:22px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);position:relative;transition:background .18s,border-color .18s;flex-shrink:0}.switch .knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:transform .18s var(--ease-out),background .18s}.switch.on .track{background:var(--accent-soft);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}.switch.on .knob{transform:translate(16px);background:var(--accent)}.chan-pick{display:flex;gap:6px;flex-wrap:wrap}.chan-chip{font-family:var(--mono);font-size:11px;font-weight:700;padding:5px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);cursor:pointer;transition:all .14s}.chan-chip.on{background:var(--accent-soft);border-color:color-mix(in srgb,var(--accent) 40%,transparent);color:var(--accent)}.drawer-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#03060e9e;animation:scrimIn .2s var(--ease-out)}@keyframes scrimIn{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;z-index:81;width:min(480px,94vw);background:var(--bg-1);border-left:1px solid var(--border);box-shadow:-20px 0 60px -20px #0009;display:flex;flex-direction:column;animation:drawerIn .28s var(--ease-out)}@keyframes drawerIn{0%{transform:translate(34px)}to{transform:none}}.drawer-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}.drawer-head .dt{font-size:16px;font-weight:600}.drawer-head .ds{font-size:12px;color:var(--text-muted);font-family:var(--mono);margin-top:2px}.drawer-body{padding:22px;overflow-y:auto;flex:1}.drawer-foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:var(--gap);flex-wrap:wrap}.page-head h1{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:600;font-size:27px;letter-spacing:-.02em;line-height:1.1}.page-head .ph-sub{font-size:13px;color:var(--text-muted);margin-top:7px}.page-head .ph-actions{display:flex;gap:10px}.statline{display:flex;gap:10px;flex-wrap:wrap}.stat-tile{flex:1;min-width:150px;background:var(--surface);background-image:var(--grad-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.stat-tile .sv{font-size:26px;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stat-tile .sl{font-size:12px;color:var(--text-muted);margin-top:3px}.help-prose{max-width:760px}.help-prose p{color:var(--text-dim);font-size:14px;line-height:1.7;margin:0 0 14px}.help-prose h3{font-size:16px;margin:26px 0 10px}.role-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.role-card .rn{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;margin-bottom:8px}.role-card ul{margin:0;padding-left:18px;color:var(--text-dim);font-size:13px;line-height:1.6}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);z-index:90;background:var(--bg-0);border:1px solid var(--border-hi);border-radius:12px;padding:12px 18px;display:flex;align-items:center;gap:10px;font-size:13.5px;box-shadow:var(--glow-soft);animation:toastIn .3s var(--ease-out)}.toast .ti{color:var(--ok)}@keyframes toastIn{0%{transform:translate(-50%,14px);opacity:0}to{transform:translate(-50%);opacity:1}}.kv{display:grid;grid-template-columns:auto 1fr;gap:9px 18px;align-items:center}.kv .k{font-size:12.5px;color:var(--text-muted)}.kv .v{font-family:var(--mono);font-size:12.5px}@media(max-width:1100px){.shell[data-nav=side]{grid-template-columns:1fr;grid-template-areas:"top" "main"}.shell[data-nav=side] .sidebar{position:fixed;top:0;left:0;bottom:0;width:min(82vw,300px);z-index:60;transform:translate(-100%);transition:transform .22s ease;box-shadow:2px 0 24px #00000059}.shell[data-nav=side] .sidebar.mobile-open{transform:translate(0)}.shell[data-nav=side] .sb-close{display:inline-flex;margin-left:auto}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.icon-btn.hamburger{display:inline-flex}.topbar{padding:0 12px;gap:10px}.topbar .live-pill{display:none}.main{padding:14px 12px}.grid[style*=repeat],.dash-row{grid-template-columns:1fr!important}.tbl{display:block;overflow-x:auto;white-space:nowrap}}@media(max-width:1100px){.shell[data-nav=top] .top-nav{flex-wrap:wrap}}@media(max-width:760px){.form-grid>div[style*=grid]{grid-template-columns:1fr!important}.range-bar{flex-wrap:wrap}.range-bar>*{min-width:0!important}[style*="minWidth: 280"],[style*="min-width: 280"],[style*="minWidth: 156"]{min-width:0!important;width:100%}}@media(max-width:560px){.topbar .brand-inline .name{display:none}[style*='gridTemplateColumns: "300px 1fr"'],[style*="grid-template-columns: 300px 1fr"],[style*="minmax(330px"],[style*="minmax(300px"]{grid-template-columns:1fr!important}[style*="width: 320"],[style*="width: 340"]{width:min(92vw,340px)!important}.range-bar>div{flex:1 1 100%}}
