/* ── Dashboard Block 1 ── */
@keyframes kpi-count-in { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
        .kpi-am-card {
            padding:18px 18px; position:relative; overflow:hidden; min-height:122px;
            display:flex; flex-direction:column; justify-content:center;
            background:linear-gradient(135deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--glass-bg) 70%, transparent));
            border:1px solid color-mix(in srgb, var(--border) 78%, var(--kpi-color, var(--accent)) 22%);
            backdrop-filter: blur(6px);
            border-radius:16px; transition:all .22s cubic-bezier(0.4,0,0.2,1);
        }
        .kpi-am-card::before {
            content:''; position:absolute; top:0; left:0; right:0; height:2px;
            background:var(--kpi-color, var(--accent));
            box-shadow:0 0 16px var(--kpi-color, var(--accent)); opacity:0.8;
        }
        .kpi-am-card:hover {
            transform:translateY(-3px);
            border-color:var(--kpi-color, var(--accent));
            box-shadow:0 10px 28px rgba(0,0,0,0.22);
        }
        .kpi-number {
            font-size:2.15em; font-weight:900; letter-spacing:-1.4px;
            color:var(--kpi-color, var(--accent));
            animation:kpi-count-in .5s ease both;
            line-height:1;
        }

/* ── Dashboard Block 2 ── */
@media (min-width: 1600px) {
            #execMainGrid { grid-template-columns: minmax(0,1fr) minmax(0,clamp(360px,24vw,500px)) !important; gap: clamp(28px,2.5vw,48px) !important; }
        }
        @media (min-width: 2200px) {
            #execMainGrid { grid-template-columns: minmax(0,1fr) minmax(0,1fr) minmax(0,clamp(340px,18vw,480px)) !important; }
        }

