/* ── PQUniversal Forensics Scanner ── v16 ── CAPABILITY GRID REDESIGN ── */

/* ── Layout override ─────────────────────────────────────────────────────── */
.pdf-tool-page:has(#ufscan-drop) { max-width: min(96vw, 1380px); width: auto; }
body:has(#ufscan-drop) .pdf-header-tool .pdf-header-inner { max-width: min(96vw, 1380px); }
@media (max-width: 700px) {
    .pdf-tool-page:has(#ufscan-drop),
    body:has(#ufscan-drop) .pdf-header-tool .pdf-header-inner { max-width: 100%; }
}

/* ── Design tokens ───────────────────────────────────────────────────────── */
:root {
    --lab-bg:        #020b14;
    --lab-panel:     rgba(3,18,32,0.92);
    --lab-border:    rgba(0,200,255,0.18);
    --lab-border-hi: rgba(0,200,255,0.55);
    --lab-cyan:      #00c8ff;
    --lab-cyan-dim:  rgba(0,200,255,0.12);
    --lab-green:     #00ff88;
    --lab-green-dim: rgba(0,255,136,0.10);
    --lab-red:       #ff2244;
    --lab-red-dim:   rgba(255,34,68,0.12);
    --lab-amber:     #ffaa00;
    --lab-amber-dim: rgba(255,170,0,0.10);
    --lab-purple:    #9f60ff;
    --lab-text:      #c8e0f0;
    --lab-text-dim:  #4a7a9a;
    --lab-mono:      'SF Mono','Fira Code',Consolas,monospace;
    --lab-scan-line: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 2px,
        rgba(0,0,0,0.08) 2px,
        rgba(0,0,0,0.08) 4px
    );
}

/* ── Scanline overlay mixin via pseudo ───────────────────────────────────── */
.lab-panel {
    position: relative;
    background: var(--lab-panel);
    border: 1px solid var(--lab-border);
    border-radius: 4px;
}
.lab-panel::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lab-scan-line);
    pointer-events: none;
    border-radius: inherit;
    z-index: 0;
    opacity: 0.5;
}
.lab-panel > * { position: relative; z-index: 1; }

/* ── HUD Corner brackets ─────────────────────────────────────────────────── */
.lab-hud {
    position: relative;
    padding: 1.2rem 1.4rem;
    background: var(--lab-panel);
    border: 1px solid rgba(0,200,255,0.12);
    border-radius: 2px;
}
.lab-hud::before, .lab-hud::after,
.lab-hud .lab-hud-br::before, .lab-hud .lab-hud-br::after {
    content: '';
    position: absolute;
    width: 14px;
    height: 14px;
    border-color: var(--lab-cyan);
    border-style: solid;
}
.lab-hud::before       { top:-1px; left:-1px;   border-width: 2px 0 0 2px; }
.lab-hud::after        { top:-1px; right:-1px;  border-width: 2px 2px 0 0; }
.lab-hud .lab-hud-br::before { bottom:-1px; left:-1px;  border-width: 0 0 2px 2px; }
.lab-hud .lab-hud-br::after  { bottom:-1px; right:-1px; border-width: 0 2px 2px 0; }

/* ── About / intro section ───────────────────────────────────────────────── */
.ufs-about { margin-bottom: 2rem; }

.ufs-about-header {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 1.2rem;
    margin-bottom: 1.5rem;
    padding: 1.4rem 1.6rem;
    background: linear-gradient(135deg, rgba(0,25,45,0.95) 0%, rgba(3,12,25,0.95) 100%);
    border: 1px solid rgba(0,200,255,0.2);
    border-radius: 4px;
    overflow: hidden;
}
.ufs-about-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lab-scan-line);
    pointer-events: none;
    opacity: 0.4;
}
.ufs-about-header::after {
    content: 'FORENSICS LAB v4.0';
    position: absolute;
    top: 0.6rem;
    right: 1rem;
    font-family: var(--lab-mono);
    font-size: 0.62rem;
    letter-spacing: 0.18em;
    color: rgba(0,200,255,0.3);
    text-transform: uppercase;
}

.ufs-about-icon {
    font-size: 2.4rem;
    flex-shrink: 0;
    margin-top: 0.1rem;
    filter: drop-shadow(0 0 12px rgba(0,200,255,0.5));
    position: relative;
    z-index: 1;
}
.ufs-about-title {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--lab-cyan);
    margin-bottom: 0.3rem;
    letter-spacing: 0.04em;
    text-shadow: 0 0 20px rgba(0,200,255,0.4);
    position: relative;
    z-index: 1;
}
.ufs-about-mission {
    font-size: 0.84rem;
    color: #90aac0;
    line-height: 1.65;
    position: relative;
    z-index: 1;
    margin-top: 0.15rem;
}
.ufs-about-mission strong { color: var(--lab-amber); }
.ufs-about-mission a { color: var(--lab-cyan); text-decoration: none; border-bottom: 1px solid rgba(0,200,255,0.3); }
.ufs-about-mission a:hover { color: #fff; border-bottom-color: var(--lab-cyan); }

/* ── Capability cluster grid ─────────────────────────────────────────────── */
.ufs-cap-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 1rem;
}
@media (max-width: 900px) { .ufs-cap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .ufs-cap-grid { grid-template-columns: 1fr; } }

.ufs-cap-card {
    position: relative;
    background: rgba(3,12,25,0.88);
    border: 1px solid rgba(0,200,255,0.1);
    border-radius: 3px;
    padding: 0.95rem 1.05rem 1rem;
    overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.ufs-cap-card:hover {
    border-color: rgba(var(--ufs-cap-rgb, 0,200,255), 0.35);
    box-shadow: 0 0 18px rgba(var(--ufs-cap-rgb, 0,200,255), 0.07);
}
.ufs-cap-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lab-scan-line);
    pointer-events: none;
    opacity: 0.25;
}
.ufs-cap-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--ufs-cap-color, var(--lab-cyan)), transparent 70%);
    opacity: 0.6;
}

.ufs-cap-head {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 0.6rem;
    position: relative;
    z-index: 1;
}
.ufs-cap-title {
    font-size: 0.82rem;
    font-weight: 800;
    color: var(--ufs-cap-color, var(--lab-cyan));
    letter-spacing: 0.03em;
    flex: 1;
}
.ufs-cap-count-pill {
    font-size: 0.57rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.08em;
    padding: 0.11rem 0.48rem;
    border-radius: 2px;
    border: 1px solid rgba(var(--ufs-cap-rgb, 0,200,255), 0.35);
    color: var(--ufs-cap-color, var(--lab-cyan));
    background: rgba(var(--ufs-cap-rgb, 0,200,255), 0.06);
    white-space: nowrap;
    flex-shrink: 0;
    opacity: 0.85;
}

