/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   Foyl Vulnerability Management — Stylesheet
   Ficsit Inc. Pioneer Division
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

:root {
  --blue:#00AEEF; --cyan:#00D4FF; --teal:#00897B; --ocean:#005F87;
  --vm:#F43F5E; --vm-lite:#FB7185;
  --bg:#111009; --bg2:#161410; --surf:#1E1B15; --surf2:#262219; --surf3:#302C22;
  --border:rgba(255,245,210,.07); --border2:rgba(255,245,210,.13);
  --tx:#ECE6D6; --tx2:#B8AFA0; --tx3:#706860;
  --crit:#FC4444;   --crit-bg:rgba(252,68,68,.1);    --crit-b:rgba(252,68,68,.25);
  --high:#F59E0B;   --high-bg:rgba(245,158,11,.1);   --high-b:rgba(245,158,11,.25);
  --med:#FBBF24;    --med-bg:rgba(251,191,36,.08);   --med-b:rgba(251,191,36,.2);
  --low:#3B82F6;    --low-bg:rgba(59,130,246,.1);    --low-b:rgba(59,130,246,.25);
  --info:#6B7280;   --info-bg:rgba(107,114,128,.1);  --info-b:rgba(107,114,128,.2);
  --ok:#00897B;     --ok-bg:rgba(0,137,123,.1);      --ok-b:rgba(0,137,123,.25);
  --purple:#8B5CF6; --purple-bg:rgba(139,92,246,.1); --purple-b:rgba(139,92,246,.25);
  --danger:#C45A50; --warn:#C4942A;
  --vm-bg:rgba(244,63,94,.1); --vm-b:rgba(244,63,94,.25);
  --font:'Outfit',sans-serif; --mono:'DM Mono',monospace; --jakarta:'Plus Jakarta Sans',sans-serif;
}
[data-theme="light"]{
  --bg:#F5F3EE; --bg2:#EDEAE3; --surf:#E4E0D8; --surf2:#DEDAD0; --surf3:#D0CBBD;
  --border:rgba(60,50,30,.09); --border2:rgba(60,50,30,.16);
  --tx:#1A1610; --tx2:#4A4030; --tx3:#8A7A60;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;overflow:hidden;}
body{background:var(--bg);color:var(--tx);font-family:var(--font);font-weight:300;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit;font-size:inherit;}
input,select,textarea{font-family:inherit;color:inherit;}
::-webkit-scrollbar{width:6px;height:6px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--surf3);border-radius:3px;}
@keyframes fade-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes slide-in{from{transform:translateX(-8px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toast-in{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── TOPBAR ── */
#topbar{height:48px;flex-shrink:0;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:0;z-index:100;}
.tb-logo{display:flex;align-items:center;gap:8px;margin-right:8px;text-decoration:none;}
.tb-logo img{height:16px;width:auto;}
.tb-product{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--vm-lite);background:var(--vm-bg);border:1px solid var(--vm-b);padding:2px 8px;border-radius:3px;}
.tb-sep{width:1px;height:20px;background:var(--border2);margin:0 14px;}
.tb-instance{font-family:var(--mono);font-size:10px;color:var(--tx2);letter-spacing:.06em;display:flex;align-items:center;gap:6px;}
.tb-instance-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 3s infinite;}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:16px;}
.tb-stat{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;color:var(--tx3);}
.tb-stat-val{color:var(--tx);font-weight:400;}
.tb-stat-val.warn{color:var(--high);}
.tb-stat-val.danger{color:var(--crit);}
.tb-clock{font-family:var(--mono);font-size:11px;color:var(--tx2);}
.tb-theme-btn{font-family:var(--mono);font-size:10px;color:var(--tx3);padding:4px 10px;border-radius:5px;border:1px solid var(--border2);background:transparent;cursor:pointer;transition:all .15s;}
.tb-theme-btn:hover{background:var(--surf);color:var(--tx2);}

/* ── LAYOUT ── */
#app-body{flex:1;display:flex;overflow:hidden;}
#sidebar{width:220px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;}
.sb-section{padding:8px 0;border-bottom:1px solid var(--border);}
.sb-section:last-of-type{border-bottom:none;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:13px;color:var(--tx3);font-weight:400;transition:background .12s,color .12s;cursor:pointer;text-decoration:none;position:relative;}
.nav-item:hover{background:var(--surf);color:var(--tx2);}
.nav-item.active{color:var(--blue);background:rgba(0,174,239,.08);}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--blue);border-radius:0 2px 2px 0;}
.nav-item svg{flex-shrink:0;opacity:.7;}
.nav-item.active svg{opacity:1;}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:9px;background:var(--crit-bg);color:var(--crit);border:1px solid var(--crit-b);padding:1px 6px;border-radius:10px;min-width:20px;text-align:center;}
.nav-badge.warn{background:var(--high-bg);color:var(--high);border-color:var(--high-b);}
.nav-badge.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-b);}
.nav-badge.info{background:var(--vm-bg);color:var(--vm-lite);border-color:var(--vm-b);}
.sb-footer{margin-top:auto;border-top:1px solid var(--border);padding:12px 16px;}
.sb-version{font-family:var(--mono);font-size:9px;color:var(--tx3);letter-spacing:.06em;line-height:1.8;}
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;}

