:root{--bg: #060a14;--bg2: #0a1020;--line: #1b2942;--text: #c7d4ec;--dim: #3d5a80;--ok: #42a0ff;--warn: #ffb020;--crit: #ff4d5e;--failover: #ff7a29;--accent: #38bdf8}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:Rajdhani,system-ui,sans-serif;overflow:hidden}.dashboard{display:flex;flex-direction:column;height:100vh}.dash-body{position:relative;flex:1;min-height:0}.map-root{position:absolute;top:0;right:0;bottom:0;left:0}.topo-root{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:radial-gradient(circle at 50% 45%,#0b1322,var(--bg));padding:12px 330px 12px 12px;box-sizing:border-box}.topo-root>svg{width:100%;height:100%;display:block}.topo-label{fill:#a8bee2;font:600 13px Rajdhani,sans-serif;letter-spacing:.5px;paint-order:stroke;stroke:#050810;stroke-width:3px;pointer-events:none}.topo-node,.topo-hit{cursor:pointer}.topo-blink{animation:topoBlink .9s steps(2) infinite}@keyframes topoBlink{50%{opacity:.2}}.topo-flow{pointer-events:none;animation:topoFlow 1.2s linear infinite}.topo-flow-rev{animation-direction:reverse}@keyframes topoFlow{to{stroke-dashoffset:-29}}.topo-tip{position:fixed;z-index:60;pointer-events:none;background:#070c1af5;border:1px solid #1e2c4a;border-radius:5px;padding:9px 11px;min-width:190px;max-width:280px;font-family:JetBrains Mono,monospace;font-size:11px;line-height:1.55;color:#c7d4ee;box-shadow:0 6px 22px #0000008c}.topo-tip-head{display:flex;justify-content:space-between;align-items:baseline;gap:14px;border-bottom:1px solid #1e2c4a;padding-bottom:5px;margin-bottom:6px}.topo-tip-title{font-family:Rajdhani,sans-serif;font-weight:700;font-size:13px;letter-spacing:.6px;color:#eaf1ff}.topo-tip-state{font-weight:700;white-space:nowrap}.topo-tip-row{display:flex;justify-content:space-between;gap:14px}.topo-tip-row span:first-child{color:#5b7398}.topo-tip-note{margin-top:5px;color:#ffb020}.topo-legend{position:absolute;left:14px;bottom:14px;display:flex;gap:14px;flex-wrap:wrap;align-items:center;padding:8px 14px;border-radius:8px;background:#070b16d1;border:1px solid rgba(120,150,200,.15);font:600 11px Rajdhani,sans-serif;letter-spacing:1px;color:#8ba0c4;white-space:nowrap;line-height:1}.topo-legend span{display:inline-flex;align-items:center;gap:6px}.topo-legend svg{display:block;flex:none}.topo-legend-sep{width:1px;height:14px;align-self:center;background:#7896c840}.topo-site-label{fill:#5f7aa6;font:700 12px Rajdhani,sans-serif;letter-spacing:2px}.topo-wg-tag{fill:#8b9cb8;font:700 9px JetBrains Mono,monospace;letter-spacing:1px}.topo-hot{animation:topoHot 1.1s ease-in-out infinite;pointer-events:none}@keyframes topoHot{0%,to{opacity:.35}50%{opacity:1}}.topo-transit-name{fill:#c7d4ec;font:700 10.5px Rajdhani,sans-serif;letter-spacing:1px;text-transform:uppercase;pointer-events:none}.topo-transit-stats{font:700 8.5px JetBrains Mono,monospace;pointer-events:none}.topo-legend i{display:inline-block;width:18px;height:3px;border-radius:2px}.topo-legend i.dot{width:9px;height:9px;border-radius:50%}.map-legend{bottom:30px;z-index:6;pointer-events:none;gap:12px;padding:6px 12px;font-size:10px;max-width:min(72vw,980px)}.topo-legend-dash{background:repeating-linear-gradient(90deg,#6e788c 0 4px,transparent 4px 8px)}.map-error{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:radial-gradient(circle at 50% 40%,#0c1426,var(--bg));text-align:center}.map-error h2{color:var(--warn);letter-spacing:2px;margin-bottom:8px}.map-error p{color:var(--dim);font-family:JetBrains Mono,monospace;font-size:13px}.topbar{display:flex;align-items:center;gap:18px;padding:8px 16px;background:linear-gradient(180deg,#0c1426,var(--bg2));border-bottom:1px solid var(--line);z-index:20}.brand{display:flex;align-items:center;gap:10px}.brand-home{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit;cursor:pointer}.brand-home:hover h1{color:var(--accent)}.brand h1{font-size:19px;letter-spacing:3px;font-weight:700;transition:color .15s}.brand h1 span{color:var(--accent)}.brand-dot{width:10px;height:10px;border-radius:50%;background:var(--crit);box-shadow:0 0 8px var(--crit)}.brand-dot[data-ok=true]{background:var(--ok);box-shadow:0 0 8px var(--ok)}.sim-badge{font-size:10px;letter-spacing:2px;color:var(--warn);border:1px solid var(--warn);border-radius:3px;padding:1px 6px}.role-tag{font:700 10px Rajdhani,sans-serif;letter-spacing:2px;color:var(--dim);background:transparent;border:1px solid var(--line);border-radius:3px;padding:2px 8px;cursor:pointer}.role-tag:hover{color:var(--text);border-color:#8b9cb8}.account{position:relative}.account-emblem{width:30px;height:30px;border-radius:50%;cursor:pointer;background:#0d2240;border:1px solid var(--line);color:var(--accent);font:700 13px Rajdhani,sans-serif;letter-spacing:0;display:flex;align-items:center;justify-content:center;padding:0}.account-emblem:hover{border-color:var(--accent);background:#123058}.account-menu{position:absolute;top:38px;right:0;z-index:60;min-width:180px;background:#0a1322;border:1px solid var(--line);border-radius:6px;box-shadow:0 12px 40px #0000008c;padding:6px;overflow:hidden}.account-id{display:flex;flex-direction:column;gap:2px;padding:8px 10px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}.account-id-name{font:700 14px Rajdhani,sans-serif;letter-spacing:1px;color:#eaf1ff}.account-id-role{font-size:10px;letter-spacing:1.5px;color:var(--dim);text-transform:uppercase}.account-item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--text);font:600 12px Rajdhani,sans-serif;letter-spacing:.5px;padding:8px 10px;border-radius:4px;cursor:pointer}.account-item:hover{background:#122440;color:#eaf1ff}.account-item.danger:hover{background:#2a0c12;color:var(--crit)}.account-ok{color:var(--ok);font-size:13px;margin:6px 0 2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#03060ea8}.modal-card{width:320px;padding:22px 22px 18px;background:#0a1020f7;border:1px solid var(--line);border-radius:8px;box-shadow:0 16px 60px #000000a6}.modal-card h3{margin:0 0 16px;font:700 16px Rajdhani,sans-serif;letter-spacing:2px;color:#eaf1ff}.modal-card form{display:flex;flex-direction:column;gap:10px}.modal-card input{background:#0c1426;border:1px solid var(--line);border-radius:4px;color:var(--text);padding:9px 12px;font-family:JetBrains Mono,monospace;font-size:13px}.modal-card input:focus{outline:none;border-color:var(--accent)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.modal-actions button{background:#0d2240;border:1px solid var(--ok);border-radius:4px;color:var(--ok);font:700 12px Rajdhani,sans-serif;letter-spacing:2px;padding:8px 16px;cursor:pointer}.modal-actions button:hover:not(:disabled){background:#123058}.modal-actions button:disabled{opacity:.45;cursor:default}.modal-actions button.ghost{background:transparent;border-color:var(--line);color:var(--dim)}.modal-actions button.ghost:hover{color:var(--text);border-color:#8b9cb8}.login-root{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 35%,#0c1426,var(--bg))}.login-card{width:340px;padding:34px 32px 26px;background:#0a1020eb;border:1px solid var(--line);border-radius:8px;box-shadow:0 12px 50px #0009}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:26px}.login-brand h1{font:700 22px Rajdhani,sans-serif;letter-spacing:3px;color:#eaf1ff}.login-brand h1 span{color:var(--accent)}.login-card form{display:flex;flex-direction:column;gap:10px}.login-card input{background:#0c1426;border:1px solid var(--line);border-radius:4px;color:var(--text);padding:9px 12px;font-family:JetBrains Mono,monospace;font-size:13px}.login-card input:focus{outline:none;border-color:var(--accent)}.login-card button{background:#0d2240;border:1px solid var(--ok);border-radius:4px;color:var(--ok);font:700 13px Rajdhani,sans-serif;letter-spacing:2px;padding:9px;cursor:pointer}.login-card button:hover:not(:disabled){background:#123058}.login-card button:disabled{opacity:.45;cursor:default}.login-err{color:var(--crit);font-family:JetBrains Mono,monospace;font-size:11px}.login-sep{display:flex;align-items:center;gap:10px;color:var(--dim);font-size:11px;letter-spacing:2px;margin:14px 0}.login-sep:before,.login-sep:after{content:"";flex:1;height:1px;background:var(--line)}.login-guest{width:100%;background:transparent!important;border:1px solid var(--line)!important;color:var(--dim)!important;border-radius:4px;font:700 13px Rajdhani,sans-serif;letter-spacing:2px;padding:9px;cursor:pointer}.login-guest:hover{color:var(--text)!important;border-color:#8b9cb8!important}.login-note{margin-top:16px;color:var(--dim);font-size:11px;line-height:1.5}.topbar-mid{display:flex;gap:6px;flex:1;justify-content:center;flex-wrap:wrap}.chip{background:transparent;color:var(--dim);border:1px solid var(--line);border-radius:3px;padding:3px 10px;font-family:inherit;font-weight:600;font-size:11px;letter-spacing:1.5px;cursor:pointer}.chip.on{color:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #38bdf833}.chip:disabled{opacity:.35;cursor:default}.topbar-right{display:flex;align-items:center;gap:14px}.alert-pills{display:flex;gap:6px}.pill{font-size:11px;font-weight:700;letter-spacing:1px;border-radius:3px;padding:2px 8px}.pill.crit{background:var(--crit);color:#fff;animation:blink 1s infinite}.pill.warn{background:var(--warn);color:#211}.pill.ok{background:#0d2240;color:var(--ok);border:1px solid var(--ok)}@keyframes blink{50%{opacity:.55}}.clock{font-family:JetBrains Mono,monospace;font-size:16px;color:var(--accent)}.nav{display:flex;gap:10px}.nav a{color:var(--dim);text-decoration:none;font-size:12px;font-weight:600;letter-spacing:1.5px;padding:3px 6px}.nav a.active,.nav a:hover{color:var(--text)}.alert-feed{position:absolute;top:10px;right:10px;bottom:10px;width:295px;display:flex;flex-direction:column;z-index:10;background:#0a1020e6;border:1px solid var(--line);border-radius:6px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.alert-feed h2{font-size:12px;letter-spacing:3px;color:var(--dim);padding:10px 12px 6px;border-bottom:1px solid var(--line)}.alert-scroll{overflow-y:auto;flex:1;padding:6px}.alert-empty{color:var(--dim);text-align:center;padding:20px;font-size:13px}.alert-item{border:1px solid var(--line);border-left-width:3px;border-radius:4px;padding:7px 9px;margin-bottom:6px;cursor:pointer;background:#0c1426}.alert-item.critical{border-left-color:var(--crit)}.alert-item.warning{border-left-color:var(--warn)}.alert-item.info{border-left-color:var(--accent)}.alert-item.resolved{opacity:.45}.alert-item.ack{opacity:.7}.alert-row{display:flex;justify-content:space-between;align-items:center}.alert-sev{font-size:10px;font-weight:700;letter-spacing:1.5px}.alert-item.critical .alert-sev{color:var(--crit)}.alert-item.warning .alert-sev{color:var(--warn)}.alert-item.info .alert-sev{color:var(--accent)}.alert-time{font-size:10px;color:var(--dim);font-family:JetBrains Mono,monospace}.gps-input{width:90px;font-size:12px}.iface-sub{color:#3d5a80;font-size:10px}.name-input{width:170px;font-size:12px;background:transparent;border-color:transparent}.name-input:hover,.name-input:focus{border-color:#1b2942;background:#0a1020}.iface-names{font-size:11px;word-break:break-all}.role-badge{font-weight:700;letter-spacing:1px;font-size:10px;border-radius:3px;padding:1px 5px}.role-badge.primary{color:#42a0ff;border:1px solid #42a0ff66}.role-badge.backup{color:#ffb020;border:1px solid #ffb02066}.role-mode{color:#3d5a80;font-size:10px}.gps-input.wide{width:185px}.gps-input.invalid{border-color:var(--crit)}.site-link.viewing{border-color:#ffffff59}.row-warn td{background:#2a180a55}.badge-warn{color:#ffb020;font-size:9px;font-weight:700;letter-spacing:1px;border:1px solid #ffb02066;border-radius:3px;padding:0 4px;margin-left:6px}button.danger{color:var(--crit);border-color:var(--crit)}.discover-preview{border:1px solid var(--line);border-radius:6px;padding:10px 12px;margin-top:10px;background:#0c1426}.discover-preview h3{margin:8px 0 4px}.dim-note{color:var(--dim);font-size:12px;margin:6px 0}code.bad{color:var(--crit)}.flap-badge{font-size:9px;font-weight:700;letter-spacing:.5px;font-family:JetBrains Mono,monospace;color:var(--dim);border:1px solid var(--line);border-radius:8px;padding:1px 6px;margin:0 6px}.flap-badge.flapping{color:#ffb020;border-color:#ffb02066;background:#ffb02014;animation:flap-pulse 1.6s ease-in-out infinite}@keyframes flap-pulse{0%,to{box-shadow:0 0 #ffb02000}50%{box-shadow:0 0 6px #ffb02055}}.alert-msg{font-size:13px;margin:3px 0;line-height:1.25}.alert-foot{margin-top:2px}.alert-cat{font-size:10px;color:var(--dim);letter-spacing:1px}.ack-btn{background:transparent;border:1px solid var(--dim);color:var(--dim);font-size:10px;padding:1px 7px;border-radius:3px;cursor:pointer;font-family:inherit;font-weight:600}.ack-btn:hover{color:var(--text);border-color:var(--text)}.ack-label,.resolved-label{font-size:10px;color:var(--dim)}.detail-panel{position:absolute;top:10px;left:10px;bottom:10px;width:340px;z-index:11;overflow-y:auto;background:#0a1020f0;border:1px solid var(--line);border-radius:6px;padding:14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.close-btn{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--dim);font-size:15px;cursor:pointer}.detail-panel h2{font-size:17px;letter-spacing:1px;margin-bottom:8px;padding-right:20px}.detail-panel h3{font-size:11px;letter-spacing:2px;color:var(--dim);margin:14px 0 6px;text-transform:uppercase}.state-banner{font-weight:700;letter-spacing:1.5px;font-size:13px;padding:6px 10px;border-radius:4px;margin-bottom:10px;display:flex;align-items:center;gap:8px}.state-banner.up{background:#0d2240;color:var(--ok)}.state-banner.degraded{background:#2e2208;color:var(--warn)}.state-banner.failover{background:#2e1808;color:var(--failover)}.state-banner.down{background:#2e0d12;color:var(--crit)}.state-banner.maint{background:#1a2230;color:#8b9cb8}.maint-btn{width:100%;margin:-2px 0 12px;padding:5px 0;background:transparent;border:1px solid #34435e;border-radius:4px;color:#8b9cb8;font:700 11px Rajdhani,sans-serif;letter-spacing:1.5px;cursor:pointer}.maint-btn:hover{border-color:#8b9cb8;color:#c6d4ec}.maint-btn.on{border-color:var(--warn);color:var(--warn)}.maint-btn:disabled{opacity:.5;cursor:wait}.alert-actions{display:inline-flex;gap:6px}.spof-tag{font-size:10px;background:var(--crit);color:#fff;padding:1px 6px;border-radius:3px}.kv{display:grid;grid-template-columns:90px 1fr;gap:4px 10px;font-size:13px}.kv dt{color:var(--dim)}.kv dd{font-family:JetBrains Mono,monospace;font-size:12px}.bad{color:var(--crit);font-weight:600}.chart-box{background:#07101e;border:1px solid var(--line);border-radius:4px;padding:4px}.site-links{display:flex;flex-direction:column;gap:4px}.site-link{display:flex;align-items:center;gap:8px;text-align:left;background:#0c1426;border:1px solid var(--line);border-radius:4px;color:var(--text);padding:6px 9px;cursor:pointer;font-family:inherit;font-size:12.5px}.site-link:hover{border-color:var(--accent)}.site-link-util{margin-left:auto;color:var(--dim);font-family:JetBrains Mono,monospace;font-size:11px}.led{width:8px;height:8px;border-radius:50%;flex-shrink:0}.led.up{background:var(--ok);box-shadow:0 0 6px var(--ok)}.led.degraded{background:var(--warn);box-shadow:0 0 6px var(--warn)}.led.failover{background:var(--failover);box-shadow:0 0 6px var(--failover)}.led.down{background:var(--crit);box-shadow:0 0 6px var(--crit)}.dash-bottom{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);background:var(--bg2);padding:6px 14px;z-index:20}.bgp-strip{display:flex;align-items:center;gap:10px;flex:1;overflow-x:auto}.bgp-title{font-size:10px;letter-spacing:3px;color:var(--dim)}.bgp-card{display:flex;flex-direction:column;gap:2px;min-width:190px;border:1px solid var(--line);border-radius:5px;padding:5px 10px;background:#0c1426}.bgp-card.down{border-color:var(--crit);animation:blink 1s infinite}.bgp-head{display:flex;align-items:center;gap:7px;font-size:13px}.bgp-asn{color:var(--dim);font-size:11px;font-family:JetBrains Mono,monospace}.bgp-led{width:8px;height:8px;border-radius:50%}.bgp-led.established{background:var(--ok);box-shadow:0 0 6px var(--ok)}.bgp-led.down{background:var(--crit);box-shadow:0 0 6px var(--crit)}.bgp-stats{display:flex;gap:10px;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--dim)}.bgp-tx{color:var(--ok)}.bgp-rx{color:var(--accent)}.bgp-down-label{color:var(--crit);font-weight:700;letter-spacing:1px}.bgp-card.disabled{border-style:dashed;opacity:.65}.bgp-led.disabled{background:#5b6c8a;box-shadow:none}.bgp-disabled-label{color:#8aa0c0;font-weight:700;letter-spacing:1px}.bgp-card.pegged{border-color:var(--crit);animation:blink 1s infinite}.bgp-util-pct{margin-left:auto;font:700 11px JetBrains Mono,monospace}.bgp-util-pct.ok{color:var(--accent)}.bgp-util-pct.warn{color:var(--warn)}.bgp-util-pct.crit{color:var(--crit)}.bgp-util-bar{height:3px;border-radius:2px;background:#16223c;overflow:hidden;margin-top:2px}.bgp-util-bar i{display:block;height:100%;border-radius:2px;transition:width .6s}.bgp-util-bar i.ok{background:var(--accent)}.bgp-util-bar i.warn{background:var(--warn)}.bgp-util-bar i.crit{background:var(--crit);box-shadow:0 0 6px var(--crit)}.replay-toggle{background:transparent;border:1px solid var(--line);color:var(--dim);font-family:inherit;font-weight:600;font-size:11px;letter-spacing:1.5px;border-radius:3px;padding:5px 12px;cursor:pointer;white-space:nowrap}.replay-toggle:hover{color:var(--accent);border-color:var(--accent)}.replay-bar{display:flex;align-items:center;gap:10px;flex:1;max-width:560px}.replay-bar input[type=range]{flex:1;accent-color:var(--accent)}.replay-btn{background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:3px;padding:3px 10px;cursor:pointer;font-family:inherit;font-weight:700}.replay-btn.live{border-color:var(--ok);color:var(--ok)}.replay-time{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--warn);white-space:nowrap}.dashboard.wall .alert-feed{width:340px;font-size:15px}.wall-banner{position:absolute;left:50%;transform:translate(-50%);top:64px;z-index:30;max-width:70vw;background:var(--crit);color:#fff;font-size:20px;font-weight:700;letter-spacing:1px;padding:10px 22px;border-radius:6px;box-shadow:0 0 30px #ff4d5e88;animation:blink 1.2s infinite;display:flex;gap:14px;align-items:center}.wall-banner-count{font-size:13px;opacity:.8;font-family:JetBrains Mono,monospace}.page-scroll{flex:1;overflow-y:auto}.page{padding:24px;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:28px}.page h2{font-size:15px;letter-spacing:2px;color:var(--accent);margin-bottom:10px}.page h3{font-size:12px;letter-spacing:1px;color:var(--dim);margin-bottom:6px}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;color:var(--dim);font-size:11px;letter-spacing:1.5px;border-bottom:1px solid var(--line);padding:6px 8px}.data-table td{border-bottom:1px solid #101a30;padding:6px 8px;font-family:JetBrains Mono,monospace;font-size:12px}.data-table.small td{padding:3px 8px;font-size:11px}.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-row{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.page select,.page input,.page textarea{background:#0c1426;color:var(--text);border:1px solid var(--line);border-radius:3px;padding:6px 8px;font-family:JetBrains Mono,monospace;font-size:12px}.page textarea{width:100%}.page button{background:transparent;border:1px solid var(--accent);color:var(--accent);font-family:inherit;font-weight:700;letter-spacing:1px;font-size:11px;border-radius:3px;padding:6px 14px;cursor:pointer}.page button:disabled{opacity:.4}.page code{color:var(--ok);font-size:11px}.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-bottom:12px}.setting-field{display:flex;flex-direction:column;gap:4px}.setting-field span{font-size:11px;letter-spacing:1px;color:var(--dim)}.setting-field input{width:100%}.admin-tabs{display:flex;gap:6px;margin-bottom:18px;border-bottom:1px solid var(--line);padding-bottom:0}.admin-tabs button{background:transparent;border:1px solid transparent;border-bottom:none;color:var(--dim);font-family:inherit;font-weight:700;letter-spacing:1.5px;font-size:11px;padding:8px 16px;cursor:pointer;border-radius:4px 4px 0 0}.admin-tabs button.active{color:var(--accent);border-color:var(--line);background:#0c1426;box-shadow:0 1px #0c1426}.slider-field{display:flex;flex-direction:column;gap:4px}.slider-field span{font-size:11px;letter-spacing:1px;color:var(--dim)}.slider-field code{color:var(--text);font-size:11px}.slider-field input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:#1c2a44;border:none;border-radius:2px;padding:0}.slider-field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #0c1426}.slider-field input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid #0c1426}.dev-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.5px;padding:1px 6px;border-radius:3px;margin-right:4px;white-space:nowrap;border:1px solid transparent}.dev-badge.ok{color:var(--ok);border-color:#1f4a7a;background:#0c1e33}.dev-badge.warn{color:var(--warn);border-color:#5a4410;background:#2a1e08}.dev-badge.crit{color:var(--crit);border-color:#5a1622;background:#2a0c12}.dev-badge.dim{color:var(--dim);border-color:var(--line);background:#0c1426}.dev-fleet tbody tr{cursor:pointer}.dev-fleet tbody tr:hover td{background:#101b30}.dev-fleet tbody tr.sel td{background:#122440}.dev-fleet td.dim,.dev-log-topics,td.dim{color:var(--dim)}.dev-split{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:start}.dev-list{display:flex;flex-direction:column;gap:2px;max-height:70vh;overflow-y:auto}.dev-list-item{display:flex;align-items:center;gap:8px;text-align:left;background:transparent;border:1px solid var(--line);border-radius:3px;padding:7px 10px;cursor:pointer;color:var(--text);width:100%}.dev-list-item:hover{background:#101b30}.dev-list-item.active{border-color:var(--accent);background:#122440}.dev-li-name{flex:1;font-size:12px;font-weight:700;letter-spacing:.3px}.dev-li-ip{font-family:JetBrains Mono,monospace;font-size:10px;color:var(--dim)}.dev-li-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dev-li-dot.ok{background:var(--ok)}.dev-li-dot.crit{background:var(--crit)}.dev-detail{border:1px solid var(--line);border-radius:4px;background:#0a1322;padding:14px;min-height:200px}.dev-detail-head{display:flex;justify-content:space-between;margin-bottom:12px}.dev-action-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.dev-action-tabs button{padding:5px 12px;font-size:10px;letter-spacing:1px;border:1px solid var(--line);color:var(--dim)}.dev-action-tabs button.active{border-color:var(--accent);color:var(--accent);background:#122440}.dev-action-body{font-size:13px}.dev-subhead{color:var(--dim);font-size:11px;letter-spacing:1.5px;margin:16px 0 6px;text-transform:uppercase}.dev-kv{grid-template-columns:120px 1fr}.dev-log td{vertical-align:top;padding:3px 8px}.dev-log-time{white-space:nowrap;color:var(--dim);font-size:11px;width:1%}.dev-log-topics{white-space:nowrap;font-size:11px}.dev-log-msg{font-family:JetBrains Mono,monospace;font-size:11px;word-break:break-word}.dev-json{background:#060c16;border:1px solid var(--line);border-radius:4px;padding:10px;font-size:11px;max-height:50vh;overflow:auto;color:var(--text)}.dev-script{width:100%;font-family:JetBrains Mono,monospace;font-size:12px;resize:vertical;margin-bottom:8px}@media(max-width:900px){.topbar{flex-wrap:wrap;gap:8px}.topbar-mid{order:3;width:100%;justify-content:flex-start}.alert-feed{width:230px;top:auto;height:40vh;bottom:10px}.detail-panel{width:calc(100vw - 20px);max-height:55vh;top:auto;bottom:10px}.bgp-card{min-width:150px}.clock{display:none}.inv-grid,.dev-split{grid-template-columns:1fr}}
