:root{--bg:#101116;--top:#171628;--panel:#1b1b2e;--panel2:#242238;--line:#302f47;--text:#eef2ff;--muted:#9da3b8;--blue:#2f80ff;--cyan:#28b7ff;--green:#35e887;--red:#ff5069;--yellow:#ffcc44;--shadow:0 18px 60px rgba(0,0,0,.42);--topH:58px;--bottomH:86px}
:root.light{--bg:#eef3f9;--top:#ffffff;--panel:#ffffff;--panel2:#f4f7fb;--line:#d7e0ee;--text:#172033;--muted:#617089;--shadow:0 18px 60px rgba(15,23,42,.16)}
*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Arial,sans-serif}button,a,select,input{font:inherit}.topbar{height:var(--topH);display:flex;align-items:center;gap:18px;padding:0 14px;background:linear-gradient(90deg,#17152a,#151622);border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:20}.brand{display:flex;align-items:center;gap:10px;min-width:270px;text-decoration:none;color:var(--text)}.brand b{display:block;letter-spacing:.08em;font-size:16px}.brand small{display:block;color:#bbc2d6;font-size:12px}.radio{font-size:26px;color:var(--blue);filter:drop-shadow(0 0 10px rgba(47,128,255,.8))}#onlineDot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green)}.mainnav{display:flex;gap:6px;height:100%;align-items:center;flex:1}.mainnav a{height:44px;display:flex;align-items:center;padding:0 16px;border-radius:6px;color:#d4d8e8;text-decoration:none}.mainnav a:hover,.mainnav a.active{background:#263866;color:#fff}.topStats{display:flex;align-items:center;gap:12px;color:#c9d0e2;white-space:nowrap}.topStats b{color:#48a5ff}.iconBtn,.loginBtn{border:1px solid #303650;background:#161a2b;color:#e7ecff;border-radius:8px;padding:9px 12px;text-decoration:none;cursor:pointer}.loginBtn{padding:9px 14px}.appShell{position:relative;height:calc(100vh - var(--topH));overflow:hidden}#mapCanvas{position:absolute;inset:0 0 var(--bottomH) 0;background:#0b0c10}.leaflet-container{background:#111}.leaflet-control-zoom a{background:#202538!important;color:#fff!important;border-color:#3b4360!important}.floatingPanel{position:absolute;z-index:10;background:rgba(28,27,47,.94);border:1px solid rgba(117,123,175,.25);box-shadow:var(--shadow);backdrop-filter:blur(10px)}.livePanel{left:14px;top:14px;width:min(690px,calc(100vw - 28px));border-radius:9px;padding:14px}.panelHeader{display:flex;align-items:center;gap:10px;letter-spacing:.22em;font-size:14px}.panelHeader button{margin-left:auto;border:1px solid #353750;background:#151629;color:#bdc7e8;border-radius:7px;padding:4px 8px}.panelHeader button+button{margin-left:2px}.redDot{width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 12px var(--red)}.liveChips{display:flex;justify-content:center;gap:10px;margin:12px 0}.liveChips span{background:#29304a;border-radius:999px;padding:4px 10px;color:#c9d1e4;font-size:12px}.liveChips b{color:#44a8ff}.controlGrid{display:grid;grid-template-columns:1.5fr .9fr .9fr .8fr;gap:8px}.controlGrid select,.search{width:100%;border:1px solid #32344d;background:#121324;color:#e9edff;border-radius:6px;padding:10px}.search{margin-top:10px}.sideList{margin-top:10px;display:none;max-height:44vh;overflow:auto}.showList .sideList{display:block}.sideItem{display:grid;grid-template-columns:1fr auto;gap:8px;padding:9px 4px;border-bottom:1px solid rgba(255,255,255,.07);cursor:pointer}.sideItem:hover{background:rgba(47,128,255,.12)}.sideItem b{font-size:13px}.sideItem small{display:block;color:var(--muted);overflow:hidden;text-overflow:ellipsis}.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#141728;border:1px solid #30364f;color:#cfd7ea;padding:3px 8px;font-size:12px}.good{color:var(--green)}.mid{color:var(--yellow)}.bad{color:var(--red)}.bottomBar{position:absolute;z-index:9;left:0;right:0;bottom:0;height:var(--bottomH);background:rgba(31,30,54,.92);border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:8px;padding:12px 14px}.bottomBar button,.liveBadge,.speedBtn{border:1px solid #343958;background:#242943;color:#eaf0ff;border-radius:8px;padding:9px 14px}.liveBadge{background:#7d293a;color:#ffb9c5;font-weight:800}.wsStatus{color:var(--green);margin-left:6px;white-space:nowrap}.miniBars{height:42px;display:flex;align-items:end;gap:5px;flex:1;overflow:hidden;padding:0 20px}.bar{width:9px;min-width:9px;background:#2f6fd5;border-radius:2px 2px 0 0;opacity:.78}.clock{width:166px;height:62px;background:#11220d;border:1px solid #285623;color:#38ff64;border-radius:4px;display:flex;flex-direction:column;align-items:end;justify-content:center;padding:6px 14px;font-family:ui-monospace,Menlo,Consolas,monospace;box-shadow:inset 0 0 25px rgba(53,255,100,.12)}.clock small{font-size:11px;letter-spacing:.2em}.clock b{font-size:30px}.routePane{position:absolute;z-index:11;right:18px;top:18px;bottom:calc(var(--bottomH) + 18px);width:min(680px,calc(100vw - 36px));background:rgba(25,25,39,.96);border:1px solid rgba(117,123,175,.25);box-shadow:var(--shadow);border-radius:10px;overflow:hidden;display:flex;flex-direction:column}.routePane.hidden{display:none}.paneHead{height:58px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.08)}.paneHead h2{margin:0;font-size:20px}.paneHead button{background:#151629;color:#fff;border:1px solid #353750;border-radius:8px;padding:6px 10px}#paneBody{overflow:auto;padding:12px}.packet{border:1px solid rgba(255,255,255,.08);background:#111522;border-radius:10px;margin-bottom:10px;overflow:hidden}.packetHead{display:grid;grid-template-columns:130px 1fr auto;gap:10px;padding:12px;border-bottom:1px solid rgba(255,255,255,.08);align-items:center}.topic{font-weight:800;word-break:break-all}.meta{padding:10px 12px;color:#aab3c7;display:flex;gap:14px;flex-wrap:wrap}pre{margin:0 12px 12px;padding:12px;background:#080c14;border:1px solid #242b3c;border-radius:8px;color:#e8edf8;white-space:pre-wrap;max-height:260px;overflow:auto}.nodeRow{display:grid;grid-template-columns:1fr 70px 70px 90px 100px;gap:10px;padding:11px;border-bottom:1px solid rgba(255,255,255,.07);align-items:center}.nodeRow:hover{background:rgba(47,128,255,.1)}.nodeName{font-weight:800}.sub{display:block;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis}.cardsGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.statCard{background:#111522;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px}.statCard span{color:var(--muted)}.statCard b{display:block;font-size:32px;margin-top:8px}.modal{position:fixed;z-index:100;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;padding:22px}.modal.hidden{display:none}.modalCard{position:relative;width:min(980px,95vw);max-height:90vh;overflow:auto;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:22px}#modalClose{position:absolute;right:12px;top:12px}.hidden{display:none!important}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333}.pulseMarker{width:18px;height:18px;border-radius:50%;border:2px solid #ff6374;background:#1f5cff;box-shadow:0 0 0 6px rgba(255,92,110,.18),0 0 18px rgba(255,92,110,.8)}.pulseMarker.obs{background:#1f5cff;border-color:#78aaff}.pulseMarker.active{animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(47,128,255,.55),0 0 20px rgba(47,128,255,.8)}70%{box-shadow:0 0 0 22px rgba(47,128,255,0),0 0 20px rgba(47,128,255,.8)}100%{box-shadow:0 0 0 0 rgba(47,128,255,0)}}
@media(max-width:900px){.brand{min-width:auto}.brand small,.mainnav a:not(.active),.topStats span{display:none}.topbar{gap:8px}.livePanel{width:calc(100vw - 20px);left:10px}.controlGrid{grid-template-columns:1fr 1fr}.clock{display:none}.routePane{left:10px;right:10px;width:auto}.packetHead,.nodeRow{grid-template-columns:1fr}.cardsGrid{grid-template-columns:1fr 1fr}}
