:root {
  --bg:#07090f;--bg2:#0b0f18;--bg3:#101520;--bg4:#151d2a;--bg5:#1b2435;
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.11);
  --text:#dde5f2;--fg:#dde5f2;--muted:#8494a7;--dim:#3d4f63;
  --accent:#00c8f0;--a-glow:rgba(0,200,240,0.12);
  --green:#1db87a;--red:#f04060;--orange:#f97316;--amber:#f59e0b;--violet:#a78bfa;
  --mono:'DM Mono',monospace;--sans:'Instrument Sans',sans-serif;--display:'Syne',sans-serif;
  /* Section accent colors */
  --sec-inventory:#00c8f0;--sec-risk:#f04060;--sec-security:#f97316;
  --sec-compliance:#1db87a;--sec-vendors:#a78bfa;--sec-governance:#f59e0b;
  --sec-discovery:#00c8f0;--sec-testing:#f97316;--sec-detection:#a78bfa;--sec-response:#f04060;
  --sec-shadow-ai:#a78bfa;--sec-guardrails:#a78bfa;
}
*{margin:0;padding:0;box-sizing:border-box;}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px;}
.skip-nav{position:absolute;top:-100%;left:16px;z-index:9999;background:var(--accent);color:#000;font-family:var(--mono);font-size:13px;font-weight:700;padding:10px 20px;border-radius:0 0 8px 8px;text-decoration:none;letter-spacing:.04em;transition:top .2s;}
.skip-nav:focus{top:0;}
body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background-image:radial-gradient(rgba(0,200,240,0.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;z-index:0;}
::-webkit-scrollbar{width:5px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px;}

/* ══ LOGIN ══ */
.login-wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:200;background:var(--bg);}
.login-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(0,200,240,0.08),transparent);}
.login-card{background:var(--bg2);border:1px solid var(--border2);border-radius:18px;width:420px;padding:40px;position:relative;z-index:1;box-shadow:0 40px 100px rgba(0,0,0,.6);}
.login-logo{font-family:var(--display);font-weight:800;font-size:26px;letter-spacing:-.5px;margin-bottom:4px;}
.login-logo span{color:var(--accent);}
.login-sub{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:32px;}
.login-lbl{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px;}
.login-in{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:11px 14px;font-family:var(--sans);font-size:14px;color:var(--text);margin-bottom:14px;transition:border-color .2s;}
.login-in:focus{outline:none;border-color:rgba(0,200,240,.4);}
.login-btn{width:100%;background:linear-gradient(135deg,rgba(0,200,240,.2),rgba(0,200,240,.08));border:1px solid rgba(0,200,240,.35);border-radius:8px;padding:13px;font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--accent);cursor:pointer;transition:all .2s;margin-top:6px;}
.login-btn:hover{background:linear-gradient(135deg,rgba(0,200,240,.3),rgba(0,200,240,.12));border-color:rgba(0,200,240,.5);}
.login-btn:disabled{opacity:.5;cursor:not-allowed;}
.login-err{font-family:var(--mono);font-size:12px;color:var(--red);background:rgba(240,64,96,.08);border:1px solid rgba(240,64,96,.2);border-radius:6px;padding:9px 12px;margin-bottom:12px;display:none;}
.login-err.show{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.login-card{animation:fadeIn .4s ease both;}

/* ══ APP SHELL ══ */
.app{display:none;width:100vw;height:100vh;overflow:hidden;}
.app.visible{display:block;}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:244px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow-y:auto;}
.logo{padding:20px 18px 16px;border-bottom:1px solid var(--border);}
.logo-mark{font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:-.5px;}
.logo-mark span{color:var(--accent);}
.logo-sub{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:3px;}
.org-pill{margin:10px 12px;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:9px 12px;display:flex;align-items:center;gap:9px;}
.org-av{width:26px;height:26px;border-radius:6px;background:linear-gradient(135deg,#0ea5e9,#6366f1);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;}
.org-name{font-family:var(--display);font-weight:600;font-size:12px;}
.org-plan{font-family:var(--mono);font-size:12px;color:var(--accent);margin-top:1px;}
.nav-sec{padding:12px 10px 4px;}
.nav-lbl{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:0 8px;margin-bottom:4px;}
.nav-i{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--muted);font-weight:500;border:1px solid transparent;transition:all .15s;}
.nav-i:hover{background:var(--bg3);color:var(--text);}
.nav-i.active{background:var(--a-glow);border-color:rgba(0,200,240,.18);color:var(--accent);}
.nav-icon{width:15px;text-align:center;font-size:13px;opacity:.8;}
.nav-group{padding:8px 10px 4px;}
.nav-group-hdr{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text);font-weight:600;font-family:var(--sans);border:1px solid transparent;transition:all .15s;user-select:none;}
.nav-group-hdr:hover{background:var(--bg3);}
.nav-group-hdr.has-active{color:var(--accent);}
.nav-group-hdr.has-active .nav-group-icon{color:var(--accent);opacity:1;}
.nav-group-arrow{width:12px;font-size:12px;color:var(--dim);transition:transform .2s ease;flex-shrink:0;}
.nav-group-icon{width:15px;text-align:center;font-size:13px;opacity:.8;}
.nav-group-items{overflow:hidden;transition:max-height .25s ease,opacity .2s ease;opacity:1;}
.nav-group-items.collapsed{max-height:0 !important;opacity:0;pointer-events:none;}
.nav-group-items .nav-i{padding-left:18px;}
.nav-sub-lbl{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:10px 18px 4px;opacity:1;margin-top:4px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:color .15s;}
.nav-sub-lbl:hover{color:var(--text);}
.nav-sub-lbl::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(132,148,167,.35),transparent);}
.nav-sub-arrow{font-size:12px;transition:transform .2s ease;display:inline-block;}
.nav-sub-items{overflow:hidden;transition:max-height .25s ease,opacity .2s ease;opacity:1;}
.nav-sub-items.collapsed{max-height:0 !important;opacity:0;pointer-events:none;}
.nav-sub-items.collapsed + .nav-sub-lbl,.nav-sub-group.collapsed .nav-sub-arrow{transform:rotate(-90deg);}
.nav-sub-group .nav-sub-lbl .nav-sub-arrow{transform:rotate(0deg);}
.nav-sub-group .nav-sub-items.collapsed ~ .nav-sub-arrow,.nav-sub-items.collapsed + * .nav-sub-arrow{transform:rotate(-90deg);}
.nav-sub-group:has(.nav-sub-items.collapsed) .nav-sub-arrow{transform:rotate(-90deg);}
.nbadge{margin-left:auto;font-family:var(--mono);font-size:12px;padding:2px 6px;border-radius:3px;background:rgba(240,64,96,.15);color:var(--red);border:1px solid rgba(240,64,96,.25);}
.nbadge.blue{background:var(--a-glow);color:var(--accent);border-color:rgba(0,200,240,.25);}
.sidebar-foot{margin-top:auto;padding:12px;border-top:1px solid var(--border);}
.user-row{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:background .15s;}
.user-row:hover{background:var(--bg3);}
.user-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;background:linear-gradient(135deg,#7c3aed,#00c8f0);flex-shrink:0;}
.user-name{font-size:12px;font-weight:600;flex:1;}
.user-role{font-family:var(--mono);font-size:12px;color:var(--muted);}
.logout-btn{font-family:var(--mono);font-size:12px;color:var(--dim);cursor:pointer;padding:2px 6px;border-radius:3px;border:1px solid transparent;transition:all .15s;}
.logout-btn:hover{color:var(--red);border-color:rgba(240,64,96,.3);}

/* ══ MAIN ══ */
.main{margin-left:244px;width:calc(100vw - 244px);height:100vh;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1;box-sizing:border-box;scrollbar-gutter:stable;}
.topbar{height:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;background:rgba(7,9,15,.88);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50;}
.tb-title{font-family:var(--display);font-weight:700;font-size:15px;}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.btn{font-family:var(--mono);font-size:12px;padding:6px 13px;border-radius:6px;border:1px solid var(--border2);background:var(--bg3);color:var(--muted);cursor:pointer;letter-spacing:.04em;transition:all .15s;white-space:nowrap;}
.btn:hover{border-color:var(--accent);color:var(--accent);}
.btn-p{background:var(--a-glow);border-color:rgba(0,200,240,.35);color:var(--accent);}
.btn-p:hover{background:rgba(0,200,240,.18);}
.btn-g{background:rgba(29,184,122,.1);border-color:rgba(29,184,122,.35);color:var(--green);}
.btn-r{background:rgba(240,64,96,.08);border-color:rgba(240,64,96,.3);color:var(--red);}
.pill{font-family:var(--mono);font-size:12px;padding:3px 8px;border-radius:20px;border:1px solid;letter-spacing:.05em;text-transform:uppercase;}
.content{padding:24px;}
#app.has-msp-banner .sidebar{top:36px;}
#app.has-msp-banner .main{margin-top:36px;height:calc(100vh - 36px);}
#app.shield-mode .sidebar{display:none;}
#app.shield-mode .main{margin-left:0;width:100vw;}
.msp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.msp-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;overflow:hidden;transition:all .2s;}
.msp-card:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,0,0,.3);}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade{animation:fadeUp .35s ease both;}

/* ══ CARDS & LAYOUT ══ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;}
.card-hd{padding:13px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.card-ttl{font-family:var(--display);font-weight:700;font-size:13px;}
.stat-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;}
.stat-grid5{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;}
.stat-c{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:15px 16px;position:relative;overflow:hidden;}
.stat-n{font-family:var(--display);font-weight:700;font-size:26px;line-height:1;margin-bottom:3px;}
.stat-l{font-size:12px;color:var(--muted);font-weight:500;}
.stat-s{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:5px;}
.stat-bar{position:absolute;bottom:0;left:0;right:0;height:2px;}

/* ══ DASHBOARD KPI & CHARTS ══ */
.kpi-grid6{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:18px;}
@media(max-width:1400px){.kpi-grid6{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.kpi-grid6{grid-template-columns:repeat(2,1fr);}}
.kpi-card{background:var(--bg2);border:1px solid var(--border2);border-radius:12px;padding:16px 18px;position:relative;overflow:hidden;}
.kpi-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;}
.kpi-label{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.kpi-value{font-family:var(--display);font-weight:800;font-size:28px;line-height:1;}
.kpi-sub{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:6px;}
.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-family:var(--mono);font-size:12px;margin-left:8px;vertical-align:middle;}
.kpi-trend-up{color:var(--green);}
.kpi-trend-down{color:var(--red);}
.kpi-trend-flat{color:var(--muted);}
.kpi-ring{display:flex;align-items:center;gap:12px;}
.kpi-ring svg{flex-shrink:0;}
.kpi-ring-val{font-family:var(--display);font-weight:800;font-size:22px;}
.fw-mini-row{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.fw-mini-row:last-child{margin-bottom:0;}
.fw-mini-label{font-family:var(--mono);font-size:12px;color:var(--muted);width:38px;text-align:right;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fw-mini-track{flex:1;height:4px;background:var(--bg5);border-radius:2px;overflow:hidden;}
.fw-mini-fill{height:100%;border-radius:2px;transition:width .4s ease;}
.fw-mini-pct{font-family:var(--mono);font-size:12px;color:var(--dim);width:26px;text-align:right;flex-shrink:0;}
.time-range{display:flex;gap:4px;margin-bottom:10px;}
.time-range-btn{font-family:var(--mono);font-size:12px;padding:4px 10px;border-radius:6px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;}
.time-range-btn:hover{color:var(--text);border-color:var(--accent);}
.time-range-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600;}
.mon-date-range input[type="date"]{color-scheme:dark;}
.mon-date-range input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(0.7);}
.risk-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
@media(max-width:900px){.risk-chart-grid{grid-template-columns:1fr;}}
.donut-wrap{display:flex;align-items:center;gap:20px;padding:16px;}
.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;}
.donut-center-val{font-family:var(--display);font-weight:800;font-size:20px;}
.donut-center-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}
.donut-legend{display:flex;flex-direction:column;gap:6px;flex:1;}
.donut-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;}
.donut-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.donut-legend-val{font-family:var(--mono);font-size:12px;color:var(--muted);margin-left:auto;}
.hbar-row{display:flex;align-items:center;gap:10px;padding:6px 16px;}
.hbar-label{font-size:12px;width:90px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hbar-track{flex:1;height:8px;background:var(--bg5);border-radius:4px;overflow:hidden;}
.hbar-fill{height:100%;border-radius:4px;transition:width .4s ease;}
.hbar-val{font-family:var(--mono);font-size:12px;color:var(--muted);width:28px;text-align:right;flex-shrink:0;}

/* ══ ATTENTION ENGINE (compact ticker) ══ */
.attn-ticker{display:flex;align-items:center;gap:8px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:2px 0;}
.attn-ticker::-webkit-scrollbar{display:none;}
.attn-chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .15s;flex-shrink:0;max-width:420px;}
.attn-chip:hover{border-color:var(--border2);background:var(--bg3);}
.attn-chip-icon{font-size:13px;flex-shrink:0;width:20px;text-align:center;}
.attn-chip-text{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;}
.attn-chip-sev{font-family:var(--mono);font-size:9px;padding:1px 6px;border-radius:3px;border:1px solid;flex-shrink:0;letter-spacing:.04em;text-transform:uppercase;}
.attn-chip-x{background:none;border:none;color:var(--dim);font-size:14px;cursor:pointer;padding:0 2px;line-height:1;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s;}
.attn-chip:hover .attn-chip-x{opacity:1;}
.attn-chip-x:hover{color:var(--red);}
.attn-chip-more{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--a-glow);border:1px solid rgba(0,200,240,.2);border-radius:8px;padding:8px 14px;cursor:pointer;flex-shrink:0;transition:all .15s;white-space:nowrap;}
.attn-chip-more:hover{background:rgba(0,200,240,.15);border-color:rgba(0,200,240,.35);}
.attn-clear-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--green);font-weight:500;padding:8px 14px;background:rgba(29,184,122,.06);border:1px solid rgba(29,184,122,.15);border-radius:8px;}
.dash-posture-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
@media(max-width:1100px){.dash-posture-row{grid-template-columns:1fr;}}
.trend-toggle{display:flex;gap:0;margin-right:12px;}
.trend-toggle-btn{font-family:var(--mono);font-size:12px;padding:4px 12px;border:1px solid var(--border2);background:transparent;color:var(--muted);cursor:pointer;transition:all .15s;letter-spacing:.04em;}
.trend-toggle-btn:first-child{border-radius:6px 0 0 6px;}
.trend-toggle-btn:last-child{border-radius:0 6px 6px 0;border-left:none;}
.trend-toggle-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600;}
.quick-status-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);}
.quick-status-cell{background:var(--bg2);padding:14px;text-align:center;}
.quick-status-val{font-family:var(--display);font-weight:700;font-size:22px;}
.quick-status-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;}
.cp-page-rings{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;padding:24px;}
.cp-ring-item{text-align:center;min-width:110px;cursor:pointer;transition:transform .15s;}
.cp-ring-item:hover{transform:translateY(-2px);}

