@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600;700&family=Syne:wght@400;600;700;800&display=swap');

/* ── TOKENS ─────────────────────────────────────────────────────── */
:root {
  --bg:#0a0a0f; --bg2:#0f0f18; --bg3:#14141f; --surface:#1a1a28; --surface2:#22223a;
  --border:#2a2a45; --border2:#3a3a60;
  --accent:#7c3aed; --accent2:#a855f7; --accent3:#c084fc;
  --green:#22d3a3; --red:#f43f5e; --orange:#f97316; --yellow:#eab308; --blue:#3b82f6;
  --text:#e2e8f0; --text2:#94a3b8; --text3:#64748b;
  --mono:'JetBrains Mono',monospace; --sans:'Syne',sans-serif;
  --radius:10px; --radius-sm:6px; --radius-lg:14px;
  --shadow:0 4px 20px rgba(0,0,0,.3);
  --shadow-accent:0 0 30px rgba(124,58,237,.2);
}

/* ── RESET ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { height:100%; }
body {
  background:var(--bg); color:var(--text);
  font-family:var(--sans); min-height:100vh;
  overflow-x:hidden; line-height:1.5;
}
body::before {
  content:'';
  position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.35;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
button { cursor:pointer; font-family:inherit; }
input, textarea, select { font-family:inherit; }
a { color:inherit; text-decoration:none; }

/* ── SCREENS ─────────────────────────────────────────────────────── */
.screen { display:none; min-height:100vh; }
.screen.active { display:flex; }

/* ── LOADING ─────────────────────────────────────────────────────── */
#loading-overlay {
  position:fixed; inset:0; background:var(--bg); z-index:500;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:16px;
}
.spinner {
  width:40px; height:40px;
  border:3px solid var(--border); border-top-color:var(--accent2);
  border-radius:50%; animation:spin .8s linear infinite;
}
.spinner-text { font-family:var(--mono); font-size:12px; color:var(--text3); }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── LOGIN ───────────────────────────────────────────────────────── */
#login-screen {
  flex-direction:column; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.login-bg-grid {
  position:absolute; inset:0;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),
                   linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:40px 40px; opacity:.25;
  animation:gridPulse 8s ease-in-out infinite;
}
.login-glow {
  position:absolute; width:600px; height:600px; border-radius:50%;
  background:radial-gradient(ellipse,rgba(124,58,237,.15) 0%,transparent 70%);
  top:50%; left:50%; transform:translate(-50%,-50%);
  animation:glowPulse 4s ease-in-out infinite;
}
@keyframes gridPulse { 0%,100%{opacity:.2} 50%{opacity:.4} }
@keyframes glowPulse { 0%,100%{transform:translate(-50%,-50%) scale(1)} 50%{transform:translate(-50%,-50%) scale(1.1)} }
.login-card {
  position:relative; z-index:10;
  background:rgba(26,26,40,.9); backdrop-filter:blur(20px);
  border:1px solid var(--border2); border-radius:var(--radius-lg);
  padding:48px 40px; width:440px;
  box-shadow:0 0 60px rgba(124,58,237,.15), 0 20px 60px rgba(0,0,0,.5);
  animation:cardIn .6s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cardIn { from{opacity:0;transform:translateY(30px) scale(.95)} to{opacity:1;transform:translateY(0) scale(1)} }
.login-logo { display:flex; align-items:center; gap:10px; margin-bottom:6px; }
.logo-icon { width:36px;height:36px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px; }
.logo-text { font-size:24px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent3),#e879f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.login-tagline { font-family:var(--mono);font-size:11px;color:var(--text3);margin-bottom:28px;letter-spacing:.1em;text-transform:uppercase; }

/* ── FORM ELEMENTS ───────────────────────────────────────────────── */
.tab-row { display:flex;gap:2px;background:var(--bg3);border-radius:8px;padding:3px;margin-bottom:20px; }
.tab-btn { flex:1;padding:8px;background:none;border:none;color:var(--text3);font-size:13px;font-weight:600;border-radius:6px;transition:all .2s; }
.tab-btn.active { background:var(--surface);color:var(--text); }
.form-group { margin-bottom:14px; }
.form-label { display:block;font-family:var(--mono);font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px; }
.form-input { width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:var(--mono);font-size:13px;transition:all .2s;outline:none; }
.form-input:focus { border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,58,237,.15); }
.form-error { color:var(--red);font-family:var(--mono);font-size:12px;margin-top:8px;display:none; }

