:root{--bg:#18191c;--panel:#202124;--panel-2:#2a2b2e;--panel-3:#35363a;--border:#2f3033;--border-bright:#3c3d40;--text:#e8eaed;--text-dim:#9aa0a6;--text-faint:#5f6368;--accent:#8ab4f8;--accent-dim:#5e8fd0;--btn-primary-bg:#e8eaed;--btn-primary-fg:#18191c;--btn-primary-hover:#fff;--download:#8ab4f8;--upload:#81c995;--warn:#fdd663;--crit:#f28b82;--info:#78d9ec;--purple:#c58af9;--pink:#ff8bcb;--orange:#fcad70;--sidebar-w:240px;--rp-w:320px;--radius:10px;--radius-sm:6px}:root[data-theme=light]{--bg:#f4f6f9;--panel:#fff;--panel-2:#f0f2f6;--panel-3:#e6e9ef;--border:#e3e7ee;--border-bright:#d3d9e2;--text:#1a1c1f;--text-dim:#5f6368;--text-faint:#9aa0a6;--accent:#1a73e8;--accent-dim:#4285f4;--btn-primary-bg:#111827;--btn-primary-fg:#fff;--btn-primary-hover:#1f2937;--download:#1a73e8;--upload:#1e8e3e;--warn:#e37400;--crit:#d93025;--info:#1295b3;--purple:#8430ce;--pink:#d01884;--orange:#e8710a}:root[data-theme=light] .brand-img{filter:none;opacity:1}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:13px;line-height:1.5}body{background:var(--bg)}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}a{color:var(--accent);text-decoration:none}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--panel);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:stretch;gap:10px;padding:20px 18px 18px;display:flex}.brand-logo{border-radius:var(--radius-sm);background:var(--accent);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.brand-img{object-fit:contain;object-position:left center;filter:invert()brightness()contrast(.92);opacity:.85;width:100%;max-height:30px;display:block}.login-logo{border-radius:var(--radius-sm);object-fit:contain;background:#fff;height:38px;margin-bottom:18px;padding:6px 10px;display:block}.brand-text{flex-direction:column;min-width:0;display:flex}.brand-text .logo{letter-spacing:-.2px;color:var(--text);font-size:16px;font-weight:700;line-height:1.1}.logo-sub{color:var(--text-faint);letter-spacing:.3px;font-size:10px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-sm);width:100%;color:var(--text-dim);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:9px 12px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item svg{opacity:.85;flex-shrink:0}.nav-item:hover{background:var(--panel-2);color:var(--text)}.nav-item.active{background:var(--panel-2);color:var(--text);position:relative}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:2px;position:absolute;top:6px;bottom:6px;left:0}.nav-item.active svg{opacity:1;color:var(--accent)}.nav-badge{background:var(--crit);color:#fff;text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.nav-badge.warning{background:var(--warn);color:#0a0d0c}.nav-badge.info{background:var(--accent);color:#fff}.sidebar-section-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint);padding:10px 16px 6px;font-size:10px}.site-list{flex-direction:column;flex-shrink:0;gap:2px;padding:0 10px 8px;display:flex}.site-select{background:var(--panel-2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:var(--radius-sm);outline:none;margin-bottom:6px;padding:8px 10px;font-size:12px}.site-row{color:var(--text-dim);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:6px 8px;font-size:12px;display:flex}.site-row .site-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.site-row .site-dot.online{background:var(--upload);box-shadow:0 0 5px var(--upload)}.site-row .site-dot.warning{background:var(--warn);box-shadow:0 0 5px var(--warn)}.site-row .site-dot.offline{background:var(--crit);box-shadow:0 0 5px var(--crit)}.site-row .site-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.site-row .site-state{color:var(--text-faint);font-size:10px}.sidebar-user{border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:12px 14px;display:flex}.sidebar-avatar{background:var(--panel-3);border:1px solid var(--border-bright);width:32px;height:32px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.sidebar-avatar-img{object-fit:cover}.sidebar-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sidebar-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-faint);text-transform:capitalize;font-size:10px}.sidebar-logout{border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:5px;transition:color .12s,border-color .12s;display:flex}.sidebar-logout:hover{color:var(--crit);border-color:var(--crit)}.main-content{flex-direction:column;flex:1;gap:18px;min-width:0;padding:20px 24px;display:flex;overflow-y:auto}.topbar{flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;display:flex}.topbar-text{flex:1;min-width:0}.nav-toggle{background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);justify-content:center;align-items:center;padding:8px;display:none}.nav-scrim{z-index:40;background:#0000008c;display:none;position:fixed;inset:0}.topbar-title{letter-spacing:-.4px;font-size:22px;font-weight:700}.topbar-sub{color:var(--text-dim);margin-top:2px;font-size:12px}.topbar-right{align-items:center;gap:10px;display:flex}.topbar-select{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);align-items:center;gap:6px;padding:7px 12px;font-size:12px;display:flex}.topbar-select svg{color:var(--text-dim)}.topbar-select-input{cursor:pointer;padding:5px 10px;transition:border-color .12s,background .12s}.topbar-select-input:hover{border-color:var(--border-bright);background:var(--panel-2)}.topbar-select-input select{color:var(--text);font:inherit;cursor:pointer;appearance:none;background:0 0;border:none;outline:none;padding:2px 4px}.topbar-select-input select option{background:var(--panel);color:var(--text)}.topbar-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);border:none;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:background .12s;display:flex}.topbar-btn:hover{background:#2563eb}.topbar-status{color:var(--text-dim);background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:6px;padding:6px 10px;font-size:11px;display:flex}.kpi-grid{flex-shrink:0;grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.kpi-tile{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:14px;padding:16px;display:flex}.kpi-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.kpi-icon.blue,.kpi-icon.green,.kpi-icon.purple,.kpi-icon.cyan,.kpi-icon.amber{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--text-dim)}.kpi-icon.red{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--crit)}.kpi-body{flex:1;min-width:0}.kpi-label{color:var(--text-dim);margin-bottom:4px;font-size:12px}.kpi-val{letter-spacing:-.4px;font-size:22px;font-weight:700;line-height:1.1}.kpi-val .unit{color:var(--text-dim);margin-left:4px;font-size:12px;font-weight:500}.kpi-delta{align-items:center;gap:6px;margin-top:4px;font-size:11px;display:flex}.kpi-delta.up{color:var(--upload)}.kpi-delta.down{color:var(--crit)}.kpi-delta.neutral{color:var(--text-dim)}.kpi-sub-row{color:var(--text-dim);gap:10px;margin-top:4px;font-size:11px;display:flex}.kpi-sub-row span.online{color:var(--upload)}.kpi-sub-row span.offline{color:var(--crit)}.kpi-sub-row span.warn{color:var(--warn)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden;container:panel/inline-size}.panel>.chart-fill{flex:1;min-height:0}.panel-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.panel-title{color:var(--text);font-size:14px;font-weight:600}.panel-title .sub{color:var(--text-dim);margin-left:6px;font-size:12px;font-weight:400}.panel-meta{color:var(--text-dim);align-items:center;gap:14px;font-size:11px;display:flex}.panel-link{color:var(--accent);background:0 0;border:none;font-size:12px;font-weight:500}.panel-body{padding:16px 18px}.chart-row{flex-shrink:0;grid-template-columns:1.4fr 1fr;gap:14px;display:grid}.wan-panel-body{grid-template-columns:1fr 130px;gap:16px;padding:16px 18px;display:grid}.wan-chart-wrap{min-width:0;height:220px}.wan-side-stats{border-left:1px solid var(--border);flex-direction:column;justify-content:center;gap:16px;padding-left:16px;display:flex}.wan-stat-label{color:var(--text-dim);font-size:11px}.wan-stat-val{letter-spacing:-.3px;font-size:22px;font-weight:700}.wan-stat-val .unit{color:var(--text-dim);margin-left:4px;font-size:11px;font-weight:500}.wan-stat-val.download{color:var(--download)}.wan-stat-val.upload{color:var(--upload)}.wan-stat-val.capacity{color:var(--text)}.wan-legend{color:var(--text-dim);align-items:center;gap:14px;font-size:11px;display:flex}.wan-legend-item{align-items:center;gap:6px;display:flex}.wan-legend-swatch{width:18px;height:2px}.wan-legend-swatch.dash{border-top:1.5px dashed;height:0}.site-wan-list{flex-direction:column;gap:12px;padding:12px 18px 14px;display:flex}.site-wan-row{flex-direction:column;gap:6px;font-size:12px;display:flex}.site-wan-head{align-items:center;gap:8px;display:flex}.site-wan-head .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.site-wan-head .name{color:var(--text);flex:1;font-weight:500}.site-wan-head .val{color:var(--text-dim);font-variant-numeric:tabular-nums}.site-wan-head .pct{color:var(--text);font-variant-numeric:tabular-nums;text-align:right;min-width:36px;font-weight:600}.site-wan-bar{background:var(--panel-2);border-radius:3px;height:6px;overflow:hidden}.site-wan-fill{border-radius:3px;height:100%;transition:width .4s}.site-wan-total{border-top:1px solid var(--border);justify-content:space-between;margin-top:4px;padding-top:12px;font-size:12px;display:flex}.site-wan-total .label{color:var(--text-dim)}.site-wan-total .val{color:var(--text);font-weight:600}.mid-row{flex-shrink:0;grid-template-columns:1.1fr 1.1fr .8fr;gap:14px;display:grid}.iface-util-list{padding:4px 0}.iface-util-head{letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);border-bottom:1px solid var(--border);grid-template-columns:1.1fr 1.1fr 1fr;gap:12px;padding:8px 18px;font-size:10px;display:grid}.iface-util-row{border-bottom:1px solid var(--border);grid-template-columns:1.1fr 1.1fr 1fr;align-items:center;gap:12px;padding:11px 18px;font-size:12px;display:grid}.iface-util-row:last-child{border-bottom:none}.iface-util-row .iname{font-weight:500}.iface-util-row .iname .role{color:var(--text-dim);margin-left:4px;font-size:11px;font-weight:400}.iface-util-row .isite{color:var(--text-dim)}.iface-util-bar-wrap{align-items:center;gap:8px;display:flex}.iface-util-bar{background:var(--panel-2);border-radius:3px;flex:1;height:6px;overflow:hidden}.iface-util-fill{border-radius:3px;height:100%;transition:width .4s}.iface-util-pct{font-variant-numeric:tabular-nums;text-align:right;min-width:34px;font-weight:600}.dist-body{grid-template-columns:160px 1fr;align-items:center;gap:16px;padding:14px 18px;display:grid}.dist-donut-wrap{flex-shrink:0;width:160px;height:160px;position:relative}@container panel (width<=420px){.dist-body{grid-template-columns:1fr;justify-items:center;gap:14px}.dist-donut-wrap{width:140px;height:140px}.dist-legend{width:100%}}.dist-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.dist-center-label{color:var(--text-dim);font-size:11px}.dist-center-val{letter-spacing:-.3px;margin-top:2px;font-size:20px;font-weight:700}.dist-center-unit{color:var(--text-dim);font-size:11px}.dist-legend{flex-direction:column;gap:8px;min-width:0;display:flex}.dist-legend-item{grid-template-columns:14px 1fr auto auto;align-items:center;gap:8px;font-size:12px;display:grid}.dist-swatch{border-radius:3px;flex-shrink:0;width:12px;height:12px}.dist-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dist-val{color:var(--text-dim);font-variant-numeric:tabular-nums}.dist-pct{color:var(--text-dim);font-variant-numeric:tabular-nums;text-align:right;min-width:50px}.gauge-body{flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:18px;display:flex}.gauge-num-row{letter-spacing:-.6px;text-align:center;font-size:28px;font-weight:700}.gauge-num-row .total{color:var(--text-dim);margin-left:4px;font-size:14px;font-weight:500}.gauge-label{color:var(--text-dim);text-align:center;font-size:12px}.right-panel{width:var(--rp-w);background:var(--bg);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:14px;padding:20px 16px;display:flex;overflow-y:auto}.top-tabs{border-bottom:1px solid var(--border);display:flex}.top-tab{color:var(--text-dim);background:0 0;border:none;flex:1;padding:10px 0;font-size:12px;font-weight:500;transition:color .12s;position:relative}.top-tab:hover{color:var(--text)}.top-tab.active{color:var(--accent)}.top-tab.active:after{content:"";background:var(--accent);height:2px;position:absolute;bottom:-1px;left:0;right:0}.settings-tabs{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;gap:4px;width:fit-content;max-width:100%;margin-bottom:22px;padding:4px;display:flex}.settings-tab{color:var(--text-dim);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.settings-tab:hover:not(.active){color:var(--text);background:var(--panel-2)}.settings-tab.active{background:var(--btn-primary-bg);color:var(--btn-primary-fg);font-weight:600}.settings-tab-panel{flex-direction:column;gap:22px;display:flex}.top-users-list{flex-direction:column;display:flex}.top-user-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 18px;display:flex}.top-user-row:last-child{border-bottom:none}.top-rank{color:var(--text-faint);min-width:16px;font-size:11px;font-weight:500}.user-avatar-circle,.user-avatar-circle.c0,.user-avatar-circle.c1,.user-avatar-circle.c2,.user-avatar-circle.c3,.user-avatar-circle.c4,.user-avatar-circle.c5{background:var(--panel-2);border:1px solid var(--border-bright);width:32px;height:32px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.top-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.top-user-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.top-user-ip{color:var(--text-faint);font-variant-numeric:tabular-nums;font-size:11px}.top-user-bps{font-variant-numeric:tabular-nums;flex-direction:column;align-items:flex-end;gap:1px;font-size:11px;display:flex}.top-user-bps .down{color:var(--download)}.top-user-bps .up{color:var(--upload)}.rp-empty{color:var(--text-dim);text-align:center;padding:18px;font-size:12px}.rp-empty.rp-ok{justify-content:center;align-items:center;gap:8px;display:flex}.qf-grid{grid-template-columns:1fr 1fr;gap:10px;padding:14px 18px;display:grid}.qf-select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);outline:none;width:100%;padding:8px 10px;font-size:12px}.qf-select.full{grid-column:1/-1}.qf-apply{background:var(--btn-primary-bg);color:var(--btn-primary-fg);border-radius:var(--radius-sm);border:none;grid-column:1/-1;padding:10px;font-size:12px;font-weight:600;transition:background .12s}.qf-apply:hover{background:var(--btn-primary-hover)}.alerts-list{flex-direction:column;display:flex}.alert-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:12px 18px;display:flex}.alert-row:last-child{border-bottom:none}.alert-icon-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;margin-top:1px;display:flex}.alert-icon-circle.critical{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--crit)}.alert-icon-circle.warning{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--warn)}.alert-icon-circle.info{background:var(--panel-2);border:1px solid var(--border-bright);color:var(--accent)}.alert-body{flex:1;min-width:0}.alert-title{margin-bottom:2px;font-size:12px;font-weight:600}.alert-detail{color:var(--text-dim);font-size:11px}.alert-badge{border-radius:10px;flex-shrink:0;align-items:center;gap:4px;margin-top:2px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.alert-badge.critical{color:var(--crit);border:1px solid var(--crit);background:0 0}.alert-badge.warning{color:var(--warn);border:1px solid var(--warn);background:0 0}.alert-badge.info{color:var(--accent);border:1px solid var(--accent);background:0 0}.alert-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.alert-provider{letter-spacing:.5px;text-transform:uppercase;color:var(--text-faint);border:1px solid var(--border-bright);vertical-align:middle;border-radius:3px;margin-left:8px;padding:1px 5px;font-size:9px;font-weight:600;display:inline-block}.alert-time{color:var(--text-faint);font-variant-numeric:tabular-nums;white-space:nowrap;margin-right:4px;font-size:11px}.alert-time-inline{color:var(--text-faint);font-variant-numeric:tabular-nums;margin-left:8px;font-size:10px}.alert-filters{flex-wrap:wrap;gap:6px;display:flex}.alert-filter-btn{color:var(--text-dim);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;transition:background .12s,color .12s,border-color .12s;display:inline-flex}.alert-filter-btn:hover{color:var(--text);border-color:var(--border-bright)}.alert-filter-btn .cnt{color:var(--text-faint);background:var(--panel-3);text-align:center;border-radius:999px;min-width:16px;padding:0 6px;font-size:10px}.alert-filter-btn.active{background:var(--btn-primary-bg);color:var(--btn-primary-fg);border-color:var(--btn-primary-bg)}.alert-filter-btn.active .cnt{color:var(--btn-primary-fg);background:#7f7f7f40}.alert-filter-btn.active.critical{background:var(--crit);border-color:var(--crit);color:#fff}.alert-filter-btn.active.warning{background:var(--warn);border-color:var(--warn);color:#1a1c1f}.alert-filter-btn.active.info{background:var(--accent);border-color:var(--accent);color:#0b1220}.alert-dismiss{border:1px solid var(--border-bright);color:var(--text-faint);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;transition:color .12s,border-color .12s,background .12s;display:flex}.alert-dismiss:hover{color:var(--crit);border-color:var(--crit);background:#ef444414}.alert-row.compact{align-items:center;padding:10px 14px}.alert-row.compact .alert-title{font-size:12px;line-height:1.3}.alert-row.compact .alert-icon-circle{width:26px;height:26px}.panel-link{cursor:pointer}.alert-badge:before{content:"●";font-size:8px}.users-table-wrap{overflow-x:auto}table.users{border-collapse:collapse;width:100%;font-size:12px}table.users thead th{text-align:left;color:var(--text-dim);border-bottom:1px solid var(--border);white-space:nowrap;background:0 0;padding:11px 16px;font-size:11px;font-weight:500}table.users tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}table.users tbody tr:hover{background:var(--panel-2)}table.users tbody tr.selected{background:#3b82f60f}table.users tbody tr.selected td:first-child{box-shadow:inset 3px 0 0 var(--accent)}table.users td{vertical-align:middle;padding:12px 16px}.user-cell{align-items:center;gap:10px;display:flex}.user-cell .name{font-weight:600}.mono{font-variant-numeric:tabular-nums;font-family:ui-monospace,JetBrains Mono,monospace}.cell-down{color:var(--download);font-weight:500}.cell-up{color:var(--upload);font-weight:500}.cell-total{font-weight:600}.sparkline{vertical-align:middle;display:inline-block}.pagination{border-top:1px solid var(--border);color:var(--text-dim);justify-content:space-between;align-items:center;padding:12px 18px;font-size:12px;display:flex}.pagination .pages{align-items:center;gap:4px;display:flex}.pagination .page-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;min-width:30px;padding:5px 10px;font-size:12px;transition:background .12s,color .12s}.pagination .page-btn:hover{background:var(--panel-3);color:var(--text)}.pagination .page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tag{letter-spacing:.3px;color:var(--text-dim);border:1px solid var(--border-bright);text-transform:lowercase;background:0 0;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.detail-grid{flex-shrink:0;grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.selected-user{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 18px;display:flex}.selected-user .info .name{font-size:16px;font-weight:700}.selected-user .info .sub{color:var(--text-dim);margin-top:2px;font-size:11px}.kv-list{padding:12px 18px}.kv{border-bottom:1px solid var(--border);justify-content:space-between;padding:7px 0;font-size:12px;display:flex}.kv:last-child{border-bottom:none}.kv .k{color:var(--text-dim)}.kv .v{color:var(--text);font-variant-numeric:tabular-nums}.dest-row{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;align-items:center;padding:9px 18px;font-size:12px;display:grid;position:relative}.dest-row:last-child{border-bottom:none}.dest-row .dest-bar{border-left:2px solid var(--accent);background:#3b82f60f;height:100%;position:absolute;top:0;left:0}.dest-row>*{z-index:2;position:relative}.dest-row .proto{color:var(--text-faint);margin-left:6px;font-size:11px}.pulse{background:var(--upload);width:7px;height:7px;box-shadow:0 0 6px var(--upload);border-radius:50%;animation:2s infinite pulse;display:inline-block}.pulse.off{background:var(--crit);box-shadow:0 0 6px var(--crit)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.login-shell{background:#141517;grid-template-columns:1.05fr 1fr;height:100vh;display:grid;overflow:hidden}.login-brand{background:radial-gradient(1200px 800px at -10% -10%,#8ab4f814,#0000 60%),radial-gradient(900px 700px at 110% 110%,#c58af90a,#0000 60%),linear-gradient(#202124 0%,#141517 100%);flex-direction:column;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.login-brand:before{content:"";pointer-events:none;background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000000d9,#00000026 70%,#0000);mask-image:linear-gradient(#000000d9,#00000026 70%,#0000)}.login-brand-inner{z-index:2;max-width:520px;position:relative}.login-constellation{z-index:1;pointer-events:none;opacity:.9;width:100%;height:100%;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 65%,#000 35%,#0000008c 65%,#0000 95%);mask-image:radial-gradient(circle at 50% 65%,#000 35%,#0000008c 65%,#0000 95%)}.login-brand-logo{background:#fff;border-radius:4px;height:30px;margin-bottom:36px;padding:5px 9px;display:block}.login-brand-org{letter-spacing:2.5px;text-transform:uppercase;color:var(--text-faint);margin-bottom:14px;font-size:11px}.login-wordmark{letter-spacing:-2px;color:#e5edf7;margin-bottom:20px;font-family:Instrument Serif,Cormorant Garamond,Georgia,serif;font-size:clamp(56px,8vw,96px);font-style:italic;font-weight:400;line-height:.95}.login-tagline{color:var(--text-dim);max-width:440px;margin-bottom:28px;font-size:16px;line-height:1.55}.login-stack-meta{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint);flex-wrap:wrap;align-items:center;gap:8px;font-size:11px;display:flex}.login-stack-meta .dot{color:var(--border-bright)}.login-brand-footer{z-index:1;color:var(--text-faint);letter-spacing:1px;justify-content:space-between;font-size:11px;display:flex;position:relative}.login-version{font-family:ui-monospace,JetBrains Mono,monospace}.login-form-pane{background:#18191c;border-left:1px solid #2f3033;justify-content:center;align-items:center;padding:48px 32px;display:flex}.login-form{flex-direction:column;width:100%;max-width:380px;display:flex}.login-form-head{margin-bottom:28px}.login-eyebrow{letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-size:10px;display:inline-block}.login-form-title{letter-spacing:-.8px;color:var(--text);margin-bottom:8px;font-family:Instrument Serif,Cormorant Garamond,Georgia,serif;font-size:36px;font-style:italic;font-weight:400;line-height:1.1}.login-form-sub{color:var(--text-dim);font-size:13px}.login-field{margin-bottom:16px}.login-field label{letter-spacing:1.8px;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px;font-size:10px;display:block}.login-field input{border:none;border-bottom:1px solid var(--border-bright);width:100%;color:var(--text);background:0 0;border-radius:0;outline:none;padding:10px 0 8px;font-family:ui-monospace,JetBrains Mono,monospace;font-size:14px;transition:border-color .15s}.login-field input:focus{border-bottom-color:var(--accent)}.login-field input::placeholder{color:var(--text-faint)}.login-google{color:#1f1f1f;border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:1px solid #0000;justify-content:center;align-items:center;gap:10px;width:100%;padding:11px 16px;font-family:Inter,-apple-system,system-ui,sans-serif;font-size:14px;font-weight:500;transition:box-shadow .15s,transform 50ms;display:flex}.login-google:hover:not(:disabled){box-shadow:0 1px 3px #0000004d,0 4px 8px #3c404329}.login-google:active:not(:disabled){transform:translateY(1px)}.login-google:disabled{opacity:.55;cursor:not-allowed}.login-divider{text-align:center;color:var(--text-faint);letter-spacing:2px;text-transform:uppercase;align-items:center;margin:18px 0 14px;font-size:11px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-divider span{padding:0 14px}.login-submit{border:1px solid var(--text);color:var(--text);letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:0;justify-content:space-between;align-items:center;margin-top:16px;padding:13px 18px;font-size:12px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:flex}.login-submit:not(:disabled):hover{background:var(--text);color:#18191c}.login-submit:disabled{opacity:.35;cursor:not-allowed}.login-submit .arrow{font-size:16px;transition:transform .15s}.login-submit:not(:disabled):hover .arrow{transform:translate(3px)}.login-err{color:var(--crit);border-left:2px solid var(--crit);margin-top:16px;padding-left:10px;font-family:ui-monospace,JetBrains Mono,monospace;font-size:12px}.login-helper{color:var(--text-faint);margin-top:28px;font-size:11px;line-height:1.6}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);width:380px;max-width:calc(100% - 32px);margin:auto;padding:36px 32px}.login-card h1{color:var(--text);letter-spacing:-.4px;margin-bottom:6px;font-family:Instrument Serif,Georgia,serif;font-size:28px;font-style:italic;font-weight:400}.login-card p{color:var(--text-dim);margin-bottom:24px;font-size:12px}.login-card label{color:var(--text-dim);margin-bottom:6px;font-size:11px;display:block}.login-card input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:var(--radius-sm);outline:none;margin-bottom:14px;padding:10px 12px;font-size:13px}.login-card input:focus{border-color:var(--accent)}.login-card button{background:var(--btn-primary-bg);width:100%;color:var(--btn-primary-fg);border-radius:var(--radius-sm);cursor:pointer;border:none;margin-top:6px;padding:12px;font-size:13px;font-weight:600;transition:background .12s}.login-card button:hover{background:var(--btn-primary-hover)}.login-card .err{color:var(--crit);margin-top:8px;font-size:12px}.login-shell:has(>.login-card){justify-content:center;align-items:center;display:flex}@media (width<=900px){.login-shell{grid-template-columns:1fr}.login-brand{min-height:50vh;padding:32px 24px}.login-wordmark{font-size:56px}.login-form-pane{border-top:1px solid #2f3033;border-left:none;padding:36px 24px}}footer{border-top:1px solid var(--border);color:var(--text-faint);flex-shrink:0;justify-content:space-between;margin-top:8px;padding-top:14px;font-size:11px;display:flex}.state-pill{letter-spacing:.5px;border:1px solid var(--border-bright);color:var(--text-dim);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:9px;font-weight:700;display:inline-block}.state-pill.state-up{color:var(--upload);border-color:var(--upload);background:#10b9810f}.state-pill.state-down{color:var(--crit);border-color:var(--crit);background:#ef44440f}.state-pill.state-no_cable,.state-pill.state-disabled{color:var(--text-faint);border-color:var(--border-bright);background:0 0}.resource-grid{grid-template-columns:repeat(4,1fr);gap:16px;padding:18px;display:grid}.resource-stat{flex-direction:column;gap:6px;display:flex}.resource-label{letter-spacing:1.2px;text-transform:uppercase;color:var(--text-faint);font-size:11px}.resource-bar{background:var(--panel-2);border-radius:3px;height:6px;overflow:hidden}.resource-fill{border-radius:3px;height:100%;transition:width .4s}.resource-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.resource-val{letter-spacing:-.3px;font-size:18px;font-weight:700}.resource-sub{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px}.resource-arch{color:var(--text);text-transform:lowercase;font-size:16px;font-weight:600}@media (width<=1100px){.resource-grid{grid-template-columns:repeat(2,1fr)}}.ai-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;padding:18px;display:grid}.ai-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.ai-card-head{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:4px;display:flex}.ai-card-title{align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.ai-card-sub{color:var(--text-dim);margin-top:2px;font-size:11px}.ai-default-pill{background:var(--accent);color:#fff;letter-spacing:.5px;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700}.ai-label{letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);margin-top:4px;font-size:10px}.ai-mask{text-transform:none;letter-spacing:0;color:var(--text-dim);margin-left:6px;font-family:ui-monospace,JetBrains Mono,monospace;font-weight:400}.ai-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);outline:none;padding:8px 10px;font-size:12px}.ai-input:focus{border-color:var(--accent)}.ai-actions{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.ai-btn{background:var(--panel-3);border:1px solid var(--border-bright);color:var(--text-dim);border-radius:var(--radius-sm);padding:6px 12px;font-size:11px;font-weight:600;transition:background .12s,color .12s}.ai-btn:hover:not(:disabled){background:var(--panel);color:var(--text)}.ai-btn:disabled{opacity:.5;cursor:not-allowed}.ai-btn.primary{background:var(--btn-primary-bg);color:var(--btn-primary-fg);border-color:var(--btn-primary-bg)}.ai-btn.primary:hover:not(:disabled){background:var(--btn-primary-hover);color:var(--btn-primary-fg);border-color:var(--btn-primary-hover)}.ai-btn.danger{color:var(--crit);border-color:var(--crit)}.ai-btn.danger:hover:not(:disabled){background:var(--crit);color:#fff}.ai-msg{border-radius:var(--radius-sm);margin-top:4px;padding:6px 8px;font-size:11px}.ai-msg.ok{color:var(--upload);background:#10b98114}.ai-msg.err{color:var(--crit);background:#ef444414}.invite-form{align-items:center;gap:8px;padding:16px 18px;display:flex}.invite-section-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-faint);border-top:1px solid var(--border);padding:12px 18px 6px;font-size:10px}.invite-empty{color:var(--text-dim);padding:14px 18px;font-size:12px}table.invite-table tbody tr{cursor:default}.invite-row-actions{justify-content:flex-end;gap:6px;display:flex}.role-select{color:var(--text-dim);border:1px solid var(--border-bright);letter-spacing:.3px;text-transform:lowercase;cursor:pointer;appearance:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%239aa0a6' stroke-width='2.5'><polyline points='6 9 12 15 18 9'/></svg>") right 6px center no-repeat;border-radius:10px;padding:2px 22px 2px 8px;font-size:10px;font-weight:600;transition:border-color .12s,color .12s}.role-select:hover{border-color:var(--accent);color:var(--text)}.role-select:focus{border-color:var(--accent);outline:none}.role-select option{background:var(--panel);color:var(--text);text-transform:none}.info-grid{grid-template-columns:1fr;gap:14px;padding:18px;display:grid}.info-grid.two{grid-template-columns:1fr 1fr;padding:0}.info-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.info-grid.two .info-card{background:var(--panel)}.info-card-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 16px;display:flex}.info-card-title{flex:1;font-size:14px;font-weight:600}.ap-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;padding:16px;display:grid}.ap-card.expanded{grid-column:1/-1}.ap-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:12px 14px;transition:border-color .12s,background .12s}.ap-card:hover{border-color:var(--border-bright)}.ap-card.expanded{border-color:var(--accent);background:var(--panel)}.ap-card-head{align-items:center;gap:8px;display:flex}.ap-card-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:600;overflow:hidden}.ap-chevron{color:var(--text-faint);flex-shrink:0;font-size:11px}.ap-summary{color:var(--text-dim);gap:14px;margin-top:8px;font-size:11px;display:flex}.ap-summary strong{color:var(--text);font-weight:600}.src-pill{letter-spacing:.3px;color:var(--text-faint);border:1px solid var(--border-bright);border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}@media (width<=1400px){.mid-row{grid-template-columns:1fr 1fr}.mid-row>:last-child{grid-column:1/-1}}@media (width<=1200px){:root{--rp-w:260px}.kpi-grid{grid-template-columns:repeat(3,1fr)}.chart-row{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr 1fr}.resource-grid{grid-template-columns:repeat(2,1fr)}.info-grid.two{grid-template-columns:1fr}}@media (width<=960px){.right-panel{display:none}.mid-row{grid-template-columns:1fr}.invite-form{flex-wrap:wrap}.wan-panel-body{grid-template-columns:1fr}.wan-side-stats{border-left:none;border-top:1px solid var(--border);flex-flow:wrap;gap:18px;padding-top:14px;padding-left:0}.dist-body{grid-template-columns:1fr}.dist-donut-wrap{margin:0 auto}}@media (width<=760px){.nav-toggle{display:inline-flex}.sidebar{z-index:50;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0006}.sidebar.open{transform:translate(0)}.nav-scrim{display:block}.main-content{gap:14px;padding:14px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-tile{gap:10px;padding:12px}.kpi-icon{width:40px;height:40px}.kpi-val,.topbar-title{font-size:18px}.topbar-sub{font-size:11px}.topbar-right{flex-wrap:wrap;gap:6px}.topbar-select{padding:6px 10px;font-size:11px}.topbar-btn{padding:7px 11px;font-size:11px}.detail-grid{grid-template-columns:1fr}.resource-grid{grid-template-columns:1fr;padding:14px}.panel-head{padding:12px 14px}.panel-title{font-size:13px}.panel-body{padding:14px}.ai-grid{grid-template-columns:1fr;gap:12px;padding:14px}.site-wan-head{flex-wrap:wrap}.iface-util-head,.iface-util-row{grid-template-columns:1fr auto auto;gap:8px;padding:10px 14px}.iface-util-row .isite{display:none}.invite-form{padding:12px 14px}.invite-form>select{width:100%}.invite-section-label{padding:12px 14px 6px}}@media (width<=420px){.kpi-grid{grid-template-columns:1fr}}@media (width<=960px){.cell-hide-md{display:none}}@media (width<=760px){.cell-hide-sm{display:none}}.users-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.users-table-wrap table.users{min-width:880px}table.users td.mono,table.users td.cell-down,table.users td.cell-up,table.users td.cell-total,table.users td.invite-row-actions{white-space:nowrap}@media (width<=760px){.users-table-wrap table.users{min-width:0}table.users thead th,table.users td{padding:10px 12px;font-size:11px}}
