.network-map-container{display:flex;flex-direction:column;gap:1rem;height:calc(100vh - 5rem)}.network-map-header{display:flex;align-items:center;gap:1rem}.network-map-header h2{margin:0}.live-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.live-badge.connected{background:#22c55e26;color:#22c55e}.live-badge.disconnected{background:#ef444426;color:#ef4444}.live-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:live-pulse 1.5s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.3}}.conn-count{color:var(--text-muted);font-size:.85rem;margin-left:auto}.world-map-wrap{flex:1;min-height:0;background:#0a0c14;border:1px solid var(--border);border-radius:12px;overflow:hidden;position:relative}.world-map-svg{width:100%;height:100%;display:block}.map-land{fill:#1a1d27;stroke:#2a2d3a;stroke-width:.5}.node-marker{fill:#6366f1}.node-marker-halo{fill:#6366f11f;animation:halo-pulse 3s ease-in-out infinite}@keyframes halo-pulse{0%,to{r:12;opacity:.12}50%{r:18;opacity:.06}}.node-label{fill:#e4e5eb;font-size:14px;font-weight:600;text-anchor:middle;pointer-events:none}.arc-single{stroke:#06b6d4;fill:none;filter:url(#arc-glow);stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw-arc 1.8s ease-out forwards,arc-fade 1s 4s forwards}.arc-stream{stroke:#6366f1;fill:none;filter:url(#arc-glow);stroke-dasharray:8 16;animation:flow-pump .8s linear infinite}.arc-stream-bg{stroke:#6366f1;fill:none;opacity:.1;stroke-linecap:round}.arc-source-dot{fill:#06b6d4;filter:url(#glow);animation:dot-fade 1.8s ease-out forwards}.arc-threat{stroke:#ef4444;fill:none;filter:url(#arc-glow);stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw-arc 1.8s ease-out forwards,arc-fade 1s 4s forwards}.arc-threat-stream{stroke:#ef4444;fill:none;filter:url(#arc-glow);stroke-dasharray:8 16;animation:flow-pump .8s linear infinite}.arc-threat-stream-bg{stroke:#ef4444;fill:none;opacity:.1;stroke-linecap:round}.arc-threat-dot{fill:#ef4444;filter:url(#glow);animation:dot-fade 1.8s ease-out forwards}@keyframes draw-arc{to{stroke-dashoffset:0}}@keyframes arc-fade{to{opacity:0}}@keyframes flow-pump{to{stroke-dashoffset:-24}}@keyframes dot-fade{0%{opacity:1;r:3}70%{opacity:.8;r:2}to{opacity:0;r:0}}.conn-table-wrap{max-height:220px;overflow-y:auto;border:1px solid var(--border);border-radius:12px;background:var(--surface);flex-shrink:0}.conn-table{width:100%;border-collapse:collapse;font-size:.82rem}.conn-table thead{position:sticky;top:0;z-index:1}.conn-table th{padding:.5rem .75rem;text-align:left;color:var(--text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;background:var(--surface);border-bottom:1px solid var(--border)}.conn-table td{padding:.4rem .75rem;border-bottom:1px solid rgba(42,45,58,.5);color:var(--text)}.conn-row{transition:background .15s;cursor:default}.conn-row:hover,.conn-row.conn-highlighted{background:var(--surface-hover)}.conn-cell-src,.conn-cell-dst{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conn-cell-ip{font-family:monospace;font-size:.75rem;color:var(--text-muted);white-space:nowrap}.conn-service{color:var(--text-muted);font-family:monospace;font-size:.78rem}.conn-type-badge{display:inline-block;padding:.1rem .45rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.conn-type-badge.stream{background:#6366f126;color:#818cf8}.conn-type-badge.single{background:#06b6d426;color:#22d3ee}.conn-threat{background:#ef44440f}.conn-threat-badge{display:inline-block;margin-left:.4rem;padding:.1rem .4rem;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.05em;background:#ef444426;color:#f87171}.conn-dir-badge{display:inline-block;padding:.1rem .45rem;border-radius:4px;font-size:.7rem;font-weight:600;letter-spacing:.03em}.conn-dir-badge.inbound{background:#22c55e26;color:#4ade80}.conn-dir-badge.outbound{background:#fb923c26;color:#fb923c}.conn-dir-badge.internal{background:#6366f126;color:#818cf8}.map-controls{position:absolute;bottom:12px;right:12px;display:flex;align-items:center;gap:.5rem}.zoom-hint{padding:.3rem .6rem;border-radius:6px;background:#0009;color:var(--text-muted);font-size:.72rem;pointer-events:none}.fullscreen-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#0009;color:var(--text-muted);cursor:pointer;transition:all .15s}.fullscreen-btn:hover{background:#000c;color:var(--text);border-color:#ffffff4d}.conn-filtered{color:var(--text-muted);opacity:.6}.conn-table-header{display:flex;justify-content:flex-end;flex-shrink:0}.filter-btn{padding:.3rem .7rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);font-size:.75rem;cursor:pointer;transition:all .15s}.filter-btn:hover{background:var(--surface-hover);color:var(--text)}.filter-btn.active{border-color:var(--accent);color:var(--accent)}.conn-empty{padding:2rem;text-align:center;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:12px;font-size:.9rem;flex-shrink:0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0f1117;--surface: #1a1d27;--surface-hover: #242736;--border: #2a2d3a;--text: #e4e5eb;--text-muted: #8b8d9a;--accent: #6366f1;--accent-hover: #818cf8;--green: #22c55e}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:1.25rem .75rem;position:fixed;top:0;bottom:0;left:0}.logo{display:flex;align-items:center;gap:.6rem;padding:0 .5rem;margin-bottom:1.5rem;font-size:1.2rem;font-weight:700;letter-spacing:.04em}.nav-links{display:flex;flex-direction:column;gap:.25rem;flex:1}.nav-links a{padding:.55rem .75rem;border-radius:8px;color:var(--text-muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-links a:hover{background:var(--surface-hover);color:var(--text)}.nav-links a.active{background:var(--accent);color:#fff}.sidebar-footer{padding:.5rem .75rem;color:var(--text-muted);font-size:.75rem}.content{flex:1;margin-left:220px;padding:2rem 2.5rem}.page h2{font-size:1.5rem;margin-bottom:1.5rem;font-weight:600}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.card{display:flex;align-items:center;gap:.75rem;padding:1.1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:var(--text);transition:border-color .15s,background .15s}.card:hover{border-color:var(--accent);background:var(--surface-hover)}.card h3{font-size:.95rem;font-weight:600}.card-url{font-size:.8rem;color:var(--text-muted)}.card-status{width:10px;height:10px;border-radius:50%;flex-shrink:0}.card-status[data-status=online]{background:var(--green);box-shadow:0 0 6px var(--green)}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem 1.5rem;margin-top:1rem}.info-card h3{margin-bottom:.75rem;font-size:1rem}.info-card ul{list-style:none;display:flex;flex-direction:column;gap:.4rem}.info-card li{color:var(--text-muted);font-size:.9rem}.info-card li:before{content:"→ ";color:var(--accent)}.page p{color:var(--text-muted);line-height:1.6;max-width:600px}.page-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.page-header h2{margin-bottom:0}.user-badge{background:var(--accent);color:#fff;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600}.auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;color:var(--text-muted)}.auth-screen h2{color:var(--text)}.auth-btn,.logout-btn{background:none;border:1px solid var(--border);color:var(--text-muted);padding:.45rem .75rem;border-radius:8px;cursor:pointer;font-size:.8rem;transition:border-color .15s,color .15s;width:100%;text-align:left}.auth-btn:hover,.logout-btn:hover{border-color:var(--accent);color:var(--text)}.auth-btn{width:auto;padding:.5rem 1.5rem;font-size:.9rem}.page-desc{margin-bottom:1.25rem}.form-grid{display:flex;flex-direction:column;gap:.75rem}.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem}.form-grid label>span{color:var(--text-muted);font-weight:500}.form-grid input,.form-grid select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:.5rem .7rem;border-radius:8px;font-size:.85rem;outline:none;transition:border-color .15s}.form-grid input:focus,.form-grid select:focus{border-color:var(--accent)}.form-grid input::placeholder{color:var(--text-muted);opacity:.5}.form-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.form-actions{display:flex;gap:.5rem;margin-top:1rem}.btn{padding:.5rem 1.25rem;border-radius:8px;border:none;font-size:.85rem;font-weight:500;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.85}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-success{background:var(--green);color:#fff}.btn-danger{background:#ef4444;color:#fff}.status-badge{padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600}.flash{padding:.6rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.flash-ok{background:#22c55e26;color:var(--green);border:1px solid rgba(34,197,94,.3)}.flash-err{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}
