/* ════════════════════════════════════════════════════════════════════════
   LVIP — Logicalis Vulnerability Intelligence Platform
   Enterprise SOC theme (dark-first, glassmorphism). Tokens align with NIMS.
   ════════════════════════════════════════════════════════════════════════ */
:root {
  --accent:#4f8ef7; --accent2:#7c5cfc; --accent3:#00d4a8;
  --danger:#f7596a; --warn:#f7a832; --success:#34d497; --info:#39bdf8;
  --crit:#ff4d6d; --high:#ff8a3d; --med:#ffc53d; --low:#4cc9f0;
  --radius:14px; --radius-lg:20px;
  --mono:'JetBrains Mono','SFMono-Regular',Consolas,monospace;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
body.theme-dark{
  --bg-deep:#04060d; --bg-panel:#0a0e1b; --bg-card:rgba(255,255,255,.045);
  --bg-card-hov:rgba(255,255,255,.075); --border:rgba(255,255,255,.08);
  --border-bright:rgba(255,255,255,.16); --glass:rgba(11,15,30,.78);
  --text:#e8eaf2; --text-muted:#838bb0; --text-dim:#4a5274;
  background:radial-gradient(1200px 700px at 80% -10%,rgba(124,92,252,.10),transparent),
             radial-gradient(900px 600px at -10% 20%,rgba(79,142,247,.10),transparent),#04060d;
  color:var(--text);
}
body.theme-light{
  --bg-deep:#eef2f9; --bg-panel:#fff; --bg-card:#fff; --bg-card-hov:#fff;
  --border:rgba(15,23,42,.10); --border-bright:rgba(15,23,42,.18);
  --glass:rgba(255,255,255,.92); --text:#0f172a; --text-muted:#5a6b8c; --text-dim:#94a3b8;
  background:#eef2f9; color:#0f172a;
}
*{box-sizing:border-box}
body{font-family:var(--font);margin:0;min-height:100vh;transition:background .3s,color .3s;font-size:14px;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-feature-settings:'cv02','cv03','cv04','cv11','ss01';letter-spacing:-.006em;text-rendering:optimizeLegibility}
.page-title,.kpi-val,.tb-title,.scorebig,h1,h2,h3{letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:6px}

/* ── Layout shell ─────────────────────────────────────────────────────── */
#topbar{position:fixed;top:0;left:0;right:0;height:60px;z-index:40;display:flex;
  align-items:center;justify-content:space-between;padding:0 20px;
  background:var(--glass);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.tb-left,.tb-right{display:flex;align-items:center;gap:14px}
.tb-logo{height:32px;background:#fff;padding:3px 7px;border-radius:8px}
.tb-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  text-align:center;pointer-events:none;white-space:nowrap}
.tb-center .tb-title{font-size:22px}
.tb-center .tb-sub{margin-top:1px}
@media(max-width:760px){.tb-center{display:none}}
.tb-title{font-weight:700;letter-spacing:.6px;font-size:17px;text-transform:uppercase}
.tb-title em{font-style:normal;background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.tb-sub{font-size:10px;color:var(--text-muted);letter-spacing:.18em;text-transform:uppercase}

#sidebar{position:fixed;top:60px;bottom:0;left:0;width:236px;z-index:30;overflow-y:auto;
  background:var(--glass);backdrop-filter:blur(16px);border-right:1px solid var(--border);
  padding:18px 12px;transition:transform .25s}
.nav-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);
  margin:18px 10px 8px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;
  color:var(--text-muted);font-weight:500;margin-bottom:2px;border:1px solid transparent;transition:.15s}
.nav-item i{width:18px;text-align:center;font-size:15px}
.nav-item:hover{background:var(--bg-card-hov);color:var(--text)}
.nav-item.active{background:rgba(79,142,247,.14);color:var(--accent);border-color:rgba(79,142,247,.25)}
.nav-item .pill{margin-left:auto;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;
  background:rgba(247,89,106,.16);color:var(--danger)}

.main{margin-left:236px;margin-top:60px;padding:26px 30px 60px}
@media(max-width:880px){#sidebar{transform:translateX(-100%)}.main{margin-left:0}}

/* ── Topbar widgets ───────────────────────────────────────────────────── */
.tb-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:20px;
  background:var(--bg-card);border:1px solid var(--border);font-size:12px;font-weight:600;
  color:var(--text-muted);cursor:pointer;transition:.15s}
.tb-chip:hover{background:var(--bg-card-hov);color:var(--text)}
.avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.role-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;
  border-radius:9px;background:rgba(79,142,247,.16);color:var(--accent);border:1px solid rgba(79,142,247,.25)}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success)}