.drm-wrap{display:grid;grid-template-columns:24px repeat(4,48px);grid-template-rows:16px repeat(4,48px);gap:2px;padding:10px;max-width:240px;margin:0 auto;}
.drm-cell{border-radius:5px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:13px;font-weight:700;transition:transform .15s;}
.drm-cell:hover{transform:scale(1.06);}
.drm-cell.empty{opacity:.25;}
.drm-axis{font-family:var(--mono);font-size:12px;color:var(--muted);display:flex;align-items:center;justify-content:center;text-transform:uppercase;letter-spacing:.06em;}
.drm-axis-row{writing-mode:vertical-rl;transform:rotate(180deg);}

.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.sec-ttl{font-family:var(--display);font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px;}
.sec-ttl::before{content:'';width:3px;height:14px;background:var(--accent);border-radius:2px;display:block;}
.fw-bar{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:10px;}
.fw-fill{height:100%;border-radius:2px;}

/* ══ LOADING ══ */
.loading{display:flex;align-items:center;justify-content:center;padding:60px;flex-direction:column;gap:12px;}
.spinner{width:28px;height:28px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.loading-txt{font-family:var(--mono);font-size:12px;color:var(--muted);}

/* ══ EMPTY STATE ══ */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;text-align:center;}
.empty-icon{font-size:36px;margin-bottom:12px;opacity:.3;}
.empty-ttl{font-family:var(--display);font-weight:700;font-size:15px;margin-bottom:6px;}
.empty-sub{font-size:12px;color:var(--muted);max-width:300px;line-height:1.6;}

/* ══ MODAL ══ */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-ov.open{opacity:1;pointer-events:all;}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;transform:translateY(20px) scale(.96);transition:transform .28s cubic-bezier(.34,1.4,.64,1);box-shadow:0 40px 100px rgba(0,0,0,.6);}
.modal-ov.open .modal{transform:translateY(0) scale(1);}
.modal-hd{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg3);position:sticky;top:0;}
.modal-ttl{font-family:var(--display);font-weight:700;font-size:15px;}
.modal-x{cursor:pointer;color:var(--dim);font-size:14px;padding:4px 8px;border-radius:4px;border:1px solid transparent;transition:all .15s;}
.modal-x:hover{color:var(--text);border-color:var(--border2);}
.modal-body{padding:22px;}
.modal-ft{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}
.form-grp{margin-bottom:14px;}
.form-lbl{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:6px;}
.form-in{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:9px 12px;font-family:var(--sans);font-size:13px;color:var(--text);transition:border-color .2s;}
.form-in:focus{outline:none;border-color:rgba(0,200,240,.4);}
.form-in[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.8);cursor:pointer;}
.form-sel{appearance:none;cursor:pointer;}
.model-opt{padding:8px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:12px;color:var(--text);transition:background .15s;}
.model-opt:hover{background:rgba(0,200,240,.07);}
.model-panel{display:none;position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--bg2);border:1px solid var(--border2);border-top:none;border-radius:0 0 7px 7px;max-height:220px;overflow-y:auto;}

/* ══ TABLE ══ */
.tbl{width:100%;border-collapse:collapse;}
.tbl th{padding:9px 14px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);background:var(--bg3);border-bottom:1px solid var(--border);text-align:left;}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--border);font-size:12px;vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr:hover td{background:var(--bg3);}

/* ══ TAGS ══ */
.tag{font-family:var(--mono);font-size:12px;padding:2px 7px;border-radius:3px;border:1px solid;}
.tag-r{color:var(--red);border-color:rgba(240,64,96,.3);background:rgba(240,64,96,.08);}
.tag-o{color:var(--orange);border-color:rgba(249,115,22,.3);background:rgba(249,115,22,.08);}
.tag-y{color:var(--amber);border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.08);}
.tag-g{color:var(--green);border-color:rgba(29,184,122,.3);background:rgba(29,184,122,.08);}
.tag-b{color:var(--accent);border-color:rgba(0,200,240,.3);background:rgba(0,200,240,.08);}
.tag-m{color:var(--muted);border-color:var(--border);background:var(--bg4);}
.tag-v{color:var(--violet);border-color:rgba(167,139,250,.3);background:rgba(167,139,250,.08);}
.tag-active{color:var(--accent)!important;border-color:rgba(0,200,240,.4)!important;background:rgba(0,200,240,.1)!important;}

/* ══ UTILITY: severity / status badges, inline mono, action buttons ══ */
.sev{font-family:var(--mono);font-size:12px;padding:2px 7px;border-radius:4px;background:rgba(0,0,0,.2);white-space:nowrap;}
.sev-c{color:var(--red);}.sev-h{color:var(--amber);}.sev-m{color:var(--accent);}.sev-l{color:var(--muted);}
.ev-type{font-size:12px;padding:2px 7px;border-radius:4px;white-space:nowrap;}
.ev-shadow{background:rgba(240,64,96,.08);color:var(--red);}
.ev-policy{background:rgba(245,158,11,.08);color:var(--amber);}
.ev-anomaly{background:rgba(167,139,250,.08);color:var(--violet);}
.ev-ok{background:rgba(29,184,122,.08);color:var(--green);}
.ev-dlp{background:rgba(240,64,96,.08);color:var(--red);}
.st-new{color:var(--amber);}.st-ack{color:var(--accent);}.st-res{color:var(--green);}.st-fp{color:var(--muted);}
.cat-pill{font-size:12px;padding:2px 7px;border-radius:4px;background:var(--bg3);color:var(--fg);white-space:nowrap;}
.mono-sm{font-family:var(--mono);font-size:12px;}
.mono-xs{font-family:var(--mono);font-size:12px;}
.txt-muted{color:var(--muted);}
.txt-dim{color:var(--dim);}
.btn-xs{font-size:12px;padding:3px 8px;border-radius:4px;border:1px solid var(--border);cursor:pointer;}
.btn-amber{background:rgba(245,158,11,.08);border-color:rgba(245,158,11,.3);color:var(--amber);}
.btn-ghost{background:var(--bg2);border-color:var(--border);color:var(--muted);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);}
.btn-danger{background:rgba(240,64,96,.08);border-color:var(--red);color:var(--red);}
.btn-danger:hover{background:rgba(240,64,96,.15);}
.btn-ghost-danger{background:var(--bg2);border-color:var(--border);color:var(--muted);}
.btn-ghost-danger:hover{border-color:var(--red);color:var(--red);}
.info-box{background:rgba(0,200,240,.05);border:1px solid rgba(0,200,240,.15);border-radius:8px;padding:14px;margin-bottom:16px;}
.info-box-title{font-size:13px;color:var(--accent);font-weight:600;margin-bottom:6px;}
.dash-section{margin-bottom:18px;}
.dash-section.collapsed .dash-section-body{display:none;}
.dash-toggle{font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;border:none;background:none;padding:4px 8px;transition:color .15s;}
.dash-toggle:hover{color:var(--accent);}

/* ══ TOAST ══ */
.toasts{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:999;}
.toast{font-family:var(--mono);font-size:12px;padding:11px 16px;border-radius:8px;animation:fadeUp .3s ease both;letter-spacing:.04em;max-width:360px;}

/* ══ INVENTORY ══ */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.inv-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;overflow:hidden;transition:all .2s;cursor:pointer;}
.inv-card:hover{border-color:var(--border2);transform:translateY(-1px);box-shadow:0 8px 28px rgba(0,0,0,.3);}
.ic-head{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px;}
.ic-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.ic-name{font-family:var(--display);font-weight:700;font-size:13px;}
.ic-type{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;}
.ic-body{padding:14px 16px;}
.ic-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px;}
.ic-row:last-child{border-bottom:none;}
.ic-row-lbl{color:var(--muted);}
.ic-row-val{font-family:var(--mono);font-size:12px;}
.ic-footer{padding:10px 16px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}

/* ══ CONTROLS ══ */
.ctrl-row{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:10px;transition:border-color .2s;}
.ctrl-row:hover{border-color:var(--border2);}
.ctrl-head{padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;}
.ctrl-icon{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.ctrl-info{flex:1;min-width:0;}
.ctrl-name{font-size:13px;font-weight:600;}
.ctrl-meta{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;display:flex;gap:8px;}
.ctrl-expand{color:var(--dim);font-size:12px;transition:transform .2s;flex-shrink:0;}
.ctrl-row.open .ctrl-expand{transform:rotate(180deg);}
.ctrl-body{display:none;padding:0 16px 16px;border-top:1px solid var(--border);}
.ctrl-row.open .ctrl-body{display:block;}
.drop-zone{border:2px dashed var(--border2);border-radius:9px;padding:20px;text-align:center;cursor:pointer;transition:all .2s;margin:10px 0;}
.drop-zone:hover{border-color:rgba(0,200,240,.4);background:rgba(0,200,240,.03);}
.attest-sel{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.attest-opt{font-family:var(--mono);font-size:12px;padding:6px 12px;border:1px solid var(--border2);border-radius:5px;cursor:pointer;color:var(--muted);transition:all .15s;}
.attest-opt:hover{border-color:var(--accent);color:var(--accent);}
.attest-opt.sel{border-color:rgba(0,200,240,.5);background:rgba(0,200,240,.1);color:var(--accent);}

/* ══ WIZARD ══ */
.wizard-wrap{display:grid;grid-template-columns:260px 1fr;gap:18px;}
.wizard-nav{background:var(--bg2);border:1px solid var(--border);border-radius:11px;overflow:hidden;position:sticky;top:68px;}
.wn-head{padding:14px 16px;border-bottom:1px solid var(--border);background:var(--bg3);}
.wn-prog-track{height:4px;background:var(--bg5);border-radius:2px;overflow:hidden;margin-top:8px;}
.wn-prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--violet));border-radius:2px;transition:width .4s ease;}
.wn-steps{padding:10px;}
.wn-step{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:all .15s;margin-bottom:2px;border:1px solid transparent;}
.wn-step:hover{background:var(--bg3);}
.wn-step.active{background:var(--a-glow);border-color:rgba(0,200,240,.18);}
.wn-step-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;flex-shrink:0;border:1px solid var(--border2);color:var(--muted);}
.wn-step.active .wn-step-num{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700;}
.wn-step.done .wn-step-num{background:rgba(29,184,122,.2);border-color:rgba(29,184,122,.4);color:var(--green);}
.ans-opt{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border2);border-radius:8px;cursor:pointer;margin-bottom:8px;transition:all .2s;background:var(--bg3);}
.ans-opt:hover{border-color:rgba(0,200,240,.3);}
.ans-opt.selected{border-color:rgba(0,200,240,.5);background:rgba(0,200,240,.08);}
.ans-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--border2);transition:all .2s;flex-shrink:0;}
.ans-opt.selected .ans-radio{background:var(--accent);border-color:var(--accent);}
.wiz-qfilter{display:flex;gap:4px;margin-bottom:14px;}
.wiz-qf-btn{font-family:var(--mono);font-size:12px;letter-spacing:.04em;padding:7px 16px;border-radius:6px;border:1px solid var(--border2);background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;}
.wiz-qf-btn:hover{border-color:rgba(0,200,240,.3);color:var(--fg);}
.wiz-qf-btn.active{border-color:var(--accent);background:rgba(0,200,240,.1);color:var(--accent);font-weight:600;}
.wiz-qf-btn .qf-count{font-size:12px;background:var(--bg5);border-radius:10px;padding:1px 7px;min-width:18px;text-align:center;}
.wiz-qf-btn.active .qf-count{background:rgba(0,200,240,.2);}