/* ── BUTTONS ─────────────────────────────────────────────────────── */
.btn-primary { width:100%;background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:8px;padding:12px;color:#fff;font-size:14px;font-weight:700;letter-spacing:.02em;transition:all .2s;margin-top:6px; }
.btn-primary:hover { transform:translateY(-1px);box-shadow:0 6px 20px rgba(124,58,237,.4); }
.btn-primary:disabled { opacity:.5;cursor:not-allowed;transform:none; }
.btn-secondary { background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 18px;color:var(--text2);font-size:13px;font-weight:600;transition:all .15s; }
.btn-secondary:hover { border-color:var(--border2);color:var(--text); }
.btn-accent { background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.3);border-radius:8px;padding:8px 16px;color:var(--accent3);font-size:13px;font-weight:700;transition:all .2s;display:inline-flex;align-items:center;gap:6px; }
.btn-accent:hover { background:rgba(124,58,237,.25);border-color:var(--accent); }
.btn-icon { background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:11px;color:var(--text3);transition:all .15s; }
.ai-btn { background:rgba(109,40,217,.12);border:1px solid rgba(109,40,217,.25);border-radius:6px;padding:3px 10px;font-size:11px;font-weight:600;color:#a78bfa;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:4px; }
.ai-btn:hover { background:rgba(109,40,217,.22);border-color:#7c3aed;color:#c4b5fd; }
.ai-btn:disabled { opacity:.5;cursor:not-allowed; }
.ai-btn.loading { opacity:.7; }
.btn-icon:hover { border-color:var(--border2);color:var(--text2); }
.btn-icon.edit:hover { border-color:var(--blue);color:var(--blue); }
.btn-icon.delete:hover { border-color:var(--red);color:var(--red); }
.btn-save { background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;border-radius:8px;padding:9px 18px;color:#fff;font-size:13px;font-weight:700;transition:all .2s; }
.btn-save:hover { transform:translateY(-1px);box-shadow:0 4px 15px rgba(124,58,237,.4); }
.btn-save:disabled { opacity:.5;cursor:not-allowed;transform:none; }
.btn-danger { background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.3);border-radius:8px;padding:8px 16px;color:var(--red);font-size:13px;font-weight:700;transition:all .2s; }
.btn-danger:hover { background:rgba(244,63,94,.2);border-color:var(--red); }

/* ── TOPBAR ──────────────────────────────────────────────────────── */
.topbar {
  background:rgba(15,15,24,.95); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border); padding:0 20px; height:56px;
  display:flex; align-items:center; gap:12px;
  position:sticky; top:0; z-index:100;
}
.topbar-logo { display:flex; align-items:center; gap:8px; }
.topbar-logo-icon { width:28px;height:28px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px; }
.topbar-logo-text { font-size:17px;font-weight:800;background:linear-gradient(135deg,var(--accent3),#e879f9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text; }
.topbar-spacer { flex:1; }
.nav-btn { background:none;border:none;color:var(--text3);font-size:13px;font-weight:600;padding:6px 11px;border-radius:6px;transition:all .2s; }
.nav-btn:hover { color:var(--text);background:var(--surface); }
.nav-btn.active { color:var(--accent3);background:rgba(124,58,237,.12); }

/* Search */
.search-wrap { position:relative; }
.search-input { background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 12px 6px 30px;color:var(--text);font-family:var(--mono);font-size:12px;width:190px;outline:none;transition:all .2s; }
.search-input:focus { border-color:var(--accent);width:240px; }
.search-icon { position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:12px;pointer-events:none; }

/* Progress pill */
.progress-pill { background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-family:var(--mono);font-size:11px;color:var(--text2);display:flex;align-items:center;gap:6px; }
.progress-bar-mini { width:50px;height:4px;background:var(--border);border-radius:2px;overflow:hidden; }
.progress-bar-mini-fill { height:100%;background:linear-gradient(90deg,var(--green),#34d399);border-radius:2px;transition:width .3s; }

/* Online presence */
.online-avatars { display:flex; gap:6px; align-items:center; }
.online-dot { position:relative; }
.avatar-sm { width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;line-height:1; }
.online-count { font-family:var(--mono);font-size:10px;color:var(--text3);margin-left:4px; }

/* User pill */
.user-pill { display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:4px 12px 4px 4px;cursor:pointer;transition:all .2s;position:relative; }
.user-pill:hover { border-color:var(--border2); }
.user-dropdown { position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:6px;min-width:180px;display:none;box-shadow:var(--shadow);z-index:200; }
.user-dropdown.open { display:block; }
.dropdown-item { display:block;width:100%;padding:8px 12px;background:none;border:none;color:var(--text2);font-size:13px;text-align:left;border-radius:6px;transition:all .15s;cursor:pointer;font-family:inherit; }
.dropdown-item:hover { background:var(--bg3);color:var(--text); }
.dropdown-item.danger:hover { background:rgba(244,63,94,.1);color:var(--red); }

/* ── LAYOUT ──────────────────────────────────────────────────────── */
#app-screen { flex-direction:column; }
.app-body { display:flex; flex:1; height:calc(100vh - 56px); }
.sidebar { width:260px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;flex-shrink:0;padding:12px 0; }
.sidebar::-webkit-scrollbar { width:4px; }
.sidebar::-webkit-scrollbar-thumb { background:var(--border2);border-radius:2px; }
.main-content { flex:1;overflow-y:auto;padding:24px; }
.main-content::-webkit-scrollbar { width:6px; }
.main-content::-webkit-scrollbar-thumb { background:var(--border2);border-radius:3px; }

/* ── SIDEBAR ─────────────────────────────────────────────────────── */
.sidebar-section-label { font-family:var(--mono);font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;padding:4px 14px 5px;margin-top:8px; }
.sidebar-item { display:flex;align-items:center;padding:6px 14px;cursor:pointer;transition:all .15s;border-left:2px solid transparent;gap:7px; }
.sidebar-item:hover { background:rgba(124,58,237,.06);border-left-color:var(--border2); }
.sidebar-item.active { background:rgba(124,58,237,.12);border-left-color:var(--accent); }
.sidebar-item-text { font-size:12px;font-weight:600;color:var(--text2);flex:1;line-height:1.3; }
.sidebar-item.active .sidebar-item-text { color:var(--accent3); }
.sidebar-item-badge { font-family:var(--mono);font-size:9px;color:var(--text3);background:var(--bg3);border-radius:10px;padding:1px 5px; }
.sidebar-item.active .sidebar-item-badge { background:rgba(124,58,237,.2);color:var(--accent3); }
.sidebar-mini-bar { width:22px;height:3px;background:var(--border);border-radius:2px;overflow:hidden;flex-shrink:0; }
.sidebar-mini-fill { height:100%;background:var(--green);border-radius:2px;transition:width .3s; }
.sidebar-divider { height:1px;background:var(--border);margin:8px 14px; }

/* ── VIEWS ───────────────────────────────────────────────────────── */
.view { display:none; }
.view.active { display:block; }
.page-header { display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px; }
.page-title { font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px; }
.page-subtitle { font-family:var(--mono);font-size:12px;color:var(--text3);margin-top:2px; }
.page-actions { display:flex;gap:8px;align-items:center;flex-shrink:0; }

/* ── STATS ───────────────────────────────────────────────────────── */
.stats-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px; }
.stat-card { background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden; }
.stat-card::before { content:'';position:absolute;top:0;left:0;right:0;height:2px; }
.stat-card.green::before { background:var(--green); }
.stat-card.red::before   { background:var(--red); }
.stat-card.orange::before { background:var(--orange); }
.stat-card.purple::before { background:var(--accent2); }
.stat-label { font-family:var(--mono);font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px; }
.stat-value { font-size:28px;font-weight:800;line-height:1;margin-bottom:4px; }
.stat-card.green .stat-value { color:var(--green); }
.stat-card.red .stat-value   { color:var(--red); }
.stat-card.orange .stat-value { color:var(--orange); }
.stat-card.purple .stat-value { color:var(--accent3); }
.stat-sub { font-family:var(--mono);font-size:11px;color:var(--text3); }

/* ── PROGRESS ────────────────────────────────────────────────────── */
.progress-section { background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px; }
.progress-label-row { display:flex;justify-content:space-between;align-items:center;margin-bottom:7px; }
.progress-label { font-family:var(--mono);font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em; }
.progress-pct { font-family:var(--mono);font-size:13px;font-weight:700;color:var(--green); }
.progress-bar { height:5px;background:var(--border);border-radius:3px;overflow:hidden; }
.progress-bar-fill { height:100%;background:linear-gradient(90deg,var(--green),#34d399);border-radius:3px;transition:width .5s ease; }

/* ── PROJECTS ────────────────────────────────────────────────────── */
.projects-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-bottom:16px; }
.project-card { background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;position:relative; }
.project-card:hover { border-color:var(--border2);transform:translateY(-1px); }
.project-card.selected { border-color:var(--accent);background:rgba(124,58,237,.05); }
.project-card-name { font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px; }
.project-card-target { font-family:var(--mono);font-size:11px;color:var(--text3);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
.project-card-meta { display:flex;gap:6px;align-items:center; }
.role-badge { font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;text-transform:uppercase; }
.role-owner   { background:rgba(220,38,38,.15);color:#dc2626; }
.role-editor  { background:rgba(5,150,105,.15);color:#059669; }
.role-viewer  { background:rgba(37,99,235,.15);color:#2563eb; }
.btn-add-project { background:rgba(124,58,237,.08);border:1px dashed rgba(124,58,237,.3);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:700;color:var(--accent3); }
.btn-add-project:hover { background:rgba(124,58,237,.16);border-color:var(--accent); }

/* ── CHECKLIST ───────────────────────────────────────────────────── */
.filter-row { display:flex;gap:5px;margin-bottom:12px;flex-wrap:wrap; }
.filter-chip { background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:4px 11px;font-family:var(--mono);font-size:11px;color:var(--text3);cursor:pointer;transition:all .15s; }
.filter-chip:hover { border-color:var(--border2);color:var(--text2); }
.filter-chip.active { background:rgba(124,58,237,.15);border-color:var(--accent);color:var(--accent3); }

.category-block { margin-bottom:4px; }
.category-header { display:flex;align-items:center;gap:10px;padding:10px 0;cursor:pointer;user-select:none;border-bottom:1px solid var(--border); }
.category-chevron { color:var(--text3);transition:transform .2s;font-size:10px; }
.category-header.open .category-chevron { transform:rotate(90deg); }
.category-badge { font-family:var(--mono);font-size:9px;font-weight:600;padding:2px 6px;border-radius:4px;background:rgba(124,58,237,.15);color:var(--accent3);letter-spacing:.05em; }
.category-name { font-size:13px;font-weight:700;color:var(--text);flex:1; }
.cat-meta { display:flex;align-items:center;gap:8px; }
.cat-count { font-family:var(--mono);font-size:11px;color:var(--text3); }
.cat-mini-bar { width:46px;height:3px;background:var(--border);border-radius:2px;overflow:hidden;display:flex; }
.cat-mini-fill { height:100%;background:var(--green);transition:width .3s; }
.cat-mini-fail { height:100%;background:var(--red);transition:width .3s; }

.test-list { display:none;padding:5px 0; }
.test-list.open { display:block; }
.test-item { border:1px solid var(--border);border-radius:var(--radius);margin:4px 0;overflow:hidden;background:var(--bg3);transition:border-color .2s; }
.test-item:hover { border-color:var(--border2); }
.test-item.completed { border-color:rgba(34,211,163,.3); }
.test-item.failed    { border-color:rgba(244,63,94,.3); }
.test-item.na        { border-color:rgba(100,116,139,.25); }

.test-header { display:flex;align-items:center;padding:9px 12px;gap:8px;cursor:pointer; }
.test-check { width:17px;height:17px;border:2px solid var(--border2);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;font-size:10px; }
.test-check:hover { border-color:var(--green); }
.test-item.completed .test-check { background:var(--green);border-color:var(--green);color:var(--bg); }
.test-item.failed    .test-check { background:var(--red);border-color:var(--red);color:#fff; }
.test-item.na        .test-check { background:var(--border2);border-color:var(--border2);color:var(--text3); }
.test-id { font-family:var(--mono);font-size:10px;color:var(--text3);flex-shrink:0;min-width:90px; }
.test-name { font-size:12px;font-weight:600;color:var(--text);flex:1;line-height:1.3; }
.test-item.completed .test-name { text-decoration:line-through;color:var(--text3); }
.test-item.na        .test-name { color:var(--text3); }

/* Last editor badge */
.last-editor { display:flex;align-items:center;gap:4px;flex-shrink:0; }
.last-editor-avatar { width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#fff; }
.last-editor-name { font-family:var(--mono);font-size:9px;color:var(--text3); }
.last-editor-time { font-family:var(--mono);font-size:9px;color:var(--text3); }

.test-actions { display:flex;gap:2px;flex-shrink:0; }
.test-action-btn { background:none;border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:var(--mono);font-size:9px;color:var(--text3);cursor:pointer;transition:all .15s; }
.test-action-btn:hover { border-color:var(--border2);color:var(--text2); }
.test-action-btn.pass:hover { border-color:var(--green);color:var(--green); }
.test-action-btn.vuln:hover { border-color:var(--red);color:var(--red); }

.test-body { display:none;padding:0 12px 12px;border-top:1px solid var(--border); }
.test-body.open { display:block; }

/* Items */
.items-section { margin-top:10px; }
.items-label { font-family:var(--mono);font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px; }
.item-row { display:flex;align-items:flex-start;gap:7px;padding:2px 0; }
.item-checkbox { width:13px;height:13px;border:1px solid var(--border2);border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;margin-top:3px;transition:all .15s;font-size:8px;line-height:1; }
.item-checkbox:hover { border-color:var(--accent); }
.item-checkbox.checked { background:rgba(124,58,237,.2);border-color:var(--accent);color:var(--accent3); }
.item-text { font-family:var(--mono);font-size:11px;color:var(--text2);line-height:1.5;flex:1; }
.item-text.done { text-decoration:line-through;color:var(--text3); }

/* Payloads */
.payload-section { margin-top:10px; }
.payload-tabs { display:flex;gap:2px;background:var(--bg2);border-radius:5px;padding:2px;margin-bottom:6px; }
.payload-tab { flex:1;padding:3px;background:none;border:none;color:var(--text3);font-family:var(--mono);font-size:9px;font-weight:600;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:all .15s; }
.payload-tab.active { background:var(--surface);color:var(--accent3); }
.payload-panel { display:none; }
.payload-panel.active { display:block; }
.payload-row { display:flex;align-items:flex-start;gap:5px;margin-bottom:3px; }
.payload-code { flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:4px 8px;font-family:var(--mono);font-size:11px;color:var(--green);word-break:break-all;line-height:1.5;white-space:pre-wrap; }

/* ── Markdown content ─────────────────────────────────────────── */
.md-body { font-size:12px;line-height:1.6;padding:2px 0; }
.md-line { line-height:1.6; }
.md-gap  { height:6px; }
.md-h2   { font-weight:700;font-size:13px;margin:8px 0 2px;line-height:1.3; }
.md-h3   { font-weight:600;font-size:12px;margin:6px 0 2px;line-height:1.3; }
.md-li   { padding-left:14px;position:relative;line-height:1.6; }
.md-li::before { content:'•';position:absolute;left:2px; }
.md-pre  { background:var(--bg2);border:1px solid var(--border);border-radius:5px;padding:8px 10px;font-family:var(--mono);font-size:11px;overflow-x:auto;margin:4px 0;white-space:pre;color:var(--text2);line-height:1.5; }
.md-ic   { background:var(--bg3);border:1px solid var(--border);border-radius:3px;padding:0 4px;font-family:var(--mono);font-size:0.88em;color:var(--text2); }

/* ── AI Chat panel ───────────────────────────────────────────── */
.ai-chat-messages { display:flex;flex-direction:column;gap:10px;overflow-y:auto;max-height:340px;padding:4px 2px;margin-bottom:10px; }
.ai-chat-msg { display:flex;flex-direction:column;gap:3px;max-width:90%; }
.ai-chat-msg.user { align-self:flex-end;align-items:flex-end; }
.ai-chat-msg.ai   { align-self:flex-start;align-items:flex-start; }
.ai-chat-bubble { padding:8px 12px;border-radius:10px;font-size:12px;line-height:1.55;word-break:break-word; }
.ai-chat-msg.user .ai-chat-bubble { background:rgba(109,40,217,.2);border:1px solid rgba(109,40,217,.3);color:var(--text); }
.ai-chat-msg.ai   .ai-chat-bubble { background:var(--bg3);border:1px solid var(--border);color:var(--text2); }
.ai-chat-bubble p { margin:0 0 6px; } .ai-chat-bubble p:last-child { margin:0; }
.ai-chat-bubble ul,.ai-chat-bubble ol { margin:4px 0 4px 16px;padding:0; }
.ai-chat-bubble li { margin-bottom:2px; }
.ai-chat-bubble code { font-family:var(--mono);font-size:11px;background:var(--bg);border:1px solid var(--border);border-radius:3px;padding:1px 4px; }
.ai-chat-bubble pre { background:var(--bg);border:1px solid var(--border);border-radius:5px;padding:8px 10px;overflow-x:auto;margin:6px 0; }
.ai-chat-bubble pre code { background:none;border:none;padding:0; }
.ai-chat-bubble strong { color:var(--text);font-weight:700; }
.ai-chat-input-row { display:flex;gap:6px; }
.ai-chat-input { flex:1;background:var(--bg);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12px;font-family:inherit;padding:7px 10px;resize:none;min-height:36px;max-height:80px;overflow-y:auto; }
.ai-chat-input:focus { outline:none;border-color:rgba(109,40,217,.5); }
.ai-chat-send { background:rgba(109,40,217,.2);border:1px solid rgba(109,40,217,.35);border-radius:7px;color:#a78bfa;font-size:13px;padding:0 12px;cursor:pointer;transition:all .15s;flex-shrink:0; }
.ai-chat-send:hover { background:rgba(109,40,217,.35); }
.ai-chat-send:disabled { opacity:.4;cursor:not-allowed; }
.ai-chat-empty { font-family:var(--mono);font-size:11px;color:var(--text3);text-align:center;padding:24px 0; }
.ai-chat-typing { display:flex;gap:4px;align-items:center;padding:8px 12px; }
.ai-chat-typing span { width:6px;height:6px;border-radius:50%;background:var(--text3);animation:ai-bounce .9s infinite; }
.ai-chat-typing span:nth-child(2) { animation-delay:.15s; }
.ai-chat-typing span:nth-child(3) { animation-delay:.3s; }
@keyframes ai-bounce { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-5px)} }

/* ── Fun modes (owner-only extras) ───────────────────────────── */
.neon-mode .sev-badge        { text-shadow:0 0 8px currentColor,0 0 16px currentColor; }
.neon-mode .progress-bar-fill{ box-shadow:0 0 8px var(--green),0 0 2px var(--green); }
.neon-mode .sev-bar          { box-shadow:0 0 6px currentColor; }

.hacker-mode::after {
  content:'';
  position:fixed;
  inset:0;
  z-index:9998;
  pointer-events:none;
  background:repeating-linear-gradient(
    0deg,
    transparent,
    transparent 3px,
    rgba(0,255,0,0.018) 3px,
    rgba(0,255,0,0.018) 4px
  );
  animation:scanlines 8s linear infinite;
}
@keyframes scanlines {
  from { background-position:0 0; }
  to   { background-position:0 100vh; }
}
.copy-btn { background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:4px 7px;font-family:var(--mono);font-size:9px;color:var(--text3);cursor:pointer;transition:all .15s;flex-shrink:0; }
.copy-btn:hover { border-color:var(--accent);color:var(--accent3); }
.copy-btn.copied { border-color:var(--green);color:var(--green); }

.note-textarea { width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:5px;padding:7px 9px;color:var(--text);font-family:var(--mono);font-size:11px;resize:vertical;min-height:52px;outline:none;transition:border-color .2s;margin-top:7px; }
.note-textarea:focus { border-color:var(--accent); }
.note-textarea::placeholder { color:var(--text3); }

/* ── PORTSWIGGER ─────────────────────────────────────────────────── */
.ps-category { margin-bottom:5px; }
.ps-cat-header { display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s; }
.ps-cat-header:hover { border-color:var(--border2); }
.ps-cat-header.open { border-radius:8px 8px 0 0; }
.ps-cat-name { font-size:13px;font-weight:700;color:var(--text);flex:1; }
.ps-cat-count { font-family:var(--mono);font-size:10px;color:var(--text3); }
.ps-labs { display:none;background:var(--bg2);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px;padding:4px; }
.ps-labs.open { display:block; }
.ps-lab-row { display:flex;align-items:center;gap:7px;padding:5px 7px;border-radius:5px;transition:background .1s; }
.ps-lab-row:hover { background:var(--surface); }
.ps-lab-check { width:15px;height:15px;border:1px solid var(--border2);border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s;font-size:9px; }
.ps-lab-check:hover { border-color:var(--green); }
.ps-lab-check.done { background:var(--green);border-color:var(--green);color:var(--bg); }
.ps-lab-title { font-size:12px;color:var(--text2);flex:1;font-family:var(--mono);line-height:1.3; }
.ps-lab-check.done ~ .ps-lab-title { text-decoration:line-through;color:var(--text3); }
.diff-badge { font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 5px;border-radius:10px;text-transform:uppercase;flex-shrink:0; }
.diff-Apprentice   { background:rgba(34,211,163,.12);color:var(--green); }
.diff-Practitioner { background:rgba(249,115,22,.12);color:var(--orange); }
.diff-Expert       { background:rgba(244,63,94,.12);color:var(--red); }

/* ── CUSTOM VULNS ────────────────────────────────────────────────── */
.vuln-card { background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:6px;overflow:hidden;transition:border-color .2s; }
.vuln-card:hover { border-color:var(--border2); }
.vuln-card.completed { border-color:rgba(34,211,163,.3); }
.vuln-card.failed    { border-color:rgba(244,63,94,.3); }
.vuln-header { display:flex;align-items:center;padding:10px 12px;gap:8px;cursor:pointer; }
.vuln-tag { font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 6px;background:rgba(168,85,247,.15);color:var(--accent2);border-radius:4px;text-transform:uppercase;flex-shrink:0; }
.vuln-name { flex:1;font-size:13px;font-weight:700;color:var(--text); }
.vuln-actions { display:flex;gap:3px;flex-shrink:0; }
.vuln-body { display:none;padding:0 12px 12px;border-top:1px solid var(--border); }
.vuln-body.open { display:block; }

/* ── ACTIVITY FEED ───────────────────────────────────────────────── */
.activity-panel { background:var(--bg2);border-left:1px solid var(--border);width:280px;flex-shrink:0;display:flex;flex-direction:column; }
.activity-header { padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0; }
.activity-title { font-size:13px;font-weight:700;color:var(--text); }
.activity-list { overflow-y:auto;padding:8px;max-height:calc(100vh - 52px - 48px); }
.activity-list::-webkit-scrollbar { width:3px; }
.activity-list::-webkit-scrollbar-thumb { background:var(--border2);border-radius:2px; }
.activity-item { display:flex;align-items:flex-start;gap:8px;padding:8px 6px;border-radius:6px;transition:background .1s; }
.activity-item:hover { background:rgba(255,255,255,.03); }
.activity-avatar { width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px; }
.activity-content { flex:1;min-width:0; }
.activity-text { font-size:12px;color:var(--text2);line-height:1.4; }
.activity-text strong { color:var(--text);font-weight:600; }
.activity-text .hl { color:var(--accent3); }
.activity-time { font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:2px; }
.activity-status-pill { display:inline-flex;align-items:center;gap:3px;padding:1px 5px;border-radius:4px;font-family:var(--mono);font-size:9px;font-weight:700; }
.pill-done { background:rgba(34,211,163,.15);color:var(--green); }
.pill-fail { background:rgba(244,63,94,.15);color:var(--red); }
.pill-cleared { background:rgba(148,163,184,.1);color:var(--text3); }
.activity-empty { padding:24px;text-align:center;color:var(--text3);font-family:var(--mono);font-size:11px; }

/* Live notification badge */
.live-badge { width:7px;height:7px;border-radius:50%;background:var(--green);animation:livePulse 2s ease-in-out infinite;flex-shrink:0; }
@keyframes livePulse { 0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,211,163,.4)} 50%{opacity:.7;box-shadow:0 0 0 5px rgba(34,211,163,0)} }

/* ── MEMBERS ─────────────────────────────────────────────────────── */
.members-card { background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px; }
.members-card-title { font-size:13px;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between; }
.member-row { display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border); }
.member-row:last-child { border-bottom:none; }
.member-avatar-lg { width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;line-height:1; }
.member-info { flex:1; }
.member-username { font-size:13px;font-weight:600;color:var(--text); }
.member-meta { font-family:var(--mono);font-size:10px;color:var(--text3); }

/* Invite UI */
.invite-code-box { background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:14px;margin-bottom:8px; }
.invite-code-label { font-family:var(--mono);font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px; }
.invite-code-row { display:flex;align-items:center;gap:8px; }
.invite-code-token { font-family:var(--mono);font-size:16px;font-weight:700;color:var(--accent3);letter-spacing:.15em;flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 12px; }
.invite-code-meta { font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:6px; }
.invite-list { margin-top:12px; }
.invite-item { display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border); }
.invite-item:last-child { border-bottom:none; }
.invite-token-display { font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent3);flex:1;letter-spacing:.1em; }
.invite-role-tag { font-family:var(--mono);font-size:9px;padding:2px 6px;border-radius:10px; }
.invite-expires { font-family:var(--mono);font-size:10px;color:var(--text3); }
.invite-used { opacity:.4;text-decoration:line-through; }
.invite-role-btn { font-family:var(--mono);font-size:12px;padding:6px 16px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--text2);cursor:pointer;transition:all .15s; }
.invite-role-btn:hover { border-color:var(--accent);color:var(--accent); }
.invite-role-btn.active { background:var(--accent)18;border-color:var(--accent);color:var(--accent);font-weight:700; }

/* ── MODAL ───────────────────────────────────────────────────────── */
.modal-overlay { position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:24px; }
.modal-overlay.open { display:flex; }
.modal { background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:26px;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;animation:modalIn .25s cubic-bezier(.34,1.56,.64,1); }
@keyframes modalIn { from{opacity:0;transform:scale(.95) translateY(10px)} to{opacity:1;transform:scale(1) translateY(0)} }
.modal-title { font-size:17px;font-weight:800;margin-bottom:18px;color:var(--text); }
.modal-footer { display:flex;gap:8px;justify-content:flex-end;margin-top:18px; }
.dynamic-row { display:flex;gap:6px;margin-bottom:5px; }
.dynamic-input { flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none; }
.dynamic-input:focus { border-color:var(--accent); }
.dynamic-textarea { flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);font-family:var(--mono);font-size:12px;outline:none;resize:vertical;min-height:52px;line-height:1.5; }
.dynamic-textarea:focus { border-color:var(--accent); }
.dynamic-textarea::placeholder { color:var(--text3); }
.btn-remove { background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.2);border-radius:5px;padding:4px 7px;color:var(--red);font-size:11px; }
.btn-add-row { background:none;border:1px dashed var(--border2);border-radius:6px;padding:5px 12px;color:var(--text3);font-family:var(--mono);font-size:11px;width:100%;transition:all .15s;text-align:center; }
.btn-add-row:hover { border-color:var(--accent);color:var(--accent3); }

/* ── CVSS Calculator ──────────────────────────────────────────────── */
.cvss-grid {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 7px 10px;
  align-items: center;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}
.cvss-label {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.cvss-btns { display: flex; gap: 4px; flex-wrap: wrap; }
.cvss-btn {
  font-family: var(--mono);
  font-size: 10px;
  padding: 3px 9px;
  border-radius: 4px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text3);
  cursor: pointer;
  transition: border-color .12s, color .12s, background .12s;
}
.cvss-btn:hover { border-color: var(--accent); color: var(--text); }
.cvss-btn.active {
  background: var(--accent)22;
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 700;
}
.cvss-divider { grid-column: 1 / -1; height: 1px; background: var(--border); margin: 2px 0; }
.cvss-score-wrap {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 10px;
  padding: 10px 14px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
}

/* ── EMPTY STATE ─────────────────────────────────────────────────── */
.empty-state { display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text3);text-align:center; }
.empty-icon { font-size:44px;margin-bottom:10px;opacity:.4; }
.empty-title { font-size:15px;font-weight:700;color:var(--text2);margin-bottom:3px; }
.empty-sub { font-family:var(--mono);font-size:11px; }

/* ── TOAST ───────────────────────────────────────────────────────── */
.toast-container { position:fixed;bottom:20px;right:20px;z-index:9000;display:flex;flex-direction:column;gap:7px; }
.toast { background:var(--surface);border:1px solid var(--border2);border-radius:8px;padding:10px 14px;font-family:var(--mono);font-size:12px;color:var(--text);box-shadow:var(--shadow);animation:toastIn .3s ease;display:flex;align-items:center;gap:8px;max-width:320px; }
.toast.success { border-color:rgba(34,211,163,.4); }
.toast.error   { border-color:rgba(244,63,94,.4); }
.toast.info    { border-color:rgba(124,58,237,.4); }
@keyframes toastIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

/* ── RESPONSIVE ──────────────────────────────────────────────────── */
@media(max-width:1200px) { .activity-panel { display:none; } }
@media(max-width:900px)  { .stats-grid{grid-template-columns:repeat(2,1fr)} .sidebar{width:200px} }
@media(max-width:640px)  { .sidebar{display:none} .login-card{width:100%;max-width:380px;margin:16px} }

/* ── PS LAB NOTES ────────────────────────────────────────────────── */
.ps-lab-item { border-radius:5px; overflow:hidden; }
.ps-lab-body {
  display:none; padding:6px 8px 8px 30px;
  background:var(--bg2); border-top:1px solid var(--border);
}
.ps-lab-body.open { display:block; }
.ps-lab-body .note-textarea { margin-top:0; min-height:60px; font-size:11px; }
.ps-lab-row { cursor:pointer; }
.ps-lab-title.done { text-decoration:line-through; color:var(--text3); }
.ps-note-indicator {
  font-size:10px; color:var(--accent3); margin-left:4px; flex-shrink:0;
  opacity:.7;
}

/* ── SEVERITY BADGES ──────────────────────────────────────────────── */
.sev-badge {
  font-family: var(--mono); font-size: 10px; font-weight: 700;
  padding: 2px 0; border-radius: 4px; text-transform: uppercase;
  letter-spacing: .05em; flex-shrink: 0;
  width: 62px; text-align: center; display: inline-block;
}
.sev-critical { background: #dc262622; color: #dc2626; border: 1px solid #dc262644; }
.sev-high     { background: #f9731622; color: #f97316; border: 1px solid #f9731644; }
.sev-medium   { background: #f59e0b22; color: #f59e0b; border: 1px solid #f59e0b44; }
.sev-low      { background: #05966922; color: #059669; border: 1px solid #05966944; }
.sev-info     { background: #64748b22; color: #64748b; border: 1px solid #64748b44; }

/* ── VULN SEVERITY SECTIONS ───────────────────────────────────────── */
.vuln-severity-section { margin-bottom: 24px; }
.vuln-severity-header  {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; margin-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.vuln-severity-count {
  font-family: var(--mono); font-size: 11px; color: var(--text3);
}

/* ── REPORT PREVIEW (export page) ────────────────────────────────── */
.report-body h1 { font-size:24px; border-bottom:2px solid var(--border); padding-bottom:8px; margin-bottom:16px; }
.report-body h2 { font-size:18px; margin-top:32px; margin-bottom:12px; color:var(--accent); }
.report-body h3 { font-size:15px; margin-top:20px; margin-bottom:8px; }
.report-body h4 { font-size:13px; margin-top:16px; margin-bottom:4px; color:var(--text2); }
.report-body p  { color:var(--text2); margin:6px 0; }
.report-body li { color:var(--text2); margin:3px 0; }

/* ── EVIDENCE ─────────────────────────────────────────────────────── */
.evidence-thumbs { display:flex;flex-wrap:wrap;gap:8px;margin-top:6px; }
.evidence-thumb {
  width:80px;height:60px;object-fit:cover;border-radius:6px;
  border:1px solid var(--border);cursor:zoom-in;transition:opacity .15s;
}
.evidence-thumb:hover { opacity:.8; }
.evidence-thumb-sm {
  width:48px;height:36px;object-fit:cover;border-radius:4px;
  border:1px solid var(--border);flex-shrink:0;
}
.evidence-preview-item {
  display:flex;align-items:center;gap:8px;padding:5px 8px;
  background:var(--bg3);border-radius:6px;border:1px solid var(--border);margin-bottom:4px;
}
.evidence-name { flex:1;font-family:var(--mono);font-size:10px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }

/* ── WSTG TARGET SELECTOR ─────────────────────────────────────────── */
.wstg-target-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px 6px 44px;
  background: var(--red)08;
  border-bottom: 1px solid var(--red)22;
}
.wstg-target-select {
  flex: 1;
  max-width: 280px;
  background: var(--bg3);
  border: 1px solid var(--red)44;
  border-radius: 5px;
  color: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  padding: 4px 8px;
  cursor: pointer;
}
.wstg-target-select:focus { outline: none; border-color: var(--red); }
.wstg-target-badge {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--red);
  background: var(--red)15;
  border: 1px solid var(--red)33;
  border-radius: 4px;
  padding: 1px 6px;
  flex-shrink: 0;
}

/* ── WSTG LINK TO FINDING ─────────────────────────────────────────── */
.wstg-link-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px 6px 44px;
  background: rgba(124,58,237,.05);
  border-bottom: 1px solid rgba(124,58,237,.15);
}
.wstg-link-select {
  flex: 1;
  max-width: 300px;
  background: var(--bg3);
  border: 1px solid rgba(124,58,237,.3);
  border-radius: 5px;
  color: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  padding: 4px 8px;
  cursor: pointer;
}
.wstg-link-select:focus { outline: none; border-color: var(--accent); }
.wstg-link-badge {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--accent3);
  background: rgba(124,58,237,.1);
  border: 1px solid rgba(124,58,237,.25);
  border-radius: 4px;
  padding: 1px 6px;
  flex-shrink: 0;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── DASHBOARD v2 ─────────────────────────────────────────────────── */
.dash-engagement {
  display: flex;
  gap: 0;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 16px;
}
.dash-eng-item {
  flex: 1;
  padding: 12px 16px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.dash-eng-item:last-child { border-right: none; }
.dash-eng-label { font-family: var(--mono); font-size: 9px; text-transform: uppercase; letter-spacing: .1em; color: var(--text3); }
.dash-eng-value { font-size: 12px; font-weight: 600; color: var(--text); }

.dash-row { display: flex; gap: 12px; }
.dash-panel {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  min-width: 0;
}
.dash-panel-title {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text3);
  font-weight: 700;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
}

/* Severity breakdown bars */
.sev-breakdown { display: flex; flex-direction: column; gap: 7px; }
.sev-row { display: flex; align-items: center; gap: 8px; }
.sev-bar-wrap { flex: 1; height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; }
.sev-bar { height: 100%; border-radius: 3px; transition: width .4s ease; min-width: 3px; }
.sev-bar-critical { background: #dc2626; }
.sev-bar-high     { background: #f97316; }
.sev-bar-medium   { background: #f59e0b; }
.sev-bar-low      { background: #059669; }
.sev-bar-info     { background: #64748b; }

/* Targets list in dash */
.dash-target-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
}
.dash-target-row:last-of-type { border-bottom: none; }

/* Category cards */
.dash-cat-card {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
}

/* Recent findings rows */
.dash-finding-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.dash-finding-row:last-child { border-bottom: none; }
.dash-ticket-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 10px 8px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.dash-ticket-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s;
  margin-bottom: 2px;
}
.dash-ticket-row:hover { background: var(--bg3); }
.dash-ticket-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── LOGO IMAGE ───────────────────────────────────────────────────── */
.topbar-logo-img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  flex-shrink: 0;
}
.login-logo-img {
  width: 52px;
  height: 52px;
  object-fit: contain;
}

/* ── METHODOLOGY ─────────────────────────────────────────────────── */
.method-library {
  width: 260px;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  background: var(--bg2);
  overflow-y: auto;
}
.method-library-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.method-list-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .15s;
}
.method-list-item:hover  { background: var(--bg3); }
.method-list-item.active { background: var(--accent)15; border-left: 2px solid var(--accent); }
.method-list-name {
  font-size: 12px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.method-badge-shared {
  font-family: var(--mono);
  font-size: 9px;
  background: var(--green)20;
  color: var(--green);
  border: 1px solid var(--green)40;
  border-radius: 4px;
  padding: 1px 5px;
  flex-shrink: 0;
}
.method-badge-owner {
  font-family: var(--mono);
  font-size: 9px;
  background: var(--accent)15;
  color: var(--accent);
  border-radius: 4px;
  padding: 1px 5px;
  flex-shrink: 0;
}
.method-runner-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 0 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
}
.method-test-row {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 10px;
}

/* ── NEW SIDENAV LAYOUT ──────────────────────────────────────────── */

/* Root layout: sidenav left, app-main right */
body { display:flex; flex-direction:row; min-height:100vh; }
#login-screen, #loading-overlay { position:fixed; inset:0; z-index:600; }

.sidenav {
  width:220px;
  flex-shrink:0;
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  overflow-y:auto;
  overflow-x:hidden;
  position:fixed;
  top:0; left:0; bottom:0;
  z-index:50;
}
.sidenav::-webkit-scrollbar { width:3px; }
.sidenav::-webkit-scrollbar-thumb { background:var(--border2); }

.app-main {
  flex:1;
  margin-left:220px;
  display:flex;
  flex-direction:column;
  height:100vh;
  overflow:hidden;
  min-width:0;
  padding-top:52px;
  box-sizing:border-box;
}

/* Slim topbar — fixed so it never scrolls away */
.topbar.slim {
  height:52px;
  padding:0 16px;
  background:rgba(10,10,15,.95);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:12px;
  position:fixed;
  top:0;
  left:220px;
  right:0;
  z-index:40;
  flex-shrink:0;
}


/* Override old topbar nav styles that don't apply anymore */
.topbar.slim .nav-btn { display:none; }

/* Sidenav internals — logo height matches topbar */
.sidenav-logo {
  display:flex;
  align-items:center;
  gap:8px;
  height:52px;
  padding:0 14px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
  box-sizing:border-box;
}

.sidenav-back-link {
  display:flex;align-items:center;gap:6px;
  padding:7px 14px;
  font-family:var(--mono);font-size:10px;color:var(--text3);
  text-decoration:none;border-bottom:1px solid var(--border);
  transition:color .15s,background .15s;
  flex-shrink:0;
}
.sidenav-back-link:hover { color:var(--text);background:rgba(124,58,237,.05); }

.sidenav-project {
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.sidenav-project-logo-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 9px;
}
.sidenav-project-logo {
  max-height: 34px;
  max-width: 100%;
  object-fit: contain;
  border-radius: 6px;
  padding: 5px 10px;
}
.sidenav-project-logo--light {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.09);
}
.sidenav-project-logo--dark {
  background: #1e1e1e;
  border: 1px solid rgba(255,255,255,.08);
}
.sidenav-project-name {
  font-size:12px;
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  margin-bottom:1px;
}
.sidenav-project-desc {
  font-family:var(--mono);
  font-size:10px;
  color:var(--text3);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  margin-bottom:6px;
}
.sidenav-progress {
  display:flex;
  align-items:center;
  gap:7px;
}
.sidenav-progress-bar {
  flex:1;
  height:3px;
  background:var(--border);
  border-radius:2px;
  overflow:hidden;
}
.sidenav-progress-fill {
  height:100%;
  background:linear-gradient(90deg,var(--green),#34d399);
  border-radius:2px;
  transition:width .4s ease;
}
.sidenav-progress-pct {
  font-family:var(--mono);
  font-size:10px;
  color:var(--text3);
  flex-shrink:0;
}

.sidenav-group-label {
  font-family:var(--mono);
  font-size:9px;
  font-weight:700;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.12em;
  padding:12px 14px 4px;
}
.sidenav-item {
  display:flex;
  align-items:center;
  gap:9px;
  padding:7px 14px;
  cursor:pointer;
  transition:all .15s;
  border-left:2px solid transparent;
  text-decoration:none;
  color:var(--text2);
}
.sidenav-item:hover {
  background:rgba(124,58,237,.07);
  border-left-color:var(--border2);
  color:var(--text);
}
.sidenav-item.active {
  background:rgba(124,58,237,.13);
  border-left-color:var(--accent);
  color:var(--accent3);
}
.sidenav-item-icon {
  font-size:13px;
  width:16px;
  text-align:center;
  flex-shrink:0;
  opacity:.7;
}
.sidenav-item.active .sidenav-item-icon { opacity:1; }
.sidenav-item-label {
  font-size:12px;
  font-weight:600;
  line-height:1;
}

/* Make sure main-content fills height under new layout */
.main-content {
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  padding:24px;
}

/* ── Target tabs (ports / endpoints / findings / notes) ────────────── */
.target-tabs {
  display: flex;
  gap: 2px;
  padding: 8px 0 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}
.target-tab {
  background: none;
  border: 1px solid transparent;
  border-radius: 5px;
  padding: 3px 10px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  cursor: pointer;
  transition: all .15s;
  display: flex;
  align-items: center;
  gap: 5px;
}
.target-tab:hover { color: var(--text); background: var(--bg3); }
.target-tab.active { color: var(--accent); border-color: var(--accent)44; background: var(--accent)11; }
.target-tab-badge {
  background: var(--red)22;
  color: var(--red);
  border-radius: 10px;
  padding: 0 5px;
  font-size: 9px;
  font-weight: 700;
}
.target-tab-body { padding: 4px 0; }
.target-loading { font-family: var(--mono); font-size: 11px; color: var(--text3); padding: 8px 0; }
.target-empty-tab { font-family: var(--mono); font-size: 11px; color: var(--text3); padding: 8px 0; }

/* Data rows inside tabs */
.target-data-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 6px;
  border-radius: 5px;
  margin-bottom: 2px;
}
.target-data-row:hover { background: var(--bg3); }
.port-num {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  width: 72px;
  flex-shrink: 0;
}

/* Inline add row */
.target-add-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.target-inline-input {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 4px 8px;
  color: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  outline: none;
  min-width: 0;
}
.target-inline-input:focus { border-color: var(--accent); }
.target-inline-select {
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 4px 6px;
  color: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  outline: none;
  cursor: pointer;
  flex-shrink: 0;
}
.target-inline-select:focus { border-color: var(--accent); }

/* ── Tickets page ───────────────────────────────────────────────────── */
.tickets-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ticket-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .1s;
  position: relative;
  overflow: hidden;
}
.ticket-row::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: transparent;
  transition: background .15s;
}
.ticket-row:hover { background: var(--surface); border-color: var(--border2); transform: translateX(2px); }
.ticket-row:hover::before { background: var(--accent); }
.ticket-row-status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ticket-row-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ticket-row-title {
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ticket-row-tag {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--accent2);
  background: var(--accent)18;
  border: 1px solid var(--accent)33;
  border-radius: 4px;
  padding: 1px 6px;
  flex-shrink: 0;
  white-space: nowrap;
}
.ticket-row-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
}
.ticket-status-badge {
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  border: 1px solid;
  border-radius: 4px;
  padding: 2px 7px;
}

/* ── Client portal ──────────────────────────────────────────────────── */
.client-proj-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
}
.client-summary-bar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.client-sev-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  min-width: 90px;
  text-align: center;
}
.client-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 20px;
  align-items: start;
}
@media (max-width: 800px) {
  .client-grid { grid-template-columns: 1fr; }
}
.client-col-main  { display: flex; flex-direction: column; gap: 20px; }
.client-col-side  { display: flex; flex-direction: column; gap: 20px; }
.client-section {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
}
.client-section-title {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text3);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.client-badge {
  background: var(--accent)22;
  color: var(--accent);
  border-radius: 10px;
  padding: 1px 7px;
  font-size: 10px;
  font-weight: 700;
}

