@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b0f1a;--bg-elev-1:#0f1421;--card:#111827;--card-2:#161d2e;--card-hover:#1a2237;--border:#1e2535;--border-2:#262e42;--border-strong:#2f3a55;--t-1:#f1f5f9;--t-2:#cbd5e1;--t-3:#94a3b8;--t-4:#64748b;--t-5:#475569;--sky:#0ea5e9;--sky-soft:#0ea5e924;--sky-line:#0ea5e959;--sky-hi:#38bdf8;--amber:#f59e0b;--amber-soft:#f59e0b24;--amber-line:#f59e0b59;--ok:#22c55e;--ok-soft:#22c55e24;--ok-line:#22c55e59;--warn:#ef4444;--warn-soft:#ef444424;--warn-line:#ef444459;--warn-hi:#f87171;--orange:#f97316;--violet:#8b5cf6;--font:"IBM Plex Sans", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--mono:"IBM Plex Mono", ui-monospace, SFMono-Regular, monospace;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-pill:999px;--shadow-card:0 1px 0 #ffffff0a inset, 0 1px 2px #0000004d;--shadow-lg:0 10px 30px #00000080, 0 1px 0 #ffffff0a inset;--bg-base:var(--bg);--bg-surface:var(--bg-elev-1);--bg-card:var(--card);--bg-elevated:var(--card-2);--bg-hover:var(--card-hover);--border-lit:var(--border-strong);--text-pri:var(--t-1);--text-sec:var(--t-3);--text-muted:var(--t-4);--accent:var(--sky);--accent-hover:var(--sky-hi);--accent-dim:var(--sky-soft);--accent-border:var(--sky-line);--success:var(--ok);--success-dim:var(--ok-soft);--success-border:var(--ok-line);--danger:var(--warn);--danger-dim:var(--warn-soft);--danger-border:var(--warn-line);--warning:var(--amber);--warning-dim:var(--amber-soft);--warning-border:var(--amber-line);--purple:var(--violet);--purple-dim:#8b5cf624;--sidebar-w:232px;--topbar-h:60px;--radius-sm:var(--r-sm);--radius-md:var(--r-md);--radius-lg:var(--r-lg)}html,body,#root{background:var(--bg);height:100%;color:var(--t-1);font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-feature-settings:"ss01", "cv11";font-size:14px;line-height:1.45}input,button,select,textarea{font-family:inherit;font-size:inherit}a{color:var(--sky);text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-2)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-card)}.card-2{background:var(--card-2)}.card-pad{padding:18px 20px}.card-pad-lg{padding:22px 26px}.pill{border-radius:var(--r-pill);border:1px solid var(--border-2);background:var(--card-2);color:var(--t-2);letter-spacing:.01em;white-space:nowrap;flex:none;align-items:center;gap:6px;padding:2px 10px;font-size:11px;font-weight:500;line-height:1.6;display:inline-flex}.pill.ok{background:var(--ok-soft);border-color:var(--ok-line);color:#4ade80}.pill.warn{background:var(--warn-soft);border-color:var(--warn-line);color:var(--warn-hi)}.pill.sky{background:var(--sky-soft);border-color:var(--sky-line);color:var(--sky-hi)}.pill.amber{background:var(--amber-soft);border-color:var(--amber-line);color:#fbbf24}.pill.mute{border-color:var(--border-2);color:var(--t-3);background:#1a2032}.dot{background:var(--t-4);border-radius:50%;flex:none;width:7px;height:7px;display:inline-block}.dot.ok{background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft)}.dot.warn{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft);animation:1.6s ease-in-out infinite dot-pulse}.dot.sky{background:var(--sky);box-shadow:0 0 0 3px var(--sky-soft)}.dot.amber{background:var(--amber);box-shadow:0 0 0 3px var(--amber-soft)}.dot.off{background:var(--t-5)}@keyframes dot-pulse{0%,to{box-shadow:0 0 0 3px var(--warn-soft)}50%{box-shadow:0 0 0 6px #ef44440a}}.btn{font-family:var(--font);border-radius:var(--r-md);border:1px solid var(--border-2);background:var(--card);color:var(--t-1);cursor:pointer;white-space:nowrap;align-items:center;gap:7px;padding:7px 12px;font-size:13px;font-weight:500;line-height:1.4;text-decoration:none;transition:background .12s,border-color .12s;display:inline-flex}.btn:hover{background:var(--card-hover);border-color:var(--border-strong)}.btn.primary{background:var(--sky);border-color:var(--sky);color:#001621;font-weight:600}.btn.primary:hover{background:var(--sky-hi)}.btn.warn{background:var(--warn);border-color:var(--warn);color:#fff;font-weight:600}.btn.warn:hover{background:var(--warn-hi)}.btn.ghost{background:0 0}.btn.active{background:var(--card-hover);border-color:var(--border-strong)}.btn.icon{padding:7px 9px}.btn.sm{padding:5px 10px;font-size:12px}.btn.lg{padding:10px 16px;font-size:14px}.btn-primary{background:var(--sky);color:#001621;border-radius:var(--r-sm);cursor:pointer;letter-spacing:.01em;border:none;align-items:center;gap:6px;padding:7px 16px;font-size:12.5px;font-weight:700;transition:background .12s,transform 80ms;display:inline-flex}.btn-primary:hover{background:var(--sky-hi)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{color:var(--t-3);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:7px 16px;font-size:12.5px;font-weight:500;transition:border-color .12s,color .12s;display:inline-flex}.btn-ghost:hover{border-color:var(--border-strong);color:var(--t-1)}.btn-danger{background:var(--warn-soft);color:var(--warn);border:1px solid var(--warn-line);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:6px;padding:7px 16px;font-size:12.5px;font-weight:600;transition:background .12s;display:inline-flex}.btn-danger:hover{background:#ef444438}.btn-icon{border-radius:var(--r-md);border:1px solid var(--border-2);background:var(--card);width:34px;height:34px;color:var(--t-2);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s;display:inline-flex}.btn-icon:hover{background:var(--card-hover);color:var(--t-1)}.iconbtn{border-radius:var(--r-md);border:1px solid var(--border-2);background:var(--card);cursor:pointer;width:34px;height:34px;color:var(--t-2);place-items:center;display:grid;position:relative}.iconbtn:hover{background:var(--card-hover);color:var(--t-1)}.iconbtn .badge{background:var(--warn);color:#fff;border:2px solid var(--bg);border-radius:999px;place-items:center;min-width:16px;height:16px;padding:0 4px;font-size:9.5px;font-weight:600;display:grid;position:absolute;top:-4px;right:-4px}.input{font-family:var(--font);background:var(--bg-elev-1);border:1px solid var(--border-2);border-radius:var(--r-md);color:var(--t-1);outline:none;width:100%;padding:8px 12px;font-size:13px;transition:border-color .12s}.input:focus{border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-soft)}.input::placeholder{color:var(--t-4)}.input:disabled{color:var(--t-4);background:var(--card);cursor:not-allowed}.input.compact{padding:5px 9px;font-size:12px}.form-input{background:var(--card-2);border:1px solid var(--border-2);border-radius:var(--r-sm);width:100%;color:var(--t-1);outline:none;padding:9px 13px;font-size:13px;transition:border-color .12s}.form-input:focus{border-color:var(--sky-line)}.form-input::placeholder{color:var(--t-4)}.switch{cursor:pointer;border:1px solid var(--border-2);background:#243049;border-radius:999px;flex:none;width:32px;height:18px;transition:background .15s;display:inline-block;position:relative}.switch:after{content:"";background:#94a3b8;border-radius:50%;width:14px;height:14px;transition:transform .18s cubic-bezier(.2,.7,.3,1),background .15s;position:absolute;top:1px;left:1px}.switch.on{background:var(--sky);border-color:var(--sky)}.switch.on:after{background:#001621;transform:translate(14px)}.switch.warn.on{background:var(--warn);border-color:var(--warn)}.switch.warn.on:after{background:#200}.label{letter-spacing:.06em;text-transform:uppercase;color:var(--t-3);white-space:nowrap;font-size:11px;font-weight:500}.h1{letter-spacing:-.01em;margin:0;font-size:24px;font-weight:600;line-height:1.2}.h2{letter-spacing:-.005em;margin:0;font-size:18px;font-weight:600;line-height:1.2}.h3{margin:0;font-size:14px;font-weight:600;line-height:1.2}.num{font-family:var(--mono);font-variant-numeric:tabular-nums}.metric{letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:32px;font-weight:600;line-height:1}.metric.lg{font-size:44px}.metric.sm{font-size:22px}.mono{font-family:var(--mono)}.t2{color:var(--t-2)}.t3{color:var(--t-3)}.t4{color:var(--t-4)}.c-ok{color:#4ade80}.c-warn{color:var(--warn-hi)}.c-sky{color:var(--sky-hi)}.c-amber{color:#fbbf24}.row{display:flex}.col{flex-direction:column;display:flex}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.center{align-items:center}.between{justify-content:space-between}.grow{flex:auto}.trend{font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:11.5px;font-weight:500;display:inline-flex}.trend.up{color:var(--warn-hi)}.trend.dn{color:#4ade80}.trend.neutral{color:var(--t-3)}.rangebar{background:var(--bg-elev-1);border:1px solid var(--border-2);border-radius:2px;height:4px;position:relative;overflow:visible}.rangebar .track{background:linear-gradient(90deg, var(--sky), var(--orange));opacity:.45;border-radius:2px;position:absolute;inset:0}.rangebar .marker{background:var(--t-1);border:2px solid var(--bg);width:10px;height:10px;box-shadow:0 0 0 1px var(--border-strong);border-radius:50%;position:absolute;top:-3px;transform:translate(-50%)}.tabs{border-bottom:1px solid var(--border);gap:20px;display:flex}.tabs .tab{color:var(--t-3);cursor:pointer;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 2px;font-size:13px;font-weight:500;display:inline-flex}.tabs .tab:hover{color:var(--t-2)}.tabs .tab.active{color:var(--t-1);border-bottom-color:var(--sky)}.tabs .tab .count{color:var(--t-4);font-size:11px;font-weight:500}.search-wrap{position:relative}.search-wrap svg{color:var(--t-4);pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{background:var(--card);border:1px solid var(--border-2);border-radius:var(--r-md);font-family:var(--font);color:var(--t-1);outline:none;width:260px;padding:7px 12px 7px 32px;font-size:12.5px;transition:border-color .12s}.search-input:focus{border-color:var(--sky-line)}.search-input::placeholder{color:var(--t-4)}.hr{background:var(--border);border:0;height:1px;margin:0}.app{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-elev-1);border-right:1px solid var(--border);flex-direction:column;gap:22px;padding:22px 14px;display:flex;position:relative}.sidebar .brand{align-items:center;gap:10px;padding:0 6px;display:flex}.sidebar .brand .logomark{background:linear-gradient(135deg, var(--sky), #0369a1);border-radius:7px;place-items:center;width:28px;height:28px;display:grid;box-shadow:0 0 0 1px #0ea5e966,0 4px 14px #0ea5e940}.sidebar .brand .logomark svg{width:16px;height:16px;display:block}.sidebar .brand .word{letter-spacing:-.01em;color:var(--t-1);font-size:17px;font-weight:600}.sidebar .brand .tag{letter-spacing:.15em;text-transform:uppercase;color:var(--t-4);margin-top:1px;font-size:10px;font-weight:500}.sidebar nav{flex-direction:column;gap:2px;display:flex}.sidebar nav .nav-section{letter-spacing:.12em;text-transform:uppercase;color:var(--t-4);margin-top:8px;padding:4px 10px;font-size:10px;font-weight:600}.sidebar nav a{border-radius:var(--r-md);color:var(--t-2);align-items:center;gap:11px;padding:8px 10px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.sidebar nav a:hover{background:var(--card);color:var(--t-1)}.sidebar nav a.active{background:linear-gradient(90deg, var(--sky-soft), transparent 80%);color:var(--sky-hi)}.sidebar nav a.active:before{content:"";background:var(--sky);border-radius:0 2px 2px 0;width:2px;position:absolute;top:6px;bottom:6px;left:-14px}.sidebar nav a svg{color:currentColor;flex:none;width:16px;height:16px}.sidebar nav a .badge{background:var(--warn);color:#fff;border-radius:999px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600;line-height:1.4}.sidebar .foot{border-top:1px solid var(--border);margin-top:auto;padding-top:14px}.sidebar .user-card{border-radius:var(--r-md);background:var(--card);border:1px solid var(--border);align-items:center;gap:10px;padding:8px 10px;display:flex}.sidebar .user-card .avatar{background:linear-gradient(135deg, var(--sky), #0369a1);color:#001621;border-radius:50%;flex:none;place-items:center;width:30px;height:30px;font-size:12px;font-weight:600;display:grid}.sidebar .user-card .name{color:var(--t-1);font-size:12.5px;font-weight:600;line-height:1.2}.sidebar .user-card .email{color:var(--t-3);margin-top:2px;font-size:11px;line-height:1.2}.sidebar .live{color:var(--t-3);letter-spacing:.05em;align-items:center;gap:8px;margin-bottom:10px;padding:0 4px;font-size:11px;font-weight:500;display:flex}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);background:var(--bg);z-index:5;justify-content:space-between;align-items:center;gap:16px;padding:0 28px;display:flex;position:sticky;top:0}.crumbs{color:var(--t-3);font-size:13px}.crumbs a{color:var(--t-3);text-decoration:none}.crumbs a:hover{color:var(--t-2)}.crumbs strong{color:var(--t-1);font-weight:600}.crumbs .sep{color:var(--t-5);margin:0 6px}.main{padding:24px 28px 40px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--sky);opacity:.25;height:2px;position:absolute;top:0;left:0;right:0}.stat-card .stat-label{color:var(--t-4);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;font-size:10px;font-weight:700}.stat-card .stat-value{letter-spacing:-.5px;font-size:28px;font-weight:700;line-height:1}.stat-card .stat-sub{color:var(--t-4);margin-top:5px;font-size:11px}.badge{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.badge-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.badge-online{background:var(--ok-soft);color:#4ade80;border:1px solid var(--ok-line)}.badge-offline{background:var(--warn-soft);color:var(--warn-hi);border:1px solid var(--warn-line)}.badge-paused{background:var(--amber-soft);color:#fbbf24;border:1px solid var(--amber-line)}.badge-info{background:var(--sky-soft);color:var(--sky-hi);border:1px solid var(--sky-line)}.badge-purple{color:#a78bfa;background:#8b5cf624;border:1px solid #8b5cf64d}.filter-tabs{background:var(--bg-elev-1);border:1px solid var(--border);border-radius:var(--r-sm);gap:2px;padding:3px;display:flex}.filter-tab{cursor:pointer;color:var(--t-3);white-space:nowrap;background:0 0;border:none;border-radius:4px;padding:5px 14px;font-size:12px;font-weight:500;transition:all .12s}.filter-tab:hover{color:var(--t-1)}.filter-tab.active{background:var(--card-hover);color:var(--t-1);font-weight:600}.table-container{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead th{text-align:left;color:var(--t-4);letter-spacing:.1em;text-transform:uppercase;background:var(--bg-elev-1);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:10px;font-weight:700}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--card-hover)}.data-table tbody td{vertical-align:middle;padding:12px 16px}.toast-success{background:var(--ok-soft);border:1px solid var(--ok-line);border-radius:var(--r-sm);color:#4ade80;margin-bottom:12px;padding:8px 12px;font-size:12px}.toast-error{background:var(--warn-soft);border:1px solid var(--warn-line);border-radius:var(--r-sm);color:var(--warn-hi);margin-bottom:12px;padding:8px 12px;font-size:12px}.toast-warning{background:var(--amber-soft);border:1px solid var(--amber-line);border-radius:var(--r-sm);color:#fbbf24;margin-bottom:12px;padding:8px 12px;font-size:12px}.empty-state{min-height:180px;color:var(--t-4);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-label{color:var(--t-4);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-weight:700}.section-title{color:var(--t-1);letter-spacing:-.005em;font-size:16px;font-weight:600}.meta{color:var(--t-3);font-size:11.5px}.spark{display:block}@media (width<=768px){.app{grid-template-columns:1fr}.sidebar{display:none}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card .stat-value{font-size:22px}.stat-card{padding:12px 14px}}.summary{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.toolbar{justify-content:space-between;align-items:center;margin:0 0 16px;display:flex}.toolbar .left{align-items:center;gap:14px;display:flex}.grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.dcard{color:inherit;cursor:pointer;flex-direction:column;gap:14px;min-width:0;padding:16px 18px 14px;text-decoration:none;transition:border-color .15s,transform .15s;display:flex;position:relative}.dcard:hover{border-color:var(--border-strong);transform:translateY(-1px)}.dcard.alert:before{content:"";background:var(--warn);border-radius:2px;width:2px;position:absolute;top:14px;bottom:14px;left:0}.dcard .head{justify-content:space-between;align-items:flex-start;gap:10px;min-width:0;display:flex}.dcard .head>div:first-child{flex:auto;min-width:0}.dcard .name{white-space:nowrap;text-overflow:ellipsis;color:var(--t-1);font-size:15px;font-weight:600;line-height:1.25;overflow:hidden}.dcard .loc{color:var(--t-3);white-space:nowrap;align-items:center;gap:5px;margin-top:2px;font-size:11.5px;display:flex;overflow:hidden}.dcard .loc svg{width:11px;height:11px;color:var(--t-4);flex:none}.dcard .readings{grid-template-columns:repeat(3,1fr);gap:12px;padding-top:4px;display:grid}.dcard .reading .label-mini{color:var(--t-4);letter-spacing:.04em;text-transform:uppercase;font-size:10.5px;font-weight:500}.dcard .reading .v{font-family:var(--mono);letter-spacing:-.01em;margin-top:4px;font-size:21px;font-weight:500;line-height:1.1}.dcard .reading .v small{color:var(--t-3);margin-left:2px;font-size:12px}.dcard .reading.warn .v{color:var(--warn-hi)}.dcard .reading.off .v{color:var(--t-4)}.dcard .spark-wrap{margin:0 -2px;position:relative}.dcard .foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:12px;font-size:11px;display:flex}.dcard .foot .seen{color:var(--t-4);white-space:nowrap;align-items:center;gap:5px;display:inline-flex}.dcard .foot .cta{color:var(--t-3);white-space:nowrap;align-items:center;gap:4px;display:inline-flex}.dcard.alert .foot .cta{color:var(--warn-hi);font-weight:500}.ico{background:var(--card-2);border:1px solid var(--border-2);color:var(--t-3)}.ico.ok{background:var(--ok-soft);border-color:var(--ok-line);color:#4ade80}.ico.warn{background:var(--warn-soft);border-color:var(--warn-line);color:var(--warn-hi)}.ico.sky{background:var(--sky-soft);border-color:var(--sky-line);color:var(--sky-hi)}.ico.amber{background:var(--amber-soft);border-color:var(--amber-line);color:#fbbf24}@media (width<=1024px){.summary,.grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.summary{grid-template-columns:repeat(2,1fr)}.grid{grid-template-columns:1fr}}