/* ══ EU AI ACT ══ */
.eu-timeline{display:flex;align-items:stretch;padding:16px 20px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;margin-bottom:18px;overflow-x:auto;gap:0;}
.eu-tl-item{display:flex;align-items:center;gap:8px;flex:1;min-width:160px;}
.eu-tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.eu-tl-line{flex:1;height:2px;background:var(--border2);min-width:16px;}
.eu-journey{display:flex;align-items:center;padding:12px 0;margin-bottom:14px;}
.eu-phase{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:6px 12px;border-radius:8px;transition:all .15s;}
.eu-phase:hover{background:var(--bg3);}
.eu-phase-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;border:2px solid var(--border2);color:var(--muted);transition:all .2s;}
.eu-phase.current .eu-phase-dot{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700;}
.eu-phase.done .eu-phase-dot{background:rgba(29,184,122,.2);border-color:rgba(29,184,122,.4);color:var(--green);}
.eu-phase-label{font-family:var(--mono);font-size:12px;color:var(--muted);white-space:nowrap;}
.eu-phase.current .eu-phase-label{color:var(--accent);font-weight:600;}
.eu-phase.done .eu-phase-label{color:var(--green);}
.eu-phase-conn{width:28px;height:2px;background:var(--border2);align-self:center;margin-bottom:16px;}
.eu-phase-conn.done{background:var(--green);}
.eu-art-row{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;background:var(--bg2);overflow:hidden;}
.eu-art-head{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;}
.eu-art-head:hover{background:var(--bg3);}
.eu-art-body{padding:0 16px 16px;display:none;border-top:1px solid var(--border);}
.eu-art-row.open .eu-art-body{display:block;padding-top:14px;}
.eu-subreq{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border);border-radius:6px;margin-bottom:6px;background:var(--bg3);}
.eu-subreq-check{width:16px;height:16px;border-radius:4px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;}
.eu-subreq-check.met{background:var(--green);border-color:var(--green);color:#000;}
.eu-section{margin-bottom:24px;}
.eu-section-hd{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.eu-section-hd .eu-section-num{display:inline-block;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#000;font-weight:800;font-size:12px;text-align:center;line-height:20px;}

/* ══ REPORTS ══ */
.report-layout{display:grid;grid-template-columns:1fr 320px;gap:18px;}
.section-chip{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:all .15s;margin-bottom:6px;background:var(--bg3);}
.section-chip.included{border-color:rgba(0,200,240,.3);background:rgba(0,200,240,.06);}
.sc-check{width:16px;height:16px;border-radius:4px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s;flex-shrink:0;}
.section-chip.included .sc-check{background:var(--accent);border-color:var(--accent);color:#000;}

/* ══ SCHEDULED REPORTS ══ */
.sched-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);}
.sched-row:last-child{border-bottom:none;}
.sched-toggle{position:relative;display:inline-block;width:34px;height:18px;flex-shrink:0;}
.sched-toggle input{opacity:0;width:0;height:0;}
.sched-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg4);border:1px solid var(--border2);border-radius:18px;transition:.2s;}
.sched-slider::before{content:'';position:absolute;height:12px;width:12px;left:2px;bottom:2px;background:var(--muted);border-radius:50%;transition:.2s;}
.sched-toggle input:checked+.sched-slider{background:rgba(0,200,240,.2);border-color:rgba(0,200,240,.4);}
.sched-toggle input:checked+.sched-slider::before{transform:translateX(16px);background:var(--accent);}
.sched-recip-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;background:var(--bg4);border:1px solid var(--border);font-size:12px;}

