/* ══════════════════════════════════════════
   Aria AI - CyberShield Design System v2
   ══════════════════════════════════════════ */

:root {
  --void: #04070d;
  --bg1: #0a0f1c;
  --bg2: #0f1629;
  --bg3: #141d33;
  --bg4: #1a2540;
  --input: #0d1322;
  --border: rgba(56,189,248,0.07);
  --border2: rgba(56,189,248,0.2);
  --t1: #e8edf5;
  --t2: #7b8baa;
  --t3: #4a5678;
  --accent: #38bdf8;
  --aglow: rgba(56,189,248,0.1);
  --abright: #7dd3fc;
  --ok: #34d399;
  --warn: #fbbf24;
  --bad: #f87171;
  --crit: #ef4444;
  --purple: #818cf8;
  --font: 'Outfit', sans-serif;
  --mono: 'IBM Plex Mono', monospace;
  --sidebar-w: 272px;
  --topbar-h: 50px;
  --transition: 0.2s cubic-bezier(.4,0,.2,1);
}

* { margin:0; padding:0; box-sizing:border-box; }
html,body { height:100%; overflow:hidden; }
body { font-family:var(--font); background:var(--void); color:var(--t1); }

/* ── Background Grid ──────────────────── */
.bg-grid {
  position:fixed; inset:0; z-index:0;
  background-image: linear-gradient(rgba(56,189,248,0.025) 1px,transparent 1px), linear-gradient(90deg,rgba(56,189,248,0.025) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 70% 50% at 50% 40%,black,transparent);
}

/* ── Layout ──────────────────────────────── */
.app { display:flex; height:100vh; position:relative; z-index:1; }

/* ══════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════ */
.sidebar {
  width:var(--sidebar-w); flex-shrink:0; background:var(--bg1);
  border-right:1px solid var(--border); display:flex; flex-direction:column;
  transition:width var(--transition), transform var(--transition);
  z-index:20;
}
.sidebar.collapsed { width:0; overflow:hidden; border-right:none; }

