@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0a0e14;--bg-secondary: #0d1117;--bg-panel: rgba(13, 17, 23, .95);--bg-card: rgba(22, 27, 34, .9);--bg-elevated: rgba(33, 38, 45, .95);--accent-primary: #00d4ff;--accent-secondary: #ff0080;--accent-success: #00ff88;--accent-warning: #ffd700;--accent-danger: #ff3366;--accent-purple: #a855f7;--accent-orange: #ff8c00;--text-primary: #f0f6fc;--text-secondary: #8b949e;--text-muted: #484f58;--border-default: rgba(48, 54, 61, .8);--border-accent: rgba(0, 212, 255, .3);--map-land: #161b22;--map-land-hover: #21262d;--map-border: #30363d;--glow-primary: 0 0 20px rgba(0, 212, 255, .4);--glow-secondary: 0 0 20px rgba(255, 0, 128, .4);--shadow-card: 0 4px 12px rgba(0, 0, 0, .4);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;background-image:radial-gradient(ellipse at 20% 0%,rgba(0,212,255,.03) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(255,0,128,.02) 0%,transparent 50%)}.app-layout{display:grid;grid-template-rows:auto 1fr;height:100vh;overflow:hidden}.dashboard-container{display:grid;grid-template-columns:220px 1fr 280px;height:100%;overflow:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-lg);background:var(--bg-panel);border-bottom:1px solid var(--border-default);height:56px}.header-brand{display:flex;align-items:center;gap:var(--space-md)}.logo{font-family:JetBrains Mono,monospace;font-size:1.25rem;font-weight:700;letter-spacing:.1em;color:var(--accent-primary);text-shadow:var(--glow-primary)}.logo-subtitle{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.header-nav{display:flex;gap:var(--space-md)}.nav-link{padding:var(--space-sm) var(--space-md);color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;border-radius:var(--radius-sm);transition:var(--transition-fast)}.nav-link:hover,.nav-link.active{color:var(--accent-primary);background:#00d4ff1a}.header-status{display:flex;align-items:center;gap:var(--space-lg)}.live-indicator{display:flex;align-items:center;gap:var(--space-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.live-dot{width:8px;height:8px;background:var(--accent-success);border-radius:50%;animation:pulse 2s infinite}.live-dot.disconnected{background:var(--accent-danger);animation:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}.sidebar{background:var(--bg-panel);border-right:1px solid var(--border-default);padding:var(--space-md);overflow-y:auto}.sidebar-right{background:var(--bg-panel);border-left:1px solid var(--border-default);padding:var(--space-md);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-md)}.panel-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-primary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-default)}.filter-list{display:flex;flex-direction:column;gap:var(--space-sm)}.filter-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;transition:background var(--transition-fast)}.filter-item:hover{background:#00d4ff1a}.filter-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.filter-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.main-content{position:relative;overflow:hidden;background:var(--bg-secondary)}.stat-card{background:var(--bg-card);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--border-default)}.stat-card-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:var(--space-sm)}.stat-card-value{font-family:JetBrains Mono,monospace;font-size:1.5rem;font-weight:700;color:var(--accent-primary)}.top-list{display:flex;flex-direction:column;gap:var(--space-xs)}.top-list-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:.8rem}.top-list-flag{font-size:1rem;width:20px;text-align:center}.top-list-name{flex:1;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-list-bar{width:50px;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.top-list-bar-fill{height:100%;border-radius:2px;transition:width var(--transition-normal)}.top-list-bar-fill.attacker{background:var(--accent-secondary)}.top-list-bar-fill.target{background:var(--accent-primary)}.top-list-bar-fill.alert{background:var(--accent-orange)}.top-list-percentage{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--accent-primary);width:36px;text-align:right}#map{width:100%;height:100%}#map svg{width:100%;height:100%}.countries path{fill:var(--map-land);stroke:var(--map-border);stroke-width:.5px;transition:fill var(--transition-fast)}.countries path:hover{fill:var(--map-land-hover)}.attack-trail{fill:none;stroke:var(--accent-secondary);stroke-width:2px;stroke-linecap:round;opacity:0}.attack-pulse{fill:var(--accent-secondary);opacity:0}.map-controls{position:absolute;bottom:var(--space-md);left:var(--space-md);display:flex;gap:var(--space-xs)}.map-btn{width:36px;height:36px;background:var(--bg-elevated);border:1px solid var(--border-default);color:var(--text-secondary);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:var(--transition-fast)}.map-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.map-legend{position:absolute;top:var(--space-md);right:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);display:flex;gap:var(--space-md);font-size:.75rem}.legend-item{display:flex;align-items:center;gap:var(--space-xs)}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.source{background:#4f8;box-shadow:0 0 6px #4f8}.legend-dot.target{background:#f44;box-shadow:0 0 6px #f44}.timeline-container{height:60px;background:#0003;border-radius:var(--radius-sm);padding:var(--space-sm);display:flex;align-items:flex-end;gap:2px}.timeline-bar{flex:1;min-width:3px;background:var(--accent-primary);border-radius:2px 2px 0 0;transition:height var(--transition-normal);opacity:.7}.timeline-bar:hover{opacity:1;background:var(--accent-secondary)}.threat-feed{display:flex;flex-direction:column;gap:var(--space-sm);max-height:200px;overflow-y:auto}.threat-item{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm);background:#ff00800d;border-left:2px solid var(--accent-secondary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.75rem;animation:slideIn var(--transition-normal)}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.threat-icon{color:var(--accent-secondary)}.threat-text{color:var(--text-secondary);line-height:1.4}.threat-text strong{color:var(--accent-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast);border:1px solid transparent}.btn-primary{background:var(--accent-primary);color:var(--bg-primary)}.btn-primary:hover{box-shadow:var(--glow-primary)}.btn-outline{background:transparent;border-color:var(--accent-primary);color:var(--accent-primary)}.btn-outline:hover{background:#00d4ff1a}.btn-play{background:linear-gradient(135deg,var(--accent-success),#00cc66);color:var(--bg-primary);font-weight:600}.btn-play:hover{box-shadow:0 0 15px #00ff8880}.btn-play:disabled{opacity:.5;cursor:not-allowed}.btn-danger{background:linear-gradient(135deg,var(--accent-danger),#ff5577);color:#fff;font-weight:600}.btn-danger:hover{box-shadow:0 0 15px #ff336680}.select{background:var(--bg-card);border:1px solid var(--border-default);color:var(--text-primary);padding:var(--space-sm) var(--space-md);font-size:.75rem;font-family:inherit;border-radius:var(--radius-sm);cursor:pointer}.select:focus{outline:none;border-color:var(--accent-primary)}.loading{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.875rem}.spinner{width:20px;height:20px;border:2px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:var(--space-sm)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:1px solid var(--border-default);color:var(--accent-primary);font-size:1.5rem;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast);margin-right:var(--space-sm)}.mobile-menu-btn:hover,.mobile-menu-btn:active{background:#00d4ff1a;box-shadow:0 0 12px #00d4ff4d}.header-nav{display:none}.drawer-overlay{position:fixed;inset:0;background:#000000b3;z-index:998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:80%;max-width:320px;background:var(--bg-panel);border-right:1px solid var(--border-default);z-index:999;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);box-shadow:4px 0 12px #00000080}.mobile-drawer.open{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-md);border-bottom:1px solid var(--border-default)}.drawer-title{font-size:1.25rem;font-weight:700;color:var(--accent-primary);margin:0}.drawer-close-btn{width:36px;height:36px;background:transparent;border:1px solid var(--border-default);color:var(--text-secondary);font-size:1.25rem;cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.drawer-close-btn:hover{color:var(--accent-danger);border-color:var(--accent-danger)}.drawer-nav{display:flex;flex-direction:column;gap:var(--space-xs)}.drawer-nav-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);color:var(--text-secondary);text-decoration:none;font-weight:500;border-radius:var(--radius-sm);transition:var(--transition-fast);border:1px solid transparent}.drawer-nav-link:hover{background:#00d4ff1a;color:var(--accent-primary)}.drawer-nav-link.active{background:#00d4ff26;color:var(--accent-primary);border-color:var(--border-accent)}.drawer-nav-icon{font-size:1.25rem}.drawer-filters{padding-top:var(--space-md);border-top:1px solid var(--border-default)}.drawer-filters .panel-title{font-size:.75rem;margin-bottom:var(--space-md)}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-panel);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--border-default);border-bottom:none;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 12px #0006;max-height:70vh;display:flex;flex-direction:column}.bottom-sheet.collapsed{transform:translateY(calc(100% - 50px))}.bottom-sheet.expanded{transform:translateY(0)}.bottom-sheet-handle{padding:var(--space-sm);display:flex;justify-content:center;cursor:pointer;flex-shrink:0}.handle-bar{width:40px;height:4px;background:var(--text-muted);border-radius:2px;transition:var(--transition-fast)}.bottom-sheet-handle:active .handle-bar{background:var(--accent-primary)}.bottom-sheet-content{padding:0 var(--space-md) var(--space-md);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--space-md)}.fab{position:fixed;width:56px;height:56px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;z-index:90;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #0006}.fab:active{transform:scale(.95)}.fab-stats{bottom:80px;right:var(--space-md);background:linear-gradient(135deg,var(--accent-primary),#0099cc);color:#fff;box-shadow:0 4px 12px #00d4ff80}.fab-stats:hover{box-shadow:0 6px 18px #00d4ff99}.sidebar,.sidebar-right{display:none!important}.dashboard-container{grid-template-columns:1fr}.header{padding:var(--space-sm)}.logo{font-size:1rem}.logo-subtitle{font-size:.65rem}.live-indicator{font-size:.7rem}.live-dot{width:6px;height:6px}}@media(min-width:769px){.mobile-nav-wrapper,.mobile-menu-btn,.bottom-sheet,.fab{display:none!important}}@media(min-width:769px)and (max-width:1024px){.dashboard-container{grid-template-columns:1fr}.sidebar,.sidebar-right{display:none}}@media(max-width:768px){.history-controls{flex-direction:column!important;gap:var(--space-sm)!important}.history-controls>div{width:100%}.history-controls input[type=date],.history-controls .select{width:100%;min-width:unset}.history-controls>div:first-child{display:flex;flex-direction:column;gap:var(--space-xs)}.history-controls button{width:100%}.attack-table{font-size:.7rem}.attack-table th,.attack-table td{padding:var(--space-xs)!important}}@media(max-width:768px){button,.btn,a.nav-link,.filter-item,.map-btn{min-height:44px;min-width:44px}.btn{padding:var(--space-md) var(--space-lg);font-size:1rem}.map-btn{width:44px;height:44px;font-size:1.5rem}.filter-item{padding:var(--space-md);cursor:pointer}.filter-item input[type=checkbox]{width:20px;height:20px}.stat-card{padding:var(--space-lg)}.stat-card-value{font-size:2rem}}
