body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.map-page{background:#000;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;height:calc(100vh - 40px);overflow:hidden}.map-header,.map-page{display:flex;position:relative}.map-header{align-items:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#000000d9;border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;padding:16px 40px;z-index:100}.map-header h1{color:#fff;font-size:28px;font-weight:600;letter-spacing:-.02em;margin:0}.map-stats{display:flex;gap:48px}.stat-item{position:relative;text-align:right;z-index:101}.stat-value{color:#fff;font-size:32px;font-weight:300;letter-spacing:-.02em;line-height:1}.stat-label{color:#fff9;font-size:11px;font-weight:500;letter-spacing:.8px;margin-top:4px;text-transform:uppercase}.map-container{align-items:center;background:radial-gradient(circle at center,#0f0f0f 0,#000 100%);display:flex;flex:1 1;min-height:0;position:relative}.marker-pulse{animation:subtle-pulse 4s ease-in-out infinite}.marker-pulse-active{animation:active-pulse 2s ease-in-out infinite}.marker-pulse-online{animation:online-pulse 2.5s ease-in-out infinite}.marker-glow{filter:drop-shadow(0 0 4px rgba(255,255,255,.3))}.marker-glow,.marker-glow-online{transition:all .4s cubic-bezier(.25,.46,.45,.94)}.marker-glow-online{animation:glow-pulse 3s ease-in-out infinite;filter:drop-shadow(0 0 6px currentColor)}.marker-glow-online:hover,.marker-glow:hover{filter:drop-shadow(0 0 12px currentColor);transform:scale(1.15)}.transaction-line{opacity:.08;transition:all .8s cubic-bezier(.25,.46,.45,.94)}.transaction-line-active{animation:smooth-line-glow 3s ease-in-out infinite;filter:drop-shadow(0 0 3px rgba(255,255,255,.3));opacity:.6}.transaction-packet{animation:packet-glow 2.5s ease-in-out infinite;filter:drop-shadow(0 0 3px rgba(0,122,255,.6))}.map-legend{backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);background:#000c;border:1px solid #ffffff1a;border-radius:16px;bottom:32px;left:32px;min-width:180px;padding:24px;position:absolute}.legend-title{color:#fff;font-size:13px;font-weight:600;letter-spacing:-.01em;margin-bottom:16px}.legend-items{display:flex;flex-direction:column;gap:12px}.legend-item{align-items:center;color:#ffffffb3;display:flex;font-size:11px;font-weight:500;gap:12px}.legend-marker{border-radius:50%;flex-shrink:0;height:8px;width:8px}.legend-marker.active-agent{animation:subtle-pulse 3s ease-in-out infinite;background:#fff;box-shadow:0 0 6px #ffffff80}.legend-marker.transaction-line{animation:smooth-line-glow 3s ease-in-out infinite;background:#fff9;box-shadow:0 0 3px #fff3}.legend-marker.data-packet{animation:smooth-glow 2s ease-in-out infinite;background:#007aff;box-shadow:0 0 4px #007aff99}.transaction-panel{backdrop-filter:blur(30px) saturate(180%);-webkit-backdrop-filter:blur(30px) saturate(180%);background:#000000d9;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 20px 40px #0006;max-height:420px;position:absolute;right:32px;top:50%;transform:translateY(-50%);width:320px}.panel-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;justify-content:space-between;padding:24px 24px 20px}.panel-title{color:#fff;font-size:17px;font-weight:600;letter-spacing:-.02em}.panel-close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;font-size:16px;font-weight:300;height:28px;justify-content:center;padding:0;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:28px}.panel-close:hover{background:#fff3;color:#fff;transform:scale(1.1)}.panel-content{padding:20px 24px 24px}.agent-details,.transaction-details{display:flex;flex-direction:column;gap:16px}.detail-row{align-items:center;display:flex;justify-content:space-between;padding:8px 0}.detail-label{color:#fff9;font-size:11px;font-weight:500;letter-spacing:.8px;text-transform:uppercase}.detail-value{word-wrap:break-word;color:#fff;font-size:13px;font-weight:500;max-width:200px;text-align:right}.status-online{color:#30d158!important}@keyframes subtle-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}@keyframes active-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}@keyframes smooth-line-glow{0%,to{opacity:.4}50%{opacity:.7}}@keyframes packet-glow{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes minimal-glow{0%,to{opacity:.6}50%{opacity:.9}}@keyframes smooth-glow{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes online-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}@keyframes glow-pulse{0%,to{filter:drop-shadow(0 0 6px currentColor)}50%{filter:drop-shadow(0 0 10px currentColor)}}@media (max-width:768px){.map-header{flex-direction:column;gap:20px;padding:20px 24px}.map-header h1{font-size:24px}.map-stats{gap:32px}.stat-value{font-size:28px}.transaction-panel{border-radius:16px;right:16px;width:300px}.map-legend{border-radius:12px;bottom:16px;left:16px;padding:20px}}@media (max-width:480px){.map-header{padding:16px 20px}.map-header h1{font-size:22px}.transaction-panel{border:none;border-radius:20px 20px 0 0;border-top:1px solid #ffffff1a;bottom:0;left:0;max-height:60vh;position:fixed;right:0;top:auto;transform:none;width:auto}.map-legend{bottom:12px;left:12px;min-width:160px;padding:16px}}*{box-sizing:border-box;margin:0;padding:0}.app{display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100vh}.app.dark{--bg-primary:#0f0f0f;--bg-secondary:#1a1a1a;--bg-tertiary:#2a2a2a;--text-primary:#fff;--text-secondary:#b3b3b3;--accent:#3b82f6;--accent-hover:#2563eb;--border:#333;--success:#10b981;--warning:#f59e0b;--error:#ef4444}.app.light{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#e2e8f0;--text-primary:#1e293b;--text-secondary:#64748b;--accent:#3b82f6;--accent-hover:#2563eb;--border:#e2e8f0;--success:#10b981;--warning:#f59e0b;--error:#ef4444}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px;width:250px}.sidebar-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.sidebar-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:600}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;padding:8px;transition:all .2s ease}.theme-toggle:hover{background:var(--accent);color:#fff}.sidebar-footer{border-top:1px solid var(--border);display:flex;justify-content:center;margin-top:auto;padding:16px 0}.theme-toggle-small{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;padding:6px;transition:all .2s ease;width:32px}.theme-toggle-small:hover{background:var(--accent);color:#fff;transform:scale(1.1)}.nav-links{list-style:none}.nav-links li{margin-bottom:8px}.nav-link{align-items:center;border-radius:8px;color:var(--text-secondary);display:flex;gap:12px;padding:12px 16px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:var(--accent);color:#fff}.main-content{background:var(--bg-primary);flex:1 1;overflow-y:auto;padding:20px}.main-content .map-page{height:calc(100vh - 40px);margin:-20px}.page{color:var(--text-primary);padding:30px}.page-header{margin-bottom:30px}.page-title{font-size:2rem;font-weight:600;margin-bottom:8px}.page-subtitle{color:var(--text-secondary);font-size:1rem}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px;transition:all .2s ease}.card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.card-title{color:var(--text-primary);font-size:1.25rem;font-weight:600}.grid{grid-gap:20px;display:grid;gap:20px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.status{align-items:center;border-radius:6px;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;padding:4px 8px}.status.online{background:#10b9811a;border:1px solid #10b98133;color:var(--success)}.status.offline{background:#ef44441a;border:1px solid #ef444433;color:var(--error)}.status.warning{background:#f59e0b1a;border:1px solid #f59e0b33;color:var(--warning)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s ease}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-secondary)}.input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;padding:12px 16px;transition:all .2s ease;width:100%}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a;outline:none}.input::placeholder{color:var(--text-secondary)}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center}.stat-value{color:var(--accent);font-size:2rem;font-weight:700;margin-bottom:8px}.stat-label{font-size:.875rem}.loading,.stat-label{color:var(--text-secondary)}.loading{align-items:center;display:flex;justify-content:center;padding:40px}@media (max-width:768px){.app{flex-direction:column}.sidebar{height:auto;width:100%}.main-content{height:calc(100vh - 200px)}.page{padding:20px}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.5092b4d6.css.map*/