/* ── PAGE STRUCTURE ── */
.page{flex:1;}
.page-header{padding:20px 28px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;flex-shrink:0;}
.page-title{font-family:var(--jakarta);font-size:18px;font-weight:600;letter-spacing:-.02em;}
.page-sub{font-size:13px;color:var(--tx3);margin-top:2px;}
.page-actions{margin-left:auto;display:flex;align-items:center;gap:8px;}
.content-wrap{padding:20px 28px 28px;}

/* ── STAT CARDS ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;}
.stat-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;}
.stat-card{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:16px 18px;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--vm);}
.stat-card.ok::before{background:var(--ok);}
.stat-card.warn::before{background:var(--high);}
.stat-card.danger::before{background:var(--crit);}
.stat-card.blue::before{background:var(--blue);}
.stat-card.med::before{background:var(--med);}
.stat-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx3);margin-bottom:8px;}
.stat-value{font-family:var(--jakarta);font-size:28px;font-weight:600;letter-spacing:-.03em;line-height:1;color:var(--tx);}
.stat-value.ok{color:var(--ok);}
.stat-value.warn{color:var(--high);}
.stat-value.danger{color:var(--crit);}
.stat-value.vm{color:var(--vm-lite);}
.stat-sub{font-size:11px;color:var(--tx3);margin-top:6px;}
.stat-sub .up{color:var(--ok);}
.stat-sub .dn{color:var(--crit);}

/* ── SECTION HEADER ── */
.section-hdr{display:flex;align-items:center;gap:12px;padding-bottom:10px;margin-bottom:14px;border-bottom:1px solid var(--border);}
.sh-title{font-family:var(--jakarta);font-size:14px;font-weight:600;letter-spacing:-.01em;flex:1;}
.sh-meta{font-family:var(--mono);font-size:11px;color:var(--tx3);}
.sh-meta .ok{color:var(--ok);}
.sh-meta .warn{color:var(--high);}
.sh-meta .danger{color:var(--crit);}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse;font-size:13px;}
.data-table th{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx3);padding:8px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap;}
.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tbody tr{transition:background .1s;cursor:pointer;}
.data-table tbody tr:hover{background:rgba(255,245,210,.025);}
.data-table tbody tr.selected{background:rgba(244,63,94,.07);}
.data-table tbody tr:last-child td{border-bottom:none;}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:2px 7px;border-radius:3px;white-space:nowrap;font-weight:400;}
.badge.ok{color:var(--ok);background:var(--ok-bg);border:1px solid var(--ok-b);}
.badge.low{color:var(--low);background:var(--low-bg);border:1px solid var(--low-b);}
.badge.med,.badge.medium{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.badge.high{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.badge.critical{color:var(--crit);background:var(--crit-bg);border:1px solid var(--crit-b);}
.badge.info{color:var(--vm-lite);background:var(--vm-bg);border:1px solid var(--vm-b);}
.badge.warn{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.badge.neutral{color:var(--tx3);background:var(--surf2);border:1px solid var(--border2);}
.badge.kev{color:#fff;background:#B91C1C;border:1px solid #DC2626;letter-spacing:.08em;font-weight:500;}
.badge.exploit{color:#F97316;background:rgba(249,115,22,.12);border:1px solid rgba(249,115,22,.3);}
.badge.purple{color:var(--purple);background:var(--purple-bg);border:1px solid var(--purple-b);}
.badge.blue{color:var(--blue);background:rgba(0,174,239,.1);border:1px solid rgba(0,174,239,.25);}
.badge.dot::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:currentColor;}
.badge.running{color:var(--vm-lite);background:var(--vm-bg);border:1px solid var(--vm-b);animation:pulse 1.5s infinite;}

/* ── SEVERITY PILL ── */
.sev-pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;font-weight:500;padding:3px 8px;border-radius:4px;}
.sev-pill.critical{color:var(--crit);background:var(--crit-bg);border:1px solid var(--crit-b);}
.sev-pill.high{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.sev-pill.medium{color:var(--med);background:var(--med-bg);border:1px solid var(--med-b);}
.sev-pill.low{color:var(--low);background:var(--low-bg);border:1px solid var(--low-b);}
.sev-pill.info{color:var(--info);background:var(--info-bg);border:1px solid var(--info-b);}

/* ── CVSS SCORE ── */
.cvss-score{display:inline-flex;align-items:baseline;gap:3px;}
.cvss-num{font-family:var(--jakarta);font-weight:700;font-size:20px;line-height:1;}
.cvss-num.critical{color:var(--crit);}
.cvss-num.high{color:var(--high);}
.cvss-num.medium{color:var(--med);}
.cvss-num.low{color:var(--low);}
.cvss-max{font-family:var(--mono);font-size:10px;color:var(--tx3);}
.cvss-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;font-family:var(--jakarta);font-size:13px;font-weight:700;}
.cvss-badge.critical{background:var(--crit-bg);border:1px solid var(--crit-b);color:var(--crit);}
.cvss-badge.high{background:var(--high-bg);border:1px solid var(--high-b);color:var(--high);}
.cvss-badge.medium{background:var(--med-bg);border:1px solid var(--med-b);color:var(--med);}
.cvss-badge.low{background:var(--low-bg);border:1px solid var(--low-b);color:var(--low);}

/* ── VPR SCORE ── */
.vpr-score{display:inline-flex;align-items:center;gap:5px;}
.vpr-num{font-family:var(--mono);font-size:13px;font-weight:500;}
.vpr-bar{height:4px;border-radius:2px;background:var(--surf3);}
.vpr-fill{height:100%;border-radius:2px;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:5px;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:var(--surf2);color:var(--tx2);white-space:nowrap;}
.btn:hover{background:var(--surf3);color:var(--tx);}
.btn.primary{background:var(--vm-bg);color:var(--vm-lite);border-color:var(--vm-b);}
.btn.primary:hover{background:rgba(244,63,94,.2);}
.btn.danger{background:var(--crit-bg);color:var(--crit);border-color:var(--crit-b);}
.btn.danger:hover{background:rgba(252,68,68,.2);}
.btn.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-b);}
.btn.ok:hover{background:rgba(0,137,123,.2);}
.btn.warn{background:var(--high-bg);color:var(--high);border-color:var(--high-b);}
.btn.warn:hover{background:rgba(245,158,11,.2);}
.btn.blue{background:rgba(0,174,239,.1);color:var(--blue);border-color:rgba(0,174,239,.25);}
.btn.blue:hover{background:rgba(0,174,239,.2);}

/* ── TABS ── */
.tab-bar{display:flex;gap:2px;border-bottom:1px solid var(--border);flex-shrink:0;}
.tab-btn{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:8px 14px;color:var(--tx3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;}
.tab-btn:hover{color:var(--tx2);}
.tab-btn.active{color:var(--vm-lite);border-bottom-color:var(--vm);}
.tab-panel{display:none;padding-top:20px;}
.tab-panel.active{display:block;}

/* ── SPLIT LAYOUT ── */
.vm-split{display:flex;height:calc(100vh - 48px);overflow:hidden;}
.vm-list-panel{width:400px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.vm-list-panel.narrow{width:340px;}
.vm-list-toolbar{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:6px;flex-shrink:0;background:var(--bg2);}
.vm-search{flex:1;background:var(--surf);border:1px solid var(--border2);border-radius:5px;padding:6px 10px;font-size:12px;color:var(--tx);outline:none;font-family:var(--mono);}
.vm-search::placeholder{color:var(--tx3);}
.vm-search:focus{border-color:var(--vm);}
.filter-select{background:var(--surf);border:1px solid var(--border2);color:var(--tx2);border-radius:5px;padding:5px 7px;font-size:11px;outline:none;cursor:pointer;font-family:var(--mono);}
.filter-select:focus{border-color:var(--vm);}
.vm-list-count{font-family:var(--mono);font-size:10px;color:var(--tx3);padding:5px 12px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg2);}
.vm-list-scroll{flex:1;overflow-y:auto;}

/* ── VULN ROWS ── */
.vuln-row{display:flex;align-items:flex-start;gap:0;padding:0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:3px solid transparent;}
.vuln-row:hover{background:rgba(255,245,210,.025);}
.vuln-row.selected{background:rgba(244,63,94,.07);border-left-color:var(--vm);}
.vuln-row.critical{border-left-color:var(--crit);}
.vuln-row.high{border-left-color:var(--high);}
.vuln-row.medium{border-left-color:var(--med);}
.vuln-row.low{border-left-color:var(--low);}
.vuln-row.selected.critical{border-left-color:var(--crit);}
.vuln-row.selected.high{border-left-color:var(--high);}
.vuln-row-content{flex:1;padding:10px 12px;}
.vuln-row-cve{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-bottom:2px;}
.vuln-row-title{font-size:12px;font-weight:400;color:var(--tx);line-height:1.35;}
.vuln-row-meta{display:flex;align-items:center;gap:6px;margin-top:5px;flex-wrap:wrap;}
.vuln-row-right{flex-shrink:0;padding:10px 10px 10px 6px;display:flex;flex-direction:column;align-items:flex-end;gap:5px;}
.vpr-bubble{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--jakarta);font-size:12px;font-weight:700;flex-shrink:0;}
.vpr-bubble.critical{background:var(--crit-bg);border:2px solid var(--crit);color:var(--crit);}
.vpr-bubble.high{background:var(--high-bg);border:2px solid var(--high);color:var(--high);}
.vpr-bubble.medium{background:var(--med-bg);border:2px solid var(--med);color:var(--med);}
.vpr-bubble.low{background:var(--low-bg);border:2px solid var(--low);color:var(--low);}

/* ── ASSET ROWS ── */
.asset-row{display:flex;align-items:center;gap:12px;padding:11px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:3px solid transparent;}
.asset-row:hover{background:rgba(255,245,210,.025);}
.asset-row.selected{background:rgba(244,63,94,.07);border-left-color:var(--vm);}
.asset-icon{width:32px;height:32px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;}
.asset-row-info{flex:1;min-width:0;}
.asset-row-name{font-size:13px;font-weight:400;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.asset-row-meta{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.vuln-mini-bar{display:flex;gap:3px;margin-top:4px;}
.vuln-mini-pill{font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:2px;}
.vuln-mini-pill.c{color:var(--crit);background:var(--crit-bg);}
.vuln-mini-pill.h{color:var(--high);background:var(--high-bg);}
.vuln-mini-pill.m{color:var(--med);background:var(--med-bg);}
.vuln-mini-pill.l{color:var(--low);background:var(--low-bg);}

/* ── TICKET ROWS ── */
.ticket-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;border-left:3px solid transparent;}
.ticket-row:hover{background:rgba(255,245,210,.025);}
.ticket-row.selected{background:rgba(244,63,94,.07);border-left-color:var(--vm);}
.ticket-row-info{flex:1;min-width:0;}
.ticket-row-id{font-family:var(--mono);font-size:10px;color:var(--tx3);}
.ticket-row-title{font-size:13px;color:var(--tx);margin-top:1px;}
.ticket-row-meta{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:3px;}

/* ── SCAN ROWS ── */
.scan-card{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:12px;cursor:pointer;transition:background .1s;}
.scan-card:hover{background:var(--surf2);}
.scan-card.selected{border-color:var(--vm-b);background:rgba(244,63,94,.04);}
.scan-header{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.scan-icon{width:36px;height:36px;border-radius:8px;background:var(--vm-bg);border:1px solid var(--vm-b);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.scan-name{font-family:var(--jakarta);font-size:13px;font-weight:600;flex:1;}
.scan-body{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.scan-stat{font-size:11px;}
.scan-stat-val{font-family:var(--jakarta);font-size:16px;font-weight:600;}
.scan-stat-lbl{font-family:var(--mono);font-size:9px;color:var(--tx3);letter-spacing:.1em;text-transform:uppercase;}

/* ── DETAIL PANEL ── */
.vm-detail-panel{flex:1;overflow-y:auto;display:flex;flex-direction:column;}
.detail-empty{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;}
.detail-empty-icon{opacity:.12;}
.detail-empty-text{font-family:var(--mono);font-size:11px;color:var(--tx3);letter-spacing:.1em;}
.detail-action-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 20px;background:var(--bg2);border-bottom:1px solid var(--border2);position:sticky;top:0;z-index:10;}
.detail-action-title{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--tx3);}
.detail-action-btns{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto;}
.detail-content{padding:20px;flex:1;}

/* ── INFO GRID ── */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.info-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:20px;}
.info-grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:20px;}
.info-card{background:var(--surf);border:1px solid var(--border);border-radius:7px;padding:12px 14px;}
.info-card-label{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx3);margin-bottom:6px;}
.info-card-value{font-size:13px;color:var(--tx);font-weight:400;}
.info-card-sub{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:3px;}