/* ══ RISK MATRIX ══ */
.rm-wrap{display:grid;grid-template-columns:72px repeat(5,1fr);grid-template-rows:20px repeat(5,1fr);gap:3px;padding:12px 12px 12px 8px;}
.rm-cell{border-radius:4px;border:1px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:44px;transition:filter .15s,transform .15s;position:relative;}
.rm-cell.clickable{cursor:pointer;}
.rm-cell.clickable:hover{filter:brightness(1.25);transform:scale(1.03);}
.rm-axis-lbl{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.3;}
.rm-axis-row{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;justify-content:flex-end;padding-right:6px;text-align:right;line-height:1.3;}
.rm-count{font-family:var(--mono);font-size:15px;font-weight:700;line-height:1;}
.rm-sublabel{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin-top:3px;opacity:.75;}
.rm-empty{font-family:var(--mono);font-size:13px;opacity:.25;}
/* Risk matrix trend arrows */
.rm-trend{position:absolute;top:2px;right:3px;font-family:var(--mono);font-size:7px;font-weight:700;line-height:1;padding:1px 3px;border-radius:3px;}
.rm-trend-up{color:#fff;background:rgba(220,38,38,.85);}
.rm-trend-down{color:#fff;background:rgba(29,184,122,.85);}
/* Hottest cell glow */
.rm-hottest{animation:rmPulse 1.8s ease-in-out infinite;box-shadow:0 0 16px 4px rgba(229,62,62,.6);border:2px solid rgba(229,62,62,.9);z-index:2;position:relative;}
.rm-hottest-calm{box-shadow:inset 0 0 0 2px rgba(255,255,255,.35);border:2px solid rgba(255,255,255,.5);z-index:2;position:relative;}
@keyframes rmPulse{0%,100%{box-shadow:0 0 12px 2px rgba(229,62,62,.5);border-color:rgba(229,62,62,.7)}50%{box-shadow:0 0 28px 8px rgba(229,62,62,.8),0 0 8px 2px rgba(255,100,100,1);border-color:rgba(255,100,100,1)}}
/* Summary strip */
.rm-summary{display:flex;gap:16px;padding:8px 16px;border-top:1px solid var(--border);font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.04em;}
.rm-summary strong{color:var(--text);}
/* Matrix drill filter banner */
.rm-filter-banner{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:rgba(0,200,240,.06);border:1px solid rgba(0,200,240,.2);border-radius:8px;margin-bottom:14px;}
/* ══ FRAMEWORK PICKER ══ */
.fw-picker{display:flex;flex-wrap:wrap;gap:6px;}
.fw-chip{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;border:1px solid var(--border2);background:var(--bg3);cursor:pointer;transition:all .2s;user-select:none;}
.fw-chip:hover{border-color:var(--accent);background:rgba(0,200,240,.04);}
.fw-chip input{display:none;}
.fw-chip span{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--muted);transition:color .2s;}
.fw-chip:has(input:checked){border-color:var(--accent);background:rgba(0,200,240,.1);}
.fw-chip:has(input:checked) span{color:var(--accent);font-weight:600;}
/* ══ COMPLIANCE HEATMAP ══ */
.ch-table{width:100%;border-collapse:separate;border-spacing:0;}
.ch-table th{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:5px 4px;text-align:center;border-bottom:1px solid var(--border);white-space:nowrap;}
.ch-table th:first-child{text-align:left;padding-left:12px;min-width:120px;}
.ch-table td{padding:3px 3px;text-align:center;border-bottom:1px solid var(--border);}
.ch-table td:first-child{text-align:left;padding-left:12px;}
.ch-table tr:last-child td{border-bottom:none;}
.ch-sys-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px;}
.ch-sys-meta{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:1px;}
.ch-cell{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:5px;border:1px solid;font-family:var(--mono);font-size:12px;font-weight:700;cursor:pointer;transition:filter .15s,transform .15s;}
.ch-cell:hover{filter:brightness(1.25);transform:scale(1.08);}
.ch-cell-na{opacity:.2;cursor:default;border:1px dashed var(--border2);background:transparent;color:var(--dim);font-size:12px;font-weight:400;}
.ch-cell-na:hover{filter:none;transform:none;}
#rm-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:498;}
#rm-drill-panel{position:fixed;top:0;right:-520px;width:480px;height:100vh;background:var(--bg2);border-left:1px solid var(--border2);z-index:499;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,.4);}
#rm-drill-panel.open{right:0;}
.rm-drill-item{display:flex;align-items:flex-start;gap:10px;padding:12px 20px;border-bottom:1px solid var(--border);transition:background .15s;}
.rm-drill-item:hover{background:var(--bg3);}
.rm-drill-sev{width:4px;min-height:36px;border-radius:3px;flex-shrink:0;margin-top:2px;}
/* ══ MSP WIDGETS ══ */
.msp-sev-bar{height:6px;border-radius:3px;overflow:hidden;display:flex;gap:1px;margin:6px 0 4px;}
.msp-sev-seg{height:100%;border-radius:1px;}
.msp-metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);}
.msp-metric{text-align:center;}
.msp-metric-n{font-family:var(--display);font-weight:700;font-size:18px;line-height:1;}
.msp-metric-l{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:2px;}
.msp-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block;margin-right:5px;}
/* ══ AI PROJECTS ══ */
.proj-status-bar{height:8px;border-radius:4px;overflow:hidden;display:flex;gap:1px;margin:8px 0;}
.proj-status-seg{height:100%;transition:width .3s ease;}
.proj-budget-bar{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.proj-budget-label{font-family:var(--mono);font-size:12px;color:var(--muted);width:80px;flex-shrink:0;text-align:right;}
.proj-budget-track{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.proj-budget-fill{height:100%;border-radius:3px;transition:width .3s ease;}
.proj-budget-val{font-family:var(--mono);font-size:12px;color:var(--text);width:80px;flex-shrink:0;}
.proj-timeline{position:relative;padding-left:24px;margin:16px 0;}
.proj-timeline::before{content:'';position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--border);}
.proj-ms{position:relative;padding:10px 0 10px 16px;border-bottom:1px solid var(--border);}
.proj-ms:last-child{border-bottom:none;}
.proj-ms::before{content:'';position:absolute;left:-20px;top:14px;width:10px;height:10px;border-radius:50%;border:2px solid var(--border);background:var(--bg2);z-index:1;}
.proj-ms.ms-completed::before{background:var(--green);border-color:var(--green);}
.proj-ms.ms-in_progress::before{background:var(--accent);border-color:var(--accent);}
.proj-ms.ms-delayed::before{background:var(--red);border-color:var(--red);}
.proj-ms.ms-pending::before{background:var(--bg4);border-color:var(--dim);}
.proj-ms-name{font-size:12px;font-weight:600;margin-bottom:3px;}
.proj-ms-dates{font-family:var(--mono);font-size:12px;color:var(--muted);display:flex;gap:12px;}
.roi-rank{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);}
.roi-rank:last-child{border-bottom:none;}
.roi-rank-num{font-family:var(--display);font-weight:700;font-size:18px;color:var(--dim);width:28px;text-align:center;}
.roi-rank-name{flex:1;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.roi-rank-val{font-family:var(--mono);font-size:12px;text-align:right;}
.ms-analytics{display:flex;align-items:center;gap:14px;padding:10px 0;margin-bottom:8px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:12px;color:var(--muted);}
.maturity-level{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;font-family:var(--display);font-weight:800;font-size:36px;line-height:1;flex-shrink:0;}
.maturity-level-1{color:var(--red);border:3px solid rgba(240,64,96,.4);background:rgba(240,64,96,.08);}
.maturity-level-2{color:var(--orange);border:3px solid rgba(249,115,22,.4);background:rgba(249,115,22,.08);}
.maturity-level-3{color:var(--amber);border:3px solid rgba(245,158,11,.4);background:rgba(245,158,11,.08);}
.maturity-level-4{color:var(--green);border:3px solid rgba(29,184,122,.4);background:rgba(29,184,122,.08);}
.maturity-level-5{color:var(--accent);border:3px solid rgba(0,200,240,.4);background:rgba(0,200,240,.08);}
.maturity-dim{margin-bottom:14px;}
.maturity-dim-hd{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:5px;}
.maturity-dim-bar{height:6px;background:var(--bg5);border-radius:3px;overflow:hidden;}
.maturity-dim-fill{height:100%;border-radius:3px;transition:width .5s ease;}
.policy-content{max-height:400px;overflow-y:auto;padding:18px;font-size:13px;line-height:1.7;color:var(--text);white-space:pre-wrap;background:var(--bg3);border:1px solid var(--border);border-radius:8px;}
.attestation-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);font-size:12px;}
.attestation-row:last-child{border-bottom:none;}
.gap-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;font-size:12px;}
.gap-item::before{content:'';width:6px;height:6px;border-radius:50%;margin-top:5px;flex-shrink:0;}
.gap-item.gap-red::before{background:var(--red);}
.gap-item.gap-amber::before{background:var(--amber);}
.gap-item.gap-green::before{background:var(--green);}
/* ── Section Jumpstarts ── */
.js-card{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:28px 32px;margin-bottom:22px;position:relative;overflow:hidden;animation:fadeIn .4s ease both;}
.js-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0;}
.js-card.js-accent-blue::before{background:linear-gradient(90deg,var(--accent),rgba(0,200,240,.2));}
.js-card.js-accent-green::before{background:linear-gradient(90deg,var(--green),rgba(29,184,122,.2));}
.js-card.js-accent-red::before{background:linear-gradient(90deg,var(--red),rgba(240,64,96,.2));}
.js-card.js-accent-orange::before{background:linear-gradient(90deg,var(--orange),rgba(249,115,22,.2));}
.js-card.js-accent-violet::before{background:linear-gradient(90deg,var(--violet),rgba(167,139,250,.2));}
.js-card.js-accent-amber::before{background:linear-gradient(90deg,var(--amber),rgba(245,158,11,.2));}
.js-hdr{display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;}
.js-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.js-icon.js-blue{background:rgba(0,200,240,.1);border:1px solid rgba(0,200,240,.25);}
.js-icon.js-green{background:rgba(29,184,122,.1);border:1px solid rgba(29,184,122,.25);}
.js-icon.js-red{background:rgba(240,64,96,.1);border:1px solid rgba(240,64,96,.25);}
.js-icon.js-orange{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25);}
.js-icon.js-violet{background:rgba(167,139,250,.1);border:1px solid rgba(167,139,250,.25);}
.js-icon.js-amber{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);}
.js-ttl{font-family:var(--display);font-weight:800;font-size:17px;margin-bottom:4px;}
.js-sub{font-size:12px;color:var(--muted);line-height:1.5;}
.js-dismiss{position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:10px;color:var(--dim);cursor:pointer;transition:color .15s;background:none;border:none;padding:4px 8px;}
.js-dismiss:hover{color:var(--muted);}
.js-body{margin-top:12px;}
.js-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.js-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.js-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.js-option{background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:14px;cursor:pointer;transition:all .2s;}
.js-option:hover{border-color:rgba(0,200,240,.3);background:rgba(0,200,240,.03);}
.js-option.selected{border-color:var(--accent);background:rgba(0,200,240,.06);}
.js-option-icon{font-size:18px;margin-bottom:6px;}
.js-option-name{font-size:12px;font-weight:700;margin-bottom:2px;}
.js-option-desc{font-family:var(--mono);font-size:9px;color:var(--muted);line-height:1.4;}
.js-option-meta{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:4px;}
.js-actions{display:flex;align-items:center;justify-content:space-between;margin-top:18px;}
.js-actions-right{display:flex;align-items:center;gap:10px;}
.js-count{font-family:var(--mono);font-size:10px;color:var(--muted);}
.js-fw-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:12px;}
.js-fw-label{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;border:1px solid var(--border2);background:var(--bg3);cursor:pointer;transition:all .15s;}
.js-fw-label:hover{border-color:rgba(0,200,240,.3);}
.js-fw-extra{display:none;}
.js-quick-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;}
.js-quick-card{background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:16px;text-align:center;cursor:pointer;transition:all .2s;}
.js-quick-card:hover{border-color:rgba(0,200,240,.4);background:rgba(0,200,240,.04);}
.js-quick-card .js-qc-icon{font-size:24px;margin-bottom:8px;opacity:.7;}
.js-quick-card .js-qc-label{font-size:12px;font-weight:700;margin-bottom:2px;}
.js-quick-card .js-qc-sub{font-family:var(--mono);font-size:9px;color:var(--muted);}
.js-risk-opts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;}
.js-risk-opt{background:var(--bg3);border:2px solid var(--border2);border-radius:10px;padding:16px;text-align:center;cursor:pointer;transition:all .2s;}
.js-risk-opt:hover{border-color:rgba(0,200,240,.3);}
.js-risk-opt.selected{border-color:var(--accent);background:rgba(0,200,240,.04);}
.js-risk-opt-label{font-size:13px;font-weight:700;margin-bottom:4px;}
.js-risk-opt-desc{font-family:var(--mono);font-size:10px;color:var(--muted);line-height:1.5;}
/* MSP Tier / Add-On Styling */
.msp-addon-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;border:1px solid var(--border);background:var(--bg3);cursor:pointer;transition:all .15s;}
.msp-addon-item:hover{border-color:rgba(0,200,240,.25);}
.msp-addon-item.disabled{opacity:.35;pointer-events:none;}
.msp-addon-item.included{border-color:rgba(29,184,122,.3);background:rgba(29,184,122,.06);}
.msp-addon-name{font-size:11px;font-weight:600;color:var(--fg);}
.msp-addon-price{font-family:var(--mono);font-size:9px;color:var(--muted);margin-top:1px;}
.msp-addon-item.included .msp-addon-price{color:var(--green);}
@media(max-width:700px){
  .js-grid,.js-fw-grid{grid-template-columns:1fr;}
  .js-grid-3,.js-quick-cards,.js-risk-opts{grid-template-columns:1fr 1fr;}
  .js-grid-4{grid-template-columns:1fr 1fr;}
}
/* Regulatory Tracker */
/* Risk Quantification */
.rq-grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
@media(max-width:1000px){.rq-grid2{grid-template-columns:1fr;}}
.rq-table{width:100%;border-collapse:collapse;}
.rq-table th{font-family:var(--mono);font-size:12px;text-transform:uppercase;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--border);text-align:left;letter-spacing:.08em;}
.rq-table td{padding:8px 12px;font-size:12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.rq-table tr:hover td{background:var(--bg3);}
.rq-bar-contrib{height:6px;background:var(--bg4);border-radius:3px;min-width:60px;}
.rq-bar-fill{height:100%;border-radius:3px;transition:width .4s ease;}
/* Model Card Detail */
.mc-back{font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;margin-bottom:16px;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);transition:all .15s}
.mc-back:hover{color:var(--text);border-color:var(--border2);background:var(--bg4)}
.mc-field{margin-bottom:14px}
.mc-field-label{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.mc-field-value{font-size:12px;color:var(--text);line-height:1.65;white-space:pre-wrap}
.mc-empty{font-size:12px;color:var(--dim);font-style:italic}
.mc-info-grid{background:var(--bg3);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.mc-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border)}
.mc-info-row:last-child{border-bottom:none}
.mc-info-lbl{font-family:var(--mono);font-size:12px;color:var(--muted)}
.mc-info-val{font-family:var(--mono);font-size:12px;color:var(--text)}
.approval-badge{padding:3px 10px;border-radius:4px;font-family:var(--mono);font-size:12px;font-weight:600;display:inline-block}
.approval-draft{color:var(--muted);border:1px solid var(--dim);background:var(--bg3)}
.approval-review{color:var(--amber);border:1px solid rgba(217,119,6,.3);background:rgba(217,119,6,.08)}
.approval-approved{color:var(--green);border:1px solid rgba(22,163,74,.3);background:rgba(22,163,74,.08)}
.approval-retired{color:var(--dim);border:1px solid var(--border);background:var(--bg2)}
.approval-active{color:var(--green);border:1px solid rgba(22,163,74,.4);background:rgba(22,163,74,.12)}
.approval-deprecated{color:var(--amber);border:1px solid rgba(217,119,6,.3);background:rgba(217,119,6,.08)}
.approval-rejected{color:var(--red);border:1px solid rgba(220,38,38,.3);background:rgba(220,38,38,.08)}
.lc-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.lc-actions .btn{font-size:12px;padding:5px 12px}
.lc-timeline{padding:16px}
.lc-entry{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.lc-entry:last-child{border-bottom:none}
.lc-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);margin-top:4px;flex-shrink:0}
.lc-entry-meta{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:3px}
.lc-entry-comment{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:4px;font-style:italic}
/* DPIA status badges */
.dpia-draft{color:var(--dim);border:1px solid var(--border2);background:var(--bg3)}
.dpia-in-progress{color:var(--amber);border:1px solid rgba(245,158,11,.3);background:rgba(245,158,11,.08)}
.dpia-completed{color:var(--accent);border:1px solid rgba(0,200,240,.3);background:rgba(0,200,240,.08)}
.dpia-under-review{color:#a78bfa;border:1px solid rgba(167,139,250,.3);background:rgba(167,139,250,.08)}
.dpia-approved{color:var(--green);border:1px solid rgba(29,184,122,.3);background:rgba(29,184,122,.08)}
/* Explainability */
.ex-card{transition:border-color .2s}
.ex-card:hover{border-color:var(--border2)}
/* Dashboard Critical & High Findings Widget */
.dash-crithigh-card{margin-bottom:18px;border-color:rgba(240,64,96,.2);background:linear-gradient(135deg,var(--bg2),rgba(240,64,96,.04))}
.dash-crithigh-list{padding:4px 18px 12px}
.dash-crithigh-row{display:flex;align-items:center;gap:12px;padding:10px 12px;margin-bottom:6px;background:var(--bg3);border-radius:8px;cursor:pointer;transition:background .15s}
.dash-crithigh-row:hover{background:var(--bg4)}
.dash-crithigh-sev{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.06em;padding:3px 8px;border-radius:4px;border:1px solid;flex-shrink:0;text-transform:uppercase}
.dash-crithigh-info{flex:1;min-width:0}
.dash-crithigh-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-crithigh-meta{display:flex;gap:10px;font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:3px}
.dash-crithigh-meta span{white-space:nowrap}
.dash-crithigh-status{font-family:var(--mono);font-size:12px;flex-shrink:0;letter-spacing:.04em}
.dash-crithigh-more{text-align:center;padding:8px;font-family:var(--mono);font-size:12px;color:var(--accent);cursor:pointer;border-top:1px solid var(--border)}
.dash-crithigh-more:hover{background:var(--bg3)}

.int-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px}
.int-tab{font-family:var(--mono);font-size:12px;padding:10px 18px;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;transition:all .15s;letter-spacing:.04em}
.int-tab:hover{color:var(--text)}
.int-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.int-tab-panel{display:none}
.int-tab-panel.active{display:block}
.connector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.connector-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:18px;transition:all .2s}
.connector-card:hover{border-color:var(--border2)}
.connector-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}
.toggle-sw{width:36px;height:20px;border-radius:10px;background:var(--bg5);border:1px solid var(--border2);cursor:pointer;position:relative;transition:all .2s;display:inline-block}
.toggle-sw.on{background:rgba(0,200,240,.2);border-color:rgba(0,200,240,.35)}
.toggle-sw::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--muted);transition:all .2s}
.toggle-sw.on::after{left:18px;background:var(--accent)}
.key-reveal{background:var(--bg3);border:1px solid rgba(0,200,240,.3);border-radius:8px;padding:12px 16px;font-family:var(--mono);font-size:12px;color:var(--accent);word-break:break-all;margin:12px 0;position:relative}
.mc-section-divider{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;padding:10px 0 8px;margin-top:8px;border-top:1px solid var(--border)}
#aira-chat-bubble{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,rgba(0,200,240,.25),rgba(0,200,240,.08));border:1px solid rgba(0,200,240,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:800;box-shadow:0 4px 20px rgba(0,200,240,.2);transition:all .2s;opacity:0;pointer-events:none}
#aira-chat-bubble.visible{opacity:1;pointer-events:all}
#aira-chat-bubble:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(0,200,240,.35)}
#aira-chat-bubble .bubble-icon{font-size:22px;color:var(--accent);line-height:1}
#aira-chat-panel{position:fixed;bottom:24px;right:24px;width:440px;height:620px;max-height:calc(100vh - 48px);background:var(--bg2);border:1px solid var(--border2);border-radius:16px;z-index:801;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.5);transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.34,1.4,.64,1)}
#aira-chat-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.chat-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.chat-hd-title{font-family:var(--display);font-weight:700;font-size:15px;color:var(--text);display:flex;align-items:center;gap:8px}
.chat-hd-title .chat-ai-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(0,200,240,.5)}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth}
.chat-msg{max-width:85%;padding:10px 14px;border-radius:12px;font-size:12px;line-height:1.6;word-wrap:break-word}
.chat-msg.user{align-self:flex-end;background:rgba(0,200,240,.12);border:1px solid rgba(0,200,240,.2);color:var(--text);border-bottom-right-radius:4px}
.chat-msg.assistant{align-self:flex-start;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}
.chat-msg.assistant strong{color:var(--accent);font-weight:600}
.chat-msg.assistant code{background:var(--bg5);padding:1px 5px;border-radius:3px;font-family:var(--mono);font-size:12px}
.chat-msg.assistant ul,.chat-msg.assistant ol{margin:6px 0;padding-left:18px}
.chat-msg.assistant li{margin:3px 0}
.chat-msg.assistant table{width:100%;border-collapse:collapse;margin:8px 0;font-size:12px}
.chat-msg.assistant th,.chat-msg.assistant td{border:1px solid var(--border);padding:4px 8px;text-align:left}
.chat-msg.assistant th{background:var(--bg4);font-family:var(--mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.05em}
.chat-msg.assistant h3,.chat-msg.assistant h4{margin:8px 0 4px;color:var(--accent);font-size:12px;font-family:var(--mono);letter-spacing:.04em}
.chat-msg .typing-dots{display:flex;gap:4px;padding:4px 0}
.chat-msg .typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:dotPulse .8s ease-in-out infinite}
.chat-msg .typing-dots span:nth-child(2){animation-delay:.15s}
.chat-msg .typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes dotPulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}
.chat-input-bar{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end}
.chat-input-bar textarea{flex:1;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:10px 14px;font-family:var(--sans);font-size:12px;color:var(--text);resize:none;max-height:80px;line-height:1.4;outline:none;transition:border-color .15s}
.chat-input-bar textarea:focus{border-color:rgba(0,200,240,.4)}
.chat-input-bar textarea::placeholder{color:var(--dim)}
.chat-send-btn{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,rgba(0,200,240,.25),rgba(0,200,240,.1));border:1px solid rgba(0,200,240,.3);color:var(--accent);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.chat-send-btn:hover{background:rgba(0,200,240,.2);border-color:rgba(0,200,240,.5)}
.chat-send-btn:disabled{opacity:.3;cursor:not-allowed}
.chat-quick-actions{display:flex;flex-direction:column;gap:6px;padding:0 16px 12px}
.chat-quick-btn{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 14px;font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;text-align:left;transition:all .15s;line-height:1.4}
.chat-quick-btn:hover{background:var(--bg4);border-color:rgba(0,200,240,.25);color:var(--accent)}
/* ── Chat mode tabs (Advisor / Auditor) ── */
.chat-mode-tabs{display:flex;gap:2px;background:var(--bg3);border-radius:6px;padding:2px;border:1px solid var(--border)}
.chat-mode-tab{background:none;border:none;padding:5px 12px;font-family:var(--mono);font-size:10px;color:var(--muted);cursor:pointer;border-radius:4px;transition:all .15s;display:flex;align-items:center;gap:4px;letter-spacing:.03em;text-transform:uppercase}
.chat-mode-tab:hover{color:var(--text)}
.chat-mode-tab.active[data-mode="advisor"]{background:rgba(0,200,240,.15);color:var(--accent);font-weight:600}
.chat-mode-tab.active[data-mode="auditor"]{background:rgba(240,64,96,.15);color:var(--red);font-weight:600}
.mode-icon{font-size:11px}
/* ── Auditor mode visual overrides ── */
#aira-chat-panel.auditor-mode .chat-ai-dot{background:var(--red)!important;box-shadow:0 0 8px rgba(240,64,96,.5)!important}
#aira-chat-panel.auditor-mode .chat-send-btn{background:linear-gradient(135deg,rgba(240,64,96,.25),rgba(240,64,96,.1));border-color:rgba(240,64,96,.3);color:var(--red)}
#aira-chat-panel.auditor-mode .chat-send-btn:hover{background:rgba(240,64,96,.2);border-color:rgba(240,64,96,.5)}
#aira-chat-panel.auditor-mode .chat-msg.assistant strong{color:var(--red)}
#aira-chat-panel.auditor-mode .chat-msg.assistant h3,#aira-chat-panel.auditor-mode .chat-msg.assistant h4{color:var(--red)}
#aira-chat-panel.auditor-mode .chat-msg.assistant th{color:var(--red)}
#aira-chat-panel.auditor-mode .chat-input-bar textarea:focus{border-color:rgba(240,64,96,.4)}
#aira-chat-panel.auditor-mode .chat-quick-btn:hover{border-color:rgba(240,64,96,.25);color:var(--red)}
#aira-chat-panel.auditor-mode .chat-msg .typing-dots span{background:var(--red)}