.sidebar-head {
  padding:16px 16px 12px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo-icon {
  width:34px; height:34px;
  background:linear-gradient(135deg,var(--accent),#6366f1);
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 24px rgba(56,189,248,0.18);
}
.logo-icon svg { width:18px; height:18px; fill:white; }
.logo-name { font-size:17px; font-weight:700; }
.logo-name span { color:var(--accent); }
.logo-sub { font-size:8px; color:var(--t3); letter-spacing:2.5px; text-transform:uppercase; margin-top:1px; }

.sidebar-collapse-btn {
  background:none; border:none; color:var(--t3); cursor:pointer;
  padding:4px; border-radius:6px; transition:all var(--transition);
  display:flex; align-items:center; justify-content:center;
}
.sidebar-collapse-btn:hover { color:var(--accent); background:var(--aglow); }

/* New Chat Button */
.new-chat-btn {
  margin:12px 12px 0; padding:9px 14px;
  background:linear-gradient(135deg,rgba(56,189,248,0.08),rgba(99,102,241,0.06));
  border:1px solid var(--border2); border-radius:10px;
  color:var(--abright); font-size:12px; font-weight:600;
  font-family:var(--font); cursor:pointer;
  display:flex; align-items:center; gap:8px;
  transition:all var(--transition);
}
.new-chat-btn:hover {
  background:linear-gradient(135deg,rgba(56,189,248,0.14),rgba(99,102,241,0.1));
  box-shadow:0 0 20px rgba(56,189,248,0.1);
  transform:translateY(-1px);
}
.new-chat-btn .kbd {
  margin-left:auto; font-size:9px; color:var(--t3);
  font-family:var(--mono); padding:1px 5px;
  background:rgba(255,255,255,.04); border-radius:3px;
}

/* View Toggle */
.view-toggle {
  margin:10px 12px; display:flex; gap:0;
  background:var(--void); border-radius:10px; padding:3px;
  border:1px solid var(--border);
}
.vtab {
  flex:1; padding:7px 0; text-align:center;
  font-size:11px; font-weight:600; border-radius:8px;
  cursor:pointer; transition:all 0.3s; color:var(--t3);
  display:flex; align-items:center; justify-content:center; gap:5px;
  border:1px solid transparent; position:relative;
}
.vtab.active {
  background:var(--bg2); color:var(--accent);
  border-color:var(--border2);
  box-shadow:0 0 16px rgba(56,189,248,0.08);
}
.vtab .dot { width:6px; height:6px; border-radius:50%; display:none; }
.vtab.active .dot { display:block; animation:pulse 2s infinite; }
.vtab:first-child.active .dot { background:var(--accent); }
.vtab:last-child.active .dot { background:var(--ok); }

@keyframes pulse { 0%,100%{opacity:1}50%{opacity:.3} }

/* Sidebar Search */
.sidebar-search {
  margin:0 12px 6px; padding:6px 10px;
  background:var(--bg2); border:1px solid var(--border);
  border-radius:8px; display:flex; align-items:center; gap:8px;
}
.sidebar-search input {
  flex:1; background:none; border:none; outline:none;
  color:var(--t1); font-size:11px; font-family:var(--font);
}
.sidebar-search input::placeholder { color:var(--t3); }
.sidebar-search svg { flex-shrink:0; color:var(--t3); }

/* Nav List */
.nav-list { flex:1; overflow-y:auto; padding:4px 8px; }
.nav-section-label {
  font-size:9px; font-weight:600; color:var(--t3);
  text-transform:uppercase; letter-spacing:1.5px;
  padding:10px 10px 4px; margin-top:2px;
}
.nav-item {
  padding:8px 10px; border-radius:8px; font-size:12px;
  color:var(--t2); cursor:pointer; margin-bottom:1px;
  display:flex; align-items:center; gap:8px; transition:all .15s;
  position:relative;
}
.nav-item:hover { background:var(--bg4); color:var(--t1); }
.nav-item.active { background:var(--aglow); color:var(--abright); }
.nav-icon { font-size:12px; width:18px; text-align:center; flex-shrink:0; }
.nav-text { flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.nav-del {
  display:none; background:none; border:none; color:var(--t3);
  font-size:14px; cursor:pointer; padding:0 2px; line-height:1;
  font-family:var(--mono);
}
.nav-item:hover .nav-del { display:block; }
.nav-del:hover { color:var(--bad); }

/* Sidebar Footer */
.sidebar-foot { padding:10px 12px; border-top:1px solid var(--border); }
.user-row {
  display:flex; align-items:center; gap:8px;
  cursor:pointer; padding:6px 8px; border-radius:8px;
  transition:all var(--transition);
}
.user-row:hover { background:var(--bg4); }
.user-av {
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg,#6366f1,var(--accent));
  display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:700; color:white; flex-shrink:0;
}
.user-name { font-size:12px; font-weight:500; }
.user-plan { font-size:9px; color:var(--ok); letter-spacing:1px; text-transform:uppercase; }
.user-settings-icon { margin-left:auto; color:var(--t3); transition:color var(--transition); }
.user-row:hover .user-settings-icon { color:var(--accent); }

/* ══════════════════════════════════════════
   MAIN AREA
   ══════════════════════════════════════════ */
.main { flex:1; display:flex; flex-direction:column; min-width:0; min-height:0; position:relative; overflow:hidden; }

/* ── Top Bar ────────────────────────────── */
.topbar {
  height:var(--topbar-h); flex-shrink:0;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 16px; background:rgba(10,15,28,0.85); backdrop-filter:blur(16px);
  z-index:10;
}
.tb-left { display:flex; align-items:center; gap:12px; }
.tb-right { display:flex; align-items:center; gap:6px; }
.tb-title { font-size:13px; font-weight:500; color:var(--t2); }

.hamburger {
  display:none; background:none; border:none; color:var(--t2);
  cursor:pointer; padding:4px; border-radius:6px;
}
.hamburger:hover { color:var(--accent); background:var(--aglow); }

.chip {
  display:flex; align-items:center; gap:5px; padding:3px 10px;
  border-radius:100px; font-size:10px; font-weight:600; font-family:var(--mono);
}
.chip.live { background:rgba(52,211,153,0.08); color:var(--ok); }
.chip-dot {
  width:5px; height:5px; border-radius:50%; background:var(--ok);
  animation:pulse 2s infinite;
}
.chip.alerts { background:rgba(251,191,36,0.08); color:var(--warn); }

/* Topbar Icon Buttons */
.tb-icon-btn {
  width:32px; height:32px; border-radius:8px; border:1px solid var(--border);
  background:transparent; color:var(--t2); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--transition); position:relative;
}
.tb-icon-btn:hover { border-color:var(--border2); color:var(--accent); background:var(--aglow); }

/* Notification Badge */
.notif-badge {
  position:absolute; top:-4px; right:-4px;
  width:16px; height:16px; border-radius:50%;
  background:var(--crit); color:white;
  font-size:9px; font-weight:700; font-family:var(--mono);
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--bg1);
}
.notif-badge.hidden { display:none; }

/* Connection Status */
.conn-status {
  display:flex; align-items:center; gap:5px; padding:4px 10px;
  border-radius:100px; font-size:10px; font-weight:500;
  color:var(--t3); font-family:var(--mono);
  border:1px solid var(--border); margin-left:4px;
}
.conn-dot {
  width:6px; height:6px; border-radius:50%;
}
.conn-dot.online { background:var(--ok); box-shadow:0 0 8px rgba(52,211,153,0.4); }
.conn-dot.offline { background:var(--bad); }

/* ── Notification Panel ─────────────────── */
.notif-wrap { position:relative; }
.notif-panel {
  display:none; position:absolute; top:calc(100% + 8px); right:0;
  width:340px; background:var(--bg2); border:1px solid var(--border2);
  border-radius:14px; box-shadow:0 16px 48px rgba(0,0,0,0.5);
  z-index:100; overflow:hidden;
  animation:fadeDown 0.2s ease;
}
.notif-panel.open { display:block; }
@keyframes fadeDown { from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)} }