.ai-dot.off{background:var(--text-dim);box-shadow:none}

/* ── Page header ──────────────────────────────────────────────────────── */
.page-head{margin-bottom:24px}
.page-eyebrow{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;opacity:.9}
.page-title{font-size:23px;font-weight:600;margin:5px 0 3px;letter-spacing:-.018em;line-height:1.2}
.page-sub{color:var(--text-muted);font-size:13.5px;font-weight:400}

/* ── Cards ────────────────────────────────────────────────────────────── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;backdrop-filter:blur(8px)}
.card-lg{border-radius:var(--radius-lg);padding:22px 24px}
.card-title{font-size:11.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);
  font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:9px}

/* ── KPI grid ─────────────────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(186px,1fr));gap:14px;margin-bottom:24px}
.kpi{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;overflow:hidden;transition:.2s}
.kpi:hover{transform:translateY(-3px);border-color:var(--border-bright);background:var(--bg-card-hov)}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}
.kpi.k-crit::before{background:var(--crit)} .kpi.k-high::before{background:var(--high)}
.kpi.k-warn::before{background:var(--warn)} .kpi.k-ok::before{background:var(--success)}
.kpi.k-info::before{background:var(--info)}
.kpi-label{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-weight:500}
.kpi-val{font-size:26px;font-weight:600;margin-top:6px;line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kpi-ico{position:absolute;right:14px;top:14px;font-size:18px;opacity:.35}
a.kpi{text-decoration:none;color:inherit;display:block}
.kpi-go{position:absolute;right:14px;bottom:12px;font-size:11px;opacity:0;transition:.15s;color:var(--accent)}
a.kpi:hover .kpi-go{opacity:.85}
a.kpi:hover .kpi-ico{opacity:.6}

/* ── AI insights panel ────────────────────────────────────────────────── */
.ai-panel{background:linear-gradient(135deg,rgba(124,92,252,.12),rgba(79,142,247,.06));
  border:1px solid rgba(124,92,252,.25);border-radius:var(--radius-lg);padding:22px 24px;margin-bottom:24px}
.ai-panel-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.ai-orb{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-size:18px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 6px 20px rgba(124,92,252,.4)}
.insight{display:flex;gap:13px;align-items:flex-start;padding:12px 14px;border-radius:11px;
  background:var(--bg-card);border:1px solid var(--border);margin-bottom:9px}
.insight i{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.insight.critical i{background:rgba(255,77,109,.16);color:var(--crit)}
.insight.high i{background:rgba(255,138,61,.16);color:var(--high)}
.insight.medium i{background:rgba(255,197,61,.16);color:var(--med)}
.insight.ok i{background:rgba(52,212,151,.16);color:var(--success)}
.insight-text{font-size:13.5px;font-weight:500;padding-top:5px}

/* ── Grid helpers ─────────────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-bottom:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:22px}
@media(max-width:1050px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ── Heatmap ──────────────────────────────────────────────────────────── */
.heat-row{display:flex;align-items:center;gap:14px;padding:12px 4px;border-bottom:1px solid var(--border)}
.heat-row:last-child{border-bottom:none}
.heat-band{width:10px;height:36px;border-radius:5px;flex-shrink:0}
.band-red{background:var(--crit)} .band-orange{background:var(--high)}
.band-yellow{background:var(--med)} .band-green{background:var(--success)}
.heat-name{font-weight:600;flex:1}
.heat-meta{font-size:11.5px;color:var(--text-muted)}
.heat-score{font-size:21px;font-weight:700;font-variant-numeric:tabular-nums;width:62px;text-align:right}
.bar{height:7px;border-radius:4px;background:var(--border);overflow:hidden;margin-top:5px}
.bar>span{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent2))}