/* ══ CONTINUOUS CONTROL MONITORING ══ */
.cm-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}
.cm-toggle{position:relative;display:inline-block;width:34px;height:18px;cursor:pointer;flex-shrink:0}
.cm-toggle input{opacity:0;width:0;height:0}
.cm-toggle-track{position:absolute;inset:0;background:var(--bg5);border:1px solid var(--border2);border-radius:9px;transition:all .2s}
.cm-toggle-track::after{content:'';position:absolute;left:2px;top:2px;width:12px;height:12px;border-radius:50%;background:var(--dim);transition:all .2s}
.cm-toggle input:checked+.cm-toggle-track{background:rgba(0,200,240,.15);border-color:rgba(0,200,240,.35)}
.cm-toggle input:checked+.cm-toggle-track::after{transform:translateX(16px);background:var(--accent)}
/* SSO / SAML */
.sso-btn{background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(124,58,237,.12));border:1px solid rgba(99,102,241,.35);color:#a5b4fc;margin-top:10px}
.sso-btn:hover{background:linear-gradient(135deg,rgba(99,102,241,.25),rgba(124,58,237,.2));border-color:rgba(99,102,241,.5)}
.sso-sp-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.sso-sp-row:last-child{border-bottom:none}
.sso-sp-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.05em;min-width:100px;flex-shrink:0}
.sso-sp-val{font-family:var(--mono);font-size:12px;color:var(--text);display:flex;align-items:center}
.sso-sp-val code{background:var(--bg3);padding:4px 8px;border-radius:4px;word-break:break-all;font-size:12px}
/* ══ GOVERNANCE CALENDAR ══ */
.cal-grid-inner{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-hdr{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);text-align:center;padding:8px 0 6px}
.cal-cell{background:var(--bg3);border:1px solid var(--border);border-radius:6px;min-height:64px;padding:6px 8px;cursor:pointer;transition:all .15s;position:relative}
.cal-cell:hover{border-color:var(--border2);background:var(--bg4)}
.cal-cell-empty{background:transparent;border-color:transparent;cursor:default}
.cal-cell-empty:hover{background:transparent;border-color:transparent}
.cal-today{border-color:rgba(0,200,240,.4);background:rgba(0,200,240,.04)}
.cal-today .cal-day-num{color:var(--accent);font-weight:700}
.cal-has-events{border-color:var(--border2)}
.cal-day-num{font-family:var(--mono);font-size:12px;color:var(--muted);display:block;margin-bottom:4px}
.cal-dots{display:flex;gap:3px;flex-wrap:wrap}
.cal-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cal-count{position:absolute;top:4px;right:6px;font-family:var(--mono);font-size:12px;color:var(--muted)}
.cal-toggles{display:flex;gap:4px;flex-wrap:wrap}
.cal-tog{font-family:var(--mono);font-size:12px;padding:4px 10px;border-radius:5px;border:1px solid var(--border2);background:var(--bg3);color:var(--dim);cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .15s;letter-spacing:.04em}
.cal-tog:hover{border-color:var(--border2);color:var(--muted)}
.cal-tog.active{border-color:var(--cat-color,var(--accent));color:var(--text);background:rgba(255,255,255,.04)}
.cal-tog-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;opacity:.4}
.cal-tog.active .cal-tog-dot{opacity:1}
.cal-ev-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.cal-ev-row:last-child{border-bottom:none}
.cal-tog-x{font-size:12px;margin-left:2px;opacity:.4;padding:0 2px;border-radius:3px;transition:all .15s}
.cal-tog-x:hover{opacity:1;color:var(--red);background:rgba(240,64,96,.1)}
.cal-color-opt{width:28px;height:28px;border-radius:7px;cursor:pointer;border:2px solid transparent;transition:all .15s}
.cal-color-opt:hover{transform:scale(1.1)}
.cal-color-opt.selected{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,.2)}
/* ══ DATA LINEAGE ══ */
.lin-canvas-wrap{position:relative;min-height:300px;background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:auto}
.lin-canvas-wrap .lin-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}
.lin-canvas-wrap .lin-svg .lin-edge-path{pointer-events:stroke;cursor:pointer;transition:stroke-width .15s}
.lin-canvas-wrap .lin-svg .lin-edge-path:hover{stroke-width:4}
.lin-canvas{position:relative;min-height:300px;min-width:100%;z-index:2}
.lin-node{position:absolute;width:180px;padding:10px 12px;border-radius:9px;border:1px solid;cursor:grab;user-select:none;transition:box-shadow .15s,border-color .15s;z-index:3}
.lin-node:hover{box-shadow:0 0 20px rgba(0,200,240,.08);z-index:4}
.lin-node:active{cursor:grabbing}
.lin-node-selected{box-shadow:0 0 0 2px var(--accent) !important}
.lin-node-hdr{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600}
.lin-node-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lin-node-del{background:none;border:none;color:var(--dim);font-size:14px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s;opacity:0}
.lin-node:hover .lin-node-del{opacity:1}
.lin-node-del:hover{color:var(--red)}
.lin-node-type{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.lin-node-desc{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lin-node-meta{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:4px}
.lin-node-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}
.lin-node:hover .lin-node-actions{opacity:1}
.lin-node-act-btn{background:none;border:none;color:var(--dim);font-size:12px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s}
.lin-node-act-btn:hover{color:var(--accent)}
/* ── Lineage tabs ── */
.lin-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding-bottom:0}
.lin-tab{background:none;border:none;color:var(--dim);font-family:var(--mono);font-size:12px;padding:8px 14px;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.lin-tab:hover{color:var(--fg)}
.lin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.lin-tab-panel{min-height:100px}
/* ── Timeline (provenance events) ── */
.lin-timeline{display:flex;flex-direction:column;gap:0;border-left:2px solid var(--border);margin-left:10px;padding-left:0}
.lin-ev-row{display:flex;gap:10px;padding:10px 0 10px 14px;position:relative;transition:background .15s}
.lin-ev-row:hover{background:rgba(0,200,240,.03)}
.lin-ev-row::before{content:'';position:absolute;left:-7px;top:16px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--border)}
.lin-ev-dot{font-size:14px;flex-shrink:0;margin-top:-1px;position:relative;z-index:1}
.lin-ev-content{flex:1;min-width:0}
.lin-ev-title{font-size:12px;font-weight:500;line-height:1.4}
.lin-ev-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--dim);margin-top:3px;align-items:center}
.lin-ev-meta span{display:inline-flex;align-items:center}
.lin-ev-type{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:rgba(0,200,240,.08);padding:1px 6px;border-radius:3px}
.lin-ev-details{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.lin-ev-chip{font-family:var(--mono);font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 7px;color:var(--muted)}
/* ── Pipeline runs ── */
.lin-snap-reason{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--violet);background:rgba(167,139,250,.08);padding:1px 6px;border-radius:3px}
/* ── Impact analysis ── */
.lin-impact-node{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px solid;border-radius:8px;margin-bottom:16px}
.lin-impact-section{margin-bottom:14px}
.lin-impact-hdr{font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase;font-family:var(--mono);letter-spacing:.05em}
.lin-impact-empty{font-size:12px;color:var(--dim);padding:6px 0}
.lin-impact-dep{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;margin-bottom:4px}
.lin-impact-related{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;margin-bottom:4px;font-size:12px}
.lin-impact-summary{margin-top:16px;padding:12px 16px;background:rgba(249,115,22,.04);border:1px solid rgba(249,115,22,.15);border-radius:8px}
/* ══ PERMISSION MATRIX (ABAC) ══ */
.perm-matrix{width:100%;border-collapse:collapse;font-size:12px}
.perm-matrix thead th{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);padding:8px 10px;border-bottom:2px solid var(--border2);white-space:nowrap}
.perm-matrix tbody tr{border-bottom:1px solid var(--border)}
.perm-matrix tbody tr:hover{background:var(--bg3)}
.perm-matrix td{padding:7px 10px}
.perm-resource{font-family:var(--mono);font-size:12px;color:var(--text);font-weight:600;white-space:nowrap}
.perm-cb{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.perm-cb:disabled{opacity:.4;cursor:not-allowed}
/* ══ SECURITY CALENDAR ══ */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border-radius:0 0 11px 11px;overflow:hidden}
.cal-hdr{background:var(--bg3);padding:8px;text-align:center;font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.cal-cell{background:var(--bg2);min-height:100px;padding:6px 8px;cursor:pointer;transition:background .15s;position:relative}
.cal-cell:hover{background:var(--bg3)}
.cal-cell.today{box-shadow:inset 0 0 0 1px rgba(0,200,240,.4)}
.cal-cell.other-month{opacity:.35}
.cal-day{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:4px}
.cal-cell.today .cal-day{color:var(--accent);font-weight:700}
.cal-evt{font-family:var(--mono);font-size:12px;padding:2px 5px;border-radius:3px;margin-bottom:2px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s;border:1px solid transparent}
.cal-evt:hover{opacity:.8}
.cal-evt.overdue{border-color:var(--red)}
.cal-evt.completed{opacity:.55}
.cal-nav{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border)}
.cal-month{font-family:var(--display);font-weight:700;font-size:15px}
.cal-more{font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;margin-top:2px}
.cal-more:hover{color:var(--accent)}
/* ══ GOVERNANCE CALENDAR EXTRAS ══ */
.gcal-add-menu{position:absolute;right:0;top:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:6px;min-width:200px;z-index:40;box-shadow:0 8px 24px rgba(0,0,0,.4);margin-top:4px}
.gcal-add-item{padding:8px 12px;border-radius:5px;cursor:pointer;font-size:12px;transition:background .15s;display:flex;align-items:center;gap:8px}
.gcal-add-item:hover{background:var(--bg3)}
.gcal-popover{position:absolute;bottom:100%;left:0;z-index:30;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:10px;min-width:220px;max-width:300px;box-shadow:0 8px 24px rgba(0,0,0,.5);max-height:240px;overflow-y:auto}
.gcal-popover-title{font-family:var(--display);font-weight:600;font-size:12px;margin-bottom:8px;color:var(--muted);padding-bottom:6px;border-bottom:1px solid var(--border)}
/* ══ SECURITY DASHBOARD ══ */
.secdash-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.secdash-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px}
.sec-activity-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.sec-activity-item:last-child{border-bottom:none}
.sec-activity-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0;background:var(--bg4)}
.sec-activity-text{font-size:12px;color:var(--text);line-height:1.4}
.sec-activity-time{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:2px}
/* ══ POSTURE MANAGEMENT DASHBOARD ══ */
.posture-hero{display:flex;align-items:center;justify-content:center;gap:40px;padding:28px 24px;background:var(--bg2);border:1px solid var(--border);border-radius:11px;margin-bottom:18px}
.posture-score-big{text-align:center;position:relative}
.posture-score-val{font-family:var(--display);font-weight:800;font-size:48px;line-height:1}
.posture-score-grade{font-family:var(--mono);font-size:14px;letter-spacing:.1em;margin-top:4px}
.posture-breakdown{display:flex;flex-direction:column;gap:10px}
.posture-breakdown-item{display:flex;align-items:center;gap:10px}
.posture-breakdown-label{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;width:110px}
.posture-breakdown-pct{font-family:var(--mono);font-size:12px;font-weight:700;width:36px;text-align:right}
.posture-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:18px}
@media(max-width:1100px){.posture-pillars{grid-template-columns:1fr}}
.posture-pillar{background:var(--bg2);border:1px solid var(--border);border-radius:11px;overflow:hidden}
.posture-pillar-hd{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.posture-pillar-ttl{font-family:var(--display);font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px}
.posture-pillar-body{padding:14px 16px}
.posture-kpi-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}
.posture-kpi-row:last-child{border-bottom:none}
.posture-kpi-label{font-family:var(--mono);font-size:12px;color:var(--muted)}
.posture-kpi-val{font-family:var(--display);font-weight:700;font-size:18px}
.posture-fw-strip{display:flex;gap:14px;overflow-x:auto;padding:16px}
.posture-fw-item{text-align:center;min-width:80px;cursor:pointer;transition:transform .15s}
.posture-fw-item:hover{transform:translateY(-2px)}
.posture-fw-name{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}
.posture-fw-score{font-family:var(--mono);font-size:12px;font-weight:700;margin-top:2px}
.posture-detail-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
@media(max-width:1100px){.posture-detail-row{grid-template-columns:1fr}}
.posture-trend-chart{position:relative;width:100%;height:220px}
.posture-attn-list{max-height:280px;overflow-y:auto}
.posture-attn-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;margin-bottom:4px;background:var(--bg3);border-radius:8px;cursor:pointer;transition:background .15s;border-left:3px solid var(--border)}
.posture-attn-item:hover{background:var(--bg4)}
.posture-attn-icon{font-size:14px;flex-shrink:0;margin-top:1px}
.posture-attn-text{flex:1;min-width:0}
.posture-attn-title{font-size:12px;font-weight:600;color:var(--text)}
.posture-attn-sub{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px}
.posture-risk-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
@media(max-width:1100px){.posture-risk-row{grid-template-columns:1fr}}
.posture-stat-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:18px}
@media(max-width:900px){.posture-stat-strip{grid-template-columns:repeat(3,1fr)}}
.posture-pillar-bar{height:4px;border-radius:0 0 11px 11px}
/* ─── Runtime Guardrails Gateway ─── */
.gr-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.gr-dot-on{background:var(--green);box-shadow:0 0 6px rgba(29,184,122,.5)}
.gr-dot-off{background:var(--dim)}
.gr-arch{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.gr-arch-node{text-align:center;padding:18px 24px;border-radius:12px;border:1px solid var(--border);background:var(--bg3);min-width:140px;transition:border-color .2s}
.gr-arch-node:hover{border-color:var(--border2)}
.gr-arch-gw{border-color:rgba(0,200,240,.4);background:linear-gradient(135deg,var(--bg3),rgba(0,200,240,.06));box-shadow:0 0 24px rgba(0,200,240,.08)}
.gr-arch-icon{font-size:24px;margin-bottom:6px}
.gr-arch-label{font-family:var(--display);font-weight:700;font-size:13px;color:var(--text)}
.gr-arch-sub{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:3px}
.gr-arch-arrow{font-size:20px;color:var(--accent);padding:0 12px;opacity:.6}
@media(max-width:700px){.gr-arch{flex-direction:column}.gr-arch-arrow{transform:rotate(90deg);padding:6px 0}}

/* ══ MISSING CLASS FIXES ══ */
.btn-sm{font-family:var(--mono);font-size:12px;padding:4px 10px;border-radius:5px;border:1px solid var(--border2);background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .15s}
.btn-sm:hover{border-color:var(--accent);color:var(--accent)}
.stat-v{font-family:var(--display);font-weight:700;font-size:26px;line-height:1;margin-bottom:3px}
.input{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:9px 12px;font-family:var(--sans);font-size:13px;color:var(--text);transition:border-color .2s}
.input:focus{outline:none;border-color:rgba(0,200,240,.4)}

/* ══ SECTION DASHBOARD SYSTEM ══ */
.section-hero{padding:22px 24px;border-radius:11px;margin-bottom:18px;display:flex;align-items:center;gap:16px}
.section-hero-icon{font-size:24px;opacity:.7}
.section-hero-ttl{font-family:var(--display);font-weight:800;font-size:18px}
.section-hero-sub{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:2px;letter-spacing:.06em}

/* Section-colored heroes */
.section-hero.sec-inventory{background:linear-gradient(135deg,rgba(0,200,240,.08),rgba(0,200,240,.02));border:1px solid rgba(0,200,240,.15)}
.section-hero.sec-risk{background:linear-gradient(135deg,rgba(240,64,96,.08),rgba(240,64,96,.02));border:1px solid rgba(240,64,96,.15)}
.section-hero.sec-security{background:linear-gradient(135deg,rgba(249,115,22,.08),rgba(249,115,22,.02));border:1px solid rgba(249,115,22,.15)}
.section-hero.sec-compliance{background:linear-gradient(135deg,rgba(29,184,122,.08),rgba(29,184,122,.02));border:1px solid rgba(29,184,122,.15)}
.section-hero.sec-vendors{background:linear-gradient(135deg,rgba(167,139,250,.08),rgba(167,139,250,.02));border:1px solid rgba(167,139,250,.15)}
.section-hero.sec-governance{background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(245,158,11,.02));border:1px solid rgba(245,158,11,.15)}
.section-hero.sec-persona{background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(99,102,241,.02));border:1px solid rgba(99,102,241,.15)}