.notif-header {
  padding:12px 16px; display:flex; justify-content:space-between; align-items:center;
  border-bottom:1px solid var(--border); font-size:13px; font-weight:600;
}
.notif-header button {
  background:none; border:none; color:var(--accent); font-size:11px;
  cursor:pointer; font-family:var(--font); font-weight:500;
}
.notif-header button:hover { color:var(--abright); }
.notif-list { max-height:300px; overflow-y:auto; }
.notif-item {
  padding:12px 16px; display:flex; gap:10px; align-items:flex-start;
  border-bottom:1px solid rgba(255,255,255,.03);
  transition:background var(--transition); cursor:pointer;
}
.notif-item:hover { background:rgba(255,255,255,.02); }
.notif-item:last-child { border-bottom:none; }
.notif-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:5px; }
.notif-dot.bad { background:var(--crit); box-shadow:0 0 8px rgba(239,68,68,0.3); }
.notif-dot.warn { background:var(--warn); box-shadow:0 0 8px rgba(251,191,36,0.3); }
.notif-dot.ok { background:var(--ok); }
.notif-body { flex:1; min-width:0; }
.notif-title { font-size:12px; font-weight:600; color:var(--t1); }
.notif-desc { font-size:11px; color:var(--t3); margin-top:2px; line-height:1.4; }
.notif-time { font-size:9px; color:var(--t3); font-family:var(--mono); margin-top:4px; }
.notif-empty { padding:32px 16px; text-align:center; color:var(--t3); font-size:12px; }

/* ══════════════════════════════════════════
   CHAT VIEW
   ══════════════════════════════════════════ */
.chat-view { flex:1; display:flex; flex-direction:column; position:relative; overflow:hidden; }
.chat-view.active { display:flex; }
.chat-scroll { flex:1; overflow-y:auto; min-height:0; }
.chat-inner { max-width:860px; margin:0 auto; padding:24px 20px 170px; }

/* Welcome Screen */
.welcome { text-align:center; padding:50px 0 30px; animation:fadeUp .7s ease; }
@keyframes fadeUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.w-shield {
  width:64px; height:64px; margin:0 auto 18px;
  background:linear-gradient(135deg,rgba(56,189,248,0.12),rgba(99,102,241,0.08));
  border-radius:20px; display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(56,189,248,0.12);
  animation:shieldGlow 3s ease-in-out infinite;
}
@keyframes shieldGlow {
  0%,100%{box-shadow:0 0 20px rgba(56,189,248,0.1)}
  50%{box-shadow:0 0 40px rgba(56,189,248,0.2),0 0 60px rgba(99,102,241,0.1)}
}
.w-shield svg { width:30px; height:30px; }
.welcome h1 { font-size:26px; font-weight:800; letter-spacing:-.5px; margin-bottom:6px; }
.welcome p { font-size:13px; color:var(--t2); max-width:420px; margin:0 auto; line-height:1.6; }

.quick-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; max-width:520px; margin:28px auto 0; }
.qa {
  padding:14px; background:var(--bg2); border:1px solid var(--border);
  border-radius:12px; cursor:pointer; text-align:left; transition:all .2s;
}
.qa:hover { border-color:var(--border2); transform:translateY(-2px); box-shadow:0 6px 24px rgba(0,0,0,.3); }
.qa-icon { font-size:18px; margin-bottom:6px; }
.qa-title { font-size:12px; font-weight:600; color:var(--t1); }
.qa-desc { font-size:10px; color:var(--t3); margin-top:3px; line-height:1.3; }

