@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0a0e1a;--bg-secondary: #0f1629;--bg-card: rgba(15, 22, 41, .7);--bg-card-hover: rgba(20, 28, 50, .8);--bg-glass: rgba(15, 22, 41, .5);--border-color: rgba(99, 102, 241, .12);--border-glow: rgba(99, 102, 241, .25);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99, 102, 241, .4);--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--cyan: #22d3ee;--purple: #8b5cf6;--radius: 12px;--radius-sm: 8px;--shadow-card: 0 4px 24px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-glow: 0 0 30px rgba(99, 102, 241, .08);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 0%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(139,92,246,.06) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6366f180}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:12px}.logo-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:10px;color:#fff;box-shadow:0 2px 12px var(--accent-glow)}.app-header h1{font-size:1.35rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.header-right{display:flex;align-items:center;gap:16px}.status-badge{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:500;transition:var(--transition)}.status-badge.connected{background:#10b9811f;color:var(--success);border:1px solid rgba(16,185,129,.2)}.status-badge.disconnected{background:#ef44441f;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.connected .status-dot{animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 #10b98166}50%{opacity:.7;box-shadow:0 0 0 6px #10b98100}}.packet-counter{display:flex;flex-direction:column;align-items:flex-end}.counter-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.counter-value{font-size:1.1rem;font-weight:700;font-family:JetBrains Mono,monospace;color:var(--accent-light)}.app-main{flex:1;padding:24px 28px}.dashboard{display:flex;flex-direction:column;gap:20px;max-width:1400px;margin:0 auto}.dashboard-row{display:flex;gap:20px}.dashboard-row-split{display:grid;grid-template-columns:1fr 1fr;gap:20px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;transition:var(--transition)}.card:hover{border-color:var(--border-glow);box-shadow:var(--shadow-card),var(--shadow-glow)}.card-full{flex:1}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.card-header h2{font-size:.95rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.card-badge{font-size:.75rem;font-weight:500;padding:3px 10px;border-radius:12px;background:#6366f11f;color:var(--accent-light);border:1px solid rgba(99,102,241,.2)}.card-body{padding:20px}.card-body-table{padding:0}.chart-container{height:220px;position:relative}.chart-traffic{height:180px}.ip-list{display:flex;flex-direction:column;gap:8px}.ip-item{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);position:relative;overflow:hidden;transition:var(--transition)}.ip-item:hover{background:#6366f10f}.ip-bar{position:absolute;left:0;bottom:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:1px;transition:width .6s ease}.ip-rank{font-size:.75rem;font-weight:600;color:var(--text-muted);font-family:JetBrains Mono,monospace}.ip-address{font-family:JetBrains Mono,monospace;font-size:.85rem;color:var(--text-primary)}.ip-count{font-family:JetBrains Mono,monospace;font-size:.8rem;font-weight:500;color:var(--accent-light)}.packet-table-wrapper{max-height:400px;overflow-y:auto}.packet-table{width:100%;border-collapse:collapse;font-size:.85rem}.packet-table thead{position:sticky;top:0;z-index:10}.packet-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.packet-table td{padding:10px 16px;border-bottom:1px solid rgba(99,102,241,.05);transition:var(--transition)}.packet-row{animation:fadeIn .3s ease}.packet-row:hover td{background:#6366f10a}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.cell-time{font-family:JetBrains Mono,monospace;color:var(--text-muted);font-size:.8rem}.cell-ip{font-family:JetBrains Mono,monospace;color:var(--text-primary);font-size:.82rem}.cell-port,.cell-size{font-family:JetBrains Mono,monospace;color:var(--text-secondary);font-size:.8rem}.protocol-tag{display:inline-block;padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:600;font-family:JetBrains Mono,monospace;letter-spacing:.03em;border:1px solid}.empty-row{text-align:center;color:var(--text-muted);padding:40px 16px!important;font-style:italic}.live-dot{width:10px;height:10px;border-radius:50%;background:var(--text-muted);transition:var(--transition)}.live-dot.live{background:var(--success);animation:pulse-dot 2s ease-in-out infinite}.upload-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px var(--accent-glow)}.upload-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}.upload-error{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);color:var(--danger);font-size:.85rem}.pcap-results{display:flex;gap:24px;align-items:flex-start}.pcap-stat{display:flex;flex-direction:column;align-items:center;min-width:120px;padding:16px;background:#6366f114;border-radius:var(--radius);border:1px solid rgba(99,102,241,.15)}.pcap-stat-value{font-size:1.8rem;font-weight:700;color:var(--accent-light);font-family:JetBrains Mono,monospace}.pcap-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:4px}.pcap-protocols{flex:1;display:flex;flex-direction:column;gap:8px}.pcap-protocol-item{display:grid;grid-template-columns:60px 1fr 50px;align-items:center;gap:12px}.protocol-name{font-family:JetBrains Mono,monospace;font-size:.82rem;font-weight:600;color:var(--text-primary)}.protocol-bar-container{height:8px;background:#6366f11a;border-radius:4px;overflow:hidden}.protocol-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--cyan));border-radius:4px;transition:width .6s ease}.protocol-pct{font-family:JetBrains Mono,monospace;font-size:.8rem;color:var(--text-secondary);text-align:right}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;align-items:center;justify-content:center;min-height:120px;color:var(--text-muted);font-size:.9rem;font-style:italic}.dns-table-wrapper{max-height:400px;overflow-y:auto}.cell-mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem}.cell-domain{font-weight:500}.domain-name{color:var(--cyan);font-weight:600}.domain-unknown{color:var(--text-muted)}.empty-row{text-align:center;color:var(--text-muted);padding:30px!important}@media(max-width:1024px){.dashboard-row-split{grid-template-columns:1fr}.app-main{padding:16px}.dashboard{gap:16px}}@media(max-width:768px){html{font-size:13px}.app-header{padding:10px 14px;flex-wrap:wrap;gap:8px}.app-header h1{font-size:1rem}.logo-icon{width:32px;height:32px;border-radius:8px}.logo-icon svg{width:20px;height:20px}.header-right{gap:8px}.status-badge{padding:4px 10px;font-size:.78rem}.counter-label{display:none}.counter-value{font-size:.95rem}.app-main{padding:10px}.dashboard{gap:10px}.dashboard-row{flex-direction:column}.card{border-radius:10px}.card-header{padding:12px 14px;flex-wrap:wrap;gap:6px}.card-header h2{font-size:.9rem}.card-body{padding:12px 14px}.chart-container{height:180px}.chart-traffic{height:150px}.card-body-table,.dns-table-wrapper,.packet-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.packet-table{font-size:.78rem;min-width:580px}.packet-table th,.packet-table td{padding:8px 10px;white-space:nowrap}.ip-item{grid-template-columns:24px 1fr auto;gap:6px;padding:6px 8px}.ip-address{font-size:.78rem}.pcap-results{flex-direction:column}.upload-btn{font-size:.78rem;padding:5px 12px}.empty-state{font-size:.85rem;padding:20px 10px}}@media(max-width:480px){html{font-size:12px}.app-header{padding:8px 10px}.header-left{gap:8px}.app-header h1{font-size:.95rem}.app-main{padding:6px}.dashboard{gap:8px}.card-header,.card-body{padding:10px 12px}.card-badge{font-size:.68rem;padding:2px 8px}.chart-container{height:160px}.chart-traffic{height:130px}.packet-table{min-width:480px;font-size:.72rem}.ip-item{grid-template-columns:20px 1fr auto;gap:4px}.ip-address{font-size:.72rem}.ip-rank{font-size:.68rem}}