.ufs-cap-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-bottom: 0.65rem;
    position: relative;
    z-index: 1;
}
.ufs-cap-tags span {
    font-size: 0.59rem;
    font-family: var(--lab-mono);
    padding: 0.13rem 0.45rem;
    border-radius: 2px;
    border: 1px solid rgba(var(--ufs-cap-rgb, 0,200,255), 0.18);
    color: var(--ufs-cap-color, var(--lab-cyan));
    background: rgba(var(--ufs-cap-rgb, 0,200,255), 0.05);
    letter-spacing: 0.04em;
    opacity: 0.85;
}

.ufs-cap-desc {
    font-size: 0.71rem;
    color: #5a7a96;
    line-height: 1.7;
    position: relative;
    z-index: 1;
}

/* Per-category accent colors */
.ufs-cap-static   { --ufs-cap-color: #00c8ff; --ufs-cap-rgb: 0,200,255; }
.ufs-cap-content  { --ufs-cap-color: #ec4899; --ufs-cap-rgb: 236,72,153; }
.ufs-cap-dynamic  { --ufs-cap-color: #ff4466; --ufs-cap-rgb: 255,68,102; }
.ufs-cap-intel    { --ufs-cap-color: #ffaa00; --ufs-cap-rgb: 255,170,0; }
.ufs-cap-campaign { --ufs-cap-color: #a855f7; --ufs-cap-rgb: 168,85,247; }
.ufs-cap-ai       { --ufs-cap-color: #2dd4bf; --ufs-cap-rgb: 45,212,191; }

/* Privacy / trust bar */
.ufs-privacy-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem 1.8rem;
    padding: 0.65rem 1rem;
    background: rgba(0,8,18,0.5);
    border: 1px solid rgba(0,200,255,0.07);
    border-radius: 2px;
    margin-bottom: 1.2rem;
}
.ufs-priv-green {
    font-size: 0.67rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.04em;
    color: var(--lab-green);
    opacity: 0.85;
}
.ufs-priv-cyan {
    font-size: 0.67rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.04em;
    color: var(--lab-text-dim);
}

/* Stack label bar */
.ufs-about-stack-label {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
    padding: 0.6rem 0.9rem;
    background: rgba(0,200,255,0.04);
    border: 1px solid rgba(0,200,255,0.12);
    border-left: 3px solid var(--lab-cyan);
    border-radius: 2px;
    flex-wrap: wrap;
}
.ufs-about-stack-name {
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--lab-cyan);
    white-space: nowrap;
}
.ufs-about-stack-desc {
    font-size: 0.68rem;
    color: var(--lab-text-dim);
    font-family: var(--lab-mono);
    flex: 1;
    min-width: 0;
    overflow-wrap: anywhere;
}
.ufs-about-stack-count {
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--lab-cyan);
    opacity: 0.6;
    text-transform: uppercase;
    white-space: nowrap;
    background: rgba(0,200,255,0.08);
    border: 1px solid rgba(0,200,255,0.2);
    padding: 0.15rem 0.55rem;
    border-radius: 2px;
}

/* ── Engine accordion grid ───────────────────────────────────────────────── */
.ufs-engine-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
    margin-bottom: 1.2rem;
}
@media (max-width: 1100px) { .ufs-engine-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 750px)  { .ufs-engine-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .ufs-engine-grid { grid-template-columns: 1fr; } }

.ufs-engine-cell { display: flex; flex-direction: column; }

.ufs-engine-card {
    display: flex;
    align-items: center;
    gap: 7px;
    background: rgba(3,18,32,0.7);
    border: 1px solid rgba(0,200,255,0.10);
    border-left: 2px solid rgba(0,200,255,0.15);
    border-radius: 2px;
    padding: 8px 10px;
    cursor: pointer;
    transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
    user-select: none;
    position: relative;
    overflow: hidden;
}
.ufs-engine-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lab-scan-line);
    pointer-events: none;
    opacity: 0.3;
}
.ufs-engine-card:hover {
    background: rgba(0,200,255,0.05);
    border-color: rgba(0,200,255,0.3);
    box-shadow: 0 0 12px rgba(0,200,255,0.08), inset 0 0 12px rgba(0,200,255,0.03);
}
.ufs-engine-card.ufs-card-open {
    border-color: rgba(0,200,255,0.4);
    box-shadow: 0 0 16px rgba(0,200,255,0.12);
}
.ufs-engine-num {
    font-size: 0.75rem;
    font-weight: 700;
    flex-shrink: 0;
    font-family: var(--lab-mono);
    opacity: 0.7;
    position: relative;
    z-index: 1;
}
.ufs-engine-name {
    font-size: 0.73rem;
    font-weight: 700;
    flex: 1;
    letter-spacing: 0.02em;
    position: relative;
    z-index: 1;
}
.ufs-engine-chev {
    font-size: 0.6rem;
    color: var(--lab-text-dim);
    flex-shrink: 0;
    position: relative;
    z-index: 1;
}