/* ── Messages ──────────────────────────── */
.msg { display:flex; gap:10px; margin-bottom:20px; animation:fadeUp .3s ease; }
.msg-av {
  width:28px; height:28px; flex-shrink:0; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; margin-top:2px;
}
.msg-av.u { background:#6366f1; color:white; }
.msg-av.a { background:linear-gradient(135deg,var(--accent),#6366f1); color:white; }
.msg-body { flex:1; min-width:0; }
.msg-head { display:flex; align-items:center; gap:8px; margin-bottom:4px; }
.msg-name { font-size:11px; font-weight:600; color:var(--t3); }
.msg-time { font-size:9px; color:var(--t3); font-family:var(--mono); opacity:0; transition:opacity var(--transition); }
.msg:hover .msg-time { opacity:1; }
.msg-text { font-size:14px; line-height:1.7; color:var(--t1); }
.msg-actions {
  display:flex; gap:4px; margin-top:6px; opacity:0;
  transition:opacity var(--transition);
}
.msg:hover .msg-actions { opacity:1; }
.msg-action-btn {
  padding:3px 8px; border-radius:5px; border:1px solid var(--border);
  background:transparent; color:var(--t3); font-size:10px;
  font-family:var(--font); cursor:pointer; transition:all var(--transition);
}
.msg-action-btn:hover { border-color:var(--border2); color:var(--accent); }

/* ── Scan Cards ────────────────────────── */
.sc { background:var(--bg2); border:1px solid var(--border); border-radius:12px; margin:10px 0; overflow:hidden; }
.sc-head { padding:14px 18px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--border); }
.sc-title { font-size:14px; font-weight:600; display:flex; align-items:center; gap:6px; }
.vb { padding:4px 12px; border-radius:100px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.8px; font-family:var(--mono); }
.vb.safe { background:rgba(52,211,153,.1); color:var(--ok); border:1px solid rgba(52,211,153,.15); }
.vb.bad { background:rgba(239,68,68,.1); color:var(--crit); border:1px solid rgba(239,68,68,.15); }
.vb.warn { background:rgba(251,191,36,.1); color:var(--warn); border:1px solid rgba(251,191,36,.15); }
.sc-body { padding:16px 20px; }
.metric-r { display:flex; gap:10px; margin:10px 0; }
.mbox { flex:1; padding:12px 14px; background:rgba(255,255,255,.02); border-radius:8px; border:1px solid rgba(255,255,255,.03); }
.mbox-l { font-size:11px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; }
.mbox-v { font-size:22px; font-weight:700; font-family:var(--mono); margin-top:4px; }
.engines { display:flex; flex-wrap:wrap; gap:5px; margin-top:10px; }
.etag { padding:4px 10px; border-radius:5px; font-size:11px; font-weight:600; font-family:var(--mono); letter-spacing:.3px; }
.etag.g { background:rgba(52,211,153,.08); color:var(--ok); }
.etag.r { background:rgba(248,113,113,.08); color:var(--bad); }
.fr { display:flex; align-items:flex-start; gap:8px; padding:7px 0; border-bottom:1px solid rgba(255,255,255,.03); font-size:13px; }
.fr:last-child { border-bottom:none; }
.fr-i { flex-shrink:0; width:16px; text-align:center; margin-top:1px; font-size:12px; }
.fr-t { color:var(--t2); line-height:1.5; }
.fixbox { margin-top:12px; padding:12px 14px; border-radius:8px; font-size:12px; }
.fixbox.green { background:rgba(52,211,153,.05); border-left:3px solid var(--ok); }
.fixbox.red { background:rgba(239,68,68,.05); border-left:3px solid var(--crit); }
.fixbox-title { font-weight:600; margin-bottom:4px; }

/* ── Typing Indicator ──────────────────── */
.typing { display:flex; gap:3px; padding:6px 0; }
.tdot { width:6px; height:6px; border-radius:50%; background:var(--accent); opacity:.3; animation:bounce 1.2s ease infinite; }
.tdot:nth-child(2){animation-delay:.12s}.tdot:nth-child(3){animation-delay:.24s}
@keyframes bounce { 0%,100%{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)} }

/* ── Input Area ────────────────────────── */
.input-wrap {
  position:absolute; bottom:0; left:0; right:0;
  padding:12px 20px 14px;
  background:linear-gradient(to top,var(--bg1) 60%,transparent);
}
.input-c { max-width:860px; margin:0 auto; }
.ptools { display:flex; gap:4px; margin-bottom:8px; flex-wrap:wrap; }
.pt {
  padding:4px 10px; border-radius:6px; border:1px solid var(--border);
  background:var(--bg2); color:var(--t2); font-size:10px; font-weight:500;
  font-family:var(--font); cursor:pointer; display:flex; align-items:center; gap:4px;
  transition:all .2s;
}
.pt:hover { border-color:var(--border2); color:var(--abright); background:var(--bg3); }
.ibox {
  display:flex; align-items:flex-end;
  background:var(--input); border:1px solid var(--border);
  border-radius:14px; padding:3px; transition:border-color .2s,box-shadow .2s;
}
.ibox:focus-within { border-color:var(--border2); box-shadow:0 0 24px rgba(56,189,248,.05); }
.ibox textarea {
  flex:1; background:transparent; border:none; outline:none;
  color:var(--t1); font-family:var(--font); font-size:13px;
  padding:8px 12px; resize:none; max-height:100px; line-height:1.5;
}
.ibox textarea::placeholder { color:var(--t3); }
.send {
  width:34px; height:34px; border-radius:10px; border:none;
  background:linear-gradient(135deg,var(--accent),#6366f1); color:white;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all .2s;
  box-shadow:0 0 16px rgba(56,189,248,.15);
}
.send:hover { transform:scale(1.05); box-shadow:0 0 24px rgba(56,189,248,.25); }

.input-hint {
  text-align:center; font-size:10px; color:var(--t3); margin-top:6px;
  font-family:var(--mono);
}
.input-hint kbd {
  padding:1px 5px; border-radius:3px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
  font-size:9px; font-family:var(--mono);
}

/* ══════════════════════════════════════════
   AGENTIC VIEW - War Room
   ══════════════════════════════════════════ */
.agent-view { flex:1; display:none; flex-direction:column; overflow:hidden; min-height:0; }
.agent-view.active { display:flex; }

.agent-grid {
  flex:1; display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:auto 1fr 1fr;
  gap:1px; background:var(--border); overflow-y:auto; min-height:0;
}
.agent-grid > div { background:var(--bg1); padding:14px 16px; overflow-y:auto; min-height:0; }

.agent-status-bar {
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; background:rgba(10,15,28,0.95);
  border-bottom:1px solid var(--border);
}
.asb-left { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.agent-indicator {
  display:flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:8px;
  font-size:11px; font-weight:600; font-family:var(--mono);
}
.agent-indicator.running { background:rgba(52,211,153,.08); color:var(--ok); }
.agent-indicator.running::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--ok); animation:pulse 1.5s infinite; }
.agent-indicator.idle { background:rgba(123,139,170,.08); color:var(--t2); }
.agent-indicator.hunting { background:rgba(56,189,248,.08); color:var(--accent); }
.agent-indicator.hunting::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--accent); animation:pulse 1s infinite; }
.asb-right { display:flex; gap:8px; }
.asb-btn {
  padding:5px 14px; border-radius:6px; border:1px solid var(--border);
  background:transparent; color:var(--t2); font-size:11px; font-family:var(--font);
  font-weight:500; cursor:pointer; transition:all .2s;
}
.asb-btn:hover { border-color:var(--border2); color:var(--accent); }
.asb-btn.primary {
  background:linear-gradient(135deg,rgba(56,189,248,.15),rgba(99,102,241,.1));
  border-color:var(--border2); color:var(--abright);
}