/* ── VULN HEADER CARD ── */
.vuln-header{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:16px 18px;margin-bottom:20px;display:flex;gap:16px;align-items:flex-start;}
.vuln-header-scores{display:flex;gap:16px;align-items:center;flex-shrink:0;}
.vuln-header-score-block{text-align:center;}
.vuln-header-score-label{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--tx3);margin-bottom:4px;}
.vuln-header-info{flex:1;min-width:0;}
.vuln-title{font-family:var(--jakarta);font-size:15px;font-weight:600;line-height:1.3;margin-bottom:6px;}
.vuln-cve{font-family:var(--mono);font-size:12px;color:var(--tx3);margin-bottom:8px;}
.vuln-badges{display:flex;gap:6px;flex-wrap:wrap;}

/* ── CVSS VECTOR ── */
.cvss-vector{font-family:var(--mono);font-size:10px;color:var(--tx3);background:var(--surf2);border:1px solid var(--border);border-radius:4px;padding:6px 10px;word-break:break-all;line-height:1.6;}
.cvss-vector-parts{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px;}
.cvss-part{background:var(--surf);border:1px solid var(--border);border-radius:5px;padding:8px;text-align:center;}
.cvss-part-label{font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--tx3);margin-bottom:3px;}
.cvss-part-val{font-family:var(--mono);font-size:11px;font-weight:500;}