/* Findings */
.client-finding-card {
  border: 1px solid var(--border);
  border-radius: 7px;
  margin-bottom: 8px;
  overflow: hidden;
  cursor: pointer;
}
.client-finding-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  background: var(--bg3);
  min-width: 0;
}
.client-finding-header:hover { background: var(--bg); }
.client-finding-name {
  font-size: 13px;
  font-weight: 600;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.client-finding-target {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  flex-shrink: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 200px;
}
.client-finding-status {
  font-family: var(--mono);
  font-size: 10px;
  border-radius: 3px;
  padding: 2px 7px;
  flex-shrink: 0;
}
.status-open        { color: var(--accent); border: 1px solid var(--accent)44; }
.status-in_progress { color: var(--yellow, #f59e0b); border: 1px solid #f59e0b44; }
.status-resolved    { color: var(--green);  border: 1px solid var(--green)44; }
.client-finding-chevron {
  font-size: 11px;
  color: var(--text3);
  flex-shrink: 0;
  transition: transform .2s ease;
  display: inline-block;
}
.client-finding-body {
  display: none;
  padding: 12px;
  border-top: 1px solid var(--border);
}
.client-finding-body.open { display: block; }
.client-finding-desc {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.6;
  white-space: pre-wrap;
}

/* Targets */
.client-target-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 4px;
  border-bottom: 1px solid var(--border)66;
}
.client-target-row:last-child { border-bottom: none; }
.client-target-row:hover { background: var(--bg3); border-radius: 5px; }

/* Ticket replies */
.client-reply {
  background: var(--bg3);
  border-radius: 7px;
  padding: 10px 12px;
}
.client-reply.own { background: var(--accent)11; border: 1px solid var(--accent)22; }
.client-reply-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
}
.client-reply-body {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.6;
  white-space: pre-wrap;
}

/* ── Welcome / onboarding cards ─────────────────────────────────────── */
.welcome-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px 20px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.welcome-card:hover { border-color: var(--accent); background: var(--accent)08; }
.welcome-card-icon {
  font-size: 24px;
  margin-bottom: 12px;
  color: var(--accent);
  font-family: var(--mono);
  font-weight: 700;
}
.welcome-card-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 6px;
}
.welcome-card-desc {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text3);
  line-height: 1.5;
}

/* ── Client settings toggles ────────────────────────────────────────── */
.client-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border)66;
}
.client-setting-row:last-child { border-bottom: none; }
.setting-toggle {
  flex-shrink: 0;
  width: 36px;
  height: 20px;
  border-radius: 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  position: relative;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.setting-toggle.on { background: var(--accent); border-color: var(--accent); }
.setting-toggle-knob {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--text3);
  transition: transform .2s, background .2s;
}
.setting-toggle.on .setting-toggle-knob { transform: translateX(16px); background: #fff; }

/* ── WSTG client view ────────────────────────────────────────────────── */
.wstg-client-cat {
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  margin-bottom: 4px;
}
.wstg-client-cat-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  cursor: pointer;
  background: var(--bg3);
  user-select: none;
}
.wstg-client-cat-header:hover { background: var(--bg); }
.wstg-client-cat.open .wstg-client-cat-header span:last-child { transform: rotate(90deg); display: inline-block; }
.wstg-client-tests {
  display: none;
  padding: 6px 10px 10px;
  border-top: 1px solid var(--border);
  flex-direction: column;
  gap: 6px;
}
.wstg-client-cat.open .wstg-client-tests { display: flex; }
.wstg-client-test {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 4px 0;
}