/* Panel Headers */
.panel-head {
  font-size:11px; font-weight:600; color:var(--t2);
  text-transform:uppercase; letter-spacing:1.5px; margin-bottom:12px;
  display:flex; align-items:center; justify-content:space-between;
}
.panel-count { font-family:var(--mono); font-size:10px; color:var(--t3); padding:2px 7px; background:var(--bg2); border-radius:4px; }

/* Live Event Feed */
.event-item {
  display:flex; gap:10px; padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.03);
  animation:slideIn .3s ease; font-size:12px;
}
@keyframes slideIn { from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)} }
.event-time { flex:0 0 50px; font-family:var(--mono); font-size:10px; color:var(--t3); margin-top:2px; }
.event-icon { flex:0 0 22px; height:22px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:11px; }
.event-icon.scan { background:rgba(56,189,248,.1); }
.event-icon.block { background:rgba(239,68,68,.1); }
.event-icon.alert { background:rgba(251,191,36,.1); }
.event-icon.ok { background:rgba(52,211,153,.1); }
.event-icon.hunt { background:rgba(129,140,248,.1); }
.event-body { flex:1; }
.event-title { color:var(--t1); font-weight:500; font-size:12px; }
.event-detail { color:var(--t3); font-size:10px; margin-top:2px; }