/* ── Tables ───────────────────────────────────────────────────────────── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl thead th{text-align:left;padding:11px 12px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:700;background:rgba(255,255,255,.02)}
.tbl tbody td{padding:11px 12px;border-bottom:1px solid var(--border)}
.tbl tbody tr:hover{background:var(--bg-card-hov)}
.tbl a.lnk{color:var(--accent);font-weight:600}
code.mono{font-family:var(--mono);font-size:12px;background:rgba(79,142,247,.1);color:var(--accent);
  padding:2px 7px;border-radius:6px}

/* ── Severity / status pills ──────────────────────────────────────────── */
.pill-sev{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 9px;border-radius:20px}
.sev-critical{background:rgba(255,77,109,.16);color:var(--crit);border:1px solid rgba(255,77,109,.3)}
.sev-high{background:rgba(255,138,61,.16);color:var(--high);border:1px solid rgba(255,138,61,.3)}
.sev-medium{background:rgba(255,197,61,.16);color:var(--med);border:1px solid rgba(255,197,61,.3)}
.sev-low{background:rgba(76,201,240,.16);color:var(--low);border:1px solid rgba(76,201,240,.3)}
.sev-unknown,.sev-none{background:rgba(131,139,176,.16);color:var(--text-muted);border:1px solid var(--border)}
.st-affected{background:rgba(255,77,109,.14);color:var(--crit)}
.st-not_affected{background:rgba(52,212,151,.14);color:var(--success)}
.st-unknown{background:rgba(255,197,61,.14);color:var(--med)}
.st-eol,.st-eos{background:rgba(124,92,252,.14);color:var(--accent2)}
.status-pill{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:capitalize}

/* ── Vendor cards ─────────────────────────────────────────────────────── */
.vendor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.vendor-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.vendor-card h3{margin:0 0 2px;font-size:17px}
.vendor-src{font-size:11px;color:var(--text-dim);margin-bottom:14px}
.vendor-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}
.vs{padding:8px 4px;border-radius:9px;background:rgba(255,255,255,.03);border:1px solid var(--border);
  display:block;text-decoration:none;color:inherit;transition:.15s}
a.vs:hover{background:var(--bg-card-hov);border-color:var(--border-bright);transform:translateY(-2px)}
.vs b{display:block;font-size:18px;font-weight:700}
.vs span{font-size:9.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}

/* ── Buttons / forms ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:10px;font-weight:600;
  font-size:13px;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text);transition:.15s}
.btn:hover{background:var(--bg-card-hov);border-color:var(--border-bright)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;color:#fff}
.btn-primary:hover{filter:brightness(1.08)}
.btn-sm{padding:6px 11px;font-size:12px}
.inp,.sel{width:100%;padding:10px 13px;border-radius:10px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:13px}
.inp:focus,.sel:focus{outline:none;border-color:var(--accent)}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}

/* ── Flash toasts ─────────────────────────────────────────────────────── */
.flash{padding:12px 16px;border-radius:11px;margin-bottom:12px;font-weight:600;font-size:13px;
  display:flex;gap:10px;align-items:center;border:1px solid}
.flash.success{background:rgba(52,212,151,.12);color:var(--success);border-color:rgba(52,212,151,.3)}
.flash.error{background:rgba(255,77,109,.12);color:var(--crit);border-color:rgba(255,77,109,.3)}
.flash.warning{background:rgba(255,197,61,.12);color:var(--med);border-color:rgba(255,197,61,.3)}

/* ── Login ────────────────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:100%;max-width:420px;background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid var(--border-bright);border-radius:var(--radius-lg);padding:38px 34px;
  box-shadow:0 30px 80px rgba(0,0,0,.5)}
.login-logo{display:block;height:42px;width:auto;margin:0 auto 24px;background:#fff;
  padding:9px 16px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.login-card h1{font-size:23px;font-weight:600;letter-spacing:-.02em;margin:0 0 4px;text-align:center}
.login-card h1 .lvip-mark{font-weight:800;background:linear-gradient(90deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.login-card p.s{color:var(--text-muted);margin:0 0 26px;font-size:13px;text-align:center}
.fld{margin-bottom:16px}
.fld label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:7px}

/* ── Modal ────────────────────────────────────────────────────────────── */
.lv-modal-overlay{position:fixed;inset:0;background:rgba(2,4,10,.72);backdrop-filter:blur(4px);
  z-index:60;display:none;align-items:center;justify-content:center;padding:20px}
.lv-modal-overlay.open{display:flex}
.lv-modal{width:100%;max-width:440px;background:var(--bg-panel);border:1px solid var(--border-bright);
  border-radius:var(--radius-lg);box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden}
.lv-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;
  border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.lv-modal-head h3{margin:0;font-size:16px;font-weight:700}
.lv-modal-body{padding:20px}
.lv-modal-x{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer}
.icon-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);
  width:30px;height:30px;border-radius:8px;cursor:pointer;font-size:12px;transition:.15s}
.icon-btn:hover{background:var(--bg-card-hov);color:var(--text);border-color:var(--border-bright)}
.icon-btn.danger:hover{color:var(--crit);border-color:rgba(255,77,109,.4)}

/* ── Floating AI Analyst widget ───────────────────────────────────────── */
.lvip-fab{position:fixed;right:26px;bottom:26px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;cursor:pointer;
  box-shadow:0 10px 30px rgba(124,92,252,.45);font-size:23px;z-index:90;display:flex;
  align-items:center;justify-content:center;transition:transform .18s,box-shadow .18s}