/* Per-engine accent colours */
.ufs-c1  { border-left-color: #6366f1; }  .ufs-c1  .ufs-engine-name, .ufs-c1  .ufs-engine-num { color: #818cf8; }
.ufs-c2  { border-left-color: #00c8ff; }  .ufs-c2  .ufs-engine-name, .ufs-c2  .ufs-engine-num { color: #00c8ff; }
.ufs-c3  { border-left-color: #ec4899; }  .ufs-c3  .ufs-engine-name, .ufs-c3  .ufs-engine-num { color: #f472b6; }
.ufs-c4  { border-left-color: #f97316; }  .ufs-c4  .ufs-engine-name, .ufs-c4  .ufs-engine-num { color: #fb923c; }
.ufs-c5  { border-left-color: #3b82f6; }  .ufs-c5  .ufs-engine-name, .ufs-c5  .ufs-engine-num { color: #60a5fa; }
.ufs-c6  { border-left-color: #f43f5e; }  .ufs-c6  .ufs-engine-name, .ufs-c6  .ufs-engine-num { color: #fb7185; }
.ufs-c7  { border-left-color: #a78bfa; }  .ufs-c7  .ufs-engine-name, .ufs-c7  .ufs-engine-num { color: #c4b5fd; }
.ufs-c8  { border-left-color: #00ff88; }  .ufs-c8  .ufs-engine-name, .ufs-c8  .ufs-engine-num { color: #00ff88; }
.ufs-c9  { border-left-color: #e879f9; }  .ufs-c9  .ufs-engine-name, .ufs-c9  .ufs-engine-num { color: #f0abfc; }
.ufs-c10 { border-left-color: #fbbf24; }  .ufs-c10 .ufs-engine-name, .ufs-c10 .ufs-engine-num { color: #fcd34d; }
.ufs-c11 { border-left-color: #22c55e; }  .ufs-c11 .ufs-engine-name, .ufs-c11 .ufs-engine-num { color: #4ade80; }
.ufs-c12 { border-left-color: #fb923c; }  .ufs-c12 .ufs-engine-name, .ufs-c12 .ufs-engine-num { color: #fdba74; }
.ufs-c13 { border-left-color: #ef4444; }  .ufs-c13 .ufs-engine-name, .ufs-c13 .ufs-engine-num { color: #f87171; }
.ufs-c14 { border-left-color: #8b5cf6; }  .ufs-c14 .ufs-engine-name, .ufs-c14 .ufs-engine-num { color: #a78bfa; }
.ufs-c15 { border-left-color: #2dd4bf; }  .ufs-c15 .ufs-engine-name, .ufs-c15 .ufs-engine-num { color: #5eead4; }
.ufs-c16 { border-left-color: #38bdf8; }  .ufs-c16 .ufs-engine-name, .ufs-c16 .ufs-engine-num { color: #7dd3fc; }
.ufs-c17 { border-left-color: #a3e635; }  .ufs-c17 .ufs-engine-name, .ufs-c17 .ufs-engine-num { color: #bef264; }
.ufs-c18 { border-left-color: #f59e0b; }  .ufs-c18 .ufs-engine-name, .ufs-c18 .ufs-engine-num { color: #fbbf24; }
.ufs-c19 { border-left-color: #e879f9; }  .ufs-c19 .ufs-engine-name, .ufs-c19 .ufs-engine-num { color: #f0abfc; }
.ufs-c20 { border-left-color: #f59e0b; }  .ufs-c20 .ufs-engine-name, .ufs-c20 .ufs-engine-num { color: #fcd34d; }
.ufs-c21 { border-left-color: #ff2244; }  .ufs-c21 .ufs-engine-name, .ufs-c21 .ufs-engine-num { color: #ff6688; }

/* Expanded desc panel */
.ufs-engine-desc-panel {
    display: none;
    font-size: 0.73rem;
    color: #90aac0;
    line-height: 1.6;
    padding: 10px 12px;
}
.ufs-engine-desc-panel code {
    font-family: var(--lab-mono);
    color: var(--lab-amber);
    font-size: 0.7rem;
    background: rgba(255,170,0,0.08);
    padding: 0.05rem 0.3rem;
    border-radius: 2px;
}

.ufs-engine-desc-wide {
    display: block;
    grid-column: 1 / -1;
    padding: 1rem 1.3rem 1.1rem;
    background: rgba(0,12,25,0.95);
    border: 1px solid rgba(0,200,255,0.2);
    border-radius: 2px;
    margin-bottom: 0.35rem;
    font-size: 0.8rem;
    color: #c0d8ea;
    line-height: 1.72;
}
.ufs-engine-desc-wide code {
    font-family: var(--lab-mono);
    font-size: 0.76rem;
    padding: 0.1rem 0.35rem;
    border-radius: 2px;
    background: rgba(0,200,255,0.08);
    color: var(--lab-amber);
}

/* ── File type categories ─────────────────────────────────────────────────── */
.ufs-filetypes {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 1.4rem;
    padding: 0.8rem 1rem;
    background: rgba(0,10,20,0.6);
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
}
.ufs-ft-group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
}
.ufs-ft-label {
    font-size: 0.62rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-right: 8px;
    flex-shrink: 0;
    width: 72px;
    font-family: var(--lab-mono);
}
.ufs-ft-ext {
    font-size: 0.62rem;
    padding: 1px 6px;
    border-radius: 2px;
    border: 1px solid;
    opacity: 0.8;
    font-family: var(--lab-mono);
    letter-spacing: 0.04em;
}
.ufs-ft-label { background: none; border: none; padding: 0; }

.ufs-cat-img { color: #ec4899; border-color: rgba(236,72,153,.3);  background: rgba(236,72,153,.06); }
.ufs-cat-aud { color: #a78bfa; border-color: rgba(167,139,250,.3); background: rgba(167,139,250,.06); }
.ufs-cat-vid { color: #fb923c; border-color: rgba(251,146,60,.3);  background: rgba(251,146,60,.06); }
.ufs-cat-arc { color: #00ff88; border-color: rgba(0,255,136,.25);  background: rgba(0,255,136,.05); }
.ufs-cat-exe { color: #ff2244; border-color: rgba(255,34,68,.3);   background: rgba(255,34,68,.06); }
.ufs-cat-scr { color: #fbbf24; border-color: rgba(251,191,36,.3);  background: rgba(251,191,36,.06); }
.ufs-cat-dat { color: #00c8ff; border-color: rgba(0,200,255,.25);  background: rgba(0,200,255,.05); }
.ufs-cat-net { color: #2dd4bf; border-color: rgba(45,212,191,.3);  background: rgba(45,212,191,.06); }

/* ── Drop zone — Scanner bay ─────────────────────────────────────────────── */
#ufscan-drop {
    position: relative;
    border: 1px solid rgba(0,200,255,0.2);
    border-radius: 4px;
    padding: 3.5rem 2rem;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
    background: rgba(0,12,28,0.7);
    margin-bottom: 1.2rem;
    overflow: hidden;
}
/* Animated corner brackets */
#ufscan-drop::before, #ufscan-drop::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border-color: var(--lab-cyan);
    border-style: solid;
    opacity: 0.5;
    transition: opacity 0.2s;
}
#ufscan-drop::before { top: 8px; left: 8px; border-width: 2px 0 0 2px; }
#ufscan-drop::after  { top: 8px; right: 8px; border-width: 2px 2px 0 0; }
.ufscan-drop-br::before, .ufscan-drop-br::after {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border-color: var(--lab-cyan);
    border-style: solid;
    opacity: 0.5;
    transition: opacity 0.2s;
    pointer-events: none;
}
.ufscan-drop-br::before { bottom: 8px; left: 8px;  border-width: 0 0 2px 2px; }
.ufscan-drop-br::after  { bottom: 8px; right: 8px; border-width: 0 2px 2px 0; }

/* Scan line sweep animation */
#ufscan-drop .ufscan-scan-sweep {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--lab-cyan), transparent);
    opacity: 0;
    pointer-events: none;
    animation: ufs-sweep 3s ease-in-out infinite;
    box-shadow: 0 0 8px var(--lab-cyan), 0 0 20px rgba(0,200,255,0.3);
}
@keyframes ufs-sweep {
    0%   { top: 0%; opacity: 0; }
    5%   { opacity: 0.7; }
    95%  { opacity: 0.7; }
    100% { top: 100%; opacity: 0; }
}

/* Grid overlay */
#ufscan-drop .ufscan-grid-overlay {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(0,200,255,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,200,255,0.04) 1px, transparent 1px);
    background-size: 30px 30px;
    pointer-events: none;
}

#ufscan-drop:hover, #ufscan-drop.dragover {
    border-color: var(--lab-cyan);
    background: rgba(0,200,255,0.04);
    box-shadow: 0 0 30px rgba(0,200,255,0.08), inset 0 0 30px rgba(0,200,255,0.03);
}
#ufscan-drop:hover::before, #ufscan-drop:hover::after,
#ufscan-drop.dragover::before, #ufscan-drop.dragover::after { opacity: 1; }
#ufscan-drop:hover .ufscan-drop-br::before,
#ufscan-drop:hover .ufscan-drop-br::after,
#ufscan-drop.dragover .ufscan-drop-br::before,
#ufscan-drop.dragover .ufscan-drop-br::after { opacity: 1; }

#ufscan-file-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
    z-index: 2;
}

.ufscan-drop-icon {
    font-size: 3rem;
    margin-bottom: 0.9rem;
    opacity: 0.75;
    filter: drop-shadow(0 0 16px rgba(0,200,255,0.5));
    position: relative;
    z-index: 1;
    display: block;
}
.ufscan-drop-title {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--lab-cyan);
    margin-bottom: 0.45rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-shadow: 0 0 20px rgba(0,200,255,0.5);
    position: relative;
    z-index: 1;
}
.ufscan-drop-sub {
    font-size: 0.79rem;
    color: var(--lab-text-dim);
    line-height: 1.65;
    font-family: var(--lab-mono);
    position: relative;
    z-index: 1;
}
.ufscan-drop-badges {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    position: relative;
    z-index: 1;
}
.ufscan-drop-badge {
    font-size: 0.6rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.18rem 0.6rem;
    border-radius: 2px;
    border: 1px solid;
}
.badge-cyan   { color: var(--lab-cyan);  border-color: rgba(0,200,255,0.35);  background: rgba(0,200,255,0.07);  }
.badge-green  { color: var(--lab-green); border-color: rgba(0,255,136,0.3);   background: rgba(0,255,136,0.06);  }
.badge-amber  { color: var(--lab-amber); border-color: rgba(255,170,0,0.35);  background: rgba(255,170,0,0.07);  }

/* ── Selected file ───────────────────────────────────────────────────────── */
.ufscan-selected {
    display: none;
    background: rgba(0,200,255,0.04);
    border: 1px solid rgba(0,200,255,0.2);
    border-radius: 4px;
    padding: 0.8rem 1.1rem;
    margin-bottom: 0.9rem;
    align-items: center;
    gap: 1rem;
    position: relative;
}
.ufscan-selected::before {
    content: 'FILE LOADED';
    position: absolute;
    top: -0.55rem;
    left: 1rem;
    font-size: 0.55rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.15em;
    color: var(--lab-cyan);
    background: var(--lab-bg, #020b14);
    padding: 0 0.4rem;
}
.ufscan-selected.visible { display: flex; }
.ufscan-sel-icon { font-size: 1.8rem; flex-shrink: 0; }
.ufscan-sel-info { flex: 1; min-width: 0; }
.ufscan-sel-name {
    font-weight: 700;
    font-size: 0.88rem;
    word-break: break-all;
    color: var(--lab-cyan);
    font-family: var(--lab-mono);
}
.ufscan-sel-size {
    font-size: 0.73rem;
    color: var(--lab-text-dim);
    margin-top: 0.2rem;
    font-family: var(--lab-mono);
}
.ufscan-sel-clear {
    flex-shrink: 0;
    background: none;
    border: 1px solid rgba(255,34,68,0.3);
    border-radius: 2px;
    padding: 0.3rem 0.8rem;
    font-size: 0.72rem;
    cursor: pointer;
    color: rgba(255,34,68,0.6);
    transition: all 0.15s;
    font-family: var(--lab-mono);
    letter-spacing: 0.06em;
}
.ufscan-sel-clear:hover { border-color: var(--lab-red); color: var(--lab-red); background: rgba(255,34,68,0.06); }

/* ── Submit button ───────────────────────────────────────────────────────── */
#ufscan-submit-wrap { display: none; margin-bottom: 1.4rem; }
#ufscan-submit-wrap.visible { display: block; }
#ufscan-submit-btn {
    width: 100%;
    padding: 0.95rem;
    font-size: 0.9rem;
    font-weight: 800;
    border: 1px solid rgba(0,200,255,0.5);
    border-radius: 4px;
    cursor: pointer;
    background: linear-gradient(135deg, rgba(0,200,255,0.12) 0%, rgba(0,100,160,0.15) 100%);
    color: var(--lab-cyan);
    transition: all 0.2s;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    font-family: var(--lab-mono);
    position: relative;
    overflow: hidden;
    text-shadow: 0 0 12px rgba(0,200,255,0.6);
    box-shadow: 0 0 20px rgba(0,200,255,0.08), inset 0 0 20px rgba(0,200,255,0.03);
}
#ufscan-submit-btn::before {
    content: '';
    position: absolute;
    top: 0; left: -100%; width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(0,200,255,0.08), transparent);
    transition: left 0.4s;
}
#ufscan-submit-btn:hover {
    border-color: var(--lab-cyan);
    background: linear-gradient(135deg, rgba(0,200,255,0.18) 0%, rgba(0,140,200,0.2) 100%);
    box-shadow: 0 0 30px rgba(0,200,255,0.2), inset 0 0 30px rgba(0,200,255,0.05);
}
#ufscan-submit-btn:hover::before { left: 100%; }
#ufscan-submit-btn:active { transform: scale(0.99); }
#ufscan-submit-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Progress — scanning beam ─────────────────────────────────────────────── */
#ufscan-progress { display: none; margin-bottom: 1.4rem; }
#ufscan-progress.visible { display: block; }

.ufscan-prog-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.6rem;
    font-family: var(--lab-mono);
}
.ufscan-prog-file {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--lab-cyan);
}
.ufscan-prog-file::before { content: '> '; opacity: 0.5; }
.ufscan-prog-pct {
    font-size: 0.72rem;
    color: var(--lab-green);
    font-weight: 700;
    letter-spacing: 0.08em;
}

.ufscan-prog-bar-wrap {
    background: rgba(0,200,255,0.05);
    border: 1px solid rgba(0,200,255,0.15);
    border-radius: 3px;
    height: 10px;
    overflow: hidden;
    margin-bottom: 1rem;
    position: relative;
}
.ufscan-prog-bar {
    height: 100%;
    background: linear-gradient(90deg, #0070a8, var(--lab-cyan) 60%, var(--lab-green));
    width: 0%;
    transition: width 0.4s ease-out;
    position: relative;
}
.ufscan-prog-bar::after {
    content: '';
    position: absolute;
    top: 0; right: 0;
    width: 40px; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35));
    animation: ufs-shimmer 1.2s ease-in-out infinite;
}
@keyframes ufs-shimmer { 0%,100% { opacity:1; } 50% { opacity:0.3; } }
@keyframes ufs-pulse   { 0%,100% { opacity:1; } 50% { opacity:0.65; } }

/* ── Engine strip ─────────────────────────────────────────────────────────── */
#ufscan-engine-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.7rem 0.9rem;
    background: rgba(0,5,15,0.8);
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
}
.ufscan-eng-chip {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    background: rgba(0,200,255,0.03);
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
    padding: 0.24rem 0.55rem;
    font-size: 0.65rem;
    font-family: var(--lab-mono);
    transition: all 0.2s;
    letter-spacing: 0.04em;
    color: var(--lab-text-dim);
}
.ufscan-eng-chip.running {
    border-color: var(--lab-cyan);
    color: var(--lab-cyan);
    background: rgba(0,200,255,0.06);
    box-shadow: 0 0 8px rgba(0,200,255,0.1);
}
.ufscan-eng-chip.done  { border-color: rgba(0,255,136,0.4); color: var(--lab-green); background: rgba(0,255,136,0.05); }
.ufscan-eng-chip.error { border-color: rgba(255,34,68,0.4);  color: var(--lab-red);   background: rgba(255,34,68,0.06); }
.ufscan-eng-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
    box-shadow: 0 0 4px currentColor;
}
.ufscan-eng-chip.running .ufscan-eng-dot { animation: ufs-blink 0.9s ease-in-out infinite; }
@keyframes ufs-blink { 0%,100% { opacity:1; } 50% { opacity:0.1; } }

/* ── Console — terminal ───────────────────────────────────────────────────── */
#ufscan-console { display: none; margin-bottom: 1.4rem; }
#ufscan-console.visible { display: block; }
.ufscan-console-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0;
    padding: 0.35rem 0.7rem;
    background: rgba(0,200,255,0.05);
    border: 1px solid rgba(0,200,255,0.12);
    border-bottom: none;
    border-radius: 2px 2px 0 0;
}
.ufscan-console-title {
    font-size: 0.62rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--lab-cyan);
    font-family: var(--lab-mono);
}
.ufscan-console-title::before { content: '⬤ ⬤ ⬤  '; font-size: 0.45rem; color: rgba(0,200,255,0.4); letter-spacing: 0.15em; }
.ufscan-console-toggle,
.ufscan-console-clear {
    background: none;
    border: 1px solid rgba(0,200,255,0.15);
    border-radius: 2px;
    padding: 0.1rem 0.45rem;
    font-size: 0.6rem;
    color: var(--lab-text-dim);
    cursor: pointer;
    font-family: var(--lab-mono);
    letter-spacing: 0.06em;
}
.ufscan-console-toggle:hover, .ufscan-console-clear:hover { color: var(--lab-cyan); border-color: rgba(0,200,255,0.4); }
.ufscan-console-toggle { margin-left: auto; }
.ufscan-console-body {
    background: #010810;
    border: 1px solid rgba(0,200,255,0.10);
    border-radius: 0 0 2px 2px;
    padding: 0.6rem 0.8rem;
    max-height: 180px;
    overflow-y: auto;
    font-family: var(--lab-mono);
    font-size: 0.7rem;
    color: #5080a0;
    line-height: 1.65;
    background-image: var(--lab-scan-line);
}
.ufscan-console-body::-webkit-scrollbar { width: 4px; }
.ufscan-console-body::-webkit-scrollbar-track { background: transparent; }
.ufscan-console-body::-webkit-scrollbar-thumb { background: rgba(0,200,255,0.2); border-radius: 2px; }

.log-info   { color: var(--lab-cyan); }
.log-warn   { color: var(--lab-amber); }
.log-error  { color: var(--lab-red); }
.log-ok     { color: var(--lab-green); }
.log-engine { color: #a78bfa; }

/* ── Error ────────────────────────────────────────────────────────────────── */
#ufscan-error {
    display: none;
    background: rgba(255,34,68,0.06);
    border: 1px solid rgba(255,34,68,0.3);
    border-left: 3px solid var(--lab-red);
    border-radius: 2px;
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    color: #ff8899;
    font-size: 0.82rem;
    font-family: var(--lab-mono);
}
#ufscan-error.visible { display: block; }

/* ── Results ──────────────────────────────────────────────────────────────── */
#ufscan-results { display: none; }
#ufscan-results.visible { display: block; }

/* ── Verdict banner ──────────────────────────────────────────────────────── */
.ufscan-verdict {
    border-radius: 4px;
    padding: 1.4rem 1.6rem;
    margin-bottom: 1.3rem;
    border: 1px solid;
    display: flex;
    align-items: center;
    gap: 1.2rem;
    position: relative;
    overflow: hidden;
}
.ufscan-verdict::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lab-scan-line);
    pointer-events: none;
    opacity: 0.5;
}
.ufscan-verdict::after {
    content: 'VERDICT';
    position: absolute;
    top: 0.6rem;
    right: 1rem;
    font-size: 0.55rem;
    font-family: var(--lab-mono);
    letter-spacing: 0.18em;
    opacity: 0.35;
}
.ufscan-verdict-icon     { font-size: 2.5rem; flex-shrink: 0; filter: drop-shadow(0 0 10px currentColor); position: relative; }
.ufscan-verdict-level    { font-size: 1.65rem; font-weight: 900; letter-spacing: 0.12em; font-family: var(--lab-mono); text-shadow: 0 0 20px currentColor; }
.ufscan-verdict-filename { font-size: 0.78rem; opacity: 0.75; margin-top: 0.25rem; word-break: break-all; font-family: var(--lab-mono); }
.ufscan-verdict-category { font-size: 0.68rem; opacity: 0.5; margin-top: 0.25rem; letter-spacing: 0.06em; }
.ufscan-verdict-rec      { font-size: 0.78rem; margin-top: 0.5rem; line-height: 1.55; }
.ufscan-verdict-score    { margin-left: auto; text-align: right; flex-shrink: 0; position: relative; }
.ufscan-score-num        { font-size: 3rem; font-weight: 900; line-height: 1; font-family: var(--lab-mono); text-shadow: 0 0 20px currentColor; }
.ufscan-score-denom      { font-size: 1rem; font-weight: 500; opacity: 0.4; font-family: var(--lab-mono); }
.ufscan-score-label      { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.55; font-family: var(--lab-mono); }

/* ── Stats bar ───────────────────────────────────────────────────────────── */
.ufscan-stats-bar {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.5rem;
    margin-bottom: 1.3rem;
}
.ufscan-stat {
    background: rgba(0,10,22,0.8);
    border: 1px solid rgba(0,200,255,0.1);
    border-radius: 2px;
    padding: 0.75rem 0.9rem;
    position: relative;
    text-align: center;
}
.ufscan-stat::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,200,255,0.3), transparent);
}
.ufscan-stat-num   { font-size: 1.85rem; font-weight: 900; line-height: 1; font-family: var(--lab-mono); text-shadow: 0 0 12px currentColor; }
.ufscan-stat-label { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--lab-text-dim); margin-top: 0.3rem; font-family: var(--lab-mono); }
.c-critical { color: var(--lab-red); }
.c-high     { color: #ff6622; }
.c-medium   { color: var(--lab-amber); }
.c-low      { color: var(--lab-cyan); }
.c-info     { color: #4a6a80; }

/* ── Tabs ────────────────────────────────────────────────────────────────── */
.ufscan-tabs {
    display: flex;
    gap: 0;
    flex-wrap: wrap;
    margin-bottom: 0;
    border-bottom: 1px solid rgba(0,200,255,0.12);
}
.ufscan-tab {
    background: rgba(0,5,15,0.7);
    border: 1px solid rgba(0,200,255,0.08);
    border-bottom: none;
    border-radius: 2px 2px 0 0;
    padding: 0.45rem 0.95rem;
    font-size: 0.72rem;
    cursor: pointer;
    color: var(--lab-text-dim);
    transition: all 0.15s;
    font-family: var(--lab-mono);
    letter-spacing: 0.05em;
    margin-right: 2px;
    margin-bottom: -1px;
    position: relative;
}
.ufscan-tab:hover { color: var(--lab-cyan); border-color: rgba(0,200,255,0.2); }
.ufscan-tab.active {
    background: rgba(0,200,255,0.06);
    border-color: rgba(0,200,255,0.25);
    border-bottom-color: rgba(0,200,255,0.06);
    color: var(--lab-cyan);
    box-shadow: 0 0 12px rgba(0,200,255,0.06);
}

.ufscan-panel { display: none; }
.ufscan-panel.active {
    display: block;
    padding-top: 0.9rem;
    border-top: none;
}

/* ── Cards ───────────────────────────────────────────────────────────────── */
.ufscan-card {
    background: rgba(0,8,18,0.85);
    border: 1px solid rgba(0,200,255,0.1);
    border-radius: 2px;
    padding: 1rem 1.1rem;
    margin-bottom: 0.75rem;
    position: relative;
}
.ufscan-card:last-child { margin-bottom: 0; }
.ufscan-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,200,255,0.2), transparent);
}
.ufscan-card-title {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--lab-text-dim);
    margin-bottom: 0.8rem;
    font-weight: 700;
    font-family: var(--lab-mono);
}
.ufscan-card-title::before { content: '// '; opacity: 0.4; }
.ufscan-findings-count {
    display: inline-block;
    background: rgba(0,200,255,0.1);
    border: 1px solid rgba(0,200,255,0.2);
    border-radius: 2px;
    padding: 0.04rem 0.45rem;
    font-size: 0.65rem;
    margin-left: 0.5rem;
    font-family: var(--lab-mono);
    color: var(--lab-cyan);
}
.ufscan-summary-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

/* ── Findings ─────────────────────────────────────────────────────────────── */
.ufscan-findings { display: flex; flex-direction: column; gap: 0.4rem; }
.ufscan-finding {
    background: rgba(0,5,15,0.7);
    border-radius: 2px;
    padding: 0.6rem 0.9rem;
    border-left: 2px solid;
    position: relative;
}
.ufscan-finding.critical { border-color: var(--lab-red); background: rgba(255,34,68,0.04); }
.ufscan-finding.high     { border-color: #ff6622; background: rgba(255,102,34,0.04); }
.ufscan-finding.medium   { border-color: var(--lab-amber); background: rgba(255,170,0,0.04); }
.ufscan-finding.low      { border-color: var(--lab-cyan); background: rgba(0,200,255,0.03); }
.ufscan-finding.info     { border-color: rgba(0,200,255,0.12); }

.ufscan-find-meta   { display: flex; align-items: center; gap: 0.45rem; margin-bottom: 0.28rem; }
.ufscan-find-sev {
    font-size: 0.58rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.1rem 0.4rem;
    border-radius: 2px;
    font-weight: 800;
    flex-shrink: 0;
    font-family: var(--lab-mono);
}
.sev-pill-critical { background: rgba(255,34,68,0.15);    color: var(--lab-red); }
.sev-pill-high     { background: rgba(255,102,34,0.15);   color: #ff6622; }
.sev-pill-medium   { background: rgba(255,170,0,0.12);    color: var(--lab-amber); }
.sev-pill-low      { background: rgba(0,200,255,0.1);     color: var(--lab-cyan); }
.sev-pill-info     { background: rgba(74,122,154,0.12);   color: #4a7a9a; }

.ufscan-find-engine { font-size: 0.67rem; color: var(--lab-text-dim); font-family: var(--lab-mono); }
.ufscan-find-text   { font-size: 0.82rem; color: var(--lab-text); }
.ufscan-find-detail { font-size: 0.72rem; color: #5a8aaa; margin-top: 0.2rem; word-break: break-all; font-family: var(--lab-mono); }

/* ── Engine result cards ─────────────────────────────────────────────────── */
.ufscan-engine-results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
    gap: 0.45rem;
    margin-bottom: 0.75rem;
}
.ufscan-eng-card {
    background: rgba(0,8,18,0.8);
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
    padding: 0.75rem 0.9rem;
    cursor: pointer;
    transition: all 0.15s;
    position: relative;
}
.ufscan-eng-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,200,255,0.15), transparent);
}
.ufscan-eng-card:hover { border-color: rgba(0,200,255,0.25); background: rgba(0,200,255,0.04); }
.ufscan-eng-card.flagged { border-color: rgba(255,102,34,0.35); background: rgba(255,102,34,0.04); }
.ufscan-eng-card-name { font-size: 0.73rem; font-weight: 700; margin-bottom: 0.3rem; display: flex; align-items: center; gap: 0.35rem; font-family: var(--lab-mono); }
.ufscan-eng-num  { font-size: 0.65rem; color: var(--lab-text-dim); }
.ufscan-eng-dot  { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; box-shadow: 0 0 4px currentColor; }
.ufscan-eng-score { font-size: 1.4rem; font-weight: 900; line-height: 1; font-family: var(--lab-mono); text-shadow: 0 0 10px currentColor; }
.ufscan-eng-meta  { font-size: 0.63rem; color: var(--lab-text-dim); margin-top: 0.25rem; font-family: var(--lab-mono); }

/* Engine detail */
.ufscan-eng-detail {
    display: none;
    background: rgba(0,5,15,0.9);
    border: 1px solid rgba(0,200,255,0.15);
    border-radius: 2px;
    padding: 1rem 1.1rem;
    margin-top: 0.5rem;
}
.ufscan-eng-detail.visible { display: block; }
.ufscan-eng-detail-title { font-size: 0.85rem; font-weight: 700; margin-bottom: 0.8rem; font-family: var(--lab-mono); color: var(--lab-cyan); }

/* ── IOC panel ───────────────────────────────────────────────────────────── */
.ufscan-ioc-section { margin-bottom: 1rem; }
.ufscan-ioc-title {
    font-size: 0.63rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--lab-text-dim);
    margin-bottom: 0.4rem;
    font-weight: 700;
    font-family: var(--lab-mono);
}
.ufscan-ioc-items { display: flex; flex-direction: column; gap: 0.25rem; }
.ufscan-ioc-item {
    background: rgba(0,5,15,0.7);
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
    padding: 0.3rem 0.6rem;
    font-size: 0.74rem;
    word-break: break-all;
    font-family: var(--lab-mono);
    color: var(--lab-green);
    transition: border-color 0.15s;
}
.ufscan-ioc-item:hover { border-color: rgba(0,255,136,0.25); }

/* Hash rows */
.ufscan-hash-row {
    display: flex;
    gap: 0.9rem;
    align-items: baseline;
    padding: 0.4rem 0;
    border-bottom: 1px solid rgba(0,200,255,0.06);
}
.ufscan-hash-row:last-child { border-bottom: none; }
.ufscan-hash-lbl {
    font-size: 0.65rem;
    color: var(--lab-text-dim);
    width: 52px;
    flex-shrink: 0;
    font-weight: 700;
    font-family: var(--lab-mono);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.ufscan-hash-val {
    font-size: 0.7rem;
    word-break: break-all;
    font-family: var(--lab-mono);
    color: var(--lab-cyan);
    opacity: 0.8;
}

/* ── AI panel ─────────────────────────────────────────────────────────────── */
.ufscan-ai-card { text-align: center; padding: 1.5rem; }
.ufscan-ai-pill {
    display: inline-block;
    font-size: 1.3rem;
    font-weight: 900;
    letter-spacing: 0.14em;
    padding: 0.5rem 1.5rem;
    border-radius: 2px;
    margin-bottom: 0.75rem;
    font-family: var(--lab-mono);
}
.ufscan-ai-meta {
    font-size: 0.73rem;
    color: var(--lab-text-dim);
    margin-bottom: 0.75rem;
    font-family: var(--lab-mono);
}
.ufscan-ai-summary {
    font-size: 0.85rem;
    line-height: 1.75;
    max-width: 720px;
    margin: 0 auto 0.9rem;
    color: var(--lab-text);
}
.ufscan-ai-section-title {
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--lab-text-dim);
    margin: 0.9rem 0 0.5rem;
    font-weight: 700;
    font-family: var(--lab-mono);
}
.ufscan-ai-findings { text-align: left; max-width: 700px; margin: 0 auto; }
.ufscan-ai-finding {
    padding: 0.4rem 0;
    border-bottom: 1px solid rgba(0,200,255,0.06);
    font-size: 0.8rem;
    color: var(--lab-text);
}
.ufscan-ai-finding:last-child { border-bottom: none; }
.ufscan-ai-actions {
    list-style: none;
    text-align: left;
    max-width: 700px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}
.ufscan-ai-action { font-size: 0.8rem; color: var(--lab-text); }
.mitre-grid { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.5rem; justify-content: center; }
.mitre-pill {
    background: rgba(159,96,255,0.08);
    border: 1px solid rgba(159,96,255,0.25);
    border-radius: 2px;
    padding: 0.4rem 0.85rem;
    text-align: left;
}
.mitre-id   { font-size: 0.72rem; color: #b088ff; font-weight: 800; font-family: var(--lab-mono); }
.mitre-name { font-size: 0.62rem; color: var(--lab-text-dim); margin-top: 0.1rem; }

/* ── Raw JSON ─────────────────────────────────────────────────────────────── */
.ufscan-raw-json {
    background: #010810;
    border: 1px solid rgba(0,200,255,0.08);
    border-radius: 2px;
    padding: 0.9rem;
    overflow: auto;
    font-family: var(--lab-mono);
    font-size: 0.7rem;
    color: #5080a0;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 580px;
    background-image: var(--lab-scan-line);
}
.ufscan-raw-json::-webkit-scrollbar { width: 4px; }
.ufscan-raw-json::-webkit-scrollbar-thumb { background: rgba(0,200,255,0.2); border-radius: 2px; }

.ufscan-dl-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(0,200,255,0.05);
    border: 1px solid rgba(0,200,255,0.18);
    border-radius: 2px;
    padding: 0.45rem 1rem;
    font-size: 0.74rem;
    color: var(--lab-cyan);
    cursor: pointer;
    text-decoration: none;
    margin-bottom: 0.9rem;
    transition: all 0.15s;
    font-family: var(--lab-mono);
    letter-spacing: 0.06em;
}
.ufscan-dl-btn:hover {
    border-color: var(--lab-cyan);
    background: rgba(0,200,255,0.1);
    box-shadow: 0 0 12px rgba(0,200,255,0.08);
}

.ufscan-empty {
    text-align: center;
    padding: 2rem;
    color: var(--lab-text-dim);
    font-size: 0.8rem;
    font-family: var(--lab-mono);
}

/* ── Watermark panel ─────────────────────────────────────────────────────── */
.ufscan-wm-vendor-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.55rem 0;
    border-bottom: 1px solid rgba(0,200,255,0.06);
}
.ufscan-wm-vendor-row:last-child { border-bottom: none; }
.ufscan-wm-vendor-pill {
    flex-shrink: 0;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    padding: 0.22rem 0.65rem;
    border-radius: 2px;
    background: rgba(255,170,0,0.1);
    color: #fcd34d;
    border: 1px solid rgba(255,170,0,0.25);
    font-family: var(--lab-mono);
    text-transform: uppercase;
}
.ufscan-wm-vendor-detail { min-width: 0; }
.ufscan-wm-indicator {
    padding: 0.5rem 0.8rem;
    margin-bottom: 0.45rem;
    background: rgba(255,170,0,0.05);
    border-left: 2px solid var(--lab-amber);
    border-radius: 0 2px 2px 0;
    font-size: 0.8rem;
    color: var(--lab-text);
    line-height: 1.6;
}
.ufscan-wm-kv-grid { display: flex; flex-direction: column; gap: 0; }
.ufscan-wm-kv-row {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 0.6rem;
    padding: 0.4rem 0.2rem;
    border-bottom: 1px solid rgba(0,200,255,0.05);
    align-items: baseline;
}
.ufscan-wm-kv-row:last-child { border-bottom: none; }
.ufscan-wm-kv-key {
    font-size: 0.67rem;
    font-weight: 700;
    color: var(--lab-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    word-break: break-all;
    font-family: var(--lab-mono);
}
.ufscan-wm-kv-val { font-size: 0.8rem; color: var(--lab-text); word-break: break-word; }
.ufscan-wm-code {
    font-family: var(--lab-mono);
    color: #fcd34d;
    font-size: 0.76rem;
}
.ufscan-wm-kv-ctx { font-size: 0.68rem; color: var(--lab-text-dim); grid-column: 1 / -1; padding-top: 0.1rem; font-family: var(--lab-mono); }
.ufscan-wm-ocr-note { font-size: 0.72rem; color: var(--lab-text-dim); margin: 0 0 0.65rem; font-style: italic; font-family: var(--lab-mono); }
.ufscan-wm-ocr-line {
    padding: 0.42rem 0.7rem;
    margin-bottom: 0.3rem;
    background: rgba(255,170,0,0.05);
    border-left: 2px solid var(--lab-amber);
    border-radius: 0 2px 2px 0;
    font-size: 0.85rem;
    color: #fcd34d;
    font-family: var(--lab-mono);
    word-break: break-word;
}
.ufscan-wm-alpha-thumb-wrap {
    margin-top: 1rem;
    padding-top: 0.85rem;
    border-top: 1px solid rgba(0,200,255,0.08);
}
.ufscan-wm-alpha-thumb {
    display: block;
    max-width: 100%;
    border-radius: 2px;
    border: 1px solid rgba(255,170,0,0.2);
    background: #010810;
}

/* ── Sandbox panel ───────────────────────────────────────────────────────── */
.ufscan-sb-meta {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.5rem;
    margin-bottom: 1rem;
}
.ufscan-sb-meta-cell {
    background: rgba(255,34,68,0.05);
    border: 1px solid rgba(255,34,68,0.15);
    border-radius: 2px;
    padding: 0.5rem 0.7rem;
    text-align: center;
}
.ufscan-sb-meta-val { font-size: 1rem; font-weight: 700; color: #ff8899; display: block; font-family: var(--lab-mono); }
.ufscan-sb-meta-lbl {
    font-size: 0.62rem;
    color: var(--lab-text-dim);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    display: block;
    margin-top: 0.12rem;
    font-family: var(--lab-mono);
}
.ufscan-sb-critical {
    background: rgba(255,34,68,0.08);
    border-left: 2px solid var(--lab-red);
    border-radius: 0 2px 2px 0;
    padding: 0.45rem 0.75rem;
    font-size: 0.8rem;
    color: #ff8899;
    margin-bottom: 0.38rem;
    word-break: break-all;
    font-family: var(--lab-mono);
}
.ufscan-sb-clean {
    background: rgba(0,255,136,0.04);
    border-left: 2px solid var(--lab-green);
    border-radius: 0 2px 2px 0;
    padding: 0.45rem 0.75rem;
    font-size: 0.8rem;
    color: #80ffbb;
    font-family: var(--lab-mono);
}
.ufscan-sb-preview-img {
    display: block;
    max-width: 100%;
    border-radius: 2px;
    border: 1px solid rgba(255,34,68,0.18);
    background: #010810;
}
.ufscan-sb-syscall-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
    gap: 0.35rem;
}
.ufscan-sb-syscall-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(0,5,15,0.7);
    border: 1px solid rgba(0,200,255,0.06);
    border-radius: 2px;
    padding: 0.28rem 0.5rem;
    font-size: 0.75rem;
}
.ufscan-sb-syscall-name { color: #6a90b0; font-family: var(--lab-mono); }
.ufscan-sb-syscall-count { color: #ff8899; font-weight: 800; font-size: 0.68rem; font-family: var(--lab-mono); }
.ufscan-sb-warn {
    background: rgba(255,170,0,0.06);
    border-left: 2px solid var(--lab-amber);
    border-radius: 0 2px 2px 0;
    padding: 0.45rem 0.75rem;
    font-size: 0.8rem;
    color: #fde68a;
    margin-bottom: 0.38rem;
    word-break: break-all;
    font-family: var(--lab-mono);
}

/* Process tree */
.ufscan-sb-proc-tree { display: flex; flex-direction: column; gap: 0.18rem; }
.ufscan-sb-proc-row {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    flex-wrap: wrap;
    font-size: 0.77rem;
    padding: 0.22rem 0.4rem;
    border-radius: 2px;
}
.ufscan-sb-proc-benign  { background: rgba(0,5,15,0.6); color: #5a7a9a; }
.ufscan-sb-proc-suspect { background: rgba(255,34,68,0.06); color: #ff8899; }
.ufscan-sb-proc-exe     { font-family: var(--lab-mono); font-weight: 700; }
.ufscan-sb-proc-args    { color: var(--lab-text-dim); font-size: 0.68rem; font-family: var(--lab-mono); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ufscan-sb-proc-pid     { font-size: 0.63rem; color: #2a3a50; margin-left: auto; white-space: nowrap; font-family: var(--lab-mono); }

/* Library calls */
.ufscan-sb-lib-grid { display: flex; flex-direction: column; gap: 0.22rem; }
.ufscan-sb-lib-row {
    display: grid;
    grid-template-columns: 155px 2.8rem 1fr;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.77rem;
    padding: 0.28rem 0.5rem;
    border-radius: 2px;
    background: rgba(0,5,15,0.6);
    border: 1px solid rgba(0,200,255,0.04);
}
.ufscan-sb-lib-danger { background: rgba(255,34,68,0.06); border-color: rgba(255,34,68,0.1); }
.ufscan-sb-lib-func { font-family: var(--lab-mono); font-weight: 700; color: #8ab0c8; }
.ufscan-sb-lib-danger .ufscan-sb-lib-func { color: #ff8899; }
.ufscan-sb-lib-count { font-size: 0.68rem; font-weight: 800; color: #ff8822; text-align: right; font-family: var(--lab-mono); }
.ufscan-sb-lib-args { font-size: 0.68rem; color: var(--lab-text-dim); font-family: var(--lab-mono); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Scrollbar ────────────────────────────────────────────────────────────── */
.ufscan-console-body::-webkit-scrollbar,
.ufscan-raw-json::-webkit-scrollbar { width: 4px; }
.ufscan-console-body::-webkit-scrollbar-track,
.ufscan-raw-json::-webkit-scrollbar-track { background: transparent; }

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .ufscan-sb-lib-row { grid-template-columns: 110px 2.5rem 1fr; }
    .ufscan-stats-bar  { grid-template-columns: repeat(3, 1fr); }
    .ufscan-summary-grid { grid-template-columns: 1fr; }
    .ufscan-verdict    { flex-wrap: wrap; }
    .ufscan-verdict-score { margin-left: 0; }
    .ufscan-tabs { gap: 2px; }
    .ufscan-tab  { padding: 0.38rem 0.65rem; font-size: 0.65rem; }
}
@media (max-width: 480px) {
    .ufscan-wm-kv-row { grid-template-columns: 1fr; }
    .ufscan-wm-kv-ctx { grid-column: 1; }
    .ufscan-stats-bar { grid-template-columns: repeat(2, 1fr); }
}