/* Agent Cards */
.agent-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:10px; padding:12px; margin-bottom:8px;
  transition:all .3s;
}
.agent-card:hover { border-color:var(--border2); }
.agent-card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.agent-name { font-size:12px; font-weight:600; display:flex; align-items:center; gap:6px; }
.agent-status { font-size:9px; font-weight:600; padding:2px 8px; border-radius:4px; font-family:var(--mono); letter-spacing:.5px; }
.agent-status.active { background:rgba(52,211,153,.1); color:var(--ok); }
.agent-status.waiting { background:rgba(123,139,170,.08); color:var(--t3); }
.agent-status.running { background:rgba(56,189,248,.1); color:var(--accent); }
.agent-task { font-size:11px; color:var(--t2); line-height:1.5; }
.agent-progress {
  height:3px; background:rgba(255,255,255,.04); border-radius:3px;
  margin:8px 0; overflow:hidden;
}
.agent-progress-bar {
  height:100%; border-radius:3px;
  background:linear-gradient(90deg,var(--ok),var(--accent));
  transition:width 1s ease;
  animation:progressPulse 2s ease-in-out infinite;
}
.hunting-bar { background:linear-gradient(90deg,var(--accent),var(--purple)); }
@keyframes progressPulse { 0%,100%{opacity:1}50%{opacity:.6} }
.agent-metrics { display:flex; gap:8px; }
.agent-metric { font-size:10px; color:var(--t3); font-family:var(--mono); }
.agent-metric b { color:var(--t1); }

/* Actions Log */
.action-item {
  display:flex; align-items:center; gap:8px;
  padding:7px 10px; margin-bottom:4px;
  background:var(--bg2); border-radius:8px;
  font-size:11px; animation:slideIn .3s ease;
}
.action-icon { font-size:13px; }
.action-text { flex:1; color:var(--t2); }
.action-text b { color:var(--t1); font-weight:500; }
.action-time { font-size:9px; color:var(--t3); font-family:var(--mono); }

/* Threat Score Gauge */
.gauge-wrap { text-align:center; padding:10px 0; }
.gauge-svg { width:140px; height:80px; }
.gauge-val { font-size:32px; font-weight:800; font-family:var(--mono); margin-top:-8px; }
.gauge-label { font-size:10px; color:var(--t3); margin-top:2px; text-transform:uppercase; letter-spacing:1px; }
.stat-row { display:flex; justify-content:center; gap:20px; margin-top:12px; }
.stat-item { text-align:center; }
.stat-val { font-size:16px; font-weight:700; font-family:var(--mono); }
.stat-label { font-size:9px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }

/* ══════════════════════════════════════════
   COMMAND PALETTE
   ══════════════════════════════════════════ */
.cmd-overlay {
  display:none; position:fixed; inset:0; z-index:200;
  background:rgba(4,7,13,0.7); backdrop-filter:blur(4px);
  align-items:flex-start; justify-content:center; padding-top:20vh;
}
.cmd-overlay.open { display:flex; animation:fadeIn .15s ease; }
@keyframes fadeIn { from{opacity:0}to{opacity:1} }

.cmd-palette {
  width:520px; max-width:90vw;
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:16px; box-shadow:0 24px 64px rgba(0,0,0,.6);
  overflow:hidden; animation:cmdSlide .2s ease;
}
@keyframes cmdSlide { from{opacity:0;transform:translateY(-16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)} }

.cmd-search-row {
  display:flex; align-items:center; gap:10px;
  padding:14px 16px; border-bottom:1px solid var(--border);
}
.cmd-input {
  flex:1; background:none; border:none; outline:none;
  color:var(--t1); font-size:15px; font-family:var(--font);
}
.cmd-input::placeholder { color:var(--t3); }
.cmd-esc {
  padding:2px 8px; border-radius:4px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
  font-size:10px; color:var(--t3); font-family:var(--mono);
}