.lvip-fab:hover{transform:scale(1.07);box-shadow:0 14px 38px rgba(124,92,252,.6)}
.lvip-fab.hide{display:none}
.lvip-fab::after{content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid rgba(124,92,252,.4);animation:fabpulse 2.2s ease-out infinite}
@keyframes fabpulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.35);opacity:0}}

.lvip-chat{position:fixed;right:26px;bottom:26px;width:392px;height:560px;max-height:calc(100vh - 90px);
  background:var(--bg-panel);border:1px solid var(--border-bright);border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.6);z-index:91;display:none;flex-direction:column;overflow:hidden}
.lvip-chat.open{display:flex}
.lvip-chat.expanded{width:min(720px,92vw);height:calc(100vh - 70px)}
.lvip-chat-head{display:flex;align-items:center;gap:10px;padding:13px 15px;
  border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(124,92,252,.16),rgba(79,142,247,.07))}
.lvip-chat-head .orb{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));font-size:15px;flex-shrink:0}
.lvip-chat-head h4{margin:0;font-size:14px;font-weight:600}
.lvip-chat-head .sub{font-size:10.5px;color:var(--text-muted)}
.lvip-chat-head .hbtn{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;
  font-size:14px;padding:5px 7px;border-radius:7px}
.lvip-chat-head .hbtn:hover{background:var(--bg-card-hov);color:var(--text)}
.lvip-chat-head .hbtn+.hbtn{margin-left:0}
.lvip-chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:11px}
.lvip-msg{max-width:86%;padding:10px 13px;border-radius:15px;font-size:13.3px;line-height:1.55}
.lvip-msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-bottom-right-radius:5px}
.lvip-msg.bot{align-self:flex-start;background:var(--bg-card);border:1px solid var(--border);border-bottom-left-radius:5px}
.lvip-msg.bot table{width:100%;border-collapse:collapse;margin:6px 0;font-size:12px}
.lvip-msg.bot th,.lvip-msg.bot td{border:1px solid var(--border);padding:4px 7px;text-align:left}
.lvip-msg.bot code{background:rgba(79,142,247,.12);padding:1px 5px;border-radius:5px;font-family:var(--mono);font-size:11.5px}
.lvip-msg.bot p{margin:0 0 7px} .lvip-msg.bot p:last-child{margin:0}
.lvip-msg.bot ul,.lvip-msg.bot ol{margin:5px 0;padding-left:18px}
.lvip-msg .by{display:block;font-size:9.5px;color:var(--text-dim);margin-top:5px}
.lvip-chat-hint{padding:0 4px}
.lvip-chip{display:inline-block;margin:4px 5px 0 0;padding:6px 11px;border-radius:16px;font-size:11.5px;
  background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:.15s}
.lvip-chip:hover{background:var(--bg-card-hov);color:var(--text);border-color:var(--border-bright)}
.lvip-chat-foot{padding:11px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:flex-end}
.lvip-chat-foot textarea{flex:1;resize:none;max-height:90px;padding:9px 12px;border-radius:11px;
  background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.4}
.lvip-chat-foot textarea:focus{outline:none;border-color:var(--accent)}
.lvip-send{width:38px;height:38px;border-radius:10px;border:none;cursor:pointer;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-size:14px}
.lvip-send:disabled{opacity:.5;cursor:default}
@media(max-width:560px){.lvip-chat{right:3vw;left:3vw;width:auto;bottom:90px}.lvip-chat.expanded{height:calc(100vh - 100px)}}

.muted{color:var(--text-muted)} .dim{color:var(--text-dim)}
.mono-sm{font-family:var(--mono);font-size:12px}
.flex{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.scorebig{font-size:42px;font-weight:600;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.donut{--p:0;--c:var(--accent);width:120px;height:120px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%),var(--border) 0);display:flex;align-items:center;justify-content:center}
.donut::before{content:"";position:absolute;width:88px;height:88px;border-radius:50%;background:var(--bg-panel)}
.donut span{position:relative;font-size:23px;font-weight:700}
.donut-wrap{position:relative;display:flex;align-items:center;justify-content:center}