/* Section summary cards for Command Center (compact 3-col) */
.section-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
@media(max-width:1200px){.section-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:800px){.section-grid{grid-template-columns:1fr}}
.section-card{background:var(--bg2);border:1px solid var(--border);border-radius:9px;overflow:hidden;transition:all .2s;cursor:pointer;position:relative}
.section-card:hover{border-color:var(--border2);transform:translateY(-1px)}
.section-card.sc-discovery:hover{box-shadow:0 6px 20px rgba(0,200,240,.1)}
.section-card.sc-governance:hover{box-shadow:0 6px 20px rgba(245,158,11,.1)}
.section-card.sc-testing:hover{box-shadow:0 6px 20px rgba(249,115,22,.1)}
.section-card.sc-detection:hover{box-shadow:0 6px 20px rgba(167,139,250,.1)}
.section-card.sc-response:hover{box-shadow:0 6px 20px rgba(240,64,96,.1)}
.section-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:9px 0 0 9px}
.section-card.sc-discovery::before{background:var(--sec-discovery)}
.section-card.sc-testing::before{background:var(--sec-testing)}
.section-card.sc-detection::before{background:var(--sec-detection)}
.section-card.sc-response::before{background:var(--sec-response)}
.section-card.sc-governance::before{background:var(--sec-governance)}
.sc-header{padding:10px 12px 6px 16px;display:flex;align-items:center;gap:8px}
.sc-icon{font-size:13px;opacity:.7}
.sc-title{font-family:var(--display);font-weight:700;font-size:12px;flex:1}
.sc-ring{display:none}
.sc-body{padding:0 12px 10px 16px}
.sc-action-hint{display:none}
.sc-metrics{display:flex;flex-wrap:wrap;gap:4px 14px}
.sc-metric{padding:2px 0}
.sc-metric-val{font-family:var(--display);font-weight:700;font-size:15px;line-height:1;display:inline}
.sc-metric-lbl{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:1px;letter-spacing:.04em}
.sc-footer{display:none}

/* KPI strip for command center */
.kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:13px;margin-bottom:18px}
@media(max-width:1200px){.kpi-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:700px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}
.kpi-tile{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}
.kpi-tile:hover{border-color:var(--border2);background:var(--bg3)}
.kpi-tile-val{font-family:var(--display);font-weight:800;font-size:24px;line-height:1}
.kpi-tile-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.08em;text-transform:uppercase}
.kpi-tile .stat-bar{position:absolute;bottom:0;left:0;right:0;height:2px}
.kpi-spark{position:absolute;bottom:6px;right:8px;opacity:.35;transition:opacity .2s}
.kpi-tile:hover .kpi-spark{opacity:.7}

/* Quick links row */
.quick-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.ql-btn{font-family:var(--mono);font-size:12px;padding:6px 14px;border-radius:6px;border:1px solid;cursor:pointer;transition:all .15s;letter-spacing:.04em;background:transparent}
.ql-btn:hover{filter:brightness(1.3)}
.ql-btn.ql-inventory{color:var(--sec-inventory);border-color:rgba(0,200,240,.25)}.ql-btn.ql-inventory:hover{background:rgba(0,200,240,.08)}
.ql-btn.ql-risk{color:var(--sec-risk);border-color:rgba(240,64,96,.25)}.ql-btn.ql-risk:hover{background:rgba(240,64,96,.08)}
.ql-btn.ql-security{color:var(--sec-security);border-color:rgba(249,115,22,.25)}.ql-btn.ql-security:hover{background:rgba(249,115,22,.08)}
.ql-btn.ql-compliance{color:var(--sec-compliance);border-color:rgba(29,184,122,.25)}.ql-btn.ql-compliance:hover{background:rgba(29,184,122,.08)}
.ql-btn.ql-vendors{color:var(--sec-vendors);border-color:rgba(167,139,250,.25)}.ql-btn.ql-vendors:hover{background:rgba(167,139,250,.08)}
.ql-btn.ql-governance{color:var(--sec-governance);border-color:rgba(245,158,11,.25)}.ql-btn.ql-governance:hover{background:rgba(245,158,11,.08)}
.ql-btn.ql-discovery{color:var(--sec-discovery);border-color:rgba(0,200,240,.25)}.ql-btn.ql-discovery:hover{background:rgba(0,200,240,.08)}
.ql-btn.ql-testing{color:var(--sec-testing);border-color:rgba(249,115,22,.25)}.ql-btn.ql-testing:hover{background:rgba(249,115,22,.08)}
.ql-btn.ql-detection{color:var(--sec-detection);border-color:rgba(167,139,250,.25)}.ql-btn.ql-detection:hover{background:rgba(167,139,250,.08)}
.ql-btn.ql-response{color:var(--sec-response);border-color:rgba(240,64,96,.25)}.ql-btn.ql-response:hover{background:rgba(240,64,96,.08)}

/* Back-to-dashboard link */
.back-dash{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;cursor:pointer;padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);margin-bottom:14px;transition:all .15s;letter-spacing:.04em}
.back-dash:hover{border-color:var(--border2);color:var(--text)}

/* Section stat bar color overrides */
.stat-c.sec-inventory .stat-bar{background:linear-gradient(90deg,var(--sec-inventory),transparent)}
.stat-c.sec-risk .stat-bar{background:linear-gradient(90deg,var(--sec-risk),transparent)}
.stat-c.sec-security .stat-bar{background:linear-gradient(90deg,var(--sec-security),transparent)}
.stat-c.sec-compliance .stat-bar{background:linear-gradient(90deg,var(--sec-compliance),transparent)}
.stat-c.sec-vendors .stat-bar{background:linear-gradient(90deg,var(--sec-vendors),transparent)}
.stat-c.sec-governance .stat-bar{background:linear-gradient(90deg,var(--sec-governance),transparent)}
.stat-c.sec-discovery .stat-bar{background:linear-gradient(90deg,var(--sec-discovery),transparent)}
.stat-c.sec-testing .stat-bar{background:linear-gradient(90deg,var(--sec-testing),transparent)}
.stat-c.sec-detection .stat-bar{background:linear-gradient(90deg,var(--sec-detection),transparent)}
.stat-c.sec-response .stat-bar{background:linear-gradient(90deg,var(--sec-response),transparent)}