/* ── REMEDIATION PROGRESS ── */
.sla-bar-wrap{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.sla-bar-item{display:flex;align-items:center;gap:10px;}
.sla-bar-label{font-size:12px;color:var(--tx2);width:80px;flex-shrink:0;}
.sla-bar-track{flex:1;height:8px;background:var(--surf2);border-radius:4px;overflow:hidden;}
.sla-bar-fill{height:100%;border-radius:4px;transition:width .4s;}
.sla-bar-pct{font-family:var(--mono);font-size:10px;color:var(--tx3);width:34px;text-align:right;flex-shrink:0;}

/* ── SLA BADGE ── */
.sla-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:3px;}
.sla-badge.ok{color:var(--ok);background:var(--ok-bg);border:1px solid var(--ok-b);}
.sla-badge.warn{color:var(--high);background:var(--high-bg);border:1px solid var(--high-b);}
.sla-badge.overdue{color:var(--crit);background:var(--crit-bg);border:1px solid var(--crit-b);}

/* ── RISK EXPOSURE GAUGE ── */
.risk-gauge-card{background:var(--surf);border:1px solid var(--border);border-radius:8px;padding:20px;display:flex;align-items:center;gap:24px;margin-bottom:24px;}
.risk-gauge{position:relative;width:90px;height:90px;flex-shrink:0;}
.risk-gauge-ring{transform:rotate(-90deg);transform-origin:50% 50%;}
.risk-gauge-bg{fill:none;stroke:var(--surf2);stroke-width:10;}
.risk-gauge-fill{fill:none;stroke-width:10;stroke-linecap:round;}
.risk-gauge-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.risk-gauge-num{font-family:var(--jakarta);font-size:18px;font-weight:700;line-height:1;}
.risk-gauge-label{font-family:var(--mono);font-size:8px;color:var(--tx3);letter-spacing:.1em;}