/* ════ Motion & entrance animations ═══════════════════════════════════════ */
@keyframes fadeUp{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:none}}
@keyframes growBar{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.reveal,.kpi-grid .kpi{animation:fadeUp .5s cubic-bezier(.22,.61,.36,1) both}
.heat-row .bar>span{transform-origin:left;animation:growBar .9s cubic-bezier(.22,.61,.36,1) both}

/* ── KPI day-over-day delta badge ─────────────────────────────────────── */
.kpi-delta{position:absolute;left:18px;bottom:11px;font-size:11px;font-weight:700;
  display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-variant-numeric:tabular-nums}
.kpi-delta i{font-size:9px}
.kpi-delta.bad{color:var(--crit);background:rgba(255,77,109,.14)}
.kpi-delta.good{color:var(--success);background:rgba(52,212,151,.14)}
.kpi:has(.kpi-delta){padding-bottom:30px}

/* ── Chart cards ──────────────────────────────────────────────────────── */
.chart-wrap{position:relative;width:100%;height:300px}
.chart-wrap.sm{height:230px}
.trend-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  min-height:200px;text-align:center;color:var(--text-muted);padding:10px 30px}
.trend-empty i{font-size:30px;opacity:.45;color:var(--accent2)}
.trend-empty b{color:var(--text)}

/* ── Severity donut + legend ──────────────────────────────────────────── */
.sev-split{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:center}
@media(max-width:520px){.sev-split{grid-template-columns:1fr}}
.donut-host{position:relative}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.donut-center b{font-size:30px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}
.donut-center span{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}
.sev-legend{display:flex;flex-direction:column;gap:4px}
.sev-legend .row{display:flex;align-items:center;gap:10px;font-size:13px;padding:7px 9px;border-radius:9px;
  color:inherit;transition:.14s}
.sev-legend .row:hover{background:var(--bg-card-hov)}
.sev-legend .dot{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.sev-legend .n{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums}
.sev-legend .pct{font-size:11px;width:38px;text-align:right}

/* ── AI summary markdown body (tidy spacing) ──────────────────────────── */
.sum-body{font-size:13.5px;line-height:1.55}
.sum-body.muted{white-space:pre-wrap}
.sum-body p{margin:0 0 8px}
.sum-body p:last-child{margin-bottom:0}
.sum-body h1,.sum-body h2,.sum-body h3,.sum-body h4{margin:12px 0 5px;font-size:14.5px;font-weight:700;line-height:1.3}
.sum-body h1:first-child,.sum-body h2:first-child,.sum-body h3:first-child{margin-top:0}
.sum-body ul,.sum-body ol{margin:5px 0 9px;padding-left:20px}
.sum-body li{margin:2px 0}
.sum-body strong{font-weight:700}
.sum-body code{background:rgba(79,142,247,.1);color:var(--accent);padding:1px 5px;border-radius:5px;font-family:var(--mono);font-size:12px}
.sum-body table{border-collapse:collapse;width:100%;margin:6px 0;font-size:12.5px}
.sum-body th,.sum-body td{border:1px solid var(--border);padding:4px 8px;text-align:left}

/* ── Device-detail findings filter tabs ───────────────────────────────── */
.findings-tabs{display:flex;gap:6px;flex-wrap:wrap}
.findings-tabs .ftab{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:20px;
  border:1px solid var(--border);color:var(--text-muted);text-transform:none;letter-spacing:0;transition:.15s}
.findings-tabs .ftab b{font-variant-numeric:tabular-nums;margin-left:3px}
.findings-tabs .ftab:hover{background:var(--bg-card-hov);color:var(--text)}
.findings-tabs .ftab.active{background:rgba(79,142,247,.14);color:var(--accent);border-color:rgba(79,142,247,.3)}

/* ── Recent vulnerabilities (per-vendor feed freshness tiles) ─────────── */
.rv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.rv{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:14px 16px;border-radius:12px;
  background:var(--bg-card);border:1px solid var(--border);position:relative;overflow:hidden;
  color:inherit;text-decoration:none;transition:.15s}
a.rv:hover{background:var(--bg-card-hov);border-color:var(--border-bright);transform:translateY(-2px)}
.rv::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent2)}
.rv b{font-size:26px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums}
.rv span{font-size:12px;color:var(--text-muted);font-weight:600}
.rv.rv-zero::before{background:var(--border-bright)}
.rv.rv-zero b{color:var(--text-dim)}

/* ── Threat-signal strip (CVE detail: EPSS + KEV) ─────────────────────── */
.signal-strip{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
@media(max-width:680px){.signal-strip{grid-template-columns:1fr}}
.signal{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px 18px}
.signal-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0}
.signal-label{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.signal-val{font-size:19px;font-weight:700;margin-top:3px;font-variant-numeric:tabular-nums;display:flex;align-items:center}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .lvip-fab::after{display:none}
}