/* Activity feed for dashboards */
.activity-feed{padding:4px 0}
.activity-item{display:flex;align-items:flex-start;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);transition:background .15s}
.activity-item:last-child{border-bottom:none}
.activity-item:hover{background:var(--bg3)}
.activity-dot{width:6px;height:6px;border-radius:50%;margin-top:5px;flex-shrink:0}
.activity-text{font-size:12px;flex:1;line-height:1.5}
.activity-time{font-family:var(--mono);font-size:12px;color:var(--dim);flex-shrink:0;white-space:nowrap}
/* ══ AGENT REGISTRY — TRUST TIER BADGES ══ */
.trust-badge{display:inline-block;padding:2px 10px;border-radius:5px;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.04em}
.trust-trusted{color:var(--green);background:rgba(29,184,122,.1);border:1px solid rgba(29,184,122,.25)}
.trust-conditional{color:var(--amber);background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.25)}
.trust-restricted{color:var(--orange);background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.3)}
.trust-untrusted{color:var(--red);background:rgba(240,64,96,.12);border:1px solid rgba(240,64,96,.3)}
/* ══ GAUGE CHART ══ */
.gauge-wrap{display:flex;flex-direction:column;align-items:center;padding:20px}
.gauge-val{font-family:var(--display);font-weight:800;font-size:28px;margin-top:-8px}
.gauge-label{font-family:var(--mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.gauge-target{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:6px}
/* ══ RADAR CHART ══ */
.radar-chart{display:flex;justify-content:center;padding:12px}
.radar-chart svg{width:100%;max-width:260px;height:auto}
/* ══ DETECTION DASHBOARD ══ */
.det-enf-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);font-size:12px}
.det-enf-row:last-child{border-bottom:none}
.det-enf-row:hover{background:var(--bg3)}
.det-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.det-svc-bar{flex:1;height:6px;background:var(--bg5);border-radius:3px;overflow:hidden}
.det-svc-fill{height:100%;background:var(--sec-detection);border-radius:3px;transition:width .4s ease}
/* ══ RESPONSE DASHBOARD ══ */
.resp-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px}
.resp-strip-item{text-align:center;padding:12px 8px;background:var(--bg3);border-radius:8px}
.resp-strip-val{font-family:var(--display);font-weight:700;font-size:20px}
.resp-strip-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}
.resp-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.resp-row:hover{background:var(--bg3)}
.resp-row:last-child{border-bottom:none}
.resp-sev{width:3px;min-height:32px;border-radius:2px;flex-shrink:0}
/* ══ FRAMEWORK READINESS STRIP ══ */
.fw-strip{display:flex;gap:20px;padding:16px 20px;overflow-x:auto}
.fw-strip::-webkit-scrollbar{height:4px}
.fw-strip::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:2px}
.fw-strip-item{text-align:center;flex-shrink:0}
.fw-strip-name{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:6px;text-transform:uppercase;letter-spacing:.06em;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* ══ COMPLIANCE ACCELERATOR ══ */
.ca-fw-strip{display:flex;gap:12px;overflow-x:auto;padding:14px 18px}
.ca-fw-strip::-webkit-scrollbar{height:4px}
.ca-fw-strip::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:2px}
.ca-fw-card{min-width:130px;padding:14px 12px;border-radius:10px;background:var(--bg3);border:1px solid var(--border);cursor:pointer;text-align:center;transition:all .2s;flex-shrink:0}
.ca-fw-card:hover{border-color:var(--border2);background:var(--bg4)}
.ca-fw-card.active{border-color:rgba(0,200,240,.4);box-shadow:0 0 16px rgba(0,200,240,.1)}
.ca-fw-card.activated{border-color:rgba(29,184,122,.25)}
.ca-fw-badge{font-size:12px;font-family:var(--mono);padding:2px 8px;border-radius:4px;letter-spacing:.08em;text-transform:uppercase;display:inline-block;margin-top:2px}
.ca-fw-badge.active{background:rgba(29,184,122,.12);color:var(--green)}
.ca-fw-badge.inactive{background:rgba(100,120,140,.12);color:var(--dim)}
.ca-matrix{display:flex;flex-wrap:wrap;gap:4px}
.ca-cell{width:44px;height:44px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;cursor:pointer;transition:all .15s;text-overflow:ellipsis;overflow:hidden}
.ca-cell.green{background:rgba(29,184,122,.12);color:var(--green);border:1px solid rgba(29,184,122,.25)}
.ca-cell.amber{background:rgba(245,158,11,.12);color:var(--amber);border:1px solid rgba(245,158,11,.25)}
.ca-cell.red{background:rgba(240,64,96,.12);color:var(--red);border:1px solid rgba(240,64,96,.25)}
.ca-cell:hover{transform:scale(1.08);z-index:1}
.ca-gap-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ══ SYSTEM MODAL — WIDE TABBED LAYOUT ══ */
#modal-system .modal{width:960px;max-height:92vh;display:flex;flex-direction:column}
#modal-system .modal-body{padding:0;flex:1;display:flex;flex-direction:column;overflow:hidden}
.sys-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg3);flex-shrink:0}
.sys-tab{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:12px 20px;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.sys-tab:hover{color:var(--text);background:rgba(255,255,255,.02)}
.sys-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.sys-tab-panels{flex:1;overflow-y:auto;padding:22px 26px}
.sys-tab-panel{display:none}
.sys-tab-panel.active{display:block}
.sys-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sys-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.sys-4col{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}
@media(max-width:700px){
  #modal-system .modal{width:95vw}
  .sys-tabs{overflow-x:auto}
  .sys-2col,.sys-3col,.sys-4col{grid-template-columns:1fr}
}

/* ══ POLICY INGESTION ══ */
.ingest-dropzone{border:2px dashed var(--border2);border-radius:12px;padding:40px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg3)}
.ingest-dropzone:hover,.ingest-dropzone.drag-over{border-color:rgba(0,200,240,.5);background:rgba(0,200,240,.04)}
.ingest-dropzone-icon{font-size:32px;opacity:.5;margin-bottom:8px}
.ingest-dropzone-text{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.04em}
.ingest-dropzone-sub{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:4px}
.ingest-file-selected{display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(0,200,240,.06);border:1px solid rgba(0,200,240,.2);border-radius:8px;margin-bottom:14px}
.ingest-file-icon{font-size:20px;flex-shrink:0}
.ingest-file-info{flex:1;min-width:0}
.ingest-file-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ingest-file-size{font-family:var(--mono);font-size:12px;color:var(--muted)}
.ingest-file-remove{font-size:14px;color:var(--dim);cursor:pointer;padding:4px;transition:color .15s}
.ingest-file-remove:hover{color:var(--red)}
.ingest-progress-list{display:flex;flex-direction:column;gap:8px}
.ingest-progress-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:8px}
.ingest-progress-fw{flex:1;font-size:12px;font-weight:600}
.ingest-progress-status{font-family:var(--mono);font-size:12px;letter-spacing:.04em}
.ingest-progress-status.analyzing{color:var(--amber)}
.ingest-progress-status.done{color:var(--green)}
.ingest-progress-status.error{color:var(--red)}
.ingest-progress-bar{width:100%;height:4px;background:var(--bg5);border-radius:2px;overflow:hidden;margin-top:6px}
.ingest-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}
.ingest-review-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:14px}
.ingest-review-tab{font-family:var(--mono);font-size:12px;padding:10px 18px;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;transition:all .15s;letter-spacing:.04em}
.ingest-review-tab:hover{color:var(--text)}
.ingest-review-tab.active{border-bottom-color:var(--accent);color:var(--accent)}
.ingest-review-tab .tab-count{font-size:12px;margin-left:4px;padding:1px 6px;border-radius:4px;font-weight:600}
.ingest-review-tab .tab-count.cnt-green{background:rgba(29,184,122,.12);color:var(--green)}
.ingest-review-tab .tab-count.cnt-amber{background:rgba(245,158,11,.12);color:var(--amber)}
.ingest-review-tab .tab-count.cnt-red{background:rgba(240,64,96,.12);color:var(--red)}
.ingest-result-row{padding:10px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;transition:border-color .15s}
.ingest-result-row:hover{border-color:var(--border2)}
.ingest-result-hdr{display:flex;align-items:center;gap:8px}
.ingest-result-ref{font-family:var(--mono);font-size:12px;color:var(--accent);flex-shrink:0;font-weight:600}
.ingest-result-name{font-size:12px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ingest-result-override{font-family:var(--mono);font-size:12px;padding:3px 8px;border-radius:5px;border:1px solid var(--border2);background:var(--bg2);color:var(--muted);cursor:pointer;flex-shrink:0}
.ingest-result-reasoning{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5}
.ingest-result-excerpt{font-size:12px;color:var(--dim);margin-top:4px;padding:6px 10px;background:var(--bg2);border-left:2px solid var(--accent);border-radius:0 4px 4px 0;font-style:italic;line-height:1.5}
.ingest-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.ingest-summary-card{text-align:center;padding:16px;border-radius:10px;border:1px solid var(--border);background:var(--bg3)}
.ingest-summary-val{font-family:var(--display);font-weight:700;font-size:28px;line-height:1}
.ingest-summary-lbl{font-family:var(--mono);font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.06em;text-transform:uppercase}

/* ── Risk Intelligence Grid ── */
.risk-intel-grid{display:grid;grid-template-columns:3fr 2fr;gap:18px;margin-bottom:18px}
@media(max-width:1100px){.risk-intel-grid{grid-template-columns:1fr}}

/* Sankey stat pills */
.sankey-stat-pills{display:flex;gap:10px;padding:0 18px 6px;flex-wrap:wrap}
.sankey-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;background:var(--bg3);border:1px solid var(--border)}
.sankey-pill-n{font-family:var(--display);font-weight:700;font-size:18px;color:var(--text);line-height:1}
.sankey-pill-l{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}

/* Sankey SVG animations */
.sankey-svg path{animation:sankeyFadeIn .6s ease-out both}
.sankey-svg rect{animation:sankeyNodeIn .4s ease-out both}
@keyframes sankeyFadeIn{from{opacity:0}to{opacity:1}}
@keyframes sankeyNodeIn{from{opacity:0;transform:scaleY(0.3)}to{opacity:0.92;transform:scaleY(1)}}

/* ══ TESTING DASHBOARD — Findings Feed ══ */
.finding-feed{max-height:380px;overflow-y:auto;padding:0}
.finding-feed-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.finding-feed-item:hover{background:var(--bg3)}
.finding-feed-hdr{display:flex;align-items:center;gap:8px;padding:10px 14px}
.finding-feed-title{flex:1;font-size:12px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.finding-feed-date{font-family:var(--mono);font-size:12px;color:var(--dim);flex-shrink:0}
.finding-feed-evidence{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;padding:0 14px;background:var(--bg3)}
.finding-feed-item.expanded .finding-feed-evidence{max-height:400px;padding:10px 14px 14px}
.finding-ev-row{display:flex;gap:8px;margin-bottom:4px;font-family:var(--mono);font-size:12px}
.finding-ev-lbl{color:var(--muted);text-transform:capitalize;flex-shrink:0;min-width:80px}
.finding-ev-val{color:var(--text);word-break:break-all}
.finding-ev-detail{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5;white-space:pre-wrap}
.sev-tag{font-family:var(--mono);font-size:12px;letter-spacing:.08em;padding:2px 6px;border-radius:3px;font-weight:600;flex-shrink:0}
.source-badge{font-family:var(--mono);font-size:12px;letter-spacing:.06em;padding:2px 6px;border-radius:3px;flex-shrink:0}

/* ══ TESTING DASHBOARD — Mini Calendar ══ */
.mini-cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.mini-cal-month{font-family:var(--display);font-weight:600;font-size:13px;color:var(--text)}
.mini-cal-arrow{cursor:pointer;font-size:18px;color:var(--muted);padding:0 6px;user-select:none;transition:color .15s}
.mini-cal-arrow:hover{color:var(--accent)}
.mini-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.mini-cal-dh{text-align:center;font-family:var(--mono);font-size:12px;color:var(--dim);padding:4px 0}
.mini-cal-cell{text-align:center;padding:4px 2px;border-radius:4px;min-height:32px;position:relative}
.mini-cal-cell.empty{visibility:hidden}
.mini-cal-cell.today{background:var(--a-glow);border:1px solid rgba(0,200,240,.25)}
.mini-cal-day{font-size:12px;color:var(--muted)}
.mini-cal-cell.today .mini-cal-day{color:var(--accent);font-weight:600}
.mini-cal-dots{display:flex;gap:2px;justify-content:center;margin-top:2px}
.mini-cal-dot{width:4px;height:4px;border-radius:50%}

/* ══ POLICY INGESTION — Visualization ══ */
.ingest-viz-grid{display:flex;gap:20px;margin-bottom:16px;align-items:flex-start}
.ingest-viz-donut{flex-shrink:0}
.ingest-viz-bars{flex:1;min-width:0}
.ingest-fw-bar{margin-bottom:8px}
.ingest-fw-bar-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}
.ingest-fw-bar-name{font-size:12px;color:var(--text)}
.ingest-fw-bar-pct{font-family:var(--mono);font-size:12px;font-weight:600}
.ingest-fw-bar-track{height:8px;background:var(--bg4);border-radius:4px;overflow:hidden;display:flex}
.ingest-fw-bar-seg{height:100%;transition:width .4s ease}
.ingest-suggestion-box{background:rgba(0,200,240,.04);border:1px solid rgba(0,200,240,.15);border-radius:6px;padding:10px 12px;margin-top:8px}
.ingest-suggestion-box textarea{width:100%;background:transparent;border:none;color:var(--text);font-family:var(--sans);font-size:12px;resize:vertical;min-height:60px;outline:none}
.ingest-suggestion-hdr{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px}
.ingest-export-bar{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border);margin-top:14px}
.ingest-export-bar label{font-family:var(--mono);font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;cursor:pointer}
.ingest-export-bar .btn{margin-left:auto}