.cmd-list { max-height:320px; overflow-y:auto; padding:6px; }
.cmd-group-label {
  font-size:9px; font-weight:600; color:var(--t3);
  text-transform:uppercase; letter-spacing:1.5px;
  padding:8px 10px 4px;
}
.cmd-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:8px; cursor:pointer;
  transition:all var(--transition);
}
.cmd-item:hover, .cmd-item:focus { background:var(--aglow); outline:none; }
.cmd-item-icon { font-size:14px; width:20px; text-align:center; }
.cmd-item-text { flex:1; font-size:13px; color:var(--t1); }
.cmd-item-kbd { font-size:10px; color:var(--t3); font-family:var(--mono); }
.cmd-item.hidden { display:none; }

/* ══════════════════════════════════════════
   SETTINGS PANEL
   ══════════════════════════════════════════ */
.settings-overlay {
  display:none; position:fixed; inset:0; z-index:200;
  background:rgba(4,7,13,0.7); backdrop-filter:blur(4px);
  align-items:center; justify-content:center;
}
.settings-overlay.open { display:flex; animation:fadeIn .15s ease; }

.settings-panel {
  width:440px; max-width:90vw; max-height:80vh;
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:16px; box-shadow:0 24px 64px rgba(0,0,0,.6);
  overflow:hidden; animation:cmdSlide .2s ease;
}
.settings-head {
  padding:16px 20px; display:flex; justify-content:space-between; align-items:center;
  border-bottom:1px solid var(--border);
}
.settings-head h3 { font-size:16px; font-weight:700; }
.settings-close {
  background:none; border:none; color:var(--t3); font-size:18px;
  cursor:pointer; font-family:var(--mono); width:28px; height:28px;
  border-radius:6px; display:flex; align-items:center; justify-content:center;
}
.settings-close:hover { color:var(--t1); background:var(--bg4); }

.settings-body { padding:16px 20px; overflow-y:auto; max-height:calc(80vh - 60px); }
.settings-section { margin-bottom:20px; }
.settings-label { font-size:10px; font-weight:600; color:var(--t3); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:8px; }
.settings-value { font-size:14px; font-weight:500; }
.plan-badge {
  padding:3px 12px; border-radius:100px; font-size:11px; font-weight:600;
  background:linear-gradient(135deg,rgba(56,189,248,.15),rgba(99,102,241,.1));
  color:var(--abright); border:1px solid var(--border2);
}

.settings-keys { display:flex; flex-direction:column; gap:6px; }
.key-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 12px; background:rgba(255,255,255,.02); border-radius:8px;
  font-size:12px;
}
.key-status { font-size:10px; font-weight:600; font-family:var(--mono); }
.key-status.connected { color:var(--ok); }
.key-status.disconnected { color:var(--t3); }

.toggle-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 0; cursor:pointer; font-size:13px;
}
.toggle-row input { display:none; }
.toggle-slider {
  width:36px; height:20px; border-radius:10px;
  background:var(--bg4); position:relative;
  transition:background var(--transition);
}
.toggle-slider::after {
  content:''; position:absolute; top:2px; left:2px;
  width:16px; height:16px; border-radius:50%; background:var(--t3);
  transition:all var(--transition);
}
.toggle-row input:checked + .toggle-slider { background:var(--accent); }
.toggle-row input:checked + .toggle-slider::after { left:18px; background:white; }

/* ── Scrollbar ─────────────────────────── */
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,.06); border-radius:3px; }

/* ══════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════ */
@media (max-width: 900px) {
  .sidebar { position:fixed; left:0; top:0; bottom:0; z-index:50; transform:translateX(-100%); }
  .sidebar.mobile-open { transform:translateX(0); }
  .hamburger { display:flex; }
  .sidebar-collapse-btn { display:none; }
  .agent-grid { grid-template-columns:1fr; grid-template-rows:auto; }
  .agent-grid > div[style*="grid-row"] { grid-row:auto !important; }
  .agent-grid > div[style*="grid-column"] { grid-column:auto !important; }
  .asb-left { gap:8px; }
  .agent-indicator { font-size:9px; padding:4px 8px; }
  .quick-grid { grid-template-columns:repeat(2,1fr); }
  .conn-status span:last-child { display:none; }
}

@media (max-width: 600px) {
  .quick-grid { grid-template-columns:1fr; }
  .chip.alerts { display:none; }
  .tb-title { font-size:12px; }
  .cmd-palette { border-radius:12px; }
  .ptools { display:none; }
}

/* Mobile sidebar overlay */
.sidebar-backdrop {
  display:none; position:fixed; inset:0; z-index:40;
  background:rgba(4,7,13,0.6);
}
.sidebar-backdrop.visible { display:block; }

/* ══════════════════════════════════════════
   SKELETON LOADING STATES
   ══════════════════════════════════════════ */