/* ── CHART (css bar) ── */
.bar-chart-v{display:flex;align-items:flex-end;gap:6px;height:80px;}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.bar{width:100%;border-radius:3px 3px 0 0;min-height:3px;}
.bar-lbl{font-family:var(--mono);font-size:9px;color:var(--tx3);}
.stacked-bar{display:flex;height:20px;border-radius:4px;overflow:hidden;margin-bottom:6px;}
.stacked-segment{height:100%;transition:width .3s;}

/* ── SLA CALENDAR HEATMAP (simple) ── */
.sla-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.sla-row:last-child{border-bottom:none;}
.sla-name{font-size:12px;color:var(--tx2);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sla-due{font-family:var(--mono);font-size:10px;color:var(--tx3);flex-shrink:0;width:90px;}

/* ── DETAIL DRAWER ── */
.detail-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:none;}
.detail-drawer-overlay.open{display:block;}
.detail-drawer{position:fixed;right:0;top:0;bottom:0;width:520px;background:var(--bg2);border-left:1px solid var(--border2);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s cubic-bezier(.25,.46,.45,.94);}
.detail-drawer.open{transform:translateX(0);}
.drawer-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0;}
.drawer-title{font-family:var(--jakarta);font-size:14px;font-weight:600;flex:1;}
.drawer-close{width:28px;height:28px;border-radius:5px;background:var(--surf);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--tx3);font-size:14px;transition:all .15s;}
.drawer-close:hover{color:var(--tx);}
.drawer-body{flex:1;overflow-y:auto;padding:20px;}
.drawer-section{margin-bottom:20px;}
.drawer-section-title{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx3);margin-bottom:10px;}
.drawer-kv{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:12px;}
.drawer-kv-label{color:var(--tx3);font-family:var(--mono);font-size:10px;padding-top:1px;}
.drawer-kv-val{color:var(--tx);}

/* ── TOAST ── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;}
.toast-item{background:var(--surf2);border:1px solid var(--border2);border-left:3px solid var(--vm);border-radius:6px;padding:10px 16px;font-family:var(--mono);font-size:11px;color:var(--tx2);max-width:360px;line-height:1.4;animation:toast-in .2s ease;pointer-events:auto;}
.toast-item.ok{border-left-color:var(--ok);}
.toast-item.warn{border-left-color:var(--high);}
.toast-item.danger{border-left-color:var(--crit);}
.toast-item.info{border-left-color:var(--vm);}

/* ── SPINNER ── */
.spin-icon{animation:spin .8s linear infinite;display:inline-block;}

/* ── MISC ── */
.mono{font-family:var(--mono);}
.section-block{margin-bottom:28px;}
.flex-row{display:flex;align-items:center;gap:8px;}
.ml-auto{margin-left:auto;}
.color-ok{color:var(--ok);}
.color-warn{color:var(--high);}
.color-danger{color:var(--crit);}
.color-dim{color:var(--tx3);}
.color-vm{color:var(--vm-lite);}
.divider{height:1px;background:var(--border);margin:16px 0;}
.text-sm{font-size:12px;}