/* ── Ingestion Viz Toggle ── */
.ingest-viz-toggle{display:flex;gap:0;margin-bottom:14px;border:1px solid var(--border2);border-radius:8px;overflow:hidden}
.ingest-viz-toggle-btn{font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:7px 16px;cursor:pointer;color:var(--muted);transition:all .15s;flex:1;text-align:center;border-right:1px solid var(--border2)}
.ingest-viz-toggle-btn:last-child{border-right:none}
.ingest-viz-toggle-btn:hover{background:var(--bg4);color:var(--text)}
.ingest-viz-toggle-btn.active{background:var(--a-glow);color:var(--accent);font-weight:600}
/* ── Ingestion Framework Filter Pill ── */
.ingest-fw-filter-pill{font-family:var(--mono);font-size:11px;color:var(--accent);background:var(--a-glow);border:1px solid rgba(0,200,240,.2);border-radius:6px;padding:5px 12px;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px}
/* ── Ingestion Heatmap ── */
.ingest-heatmap-wrap{margin-bottom:16px;overflow-x:auto}
.ingest-hm-table{width:100%;border-collapse:separate;border-spacing:3px}
.ingest-hm-table thead th{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:6px 8px;text-align:center}
.ingest-hm-table thead th:first-child{text-align:left}
.ingest-hm-fw{font-size:12px;color:var(--text);font-weight:500;padding:4px 8px;white-space:nowrap}
.ingest-hm-cell{display:flex;align-items:center;justify-content:center;min-width:44px;height:36px;border-radius:6px;font-family:var(--mono);font-size:13px;font-weight:700;color:var(--text);cursor:pointer;transition:filter .15s,transform .15s}
.ingest-hm-cell:hover{filter:brightness(1.3);transform:scale(1.06)}
.ingest-hm-pct{font-family:var(--mono);font-size:12px;font-weight:600;text-align:center;padding:4px 8px}
/* ── Ingestion Radar ── */
.ingest-radar-wrap{margin-bottom:16px;display:flex;justify-content:center;padding:8px}
.ingest-radar-wrap svg{max-width:320px;width:100%;height:auto}
/* ── Ingestion Gap Bars ── */
.ingest-gap-bars{padding:0 2px}
.ingest-gap-bar-row{display:flex;align-items:center;gap:10px;padding:4px 6px;transition:background .15s;border-radius:4px;cursor:pointer}
.ingest-gap-bar-row:hover{background:var(--bg4)}
.ingest-gap-bar-label{font-size:11px;color:var(--text);width:120px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ingest-gap-bar-track{flex:1;height:8px;background:var(--bg5);border-radius:4px;overflow:hidden}
.ingest-gap-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}
.ingest-gap-bar-val{font-family:var(--mono);font-size:11px;color:var(--muted);width:24px;text-align:right;flex-shrink:0}

/* ══ SEARCH / FILTER BAR ══ */
.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px;padding:12px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:10px}
.filter-bar .filter-search{flex:1;min-width:180px;background:var(--bg3);border:1px solid var(--border2);border-radius:6px;padding:8px 12px 8px 32px;font-family:var(--sans);font-size:13px;color:var(--text);transition:border-color .2s}
.filter-bar .filter-search:focus{outline:none;border-color:rgba(0,200,240,.4)}
.filter-bar .filter-search-wrap{position:relative;flex:1;min-width:180px}
.filter-bar .filter-search-wrap::before{content:'\26B2';position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--dim);font-size:13px;pointer-events:none}
.filter-bar .filter-sel{background:var(--bg3);border:1px solid var(--border2);border-radius:6px;padding:7px 10px;font-family:var(--mono);font-size:12px;color:var(--muted);cursor:pointer;min-width:110px;transition:border-color .2s}
.filter-bar .filter-sel:focus{outline:none;border-color:rgba(0,200,240,.4)}
.filter-bar .filter-clear{font-family:var(--mono);font-size:12px;color:var(--dim);cursor:pointer;padding:4px 8px;border-radius:4px;border:1px solid transparent;transition:all .15s}
.filter-bar .filter-clear:hover{color:var(--red);border-color:rgba(240,64,96,.3)}

/* ══ PAGINATION ══ */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:18px;padding:12px 0}
.pagination .pg-btn{font-family:var(--mono);font-size:12px;padding:5px 10px;border-radius:5px;border:1px solid var(--border2);background:var(--bg3);color:var(--muted);cursor:pointer;transition:all .15s}
.pagination .pg-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.pagination .pg-btn:disabled{opacity:.35;cursor:not-allowed}
.pagination .pg-btn.active{background:var(--a-glow);border-color:rgba(0,200,240,.35);color:var(--accent)}
.pagination .pg-info{font-family:var(--mono);font-size:12px;color:var(--dim);padding:0 6px}

/* ══ RESPONSIVE SIDEBAR ══ */
.sidebar-toggle{display:none;background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .15s;line-height:1}
.sidebar-toggle:hover{color:var(--accent)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99;opacity:0;transition:opacity .25s}
.sidebar-overlay.visible{display:block;opacity:1}
@media(max-width:900px){
  .sidebar-toggle{display:flex;align-items:center}
  .sidebar{transform:translateX(-100%);transition:transform .25s ease}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0!important;width:100vw!important}
}

/* ══ PHASE 4 POLISH ══ */

/* ── 15. CSS Transitions & Animations ── */
@keyframes slideInRight{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes borderPulse{0%,100%{border-color:rgba(0,200,240,.2)}50%{border-color:rgba(0,200,240,.5)}}
.anim-slide-in{animation:slideInRight .35s ease both}
.anim-scale-in{animation:scaleIn .3s ease both}
.anim-count-up{animation:countUp .4s ease both}
.card{transition:border-color .2s,box-shadow .25s}
.card:hover{border-color:var(--border2)}
.stat-c{transition:transform .2s,border-color .2s,box-shadow .2s}
.stat-c:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.stat-c.sec-risk:hover{box-shadow:0 6px 20px rgba(240,64,96,.12)}
.stat-c.sec-compliance:hover{box-shadow:0 6px 20px rgba(29,184,122,.12)}
.stat-c.sec-inventory:hover,.stat-c.sec-discovery:hover{box-shadow:0 6px 20px rgba(0,200,240,.12)}
.stat-c.sec-security:hover,.stat-c.sec-testing:hover{box-shadow:0 6px 20px rgba(249,115,22,.12)}
.stat-c.sec-governance:hover{box-shadow:0 6px 20px rgba(245,158,11,.12)}
.stat-c.sec-detection:hover,.stat-c.sec-vendors:hover{box-shadow:0 6px 20px rgba(167,139,250,.12)}
.kpi-card{transition:transform .2s,border-color .2s,box-shadow .2s}
.kpi-card:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.ctrl-row{transition:border-color .2s,box-shadow .2s}
.ctrl-row:hover{box-shadow:0 4px 16px rgba(0,0,0,.2)}
.tbl tr td{transition:background .15s}
.tag{transition:all .15s}
.pill{transition:all .15s}
.sev{transition:background .15s}
.btn{transition:all .15s,transform .1s}
.btn:active:not(:disabled){transform:scale(.97)}
.toast{animation:slideInRight .3s ease both}

/* ── 16. Skeleton Loading States ── */
.skel{background:var(--bg3);border-radius:6px;position:relative;overflow:hidden}
.skel::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite}
.skel-text{height:12px;margin-bottom:8px}
.skel-text:last-child{width:60%}
.skel-heading{height:18px;width:45%;margin-bottom:12px}
.skel-circle{border-radius:50%}
.skel-stat{height:32px;width:60px;margin-bottom:6px}
.skel-bar{height:6px;border-radius:3px}
.skel-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:18px;overflow:hidden}
.skel-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}
.skel-avatar{width:32px;height:32px;border-radius:7px;flex-shrink:0}

/* ── 17. Empty-State SVG Illustrations ── */
.empty-illust{width:80px;height:80px;margin:0 auto 16px;opacity:.45}
.empty-illust svg{width:100%;height:100%}
.empty{animation:fadeUp .4s ease both}
.empty .btn{margin-top:14px}

/* ── 18. Themed Confirmation Modals ── */
.confirm-ov{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);z-index:550;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.confirm-ov.open{opacity:1;pointer-events:all}
.confirm-box{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:420px;max-width:95vw;padding:28px;transform:translateY(20px) scale(.96);transition:transform .28s cubic-bezier(.34,1.4,.64,1);box-shadow:0 40px 100px rgba(0,0,0,.6);text-align:center}
.confirm-ov.open .confirm-box{transform:translateY(0) scale(1)}
.confirm-icon{width:56px;height:56px;border-radius:14px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:24px}
.confirm-icon.ci-danger{background:rgba(240,64,96,.12);border:1px solid rgba(240,64,96,.25);color:var(--red)}
.confirm-icon.ci-warn{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.25);color:var(--amber)}
.confirm-icon.ci-info{background:rgba(0,200,240,.1);border:1px solid rgba(0,200,240,.25);color:var(--accent)}
.confirm-icon.ci-success{background:rgba(29,184,122,.12);border:1px solid rgba(29,184,122,.25);color:var(--green)}
.confirm-ttl{font-family:var(--display);font-weight:700;font-size:16px;margin-bottom:8px}
.confirm-msg{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:22px;max-width:340px;margin-left:auto;margin-right:auto}
.confirm-actions{display:flex;gap:8px;justify-content:center}
.confirm-actions .btn{min-width:100px;padding:9px 18px}

/* ── 19. Chart Accessibility ── */
.chart-wrap{position:relative}
.chart-wrap[role="img"]{outline:none}
.chart-wrap:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:8px}
.chart-tooltip{position:absolute;z-index:200;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;padding:8px 12px;font-family:var(--mono);font-size:11px;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,.4);pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;white-space:nowrap;max-width:240px}
.chart-tooltip.visible{opacity:1;transform:translateY(0)}
.chart-tooltip-label{color:var(--muted);margin-bottom:2px}
.chart-tooltip-value{font-weight:700;font-size:12px}
.chart-sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.chart-pattern-stripe{background-image:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,.08) 3px,rgba(255,255,255,.08) 6px)}
.chart-pattern-dot{background-image:radial-gradient(circle 1.5px,rgba(255,255,255,.12) 100%,transparent 100%);background-size:6px 6px}
.chart-pattern-cross{background-image:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,255,255,.07) 3px,rgba(255,255,255,.07) 4px),repeating-linear-gradient(90deg,transparent,transparent 3px,rgba(255,255,255,.07) 3px,rgba(255,255,255,.07) 4px);background-size:8px 8px}

/* CI/CD Gates */
.cicd-setup-section{border:1px solid var(--border);border-radius:8px;margin-bottom:12px;overflow:hidden}
.cicd-setup-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:var(--bg);transition:background .15s}
.cicd-setup-hdr:hover{background:var(--bg2)}
.cicd-setup-body{padding:14px 16px;border-top:1px solid var(--border)}
.cicd-code-block{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:14px 16px;font-family:var(--mono);font-size:10.5px;line-height:1.6;color:var(--text);overflow-x:auto;white-space:pre;margin:0;max-height:400px;overflow-y:auto}

/* Command Palette */
.cmd-palette-ov{position:fixed;inset:0;z-index:550;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,160px);animation:fadeIn .12s ease}
.cmd-palette{width:560px;max-width:95vw;max-height:480px;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;box-shadow:0 40px 100px rgba(0,0,0,.7);display:flex;flex-direction:column;overflow:hidden}
.cmd-input{width:100%;padding:16px 18px;background:transparent;border:none;border-bottom:1px solid var(--border);font-size:15px;font-family:var(--sans);color:var(--text);outline:none}
.cmd-input::placeholder{color:var(--dim)}
.cmd-results{overflow-y:auto;flex:1;padding:6px}
.cmd-item{padding:10px 14px;border-radius:7px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:background .08s}
.cmd-item:hover,.cmd-item.active{background:var(--bg4, rgba(255,255,255,.06))}
.cmd-item-icon{width:22px;text-align:center;font-size:14px;opacity:.7;flex-shrink:0}
.cmd-item-label{font-size:13px;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cmd-item-group{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:.04em;flex-shrink:0}
.cmd-item-type{font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:3px;flex-shrink:0}
.cmd-item-type.recent{color:var(--accent);background:rgba(0,200,240,.08);border:1px solid rgba(0,200,240,.15)}
.cmd-item-type.action{color:var(--green);background:rgba(29,184,122,.08);border:1px solid rgba(29,184,122,.15)}
.cmd-footer{border-top:1px solid var(--border);padding:10px 14px;font-family:var(--mono);font-size:10px;color:var(--dim);display:flex;gap:12px}
.cmd-kbd{display:inline-block;background:var(--bg);border:1px solid var(--border2);border-radius:3px;padding:1px 5px;font-family:var(--mono);font-size:9px;line-height:1.4;margin:0 2px}

/* Keyboard Shortcuts Overlay */
.shortcuts-ov{position:fixed;inset:0;z-index:560;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fadeIn .12s ease}
.shortcuts-panel{width:420px;max-width:95vw;max-height:80vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:24px;box-shadow:0 40px 100px rgba(0,0,0,.7)}
.sc-title{font-size:15px;font-weight:700;margin-bottom:18px;color:var(--text)}
.sc-group{margin-bottom:16px}
.sc-group-ttl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.sc-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.sc-keys{display:flex;gap:4px}
.sc-desc{font-size:12px;color:var(--text)}