@keyframes skeletonPulse {
  0%, 100% { opacity:0.4; }
  50% { opacity:0.15; }
}
.skel {
  background:var(--bg4);
  border-radius:6px;
  animation:skeletonPulse 1.5s ease-in-out infinite;
}
.skel-line { height:12px; margin-bottom:8px; }
.skel-line.short { width:60%; }
.skel-line.med { width:80%; }
.skel-line.xs { width:40%; height:10px; }
.skel-circle { width:36px; height:36px; border-radius:50%; }
.skel-block { height:48px; margin-bottom:10px; }
.skel-bar { height:6px; margin-bottom:6px; }
.skel-row { display:flex; align-items:center; gap:12px; padding:8px 0; }

/* ══════════════════════════════════════════
   DARK / LIGHT THEME TOGGLE
   ══════════════════════════════════════════ */
.theme-toggle {
  display:flex; align-items:center; gap:8px;
  cursor:pointer; padding:4px 0;
}
.theme-switch {
  width:36px; height:20px; border-radius:10px;
  background:var(--bg4); border:1px solid var(--border2);
  position:relative; transition:all .3s;
}
.theme-switch::after {
  content:''; position:absolute; top:2px; left:2px;
  width:14px; height:14px; border-radius:50%;
  background:var(--t2); transition:all .3s;
}
.theme-switch.active { background:var(--accent); border-color:var(--accent); }
.theme-switch.active::after { left:18px; background:#fff; }
.theme-label { font-size:12px; color:var(--t2); font-weight:500; }

/* ── Light theme overrides ──────────────── */
[data-theme="light"] {
  --void: #f8fafc;
  --bg1: #ffffff;
  --bg2: #f1f5f9;
  --bg3: #e2e8f0;
  --bg4: #cbd5e1;
  --input: #f1f5f9;
  --border: rgba(15,23,42,0.08);
  --border2: rgba(15,23,42,0.15);
  --t1: #0f172a;
  --t2: #475569;
  --t3: #94a3b8;
}
[data-theme="light"] .bg-grid {
  background-image: linear-gradient(rgba(15,23,42,0.03) 1px,transparent 1px), linear-gradient(90deg,rgba(15,23,42,0.03) 1px,transparent 1px);
}
[data-theme="light"] .dash-card,
[data-theme="light"] .report-card,
[data-theme="light"] .set-card,
[data-theme="light"] .mon-card {
  box-shadow:0 1px 3px rgba(0,0,0,0.06);
}
[data-theme="light"] .topbar {
  background:rgba(255,255,255,0.9);
  border-bottom-color:rgba(0,0,0,0.06);
}
[data-theme="light"] .sidebar {
  background:#fff;
  border-right-color:rgba(0,0,0,0.06);
}
[data-theme="light"] .notif-panel {
  background:rgba(255,255,255,0.97);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
}
[data-theme="light"] .notif-item { border-bottom-color:rgba(0,0,0,0.05); }
[data-theme="light"] .cmd-palette {
  background:rgba(255,255,255,0.97);
  box-shadow:0 8px 32px rgba(0,0,0,0.12);
}
[data-theme="light"] .cmd-item:hover { background:rgba(56,189,248,0.08); }
[data-theme="light"] .score-ring-val { fill:#0f172a; }
[data-theme="light"] .msg.bot { background:#f1f5f9; border-color:rgba(0,0,0,0.06); }
[data-theme="light"] .msg.user { background:rgba(56,189,248,0.08); }
[data-theme="light"] .chat-input {
  background:#fff; border-color:rgba(0,0,0,0.1);
  color:#0f172a;
}
[data-theme="light"] .chat-input::placeholder { color:#94a3b8; }
[data-theme="light"] .aria-toast {
  background:rgba(255,255,255,0.97) !important;
  border-color:rgba(0,0,0,0.08) !important;
}
[data-theme="light"] .aria-toast .notif-title,
[data-theme="light"] .aria-toast div[style*="color:#e2e8f0"] { color:#0f172a !important; }
[data-theme="light"] .settings-panel { background:#fff; }
[data-theme="light"] .login-card { background:#fff; box-shadow:0 4px 24px rgba(0,0,0,0.08); }

/* ══════════════════════════════════════════
   MOBILE NOTIFICATION PANEL FIX
   ══════════════════════════════════════════ */
@media (max-width: 600px) {
  .notif-panel { width:calc(100vw - 24px); right:-8px; }
  .cmd-palette { width:calc(100vw - 32px); left:16px; right:16px; transform:none; }
}