/* ── Dashboard Block 3 ── */
#rgExecGrid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,clamp(290px,28vw,460px));gap:clamp(16px,2vw,28px);align-items:flex-start}
            @media(min-width:1440px){#rgExecGrid{grid-template-columns:minmax(0,1fr) minmax(0,clamp(340px,26vw,500px))}}
            @media(min-width:2000px){#rgExecGrid{grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,clamp(300px,18vw,440px))}#rgExecLeft{display:contents}}
            @media(max-width:900px){#rgExecGrid{grid-template-columns:1fr}}
            .rg-kpi{position:relative;overflow:hidden;border-radius:16px;padding:clamp(14px,1.5vw,20px) clamp(16px,1.8vw,24px);background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;transition:transform .2s,border-color .2s,box-shadow .2s;min-height:clamp(90px,9vh,120px)}
            .rg-kpi:hover{transform:translateY(-4px);border-color:var(--accent-border);box-shadow:0 12px 40px rgba(0,0,0,.22)}
            .rg-kpi-num{font-size:clamp(1.6em,3.2vw,2.8em);font-weight:900;letter-spacing:-2px;line-height:1;margin:4px 0 3px;font-variant-numeric:tabular-nums}
            .rg-kpi-label{font-size:clamp(.5em,.65vw,.68em);text-transform:uppercase;letter-spacing:2px;color:var(--dim);font-weight:800}
            .rg-kpi-sub{font-size:.63em;color:var(--dim);margin-top:3px}
            .rg-kpi-icon{position:absolute;right:clamp(14px,2vw,22px);top:clamp(14px,2vh,22px);opacity:.08;pointer-events:none}
            .rg-kpi-bar{position:absolute;left:0;top:0;width:3px;height:100%;border-radius:20px 0 0 20px}
            .rg-kpi-glow{position:absolute;inset:0;pointer-events:none;border-radius:20px;background:radial-gradient(ellipse at 0% 50%,var(--kpi-glow,transparent) 0%,transparent 70%);opacity:0;transition:opacity .3s}
            .rg-kpi:hover .rg-kpi-glow{opacity:1}
            .rg-ph{padding:clamp(18px,2vw,22px) clamp(20px,2vw,24px);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:nowrap;gap:16px;min-width:0;flex-direction:row}
            @media(max-width:768px){ .rg-ph{flex-direction:column;align-items:flex-start;gap:12px;} }
            .rg-ph-title{font-size:.68em;font-weight:900;text-transform:uppercase;letter-spacing:2px;color:var(--text);line-height:1.4}
            .rg-ph-sub{font-size:.70em;color:var(--dim);margin-top:6px;line-height:1.5}
            .sev-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
            .sev-lollipop{flex:1;height:5px;border-radius:5px;background:var(--border);overflow:hidden}
            .sev-lollipop-fill{height:100%;border-radius:5px;width:0;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
            .rg-finding{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);transition:background .15s;border-radius:6px}
            .rg-finding:last-child{border-bottom:none}
            .rg-finding:hover{background:var(--glass-bg)}
            .rg-sev-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
            .rg-infra-cell{padding:12px 15px;border:1px solid var(--border);border-radius:14px;background:var(--surface);cursor:pointer;transition:all .18s}
            .rg-infra-cell:hover{background:var(--accent-muted);border-color:var(--accent-border);transform:translateY(-2px)}
            .drag-handle{cursor:grab;color:var(--dim);opacity:.35;font-size:1.2em;padding:4px 8px;user-select:none;line-height:1;transition:opacity .2s}
            .drag-handle:hover{opacity:.7}
            .drag-handle:active{cursor:grabbing}
            .dash-panel{transition:box-shadow .2s}
            .dash-panel.sortable-ghost{opacity:.3;border:2px dashed var(--accent)!important}
            .dash-panel.sortable-chosen{box-shadow:0 10px 40px rgba(255,255,255,.06)!important}
            @keyframes scanLine{0%{top:0;opacity:.4}100%{top:100%;opacity:0}}
            .gauge-scan-line{position:absolute;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:scanLine 3s linear infinite;pointer-events:none}
            .sev-legend-row{display:flex;align-items:center;gap:8px;padding:4px 0}

/* ── Dashboard Block 4 ── */
#rgTechGrid{display:flex;flex-direction:column;gap:clamp(16px,2vh,26px)}
            .rg-ring-gallery{display:flex;flex-wrap:wrap;gap:10px;padding:16px}
            .rg-mod-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border-radius:14px;border:1px solid var(--border);background:var(--glass-bg);transition:all .18s;cursor:default;min-width:clamp(72px,7vw,96px)}
            .rg-mod-ring-wrap:hover{background:var(--accent-muted);border-color:var(--accent-border);transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
            .rg-attack-canvas-wrap{width:100%;min-height:clamp(300px,38vh,480px);position:relative;border-radius:16px;overflow:hidden;background:var(--surface);border:1px solid var(--border)}
            #attackPathCanvas{width:100%;height:100%;display:block}
            .sev-legend-row{display:flex;align-items:center;gap:8px;padding:4px 0}

/* ── Dashboard Block 5 ── */
/* ── Inventory page design system ─────────────────────── */
    .inv-kpi-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 14px;
        margin-bottom: 28px;
    }
    .inv-kpi-card {
        background: var(--card);
        border: 1px solid var(--border);
        border-radius: 14px;
        padding: 18px 20px;
        display: flex;
        align-items: center;
        gap: 14px;
        position: relative;
        overflow: hidden;
        transition: border-color .2s;
    }
    .inv-kpi-card::before {
        content: '';
        position: absolute;
        top: 0; left: 0; right: 0;
        height: 2px;
        background: var(--kpi-accent, var(--accent));
        border-radius: 14px 14px 0 0;
    }
    .inv-kpi-card:hover { border-color: var(--accent-border); }
    .inv-kpi-icon {
        width: 38px; height: 38px;
        border-radius: 10px;
        background: var(--kpi-bg, var(--accent-muted));
        border: 1px solid var(--kpi-bd, var(--accent-border));
        display: flex; align-items: center; justify-content: center;
        color: var(--kpi-accent, var(--accent));
        flex-shrink: 0;
    }
    .inv-kpi-val {
        font-size: 1.8em;
        font-weight: 900;
        color: var(--kpi-accent, var(--text));
        letter-spacing: -1.5px;
        line-height: 1;
    }
    .inv-kpi-lbl {
        font-size: 0.58em;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 1.2px;
        color: var(--dim);
        margin-top: 3px;
    }

    /* ── Filter/Sort strip ── */
    .inv-filter-strip {
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
        margin-bottom: 20px;
        padding: 12px 16px;
        background: var(--card);
        border: 1px solid var(--border);
        border-radius: 14px;
    }
    .inv-filter-pill {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        padding: 5px 12px;
        border-radius: 100px;
        font-size: 0.65em;
        font-weight: 700;
        letter-spacing: 0.5px;
        background: rgba(255,255,255,0.04);
        border: 1px solid var(--border);
        color: var(--dim);
        text-decoration: none;
        transition: all .15s;
        white-space: nowrap;
    }
    .inv-filter-pill:hover {
        background: var(--accent-muted);
        border-color: var(--accent-border);
        color: var(--accent);
    }
    .inv-filter-pill.active {
        background: rgba(37,99,235,0.15);
        border-color: rgba(37,99,235,0.5);
        color: var(--accent);
    }
    .inv-search-wrap {
        display: flex;
        align-items: center;
        gap: 6px;
        margin-left: auto;
    }
    .inv-sep-v {
        width: 1px; height: 18px;
        background: var(--border);
        flex-shrink: 0;
    }
    .inv-sort-select {
        padding: 5px 10px;
        border-radius: 8px;
        border: 1px solid var(--border);
        background: rgba(255,255,255,0.03);
        color: var(--text);
        font-size: 0.68em;
        font-weight: 700;
        cursor: pointer;
        font-family: inherit;
    }

    /* ── Table ── */
    .inv-table-wrap {
        border-radius: 14px;
        border: 1px solid var(--border);
        overflow: hidden;
        box-shadow: 0 4px 24px rgba(0,0,0,0.08);
    }
    .inventory-table { width: 100%; border-collapse: collapse; min-width: 700px; }
    .inv-th {
        padding: 11px 12px;
        font-size: 0.6em;
        font-weight: 800;
        letter-spacing: 1.2px;
        text-transform: uppercase;
        color: var(--dim);
        background: linear-gradient(135deg, rgba(37,99,235,0.04), rgba(37,99,235,0.02));
        white-space: nowrap;
        border-bottom: 1px solid var(--border);
    }
    .inv-th-sort a {
        color: var(--dim); text-decoration: none; transition: color .15s;
    }
    .inv-th-sort a:hover { color: var(--accent); }
    .inv-th-active a { color: var(--accent) !important; }

    /* ── Rows ── */
    .inv-row { transition: background 0.15s ease; }
    .inv-row:hover { background: rgba(37,99,235,0.025) !important; }
    .inv-row td { border-bottom: 1px solid var(--border); vertical-align: middle; }
    .inv-row:last-child td { border-bottom: none; }
    .inv-row-root td { padding: 13px 12px; }
    .inv-row-sub td { padding: 9px 12px; background: rgba(0,0,0,0.12); }
    .inv-row-sub:hover { background: rgba(59,130,246,0.03) !important; }

    /* ── Cell specifics ── */
    .inv-td-cb { width: 38px; padding-left: 16px !important; }
    .inv-td-actions { padding-right: 16px !important; }
    .inv-td-firstseen, .inv-td-lastscan { white-space: nowrap; }
    .inv-td-ports { max-width: 160px; }
    .inv-td-asset { min-width: 220px; }

    .inv-asset-name {
        display: flex;
        align-items: center;
        gap: 7px;
        cursor: pointer;
    }
    .inv-status-dot {
        width: 7px; height: 7px;
        border-radius: 50%;
        flex-shrink: 0;
    }
    .inv-value {
        font-weight: 700;
        color: var(--text);
        font-size: 0.88em;
        transition: color .15s;
    }
    .inv-asset-name:hover .inv-value { color: var(--accent); }
    .inv-asset-meta {
        display: flex;
        gap: 7px;
        align-items: center;
        font-size: 0.6em;
        color: var(--dim);
        margin-top: 3px;
        padding-left: 14px;
    }
    .inv-sep { opacity: 0.35; }
    .inv-mono { font-family: 'Fira Code', monospace; }
    .inv-tree-line {
        color: var(--border);
        font-size: 0.9em;
        flex-shrink: 0;
        padding-left: 8px;
    }

    /* ── Chips ── */
    .inv-sub-chip {
        background: rgba(59,130,246,0.12);
        color: #60a5fa;
        font-size: 0.5em;
        font-weight: 800;
        letter-spacing: 0.5px;
        padding: 2px 5px;
        border-radius: 3px;
        border: 1px solid rgba(59,130,246,0.2);
        flex-shrink: 0;
    }
    .inv-product-chip {
        background: rgba(37,99,235,0.1);
        color: var(--accent);
        font-size: 0.52em;
        font-weight: 700;
        padding: 1px 5px;
        border-radius: 3px;
        border: 1px solid var(--accent-border);
    }
    .inv-verified-chip {
        background: rgba(16,185,129,0.1);
        color: #34d399;
        font-size: 0.5em;
        font-weight: 800;
        padding: 1px 5px;
        border-radius: 3px;
        border: 1px solid rgba(16,185,129,0.2);
    }
    .inv-port-chip {
        display: inline-block;
        background: rgba(6,182,212,0.08);
        color: #22d3ee;
        font-size: 0.6em;
        font-weight: 800;
        border: 1px solid rgba(6,182,212,0.2);
        padding: 2px 5px;
        border-radius: 3px;
        font-family: 'Fira Code', monospace;
    }
    .inv-ports-wrap { display: flex; flex-wrap: wrap; gap: 3px; }
    .inv-date-primary { font-size: 0.72em; font-weight: 600; color: var(--text); }
    .inv-date-age { font-size: 0.58em; color: var(--dim); margin-top: 1px; }

    /* ── Action buttons ── */
    .inv-btn {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 5px 10px;
        font-size: 0.6em;
        font-weight: 700;
        border-radius: 6px;
        border: 1px solid var(--border);
        background: transparent;
        color: var(--text);
        text-decoration: none;
        cursor: pointer;
        white-space: nowrap;
        transition: all .15s;
        font-family: inherit;
    }
    .inv-btn:hover {
        background: rgba(255,255,255,0.05);
        border-color: rgba(255,255,255,0.2);
    }
    .inv-btn-mission {
        background: linear-gradient(135deg, rgba(37,99,235,0.2), rgba(37,99,235,0.15));
        border-color: var(--accent-border) !important;
        color: var(--accent) !important;
    }
    .inv-btn-mission:hover {
        background: linear-gradient(135deg, rgba(37,99,235,0.35), rgba(37,99,235,0.25)) !important;
    }
    .inv-td-actions {
        display: flex; /* note: td shouldn't use flex, but we'll wrap a div */
    }
    .inv-td-actions .inv-actions-wrap {
        display: flex;
        gap: 5px;
        align-items: center;
    }
    .inv-actions-td {
        padding-right: 20px;
    }

    /* ── Table Cell Helpers ── */
    .inv-td-main {
        vertical-align: middle;
    }
    .inv-asset-name {
        font-weight: 700;
        color: var(--text);
        font-size: 0.9em;
    }
    .inv-asset-meta {
        font-size: 0.6em;
        color: var(--dim);
        margin-top: 3px;
        display: flex;
        gap: 8px;
        align-items: center;
    }
    .inv-meta-sep {
        opacity: 0.4;
    }
    .inv-monospace {
        font-family: 'Fira Code', monospace;
    }
    .inv-geo-cell {
        display: flex;
        align-items: center;
        gap: 6px;
        color: var(--dim);
        font-size: 0.75em;
    }
    .inv-geo-icon {
        width: 11px;
        height: 11px;
        flex-shrink: 0;
    }
    .inv-ports-wrap {
        display: flex;
        flex-wrap: wrap;
        gap: 3px;
        max-width: 160px;
    }
    .inv-risk-cell {
        display: flex;
        align-items: center;
        gap: 8px;
    }
    .inv-risk-val {
        font-size: 1em;
        font-weight: 900;
        line-height: 1;
    }
    .inv-risk-lbl {
        font-size: 0.5em;
        color: var(--dim);
        text-transform: uppercase;
        margin-top: 2px;
    }
    .inv-risk-bar {
        width: 3px;
        height: 28px;
        border-radius: 2px;
        flex-shrink: 0;
    }
    .inv-risk-label {
        font-size: 0.55em;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    .inv-date-primary {
        font-size: 0.72em;
        color: var(--text);
        font-weight: 600;
    }
    .inv-date-age {
        font-size: 0.58em;
        color: var(--dim);
    }

    /* ── Badge Chips ── */
    .inv-sub-chip {
        background: rgba(59,130,246,0.15);
        color: #60a5fa;
        font-size: 0.5em;
        font-weight: 800;
        letter-spacing: 0.5px;
        padding: 1px 5px;
        border-radius: 3px;
        margin-right: 5px;
        border: 1px solid rgba(59,130,246,0.2);
        vertical-align: middle;
        display: inline-block;
    }
    .inv-product-chip {
        background: rgba(37,99,235,0.1);
        color: #60a5fa;
        font-size: 0.55em;
        font-weight: 700;
        padding: 1px 6px;
        border-radius: 3px;
        border: 1px solid rgba(37,99,235,0.2);
        margin-left: 4px;
        vertical-align: middle;
        display: inline-block;
    }
    .inv-port-chip {
        background: rgba(6,182,212,0.1);
        color: #22d3ee;
        font-size: 0.6em;
        font-weight: 800;
        border: 1px solid rgba(6,182,212,0.25);
        padding: 2px 6px;
        border-radius: 3px;
        font-family: 'Fira Code', monospace;
        display: inline-block;
        white-space: nowrap;
    }
    .inv-port-extra {
        font-size: 0.6em;
        color: var(--dim);
    }
    .inv-port-empty {
        color: var(--dim);
        font-size: 0.75em;
    }

    /* ── Project Cards (Scope Overview) ── */
    .inv-project-grid {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
        gap: 14px;
    }
    .inv-project-card {
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: 14px;
        padding: 0;
        position: relative;
        overflow: hidden;
        cursor: pointer;
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.3s ease;
    }
    .inv-project-card:hover {
        transform: translateY(-5px);
        box-shadow: var(--shadow-hover, 0 16px 40px rgba(0,0,0,0.18));
        border-color: var(--border-hover, var(--border-strong));
    }
    .inv-project-card-accent {
        position: absolute;
        top: 0; left: 0; bottom: 0;
        width: 3px;
        opacity: 0.8;
    }
    .inv-project-card-inner {
        padding: 14px 16px 14px 18px;
    }
    .inv-project-card-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 12px;
    }
    .inv-project-card-icon {
        padding: 8px;
        border-radius: 10px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .inv-project-card-name {
        font-size: 0.95em;
        font-weight: 900;
        color: var(--text);
        letter-spacing: -0.5px;
        line-height: 1.2;
        margin-bottom: 2px;
    }
    .inv-project-card-id {
        font-size: 0.5em;
        font-weight: 900;
        color: var(--dim);
        text-transform: uppercase;
        letter-spacing: 1px;
        opacity: 0.7;
    }
    .inv-project-badge {
        background: var(--surface);
        border: 1px solid var(--border);
        padding: 4px 8px;
        border-radius: 100px;
        font-size: 0.55em;
        font-weight: 900;
        color: var(--text);
        letter-spacing: 1px;
        white-space: nowrap;
    }
    .inv-sev-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
        margin-bottom: 16px;
    }
    .inv-sev-stat {
        border-radius: 10px;
        padding: 8px 4px;
        text-align: center;
    }
    .inv-sev-stat-val {
        font-size: 1.1em;
        font-weight: 900;
        line-height: 1;
    }
    .inv-sev-stat-lbl {
        font-size: 0.48em;
        font-weight: 900;
        text-transform: uppercase;
        letter-spacing: 1px;
        margin-top: 4px;
    }
    .inv-project-card-footer {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .inv-monitor-indicator {
        display: flex;
        align-items: center;
        gap: 6px;
    }
    .inv-monitor-dot {
        width: 5px;
        height: 5px;
        border-radius: 50%;
    }
    .inv-manage-label {
        font-size: 0.55em;
        font-weight: 900;
        color: var(--dim);
        text-transform: uppercase;
        letter-spacing: 1px;
        opacity: 0.8;
    }

    /* ── Shared Button — Primary Action (monochrome) ── */
    .btn-blue {
        background: var(--primary);
        color: var(--bg);
        border: 1px solid var(--border-strong);
        box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    }
    .btn-blue:hover {
        opacity: 0.88;
        box-shadow: 0 4px 16px rgba(0,0,0,0.2);
        transform: translateY(-1px);
    }

    /* ── Responsive ── */
    @media (max-width: 900px) {
        .inv-kpi-grid { grid-template-columns: repeat(3, 1fr); gap: 10px; }
        .col-hide-md { display: none !important; }
    }
    @media (max-width: 600px) {
        .inv-kpi-grid { grid-template-columns: 1fr 1fr; }
        .inv-filter-strip { flex-wrap: wrap; }
        .inv-search-wrap { margin-left: 0; width: 100%; }
    }

/* ── Dashboard Block 6 ── */
@keyframes march {
                            from { stroke-dashoffset: 16; }
                            to { stroke-dashoffset: 0; }
                        }
                        .blink-line {
                            animation: march 0.8s linear infinite;
                        }

/* ── Dashboard Block 7 ── */
.al-action-badge {
        display: inline-flex;
        align-items: center;
        padding: 3px 10px;
        border-radius: 6px;
        font-size: 0.62em;
        font-weight: 900;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        white-space: nowrap;
    }
    .al-row-detail {
        animation: slideInLog 0.18s ease-out;
    }
    @keyframes slideInLog {
        from { opacity:0; transform: translateY(-4px); }
        to { opacity:1; transform: translateY(0); }
    }
    .al-table thead th {
        font-size: 0.6em;
        text-transform: uppercase;
        letter-spacing: 1.5px;
        color: var(--dim);
        font-weight: 700;
        padding: 10px 16px;
        border-bottom: 1px solid var(--border);
        white-space: nowrap;
    }
    .al-table tbody tr {
        border-bottom: 1px solid var(--border);
        transition: background 0.15s;
    }
    .al-table tbody tr:last-child { border-bottom: none; }
    .al-table tbody td {
        padding: 11px 16px;
        font-size: 0.82em;
        vertical-align: middle;
    }

/* ── Dashboard Block 8 ── */
/*═══════════════════════════════════════════════════════════════
      FINDINGS INTELLIGENCE  ·  CLASSIFIED OPERATIONS TERMINAL
    ═══════════════════════════════════════════════════════════════*/

    /* ══ KPI STRIP ══════════════════════════════════════════════ */
    .fi-kpi-grid {
        display: grid;
        grid-template-columns: repeat(4,1fr);
        gap: 10px;
        margin-bottom: 28px;
    }
    @media(max-width:800px){.fi-kpi-grid{grid-template-columns:repeat(2,1fr);}}
    .fi-kpi {
        position:relative; background:var(--surface); border:1px solid var(--border);
        border-radius:16px; padding:18px 16px 14px; display:flex; flex-direction:column;
        gap:3px; overflow:hidden; transition:transform .18s,box-shadow .18s;
    }
    .fi-kpi::after {
        content:''; position:absolute; inset:0; opacity:0;
        background:var(--kpi-glow,transparent); transition:opacity .2s; pointer-events:none;
    }
    .fi-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.18);}
    .fi-kpi:hover::after{opacity:1;}
    .fi-kpi-accent{position:absolute;top:0;left:0;right:0;height:3px;border-radius:16px 16px 0 0;}
    .fi-kpi-val{font-size:2.1em;font-weight:900;line-height:1;letter-spacing:-2px;font-family:'Syne',sans-serif;}
    .fi-kpi-label{font-size:.57em;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--dim);margin-top:3px;}
    .fi-kpi-sub{font-size:.55em;color:var(--dim);opacity:.65;margin-top:1px;}
    @keyframes fi-sla-pulse{0%,100%{box-shadow:0 0 0 2px rgba(239,68,68,.0);}50%{box-shadow:0 0 0 3px rgba(239,68,68,.4);}}
    .fi-kpi.sla-breach{animation:fi-sla-pulse 1.6s ease-in-out infinite;}

    /* ══ FILTER STRIP ═══════════════════════════════════════════ */
    .fi-filter-strip {
        position:sticky; top:0; z-index:30; background:var(--bg);
        padding:10px 0 12px; margin-bottom:20px;
        border-bottom:1px solid var(--border);
        display:flex; align-items:center; gap:8px; flex-wrap:wrap;
    }
    .fi-sev-pill {
        display:inline-flex; align-items:center; gap:5px;
        padding:5px 13px; border-radius:30px; font-family:'DM Mono',monospace;
        font-size:.64em; font-weight:500; letter-spacing:.5px; text-transform:uppercase;
        cursor:pointer; border:1px solid var(--border); background:transparent;
        color:var(--dim); transition:all .15s ease; white-space:nowrap;
    }
    .fi-sev-pill:hover{color:var(--text);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.04);}
    .fi-sev-pill.active{color:var(--pill-color,var(--accent));border-color:var(--pill-color,var(--accent));background:var(--pill-bg,var(--accent-muted));}
    .fi-sev-pill .pill-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;}

    /* Severity dot in block */
    .fi-sev-dot{
        width:6px;height:6px;border-radius:50%;
        background:var(--sev-color,var(--dim));
        box-shadow:0 0 6px var(--sev-color,transparent);
        flex-shrink:0;
    }

    /* ══ FINDING CARDS ══════════════════════════════════════════ */
    @keyframes fi-slide-in{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
    .fi-row {
        background:var(--surface);
        border:1px solid var(--border);
        border-left:3px solid var(--row-accent,var(--border));
        border-radius:14px;
        margin-bottom:8px;
        overflow:hidden;
        transition:border-color .18s,box-shadow .18s,background .18s;
        animation:fi-slide-in .28s ease both;
    }
    .fi-row:hover{background:rgba(255,255,255,.015);box-shadow:0 4px 28px rgba(0,0,0,.14);}
    .fi-row.fi-open{border-color:var(--row-accent,var(--border));box-shadow:0 0 0 1px var(--row-accent,transparent) inset,0 6px 32px rgba(0,0,0,.18);}

    .fi-row-summary {
        display:grid; grid-template-columns:80px 1fr auto;
        align-items:center; gap:14px; padding:12px 16px;
        cursor:pointer; transition:background .15s;
    }
    @media(max-width:700px){.fi-row-summary{grid-template-columns:64px 1fr;}.fi-row-actions{display:none;}}
    .fi-row-summary:hover{background:rgba(255,255,255,.02);}

    /* Severity block */
    .fi-sev-block {
        display:flex; flex-direction:column; align-items:center; justify-content:center;
        gap:4px; padding:8px 6px; border-radius:10px;
        background:var(--sev-bg,rgba(255,255,255,.03));
        border:1px solid var(--sev-bd,rgba(255,255,255,.06));
        min-height:54px; position:relative; overflow:hidden;
    }
    /* Threat level fill bar at bottom of sev block */
    .fi-sev-bar {
        position:absolute; bottom:0; left:0; right:0; height:3px;
        background:var(--sev-color,var(--dim));
        border-radius:0 0 9px 9px;
        width:var(--sev-pct,0%);
        transition:width 1s cubic-bezier(.4,0,.2,1) .3s;
    }
    .fi-sev-label {
        font-family:'DM Mono',monospace; font-size:.52em; font-weight:500;
        text-transform:uppercase; letter-spacing:1.5px;
        color:var(--sev-color,var(--dim));
    }
    .fi-sev-icon {
        font-size:1.2em; line-height:1;
    }
    .fi-status-chip {
        font-family:'DM Mono',monospace; font-size:.46em; font-weight:500;
        text-transform:uppercase; letter-spacing:.8px;
        color:var(--status-color,var(--dim));
    }

    /* Body col */
    .fi-row-body{min-width:0;display:flex;flex-direction:column;gap:4px;}
    .fi-row-title {
        font-family:'Inter',sans-serif; font-size:.87em; font-weight:700;
        color:var(--text); white-space:nowrap; overflow:hidden;
        text-overflow:ellipsis; line-height:1.3;
    }
    .fi-row-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
    .fi-tag {
        display:inline-flex; align-items:center; gap:3px;
        font-family:'DM Mono',monospace; font-size:.58em; font-weight:500;
        color:var(--dim); padding:1px 7px; border-radius:4px;
        background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06);
        white-space:nowrap;
    }
    .fi-tag.ai{background:rgba(37,99,235,.1);color:#60a5fa;border-color:rgba(37,99,235,.2);}
    .fi-tag.manual{background:rgba(59,130,246,.1);color:#60a5fa;border-color:rgba(59,130,246,.2);}
    .fi-tag.target{background:rgba(6,182,212,.07);color:#22d3ee;border-color:rgba(6,182,212,.2);}
    .fi-tag.age{background:transparent;border-color:transparent;opacity:.55;}
    .fi-row-summary-text {
        font-size:.71em; color:var(--dim); white-space:nowrap;
        overflow:hidden; text-overflow:ellipsis; opacity:.75;
    }

    /* Quick actions */
    .fi-row-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;}
    .fi-action-btn {
        padding:5px 11px; border-radius:8px; font-size:.61em; font-weight:700;
        cursor:pointer; border:1px solid rgba(255,255,255,.08);
        background:rgba(255,255,255,.03); color:var(--dim);
        transition:all .15s; white-space:nowrap; text-decoration:none;
        display:inline-flex; align-items:center; gap:4px; font-family:'Inter',sans-serif;
    }
    .fi-action-btn:hover{background:rgba(255,255,255,.08);color:var(--text);border-color:rgba(255,255,255,.15);}
    .fi-action-btn.mission{background:rgba(37,99,235,.1);color:#60a5fa;border-color:rgba(37,99,235,.25);}
    .fi-action-btn.mission:hover{background:rgba(37,99,235,.2);border-color:rgba(37,99,235,.45);}
    .fi-expand-btn {
        width:28px;height:28px;display:flex;align-items:center;justify-content:center;
        border-radius:7px;border:1px solid rgba(255,255,255,.07);
        background:rgba(255,255,255,.03);color:var(--dim);cursor:pointer;
        font-size:.65em;transition:all .15s;flex-shrink:0;
    }
    .fi-expand-btn:hover{background:rgba(255,255,255,.08);color:var(--text);}

    /* ══ EXPANDED DETAIL PANEL ═══════════════════════════════════ */
    .fi-row-detail{display:none;}
    .fi-row-detail.open{display:block;border-top:1px solid var(--border);padding:20px;}
    .fi-detail-inner{padding:20px 20px 24px;display:grid;grid-template-columns:1fr 1fr;gap:20px;}
    @media(max-width:800px){.fi-detail-inner{grid-template-columns:1fr;}}

    .fi-detail-col{display:flex;flex-direction:column;gap:14px;}
    .fi-detail-section {
        font-family:'DM Mono',monospace; font-size:.6em; font-weight:500;
        text-transform:uppercase; letter-spacing:2px;
        color:var(--dim); margin-bottom:6px;
        display:flex; align-items:center; gap:8px;
    }
    .fi-detail-section::before {
        content:''; display:block; width:12px; height:1px;
        background:var(--row-accent,var(--border));
    }
    .fi-desc-body {
        font-size:.82em; color:var(--dim); line-height:1.7;
        background:rgba(0,0,0,.18); border-radius:10px; padding:14px 16px;
        border:1px solid var(--border);
    }
    .fi-evidence-panel {
        background:rgba(0,0,0,.25); border-radius:10px; overflow:hidden;
        border:1px solid var(--border);
    }
    .fi-evidence-hdr {
        display:flex; align-items:center; gap:8px; padding:9px 14px;
        background:rgba(59,130,246,.06); border-bottom:1px solid var(--border);
        font-family:'DM Mono',monospace; font-size:.58em; color:#60a5fa;
        text-transform:uppercase; letter-spacing:1.5px;
    }
    .fi-evidence-grid {
        display:grid; grid-template-columns:1fr 1fr; gap:1px;
        background:var(--border);
    }
    .fi-ev-cell {
        background:var(--surface); padding:12px 14px; overflow-x:auto;
    }
    .fi-ev-label {
        font-family:'DM Mono',monospace; font-size:.56em; color:var(--dim);
        text-transform:uppercase; letter-spacing:1px; margin-bottom:7px;
    }
    .fi-ev-pre {
        margin:0; font-family:'DM Mono',monospace; font-size:.73em;
        color:var(--dim); white-space:pre-wrap; word-break:break-all; line-height:1.6;
    }
    .fi-action-strip {
        display:flex; flex-wrap:wrap; gap:8px; align-items:center;
        padding:14px 20px; border-top:1px solid var(--border);
        background:rgba(0,0,0,.12);
    }

/* ── Dashboard Block 9 ── */
.workspace-header {
        background: var(--surface);
        border-bottom: 1px solid var(--border);
        padding: 30px;
        margin: -30px -30px 30px -30px;
    }
    .wk-grid {
        display: grid;
        grid-template-columns: 2fr 1fr;
        gap: 20px;
    }
    @media (max-width: 900px) { .wk-grid { grid-template-columns: 1fr; } }
    .wk-panel {
        background: var(--surface);
        border: 1px solid var(--border);
        border-radius: 12px;
        padding: 24px;
        margin-bottom: 20px;
    }
    .wk-panel h3 {
        margin: 0 0 15px 0;
        font-size: 0.85em;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--dim);
        display: flex;
        align-items: center;
        gap: 8px;
    }

/* ── Dashboard Block 10 ── */
.history-card {
        background: var(--surface); border: 1px solid var(--border);
        border-radius: 12px; padding: 20px; margin-bottom: 12px;
        display: flex; gap: 20px; align-items: center; justify-content: space-between;
    }
    .history-meta { font-family: 'DM Mono', monospace; font-size: 0.7em; color: var(--dim); }
    .history-title { font-family: 'Syne', sans-serif; font-size: 1.1em; color: var(--text); font-weight: 800; }

/* ── Dashboard Block 11 ── */
.help-wrap { max-width:1040px; margin:0 auto; padding-bottom:120px; }
    .help-tab-btn { background:none; border:none; color:var(--dim); font-size:0.85em; font-weight:800; padding:11px 20px; cursor:pointer; border-bottom:2px solid transparent; transition:all 0.2s; letter-spacing:0.5px; white-space:nowrap; }
    .help-tab-btn:hover { color:var(--text); }
    .help-tab-btn.active { color:var(--accent); border-bottom-color:var(--accent); }
    .help-tab-content { display:none; animation:fadeIn 0.25s; }
    .help-tab-content.active { display:block; }
    @keyframes fadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
    .help-section { margin-bottom:32px; }
    .help-section-title { font-size:0.6em; font-weight:900; text-transform:uppercase; letter-spacing:2px; color:var(--accent); margin-bottom:14px; }
    .help-card { background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:22px 24px; margin-bottom:12px; transition:all 0.2s; }
    .help-card:hover { border-color:var(--accent-border); }
    .help-card h4 { margin:0 0 8px; font-size:0.95em; color:var(--text); font-weight:800; }
    .help-card p { margin:0; font-size:0.8em; color:var(--dim); line-height:1.6; }
    .help-tag { display:inline-block; font-size:0.6em; font-weight:800; text-transform:uppercase; letter-spacing:1px; padding:2px 8px; border-radius:5px; margin-bottom:10px; }
    .module-entry { background:var(--surface); border:1px solid var(--border); border-left:3px solid; border-radius:12px; padding:18px 20px; margin-bottom:10px; }
    .module-entry h4 { margin:0 0 5px; font-size:0.88em; color:var(--text); }
    .module-entry p { margin:0; font-size:0.76em; color:var(--dim); line-height:1.55; }
    .module-tier { float:right; font-size:0.58em; font-weight:900; text-transform:uppercase; padding:2px 8px; border-radius:5px; }
    .faq-item { background:var(--surface); border:1px solid var(--border); border-radius:14px; margin-bottom:10px; overflow:hidden; }
    .faq-q { cursor:pointer; font-weight:800; font-size:0.88em; color:var(--text); padding:18px 20px; display:flex; justify-content:space-between; align-items:center; gap:12px; transition:0.15s; }
    .faq-q:hover { background:var(--card-hover); }
    .faq-a { display:none; color:var(--dim); font-size:0.8em; padding:0 20px 18px; line-height:1.65; }
    .faq-item.open .faq-a { display:block; }
    .faq-item.open .faq-icon { transform:rotate(180deg); }
    .faq-icon { transition:0.25s; color:var(--dim); flex-shrink:0; }
    .agent-doc-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
    @media (max-width:700px) { .agent-doc-row { grid-template-columns:1fr; } }
    .agent-doc-card { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:18px; }
    .agent-doc-card h5 { margin:0 0 6px; font-size:0.85em; font-weight:800; display:flex; align-items:center; gap:8px; }
    .agent-doc-card p { margin:0; font-size:0.75em; color:var(--dim); line-height:1.55; }
    .agent-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
    .finding-anatomy { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-top:12px; }
    @media (max-width:700px) { .finding-anatomy { grid-template-columns:1fr; } }
    .anat-block { background:var(--surface); border:1px solid var(--border); border-radius:12px; padding:16px; }
    .anat-block .anat-label { font-size:0.58em; font-weight:900; text-transform:uppercase; letter-spacing:1.5px; color:var(--accent); margin-bottom:6px; }
    .anat-block p { font-size:0.74em; color:var(--dim); margin:0; line-height:1.5; }
    .flow-step { display:flex; gap:14px; margin-bottom:20px; }
    .flow-step-dot { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.7em; font-weight:900; color:#fff; flex-shrink:0; margin-top:2px; }
    .flow-step-body h5 { margin:0 0 4px; font-size:0.85em; color:var(--text); font-weight:800; }
    .flow-step-body p { margin:0; font-size:0.74em; color:var(--dim); line-height:1.55; }

/* ── Dashboard Block 12 ── */
.hyg-section{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:18px}.hyg-sec-header{display:flex;align-items:center;gap:10px;padding:13px 20px;font-size:0.82em;font-weight:800;border-left:3px solid;background:rgba(255,255,255,0.01)}.hyg-badge{display:inline-flex;padding:2px 9px;border-radius:100px;font-size:0.68em;font-weight:800;border:1px solid var(--border);background:rgba(255,255,255,0.04);color:var(--dim)}.hyg-badge-ok{background:rgba(16,185,129,0.1)!important;color:var(--success)!important;border-color:rgba(16,185,129,0.3)!important;margin-left:auto}.hyg-table{width:100%;border-collapse:collapse}.hyg-th{padding:8px 16px;font-size:0.58em;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--dim);background:rgba(0,0,0,0.25);border-bottom:1px solid var(--border);white-space:nowrap}.hyg-td{padding:9px 16px;border-bottom:1px solid rgba(255,255,255,0.03);color:var(--text);font-size:0.72em;font-family:monospace}.hyg-tr:last-child .hyg-td{border-bottom:none}.hyg-tr:hover{background:var(--card-hover)}

/* ── Dashboard Block 13 ── */
.ic-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:clamp(12px,1.4vw,20px);
  margin-bottom:28px;
}
@media(max-width:900px){.ic-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}}
@media(max-width:600px){.ic-grid{grid-template-columns:1fr 1fr;}}
.ic-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:20px;
  padding:clamp(18px,2vw,26px) clamp(18px,2vw,24px) clamp(16px,1.8vw,22px);
  position:relative;
  overflow:hidden;
  min-height:120px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  transition:border-color .2s,transform .2s,box-shadow .2s;
}
.ic-card:hover{
  border-color:var(--ic-accent,var(--border-strong));
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(0,0,0,0.18);
}
.ic-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:var(--ic-accent,var(--border));
  box-shadow:0 0 14px var(--ic-accent,transparent);
  opacity:.85;
}
.ic-card::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at 0% 0%, color-mix(in srgb, var(--ic-accent,transparent) 8%, transparent) 0%, transparent 65%);
  pointer-events:none;
}
.ic-label{
  font-size:.6em;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--dim);
  margin-bottom:10px;
  font-family:'Fira Code',monospace;
}
.ic-value{
  font-size:clamp(2em,4vw,2.7em);
  font-weight:900;
  color:var(--text);
  line-height:1;
  letter-spacing:-1.5px;
}
.ic-sub{
  font-size:.68em;
  color:var(--dim);
  margin-top:8px;
  line-height:1.4;
}
.ic-panel{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:20px;
  padding:clamp(18px,2vw,26px) clamp(18px,2vw,24px);
}
.ic-section{
  font-size:.6em;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--dim);
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:10px;
}
.ic-section::before{
  content:'';
  display:block;
  width:18px;
  height:1px;
  background:var(--border-strong);
}

/* ── Dashboard Block 14 ── */
#3d-graph { position: absolute; top:0; left:0; width: 100vw; height: 100vh; background: #020408; z-index:9000; overflow:hidden; }
            #hud-overlay { position: absolute; top:30px; left:30px; z-index:9001; pointer-events: none; }
            #graph-close { position: absolute; top:30px; right:30px; z-index:9002; cursor: pointer; padding:10px 20px; background: rgba(14,165,233,0.1); border: 1px solid rgba(14,165,233,0.3); color: #38bdf8; font-weight:800; font-size: 0.8em; border-radius:8px; display:flex; align-items:center; gap:8px; text-decoration:none; transition:0.2s; }
            #graph-close:hover { background: rgba(14,165,233,0.3); }
            .node-tooltip { background:rgba(0,0,0,0.85); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,0.1); padding:10px 15px; border-radius:10px; color:#fff; font-family:'DM Mono',monospace; font-size:0.75em; min-width:200px; box-shadow:0 10px 30px rgba(0,0,0,0.5); }
            .node-h1 { font-size:1.1em; font-weight:900; margin:0 0 5px; color:var(--accent); }
