*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#04060e;--surface:rgba(255,255,255,0.025);--surface2:rgba(255,255,255,0.045);
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.12);
  --text:#E2E8F0;--muted:#94A3B8;--dim:#64748B;--dark:#475569;
  --blue:#3B82F6;--green:#10B981;--yellow:#F59E0B;--red:#EF4444;
  --purple:#8B5CF6;--crimson:#DC2626;--cyan:#06B6D4;--orange:#F97316;
  --mono:'JetBrains Mono',monospace;--sans:'Inter',system-ui,sans-serif;
}
body{background:var(--bg);color:var(--text);font-family:var(--mono);font-size:13px;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:-1;background:radial-gradient(ellipse at 15% 0%,rgba(6,182,212,0.06) 0%,transparent 50%),radial-gradient(ellipse at 85% 100%,rgba(139,92,246,0.04) 0%,transparent 50%)}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:3px}

@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes critPulse{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes countUp{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
@keyframes borderGlow{0%,100%{border-color:rgba(239,68,68,.3)}50%{border-color:rgba(239,68,68,.7)}}
@keyframes dotPing{0%{transform:scale(1);opacity:1}75%{transform:scale(2.5);opacity:0}100%{transform:scale(1);opacity:0}}
@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}
.animate-in{animation:fadeIn .4s ease both}

/* ── HEADER ─────────────────────────── */
.header{background:rgba(4,6,14,.9);border-bottom:1px solid var(--border);padding:10px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(30px)}
.header-left{display:flex;align-items:center;gap:14px}
.logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#06B6D4,#3B82F6,#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 0 24px rgba(6,182,212,.25);position:relative}
.logo::after{content:'';position:absolute;inset:-2px;border-radius:14px;background:inherit;z-index:-1;opacity:.3;filter:blur(10px)}
.header h1{font-family:var(--sans);font-size:20px;font-weight:800;letter-spacing:-.5px;color:#fff}
.header h1 span{background:linear-gradient(135deg,var(--cyan),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.header-sub{font-size:9px;color:var(--dim);letter-spacing:3px;text-transform:uppercase}
.header-right{display:flex;align-items:center;gap:14px}
.clock-date{font-size:10px;color:var(--dim);text-align:right}
.clock-time{font-size:14px;color:#fff;font-weight:600;font-variant-numeric:tabular-nums}
.threat-pill{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:1.5px}
.status-badge{display:flex;align-items:center;gap:7px;padding:6px 12px;border-radius:10px;cursor:pointer;transition:all .3s}
.status-badge:hover{transform:scale(1.05)}
.status-dot{width:7px;height:7px;border-radius:50%}
.status-dot.live{animation:pulse 2s ease infinite}
.status-label{font-size:10px;font-weight:700;letter-spacing:1px}

/* ── TABS ───────────────────────────── */
.tabs{display:flex;gap:2px;margin-bottom:16px;background:var(--surface);border-radius:10px;padding:3px;width:fit-content}
.tab{padding:8px 20px;border-radius:8px;font-size:11px;cursor:pointer;font-family:var(--mono);font-weight:500;color:var(--dim);transition:all .2s;border:none;background:none}
.tab.active{background:var(--surface2);color:var(--cyan);border:1px solid rgba(6,182,212,.2)}
.tab:hover:not(.active){color:var(--muted)}

/* ── LAYOUT ─────────────────────────── */
.container{padding:16px 24px;max-width:1600px;margin:0 auto}

/* ── THREAT BANNER ──────────────────── */
.threat-banner{border-radius:10px;padding:12px 18px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;border:1px solid rgba(220,38,38,.2);background:linear-gradient(90deg,rgba(220,38,38,.08),rgba(139,92,246,.03),rgba(220,38,38,.08));background-size:200% 100%;animation:critPulse 4s ease infinite}
.threat-banner.safe{border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.04);animation:none}
.threat-info{display:flex;align-items:center;gap:10px}
.threat-text{font-size:12px;font-weight:600}
.threat-count{font-size:26px;font-weight:800;font-family:var(--sans)}

/* ── SOC OVERVIEW PANEL ─────────────── */
.soc-overview{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:10px}
.soc-metric{padding:10px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);transition:all .3s}
.soc-metric:hover{transform:translateY(-2px);border-color:var(--border2)}
.soc-metric-label{font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}
.soc-metric-value{font-size:20px;font-weight:800;font-family:var(--sans);color:var(--cyan);line-height:1.2}
.soc-metric-sub{font-size:9px;color:var(--muted);margin-top:4px}
.proto-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;margin-top:6px}
.proto-segment{height:100%;transition:width .5s ease}

/* ── STAT CARDS ─────────────────────── */
.stat-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.stat-card{border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid transparent;position:relative;overflow:hidden}
.stat-card:hover{transform:translateY(-2px);border-color:var(--border2)}
.stat-card.active{outline:2px solid currentColor;outline-offset:-1px}
.stat-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}
.stat-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.stat-icon{font-size:16px}
.stat-value{font-size:28px;font-weight:800;font-family:var(--sans);animation:countUp .5s ease}
.stat-pct{font-size:10px;color:var(--dim);margin-top:2px}

/* ── CHARTS ─────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:14px}
.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;transition:border-color .3s}
.card:hover{border-color:var(--border2)}
.card-title{margin:0 0 12px;font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:2px;font-weight:700;display:flex;align-items:center;gap:7px}
.card-title-icon{font-size:13px}
.bar-row{margin-bottom:9px}
.bar-row.clickable{cursor:pointer;transition:transform .15s}.bar-row.clickable:hover{transform:translateX(3px)}
.bar-header{display:flex;justify-content:space-between;margin-bottom:3px}
.bar-label{font-size:11px;color:var(--muted)}.bar-count{font-size:11px;font-weight:600}
.bar-track{height:4px;background:rgba(255,255,255,.04);border-radius:2px;overflow:hidden}
.bar-fill{height:100%;border-radius:2px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.mitre-tag{display:inline-block;padding:1px 6px;border-radius:3px;font-size:9px;font-weight:600;letter-spacing:.5px;background:rgba(139,92,246,.12);color:var(--purple);border:1px solid rgba(139,92,246,.15);cursor:pointer;transition:all .2s}
.mitre-tag:hover{background:rgba(139,92,246,.2);transform:scale(1.05)}

/* ── MITRE HEATMAP ──────────────────── */
.mitre-heatmap{display:grid;gap:12px}
.mitre-tactic{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px}
.mitre-tactic-title{font-size:10px;color:var(--cyan);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.mitre-techniques{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}
.mitre-cell{padding:8px;border-radius:6px;text-align:center;cursor:pointer;border:1px solid transparent;transition:all .2s;position:relative}
.mitre-cell:hover{transform:translateY(-2px);border-color:var(--border2)}
.mitre-cell.active{border-color:var(--purple);box-shadow:0 0 12px rgba(139,92,246,.3)}
.mitre-cell-id{font-size:9px;color:var(--text);font-weight:600;display:block}
.mitre-cell-count{font-size:14px;color:#fff;font-weight:800;font-family:var(--sans);display:block;margin-top:2px}
.mitre-cell-name{font-size:8px;color:var(--dim);display:block;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── MAP ────────────────────────────── */
.map-container{position:relative;width:100%;height:400px;border-radius:8px;overflow:hidden;background:#080c18}
.map-container canvas{width:100%;height:100%}
.map-dot{position:absolute;width:8px;height:8px;border-radius:50%;transform:translate(-50%,-50%)}
.map-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;background:inherit;opacity:.3;animation:dotPing 2s ease infinite}
.map-legend{display:flex;gap:12px;margin-top:8px;flex-wrap:wrap}
.map-legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--dim)}
.map-legend-dot{width:6px;height:6px;border-radius:50%}
.map-stats-overlay{position:absolute;top:10px;right:10px;background:rgba(4,6,14,.9);border:1px solid var(--border);border-radius:8px;padding:8px 12px;backdrop-filter:blur(10px);z-index:1000;pointer-events:none}
.map-stats-item{font-size:10px;color:var(--muted);margin-bottom:4px}
.map-stats-item:last-child{margin-bottom:0}
.map-stats-value{color:var(--cyan);font-weight:700;margin-left:6px}

/* Leaflet overrides for dark theme */
.leaflet-container{background:#080c18;font-family:var(--mono)}
.leaflet-control-zoom a{background:rgba(4,6,14,.9)!important;color:var(--text)!important;border-color:var(--border)!important}
.leaflet-control-zoom a:hover{background:var(--surface2)!important;color:#fff!important}
.leaflet-control-attribution{background:rgba(4,6,14,.7)!important;color:var(--dim)!important;font-size:8px!important}
.leaflet-control-attribution a{color:var(--cyan)!important}
.leaflet-popup-content-wrapper{background:rgba(10,10,30,.95)!important;color:var(--text)!important;border:1px solid var(--border2)!important;border-radius:8px!important;font-family:var(--mono)!important;font-size:11px!important}
.leaflet-popup-tip{background:rgba(10,10,30,.95)!important}
.leaflet-popup-close-button{color:var(--muted)!important}

/* Server pulsing marker */
@keyframes serverPulse{0%,100%{box-shadow:0 0 0 0 rgba(16,185,129,.6)}70%{box-shadow:0 0 0 12px rgba(16,185,129,0)}}
.server-marker{width:16px;height:16px;background:#10B981;border-radius:50%;border:2px solid #fff;box-shadow:0 0 10px rgba(16,185,129,.8);animation:serverPulse 2s ease infinite}

/* ── TIMELINE ───────────────────────── */
.timeline-chart{display:flex;align-items:flex-end;gap:2px;height:80px;padding-top:8px}
.timeline-bar{flex:1;border-radius:2px 2px 0 0;min-width:3px;transition:height .5s ease;position:relative;cursor:pointer}
.timeline-bar:hover{opacity:.8}
.timeline-bar:hover::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:#1a1a2e;color:#fff;padding:3px 8px;border-radius:4px;font-size:9px;white-space:nowrap;margin-bottom:4px;border:1px solid var(--border2);z-index:10}
.timeline-labels{display:flex;justify-content:space-between;margin-top:4px}
.timeline-labels span{font-size:9px;color:var(--dark)}

/* ── HOURLY HEATMAP ─────────────────── */
.hourly-heatmap{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;margin-top:8px}
.hourly-cell{aspect-ratio:1;border-radius:3px;cursor:pointer;transition:all .2s;position:relative}
.hourly-cell:hover{transform:scale(1.1);z-index:10}
.hourly-cell:hover::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:#1a1a2e;color:#fff;padding:3px 8px;border-radius:4px;font-size:9px;white-space:nowrap;margin-bottom:4px;border:1px solid var(--border2);z-index:20}
.hourly-labels{display:flex;justify-content:space-between;margin-top:4px}
.hourly-labels span{font-size:8px;color:var(--dark)}

/* ── TREND INDICATOR ────────────────── */
.trend-indicator{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;background:var(--surface2);border:1px solid var(--border)}
.trend-arrow{font-size:16px}
.trend-text{font-size:10px;color:var(--muted)}
.trend-value{font-size:14px;font-weight:700;font-family:var(--sans);margin-left:4px}

/* ── LIVE FEED ──────────────────────── */
.feed-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:7px;margin-bottom:3px;transition:all .2s;border-left:3px solid transparent;font-size:11px}
.feed-item:hover{background:rgba(255,255,255,.02)}
.feed-item.critical{border-left-color:var(--crimson);background:rgba(220,38,38,.04)}
.feed-item.high{border-left-color:var(--red)}
.feed-item.medium{border-left-color:var(--yellow)}
.feed-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.feed-time{color:var(--dim);font-size:10px;min-width:65px;font-variant-numeric:tabular-nums}
.feed-msg{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-src{color:var(--muted);font-size:10px;min-width:110px;text-align:right}

/* ── FILTER & TABLE ─────────────────── */
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.search-box{flex:1;min-width:180px;position:relative}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--dark);font-size:13px}
.search-input{width:100%;padding:9px 10px 9px 32px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:#fff;font-size:12px;font-family:var(--mono);outline:none;transition:border-color .3s}
.search-input:focus{border-color:rgba(6,182,212,.4)}
.filter-btn{padding:7px 12px;border-radius:7px;font-size:10px;cursor:pointer;font-family:var(--mono);font-weight:500;transition:all .2s;border:1px solid var(--border);background:var(--surface);color:var(--muted)}
.filter-btn:hover{border-color:var(--border2);color:var(--text)}
.filter-btn.active{border-color:rgba(6,182,212,.4);background:rgba(6,182,212,.08);color:var(--cyan)}
.sort-btn{padding:7px 10px;border-radius:7px;font-size:10px;cursor:pointer;font-family:var(--mono);border:1px solid var(--border);background:var(--surface);color:var(--muted)}
.export-btn{padding:7px 12px;border-radius:7px;font-size:10px;cursor:pointer;font-family:var(--mono);font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--muted);transition:all .2s}
.export-btn:hover{border-color:var(--cyan);color:var(--cyan)}

.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.table-header{display:grid;grid-template-columns:85px 56px 1fr 125px 125px 55px 50px;padding:9px 14px;background:var(--surface2);border-bottom:1px solid var(--border);gap:6px}
.table-header span{font-size:9px;color:var(--dark);text-transform:uppercase;letter-spacing:2px;font-weight:700;cursor:pointer;user-select:none}
.table-header span:hover{color:var(--muted)}
.table-body{max-height:380px;overflow-y:auto}
.table-row{display:grid;grid-template-columns:85px 56px 1fr 125px 125px 55px 50px;padding:8px 14px;gap:6px;align-items:center;border-bottom:1px solid rgba(255,255,255,.02);transition:all .15s;cursor:pointer}
.table-row:hover{background:rgba(6,182,212,.03)}
.table-row.crit-row{background:rgba(220,38,38,.03)}
.table-row.crit-row:hover{background:rgba(220,38,38,.06)}
.cell-time{font-size:10px;color:var(--dim);font-variant-numeric:tabular-nums}
.cell-sev{font-size:8px;font-weight:700;padding:2px 5px;border-radius:3px;text-align:center;letter-spacing:1px}
.cell-msg{min-width:0}
.cell-msg-text{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cell-msg-sub{font-size:9px;color:var(--dark);margin-top:1px}
.cell-ip{font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums}
.cell-ip.dim{color:var(--dim)}
.cell-port{font-size:9px;color:var(--muted);text-align:center;background:rgba(255,255,255,.03);border-radius:3px;padding:1px 3px}
.cell-proto{font-size:9px;color:var(--dim);text-align:center}
.empty-state{padding:30px;text-align:center;color:var(--dark);font-size:12px}

.footer{display:flex;justify-content:space-between;padding:12px 0;font-size:9px;color:#1E293B;border-top:1px solid rgba(255,255,255,.02);margin-top:6px}

/* ── ALERT DETAIL PANEL ─────────────── */
.detail-panel{position:fixed;right:0;top:0;bottom:0;width:500px;max-width:90vw;background:rgba(4,6,14,.98);border-left:1px solid var(--border);box-shadow:-4px 0 24px rgba(0,0,0,.5);z-index:200;overflow-y:auto;animation:slideInRight .3s ease;backdrop-filter:blur(20px)}
.detail-header{padding:20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:rgba(4,6,14,.95);backdrop-filter:blur(10px);z-index:10}
.detail-title{font-family:var(--sans);font-size:16px;color:#fff;font-weight:700}
.detail-close{background:none;border:none;color:var(--dim);font-size:24px;cursor:pointer;transition:color .2s}
.detail-close:hover{color:var(--text)}
.detail-body{padding:20px}
.detail-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.detail-section:last-child{border-bottom:none}
.detail-section-title{font-size:11px;color:var(--cyan);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-bottom:10px}
.detail-field{margin-bottom:10px}
.detail-field-label{font-size:9px;color:var(--dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.detail-field-value{font-size:12px;color:var(--text);word-break:break-word}
.detail-json{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:12px;font-size:10px;color:var(--muted);max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}
.detail-btn{width:100%;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:11px;cursor:pointer;font-family:var(--mono);transition:all .2s;margin-bottom:8px}
.detail-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.detail-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:10px;font-weight:600;margin-right:6px;margin-bottom:6px}
.detail-badge.blocked{background:rgba(220,38,38,.12);color:var(--crimson);border:1px solid rgba(220,38,38,.2)}
.detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;animation:fadeIn .3s ease}

/* ── ACTIVE RESPONSE LOG ────────────── */
.response-log{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}
.response-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);margin-bottom:8px;transition:all .2s}
.response-item:hover{border-color:var(--border2)}
.response-ip{font-size:12px;color:var(--text);font-weight:600;min-width:120px}
.response-reason{flex:1;font-size:10px;color:var(--muted)}
.response-time{font-size:9px;color:var(--dim);text-align:right}
.response-badge{padding:3px 8px;border-radius:4px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.response-badge.active{background:rgba(220,38,38,.12);color:var(--crimson);border:1px solid rgba(220,38,38,.2)}
.response-badge.expired{background:rgba(64,64,64,.12);color:var(--dim);border:1px solid rgba(64,64,64,.2)}
.response-unblock-btn{padding:5px 10px;background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.25);border-radius:6px;color:var(--crimson);font-size:9px;font-weight:700;cursor:pointer;font-family:var(--mono);transition:all .2s;white-space:nowrap}
.response-unblock-btn:hover{background:rgba(220,38,38,.18);border-color:var(--crimson);transform:scale(1.05)}
.response-offense{font-size:9px;color:var(--orange);font-weight:600;min-width:50px;text-align:center}
.response-duration{font-size:9px;color:var(--muted);min-width:40px;text-align:center}

/* ── LOADING SKELETON ───────────────── */
.skeleton{background:linear-gradient(90deg,var(--surface) 0%,var(--surface2) 50%,var(--surface) 100%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:6px}
.skeleton-card{height:100px;margin-bottom:14px}
.skeleton-row{height:40px;margin-bottom:8px}

/* ── MODAL ──────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}
.modal{background:#0a0a1e;border:1px solid var(--border2);border-radius:14px;padding:28px;width:440px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.modal-head h2{color:#fff;font-family:var(--sans);font-size:16px}
.modal-close{background:none;border:none;color:#555;font-size:22px;cursor:pointer;transition:color .2s}
.modal-close:hover{color:var(--text)}
.modal-field{margin-bottom:14px}
.modal-label{display:block;color:var(--muted);font-size:10px;margin-bottom:5px;text-transform:uppercase;letter-spacing:1.5px}
.modal-input{width:100%;padding:9px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;color:#fff;font-size:12px;font-family:var(--mono);outline:none;transition:border-color .2s}
.modal-input:focus{border-color:rgba(6,182,212,.4)}
.modal-btns{display:flex;gap:10px;margin-top:20px}
.btn-primary{flex:1;padding:10px 0;background:linear-gradient(135deg,var(--cyan),var(--blue));border:none;border-radius:8px;color:#fff;font-size:12px;cursor:pointer;font-family:var(--mono);font-weight:600;box-shadow:0 4px 12px rgba(6,182,212,.25);transition:transform .2s}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{flex:1;padding:10px 0;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:12px;cursor:pointer;font-family:var(--mono);transition:all .2s}
.btn-secondary:hover{border-color:var(--border2);color:var(--text)}
.modal-hint{color:var(--dim);font-size:9px;margin-top:12px;line-height:1.5}
.ok-badge{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15);border-radius:6px;padding:6px 10px;margin-bottom:12px;color:var(--green);font-size:11px}
.err-badge{background:rgba(239,68,68,.06);border:1px solid rgba(239,68,68,.15);border-radius:6px;padding:6px 10px;margin-bottom:12px;color:var(--red);font-size:11px}

@media(max-width:1200px){
  .stat-cards{grid-template-columns:repeat(3,1fr)}
  .soc-overview{grid-template-columns:repeat(3,1fr)}
  .grid-4,.grid-3{grid-template-columns:1fr 1fr}
  .grid-5{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:800px){
  .stat-cards{grid-template-columns:repeat(2,1fr)}
  .soc-overview{grid-template-columns:repeat(2,1fr)}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .grid-5{grid-template-columns:repeat(2,1fr)}
  .filter-bar .filter-btn{display:none}
  .detail-panel{width:100%}
}

/* ── Caméra ── */
.cam-panel{display:flex;flex-direction:column;gap:16px;padding:20px 0}
.cam-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.cam-title-group{display:flex;align-items:center;gap:8px}
.cam-title{font-size:14px;font-weight:500;color:var(--text)}
.cam-header-right{display:flex;align-items:center;gap:12px}
.cam-age{font-size:11px;color:var(--dim)}
.cam-badge{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.06em;padding:4px 10px;border-radius:20px}
.cam-badge--live{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:#10B981}
.cam-badge--offline{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#EF4444}
.cam-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.cam-badge--live .cam-dot{animation:pulse 1.4s ease-in-out infinite}
.cam-video-wrapper{position:relative;width:100%;aspect-ratio:854/480;background:#080b10;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.cam-video-wrapper img{width:100%;height:100%;object-fit:cover;display:block}
.cam-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:rgba(8,11,16,.8);color:var(--dim);font-size:12px;transition:opacity .4s;pointer-events:none}
.cam-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cam-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:6px 14px;border-radius:6px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--cyan);text-decoration:none;transition:background .2s}
.cam-btn:hover{background:rgba(255,255,255,.08)}
.cam-meta{font-size:11px;color:var(--dim)}
.cam-auth-wall{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center}
.cam-auth-icon{font-size:36px}
.cam-auth-title{font-size:16px;font-weight:600;color:var(--text)}
.cam-auth-sub{font-size:13px;color:var(--dim);max-width:340px;line-height:1.6}

/* ── Onglet appels ── */
.call-card{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:14px 16px;margin-bottom:10px;transition:border .2s}
.call-card:hover{border-color:rgba(255,255,255,.12)}
.call-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.call-number{font-size:15px;font-weight:600;color:var(--text);font-family:'JetBrains Mono',monospace;letter-spacing:.04em}
.call-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:12px;letter-spacing:.04em}
.call-time{font-size:11px;color:var(--dim);margin-left:auto}
.call-meta{display:flex;gap:16px;font-size:12px;color:var(--dim);flex-wrap:wrap}
.call-joke{margin-top:10px;font-size:12px;color:var(--cyan);font-style:italic;border-left:2px solid rgba(88,166,255,.3);padding-left:10px}
