* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

:root {
    /* KORUM-OS Design System v1.0 */
    --bg-base: #0A0A0A;
    --bg-gradient-start: #141414;
    --bg-gradient-end: #000000;
    --surface-black: #141414;
    --surface-elevated: #1E1E1E;
    --panel-bg: linear-gradient(180deg, rgba(30, 30, 30, 0.98), rgba(20, 20, 20, 0.98));

    --text-primary: #E8E8EC;
    --text-secondary: #C8C8CC;
    --text-tertiary: #6B6B6B;
    --accent-taupe: #C8C8CC;
    --accent-gold: #F5A800;
    --accent-gold-deep: #C47D00;
    --accent-gold-bright: #FFD166;
    --accent-green: #4CAF7D;
    --accent-red: #FF4D4D;
    --accent-warning: #E8B84B;
    --border-subtle: #2A2A2A;
    --dock-resting-height: 76px;

    --font-head: 'Outfit', sans-serif;
    --font-body: 'Inter', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;

    /* Utility UI Colors */
    --ui-sys-dim: #3D3D3D;
    --active-accent: #F5A800;
    --active-glow: rgba(245, 168, 0, 0.24);

    /* Readability scale */
    --ui-xs: 12px;
    --ui-sm: 13px;
    --ui-md: 14px;
}

/* SVG Layer Infrastructure */
.lightning-layer {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 4;
    pointer-events: none;
}

.orbit-rings {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

/* Telemetry Logic Tags */
.log-sys-tag {
    color: var(--ui-sys-dim);
}


/* Accessibility: Strong keyboard focus */
a:focus-visible,
button:focus-visible,
.deck-card:focus-visible,
.mode-btn:focus-visible,
.comms-tab:focus-visible,
.dock-action:focus-visible {
    outline: 2px solid var(--accent-green);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(0, 255, 157, 0.2);
}

/* Control Readability: Avoid tiny type */
.nav-links a,
.deck-avatar,
.deck-title,
.mode-btn,
.comms-tab,
.dock-action {
    font-size: var(--ui-xs);
}

body {
    background-color: var(--bg-base);
    background-image:
        radial-gradient(circle at 50% -10%, rgba(245, 168, 0, 0.05), transparent 25%),
        radial-gradient(circle at 60% 40%, #171717 0%, #000 100%);
    color: var(--text-primary);
    font-family: var(--font-body);
    height: 100vh;
    overflow-x: hidden;
    overflow-y: hidden;
    /* Controlled by media queries on mobile */
    display: flex;
    justify-content: center;
    align-items: center;
}

.screen-container {
    width: 100vw;
    height: 100vh;
    max-width: 100%;
    max-height: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    padding: 12px;
    background: linear-gradient(180deg, rgba(10, 10, 10, 0.78), rgba(6, 6, 6, 0.92));
    box-shadow: inset 0 0 100px rgba(0, 0, 0, 0.55);
    overflow-x: hidden;
    overflow-y: visible;
}

.mission-flow-strip {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
    transition: all 0.3s ease;
}

@media (max-height: 800px) {
    .mission-flow-strip {
        gap: 6px;
        margin-bottom: 8px;
    }
    .mission-flow-step {
        min-height: 48px !important;
        padding: 6px 10px !important;
    }
    .flow-copy {
        display: none !important; /* Hide copy to save major vertical space */
    }
    .flow-index {
        font-size: 8px !important;
    }
    .flow-title {
        font-size: 10px !important;
    }
}

.mission-flow-step {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-height: 76px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(200, 200, 204, 0.12);
    background: linear-gradient(180deg, rgba(30, 30, 30, 0.96), rgba(18, 18, 18, 0.96));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
    transition: all 0.3s ease;
}

.mission-flow-step.is-complete {
    border-color: rgba(76, 175, 125, 0.18);
    background: linear-gradient(180deg, rgba(28, 36, 31, 0.96), rgba(18, 24, 20, 0.96));
}

.mission-flow-step.is-active {
    border-color: rgba(245, 168, 0, 0.24);
    background: linear-gradient(180deg, rgba(45, 33, 12, 0.98), rgba(24, 18, 10, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 209, 102, 0.08);
}

.mission-flow-step.processing {
    border-color: rgba(245, 168, 0, 0.35);
    background: linear-gradient(180deg, rgba(45, 33, 12, 0.98), rgba(24, 18, 10, 0.98));
    animation: flowStepPulse 2s ease-in-out infinite;
}

@keyframes flowStepPulse {
    0%, 100% { box-shadow: inset 0 1px 0 rgba(255, 209, 102, 0.08); }
    50% { box-shadow: inset 0 1px 0 rgba(255, 209, 102, 0.08), 0 0 12px rgba(245, 168, 0, 0.15); }
}

.mission-flow-step.is-complete .flow-index::after {
    content: ' \2713';
    color: rgba(76, 175, 125, 0.7);
}

.flow-index,
.flow-title {
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.flow-index {
    color: var(--text-tertiary);
    font-size: 10px;
}

.flow-title {
    color: var(--text-primary);
    font-size: 12px;
    font-weight: 700;
}

.flow-copy {
    color: var(--text-secondary);
    font-size: 11px;
    line-height: 1.45;
}

/* TOP BAR */
.top-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    z-index: 100;
    gap: 12px; /* Reduced from 20px */
    padding: 0 4px;
    height: 60px;
}

.top-bar-wordmark {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
}

.top-bar-wordmark-img {
    height: 54px;
    width: auto;
    display: block;
    opacity: 0.92;
    filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.1));
}

.mobile-nav-toggle {
    display: none;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 8px;
    padding: 6px;
    cursor: pointer;
}

.nav-links {
    flex: 1;
    min-width: 0;
    display: flex;
    gap: 6px;
    flex-wrap: nowrap;
    overflow: visible;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
}

.nav-links::-webkit-scrollbar {
    display: none;
}

.rfp-intel-report {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.rfp-intel-hero,
.rfp-summary-grid,
.rfp-two-up,
.rfp-truth-grid {
    display: grid;
    gap: 14px;
}

.rfp-intel-hero {
    grid-template-columns: 1fr auto;
    align-items: start;
    padding: 18px;
    border: 1px solid rgba(245, 168, 0, 0.16);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(31, 24, 15, 0.96), rgba(16, 14, 10, 0.98));
}

.rfp-intel-hero h2 {
    margin: 4px 0 6px;
    font-size: 24px;
    font-family: var(--font-head);
    letter-spacing: 0.04em;
}

.rfp-kicker,
.rfp-subhead,
.rfp-panel-title,
.rfp-stat-label,
.rfp-mini-title,
.rfp-response-id,
.rfp-footnote {
    font-family: var(--font-mono);
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.rfp-kicker,
.rfp-panel-title,
.rfp-mini-title,
.rfp-response-id {
    color: rgba(245, 168, 0, 0.72);
    font-size: 11px;
}

.rfp-subhead,
.rfp-footnote {
    color: var(--text-secondary);
    font-size: 11px;
}

.rfp-readiness-pill,
.rfp-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 6px 12px;
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.rfp-readiness-pill.readiness-ready_for_review {
    color: #4CAF7D;
    border-color: rgba(76, 175, 125, 0.28);
    background: rgba(76, 175, 125, 0.12);
}

.rfp-readiness-pill.readiness-needs_input {
    color: #FFD166;
    border-color: rgba(255, 209, 102, 0.28);
    background: rgba(255, 209, 102, 0.1);
}

.rfp-readiness-pill.readiness-at_risk,
.rfp-chip.risk-high,
.rfp-chip.status-missing {
    color: #FF6B6B;
    border-color: rgba(255, 107, 107, 0.28);
    background: rgba(255, 107, 107, 0.1);
}

.rfp-readiness-pill.readiness-draft,
.rfp-chip.status-unknown {
    color: #C8C8CC;
    border-color: rgba(200, 200, 204, 0.2);
    background: rgba(200, 200, 204, 0.08);
}

/* Win Likelihood Badge */
.rfp-hero-badges {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}

.rfp-win-likelihood {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    border-radius: 8px;
    padding: 6px 12px;
    font-family: var(--font-mono);
    border: 1px solid rgba(255, 255, 255, 0.1);
    min-width: 100px;
}

.rfp-win-label {
    font-size: 9px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 2px;
}

.rfp-win-value {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.rfp-win-likelihood.win-low {
    color: #FF6B6B;
    border-color: rgba(255, 107, 107, 0.3);
    background: rgba(255, 107, 107, 0.08);
}

.rfp-win-likelihood.win-medium {
    color: #FFD166;
    border-color: rgba(255, 209, 102, 0.3);
    background: rgba(255, 209, 102, 0.08);
}

.rfp-win-likelihood.win-high {
    color: #4CAF7D;
    border-color: rgba(76, 175, 125, 0.3);
    background: rgba(76, 175, 125, 0.08);
}

.rfp-win-driver {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 0.06em;
    padding: 6px 12px;
    border-left: 2px solid rgba(255, 255, 255, 0.12);
    margin-bottom: 4px;
}

.rfp-win-driver-label {
    color: rgba(245, 168, 0, 0.6);
    font-weight: 700;
    margin-right: 6px;
}

.rfp-chip.status-full {
    color: #4CAF7D;
    border-color: rgba(76, 175, 125, 0.25);
    background: rgba(76, 175, 125, 0.1);
}

.rfp-chip.status-partial,
.rfp-chip.risk-medium {
    color: #FFD166;
    border-color: rgba(255, 209, 102, 0.25);
    background: rgba(255, 209, 102, 0.08);
}

.rfp-chip.risk-low {
    color: #8BE28B;
    border-color: rgba(139, 226, 139, 0.24);
    background: rgba(139, 226, 139, 0.08);
}

.rfp-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rfp-stat-card,
.rfp-panel,
.rfp-response-card {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(24, 24, 24, 0.96), rgba(14, 14, 14, 0.98));
}

.rfp-stat-card {
    padding: 14px 16px;
}

.rfp-stat-value {
    margin-top: 8px;
    font-size: 26px;
    color: var(--text-primary);
    font-family: var(--font-head);
}

.rfp-stat-value.rfp-stat-value-state {
    font-size: 15px;
    line-height: 1.5;
    color: var(--text-secondary);
    font-family: var(--font-body);
    max-width: 220px;
}

.rfp-panel {
    padding: 16px 18px;
}

.rfp-panel-body {
    color: var(--text-primary);
    line-height: 1.7;
}

.rfp-inline-callout {
    margin-top: 12px;
    padding: 12px 14px;
    border-left: 2px solid rgba(245, 168, 0, 0.35);
    background: rgba(245, 168, 0, 0.06);
    color: var(--text-primary);
}

.rfp-pursue-panel .rfp-pursue-title {
    color: rgba(76, 175, 125, 0.8);
}

.rfp-pursue-panel {
    border-left: 2px solid rgba(76, 175, 125, 0.25);
}

.rfp-dnp-panel .rfp-dnp-title {
    color: rgba(255, 107, 107, 0.8);
}

.rfp-dnp-panel {
    border-left: 2px solid rgba(255, 107, 107, 0.25);
}

.rfp-two-up,
.rfp-truth-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.rfp-bullet-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.rfp-bullet-item,
.rfp-empty-note {
    color: var(--text-secondary);
    line-height: 1.6;
    font-size: 13px;
}

.rfp-bullet-item::before {
    content: "•";
    color: var(--accent-gold);
    margin-right: 8px;
}

.rfp-meta-list {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
}

.rfp-meta-list div {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.rfp-meta-list span {
    color: var(--text-tertiary);
    font-size: 12px;
}

.rfp-meta-list strong {
    color: var(--text-primary);
    font-size: 12px;
    text-align: right;
}

.rfp-table-wrap {
    overflow-x: auto;
}

.rfp-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 860px;
}

.rfp-table th,
.rfp-table td {
    padding: 12px 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    text-align: left;
    vertical-align: top;
    font-size: 12px;
}

.rfp-table th {
    color: rgba(245, 168, 0, 0.82);
    font-family: var(--font-mono);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 10px;
}

.rfp-req-title,
.rfp-response-title {
    color: var(--text-primary);
    font-weight: 600;
    margin-bottom: 4px;
}

.rfp-req-meta,
.rfp-source-meta {
    color: var(--text-tertiary);
    font-size: 11px;
}

.rfp-table-state {
    color: var(--text-secondary);
    font-size: 11px;
}

.rfp-response-stack {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.rfp-response-card {
    padding: 16px;
}

.rfp-response-header {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: start;
    margin-bottom: 10px;
}

.rfp-response-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.rfp-response-body {
    margin: 12px 0;
    color: var(--text-primary);
    line-height: 1.7;
}

@media (max-width: 980px) {
    .rfp-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .rfp-two-up,
    .rfp-truth-grid,
    .rfp-intel-hero {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .rfp-summary-grid {
        grid-template-columns: 1fr;
    }
}

/* ── Mega-Category Dropdown Nav ─────────────────────────────────── */
.nav-group {
    position: relative;
    flex: 0 0 auto;
}

.nav-group-btn {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
    font-family: var(--font-mono);
}

.nav-group-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.25);
    color: var(--text-primary);
}

/* Group button color accents */
.nav-group-btn[data-group="business"] { color: #FF3C3C; border-color: rgba(255, 60, 60, 0.25); }
.nav-group-btn[data-group="creative"] { color: #FF64C8; border-color: rgba(255, 100, 200, 0.25); }
.nav-group-btn[data-group="security"] { color: #E03030; border-color: rgba(224, 48, 48, 0.25); }
.nav-group-btn[data-group="intelligence"] { color: #64C8B4; border-color: rgba(100, 200, 180, 0.25); }
.nav-group-btn[data-group="compliance"] { color: #FFA032; border-color: rgba(255, 160, 50, 0.25); }

/* Active group button — solid fill */
.nav-group-btn.active[data-group="business"] { background: rgba(255, 60, 60, 0.15); border-color: rgba(255, 60, 60, 0.5); box-shadow: 0 0 12px rgba(255, 60, 60, 0.2); }
.nav-group-btn.active[data-group="creative"] { background: rgba(255, 100, 200, 0.15); border-color: rgba(255, 100, 200, 0.5); box-shadow: 0 0 12px rgba(255, 100, 200, 0.2); }
.nav-group-btn.active[data-group="security"] { background: rgba(224, 48, 48, 0.15); border-color: rgba(224, 48, 48, 0.5); box-shadow: 0 0 12px rgba(224, 48, 48, 0.2); }
.nav-group-btn.active[data-group="intelligence"] { background: rgba(100, 200, 180, 0.15); border-color: rgba(100, 200, 180, 0.5); box-shadow: 0 0 12px rgba(100, 200, 180, 0.2); }
.nav-group-btn.active[data-group="compliance"] { background: rgba(255, 160, 50, 0.15); border-color: rgba(255, 160, 50, 0.5); box-shadow: 0 0 12px rgba(255, 160, 50, 0.2); }

/* Dropdown panel */
.nav-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 160px;
    background: rgba(12, 12, 18, 0.96);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 6px;
    padding-top: 10px;
    flex-direction: column;
    gap: 3px;
    z-index: 100;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6);
}

/* Invisible bridge so mouse can travel from button to dropdown */
.nav-dropdown::after {
    content: '';
    position: absolute;
    top: -8px;
    left: 0;
    right: 0;
    height: 8px;
}

/* Show on hover (desktop) */
.nav-group:hover .nav-dropdown,
.nav-group.open .nav-dropdown {
    display: flex;
}

/* Dropdown arrow */
.nav-dropdown::before {
    content: '';
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    background: rgba(12, 12, 18, 0.96);
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* Workflow links inside dropdown */
.nav-dropdown a {
    display: flex;
    align-items: center;
    padding: 8px 14px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: 5px;
    transition: all 0.15s;
    text-decoration: none;
    color: var(--text-secondary);
    background: transparent;
    border: 1px solid transparent;
    white-space: nowrap;
}

.nav-dropdown a:hover {
    background: rgba(255, 255, 255, 0.08);
    color: var(--text-primary);
}

.nav-dropdown a.active {
    color: #000;
    font-weight: 700;
}

.top-bar-utilities {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 8px;
    z-index: 10;
    padding-left: 10px;
    border-left: 1px solid rgba(255, 255, 255, 0.05); /* Clean divider instead of gradient */
}

.auth-user-email {
    display: inline-block; /* Required for max-width to work on span */
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 11px;
    color: var(--text-tertiary);
    font-family: var(--font-mono);
    vertical-align: middle;
}

.nav-links a {
    text-decoration: none;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 6px 12px;
    border-radius: 6px;
    transition: all 0.2s;
    white-space: nowrap;
}

.nav-links a:hover,
.nav-links a.active,
.nav-links a:focus-visible {
    background: var(--text-primary);
    color: #000;
    border-color: #FFF;
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.4);
}

@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    .mobile-nav-toggle {
        display: block !important;
        position: relative;
        z-index: 1001;
    }

    /* 
       Updated: Only apply these vertical stacking styles if the screen is narrow 
       AND it's NOT a desktop-class device (hover: none) OR the mobile nav is explicitly open.
    */
    .nav-links.mobile-open {
        display: flex !important;
        position: fixed !important;
        top: 0;
        right: 0;
        width: 100%;
        height: 100%;
        background: rgba(10, 10, 15, 0.98) !important;
        backdrop-filter: blur(20px);
        flex-direction: column !important;
        justify-content: flex-start !important;
        align-items: center !important;
        z-index: 1000;
        gap: 10px !important;
        padding: 60px 20px 40px !important;
        animation: fadeIn 0.3s ease;
        overflow-y: auto;
    }

    /* Mobile: groups stack vertically */
    .nav-links.mobile-open .nav-group {
        width: 90%;
    }

    .nav-links.mobile-open .nav-group-btn {
        width: 100%;
        font-size: 14px;
        padding: 12px 16px;
        text-align: left;
    }

    /* Mobile: dropdowns are inline (not absolute) */
    .nav-links.mobile-open .nav-dropdown {
        position: static !important;
        transform: none !important;
        display: none;
        background: rgba(255, 255, 255, 0.02);
        border: none;
        border-left: 2px solid rgba(255, 255, 255, 0.1);
        border-radius: 0;
        margin: 4px 0 4px 12px;
        padding: 4px 0;
        box-shadow: none;
        backdrop-filter: none;
    }

    .nav-links.mobile-open .nav-dropdown::before {
        display: none;
    }

    .nav-links.mobile-open .nav-group.open .nav-dropdown {
        display: flex;
    }

    .nav-links.mobile-open .nav-dropdown a {
        font-size: 13px !important;
        padding: 10px 16px !important;
    }

    @keyframes fadeIn {
        from { opacity: 0; transform: translateY(-10px); }
        to { opacity: 1; transform: translateY(0); }
    }
}

/* Defense & Intelligence */
.nav-links a[data-role="Defense Council"] {
    border-color: rgba(120, 180, 50, 0.3);
    color: #7AB432;
}

.nav-links a[data-role="Cyber Command"] {
    border-color: rgba(255, 50, 50, 0.3);
    color: #E03030;
}

.nav-links a[data-role="Intel Brief"] {
    border-color: rgba(255, 180, 0, 0.3);
    color: #D4A017;
}

/* Preset Color Coding — resting state tint (always visible) */
.nav-links a[data-role="War Room"] {
    border-color: rgba(255, 60, 60, 0.3);
    color: #FF3C3C;
}
.nav-links a[data-role="Deep Research"] {
    border-color: rgba(100, 200, 180, 0.3);
    color: #64C8B4;
}
.nav-links a[data-role="Creative Council"] {
    border-color: rgba(255, 100, 200, 0.3);
    color: #FF64C8;
}
.nav-links a[data-role="Code Audit"] {
    border-color: rgba(255, 160, 50, 0.3);
    color: #FFA032;
}
.nav-links a[data-role="System Core"] {
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.7);
}
.nav-links a[data-role="Legal Review"] {
    border-color: rgba(255, 191, 0, 0.3);
    color: #FFBF00;
}
.nav-links a[data-role="Medical Council"] {
    border-color: rgba(255, 70, 70, 0.3);
    color: #FF4646;
}
.nav-links a[data-role="Finance Desk"] {
    border-color: rgba(0, 255, 157, 0.3);
    color: var(--accent-green);
}
.nav-links a[data-role="Science Panel"] {
    border-color: rgba(80, 140, 255, 0.3);
    color: #508CFF;
}
.nav-links a[data-role="Startup Launch"] {
    border-color: rgba(180, 100, 255, 0.3);
    color: #B464FF;
}
.nav-links a[data-role="Tech Council"] {
    border-color: rgba(0, 220, 255, 0.3);
    color: #00DCFF;
}
.nav-links a[data-role="Quantum Security"] {
    border-color: rgba(245, 168, 0, 0.3);
    color: #F5A800;
}
/* New workflow tabs */
.nav-links a[data-role="Social Post"] {
    border-color: rgba(29, 161, 242, 0.3);
    color: #1DA1F2;
}
.nav-links a[data-role="Capital Control"] {
    border-color: rgba(0, 255, 157, 0.3);
    color: var(--accent-green);
}
.nav-links a[data-role="Portfolio Builder"] {
    border-color: rgba(180, 100, 255, 0.3);
    color: #B464FF;
}
.nav-links a[data-role="Genealogy"] {
    border-color: rgba(200, 160, 110, 0.3);
    color: #C8A06E;
}
.nav-links a[data-role="Risk Exposure"] {
    border-color: rgba(255, 100, 50, 0.3);
    color: #FF6432;
}
.nav-links a[data-role="Sales & Marketing"] {
    border-color: rgba(0, 204, 136, 0.3);
    color: #00CC88;
}
.nav-links a[data-role="Telco Command"] {
    border-color: rgba(0, 191, 255, 0.3);
    color: #00BFFF;
}
.nav-links a[data-role="Proposal Analyzer"] {
    border-color: rgba(245, 168, 0, 0.3);
    color: #F5A800;
}
.nav-links a[data-role="Crypto Assets"] {
    border-color: rgba(255, 215, 0, 0.3);
    color: #FFD700;
}
.nav-links a[data-role="Real Estate"] {
    border-color: rgba(180, 140, 50, 0.3);
    color: #B48C32;
}
.nav-links a[data-role="Govt Policy"] {
    border-color: rgba(123, 104, 238, 0.3);
    color: #7B68EE;
}

/* Preset Color Coding — active/hover glow */
/* General */
.nav-links a[data-role="War Room"]:hover,
.nav-links a[data-role="War Room"].active {
    background: #FF3C3C;
    color: #000;
    border-color: #FF3C3C;
    box-shadow: 0 0 15px rgba(255, 60, 60, 0.4);
}

.nav-links a[data-role="Deep Research"]:hover,
.nav-links a[data-role="Deep Research"].active {
    background: #64C8B4;
    color: #000;
    border-color: #64C8B4;
    box-shadow: 0 0 15px rgba(100, 200, 180, 0.4);
}

.nav-links a[data-role="Creative Council"]:hover,
.nav-links a[data-role="Creative Council"].active {
    background: #FF64C8;
    color: #000;
    border-color: #FF64C8;
    box-shadow: 0 0 15px rgba(255, 100, 200, 0.4);
}

.nav-links a[data-role="Code Audit"]:hover,
.nav-links a[data-role="Code Audit"].active {
    background: #FFA032;
    color: #000;
    border-color: #FFA032;
    box-shadow: 0 0 15px rgba(255, 160, 50, 0.4);
}

.nav-links a[data-role="System Core"]:hover,
.nav-links a[data-role="System Core"].active {
    background: #FFFFFF;
    color: #000;
    border-color: #FFF;
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.4);
}

/* Domain */
.nav-links a[data-role="Legal Review"]:hover,
.nav-links a[data-role="Legal Review"].active {
    background: #FFBF00;
    color: #000;
    border-color: #FFBF00;
    box-shadow: 0 0 15px rgba(255, 191, 0, 0.4);
}

.nav-links a[data-role="Medical Council"]:hover,
.nav-links a[data-role="Medical Council"].active {
    background: #FF4646;
    color: #000;
    border-color: #FF4646;
    box-shadow: 0 0 15px rgba(255, 70, 70, 0.4);
}

.nav-links a[data-role="Finance Desk"]:hover,
.nav-links a[data-role="Finance Desk"].active {
    background: var(--accent-green);
    color: #000;
    border-color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.4);
}

.nav-links a[data-role="Science Panel"]:hover,
.nav-links a[data-role="Science Panel"].active {
    background: #508CFF;
    color: #000;
    border-color: #508CFF;
    box-shadow: 0 0 15px rgba(80, 140, 255, 0.4);
}

.nav-links a[data-role="Startup Launch"]:hover,
.nav-links a[data-role="Startup Launch"].active {
    background: #B464FF;
    color: #000;
    border-color: #B464FF;
    box-shadow: 0 0 15px rgba(180, 100, 255, 0.4);
}

.nav-links a[data-role="Tech Council"]:hover,
.nav-links a[data-role="Tech Council"].active {
    background: #00DCFF;
    color: #000;
    border-color: #00DCFF;
    box-shadow: 0 0 15px rgba(0, 220, 255, 0.4);
}

/* Defense & Intelligence */
.nav-links a[data-role="Defense Council"]:hover,
.nav-links a[data-role="Defense Council"].active {
    background: #7AB432;
    color: #000;
    border-color: #7AB432;
    box-shadow: 0 0 15px rgba(120, 180, 50, 0.5);
}

.nav-links a[data-role="Cyber Command"]:hover,
.nav-links a[data-role="Cyber Command"].active {
    background: #E03030;
    color: #FFF;
    border-color: #E03030;
    box-shadow: 0 0 15px rgba(255, 50, 50, 0.5);
}

.nav-links a[data-role="Intel Brief"]:hover,
.nav-links a[data-role="Intel Brief"].active {
    background: #D4A017;
    color: #000;
    border-color: #D4A017;
    box-shadow: 0 0 15px rgba(255, 180, 0, 0.5);
}

.nav-links a[data-role="Quantum Security"]:hover,
.nav-links a[data-role="Quantum Security"].active {
    background: #F5A800;
    color: #000;
    border-color: #F5A800;
    box-shadow: 0 0 15px rgba(245, 168, 0, 0.5);
}

/* New workflow active/hover glows */
.nav-links a[data-role="Social Post"]:hover,
.nav-links a[data-role="Social Post"].active {
    background: #1DA1F2;
    color: #000;
    border-color: #1DA1F2;
    box-shadow: 0 0 15px rgba(29, 161, 242, 0.4);
}
.nav-links a[data-role="Capital Control"]:hover,
.nav-links a[data-role="Capital Control"].active {
    background: var(--accent-green);
    color: #000;
    border-color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.4);
}
.nav-links a[data-role="Portfolio Builder"]:hover,
.nav-links a[data-role="Portfolio Builder"].active {
    background: #B464FF;
    color: #000;
    border-color: #B464FF;
    box-shadow: 0 0 15px rgba(180, 100, 255, 0.4);
}
.nav-links a[data-role="Genealogy"]:hover,
.nav-links a[data-role="Genealogy"].active {
    background: #C8A06E;
    color: #000;
    border-color: #C8A06E;
    box-shadow: 0 0 15px rgba(200, 160, 110, 0.4);
}
.nav-links a[data-role="Risk Exposure"]:hover,
.nav-links a[data-role="Risk Exposure"].active {
    background: #FF6432;
    color: #000;
    border-color: #FF6432;
    box-shadow: 0 0 15px rgba(255, 100, 50, 0.4);
}
.nav-links a[data-role="Sales & Marketing"]:hover,
.nav-links a[data-role="Sales & Marketing"].active {
    background: #00CC88;
    color: #000;
    border-color: #00CC88;
    box-shadow: 0 0 15px rgba(0, 204, 136, 0.4);
}
.nav-links a[data-role="Telco Command"]:hover,
.nav-links a[data-role="Telco Command"].active {
    background: #00BFFF;
    color: #000;
    border-color: #00BFFF;
    box-shadow: 0 0 15px rgba(0, 191, 255, 0.4);
}
.nav-links a[data-role="Proposal Analyzer"]:hover,
.nav-links a[data-role="Proposal Analyzer"].active {
    background: #F5A800;
    color: #000;
    border-color: #F5A800;
    box-shadow: 0 0 15px rgba(245, 168, 0, 0.4);
}
.nav-links a[data-role="Crypto Assets"]:hover,
.nav-links a[data-role="Crypto Assets"].active {
    background: #FFD700;
    color: #000;
    border-color: #FFD700;
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.4);
}
.nav-links a[data-role="Real Estate"]:hover,
.nav-links a[data-role="Real Estate"].active {
    background: #B48C32;
    color: #000;
    border-color: #B48C32;
    box-shadow: 0 0 15px rgba(180, 140, 50, 0.4);
}
.nav-links a[data-role="Govt Policy"]:hover,
.nav-links a[data-role="Govt Policy"].active {
    background: #7B68EE;
    color: #000;
    border-color: #7B68EE;
    box-shadow: 0 0 15px rgba(123, 104, 238, 0.4);
}

/* LAYOUT */
.dashboard-grid {
    display: grid;
    grid-template-columns: minmax(400px, 430px) minmax(0, 1fr) minmax(380px, 430px);
    gap: 14px;
    height: calc(100% - 136px - var(--dock-resting-height));
    position: relative;
    overflow: hidden;
    transition: grid-template-columns 0.4s ease;
}

@media (max-width: 1600px) {
    .dashboard-grid {
        grid-template-columns: minmax(360px, 400px) minmax(0, 1fr) minmax(340px, 400px);
        gap: 12px;
    }
}

@media (max-width: 1440px) {
    .dashboard-grid {
        grid-template-columns: minmax(330px, 360px) minmax(0, 1fr) minmax(320px, 360px);
        gap: 10px;
    }
    .panel {
        padding: 16px !important;
    }
}

@media (max-width: 1366px) {
    .dashboard-grid {
        grid-template-columns: minmax(300px, 340px) minmax(0, 1fr) minmax(280px, 340px);
        gap: 10px;
    }
    .top-bar-wordmark-img {
        height: 28px !important;
    }
    .nav-links a {
        padding: 6px 10px !important;
        font-size: 10px !important;
    }
    .panel {
        padding: 14px !important;
    }
}

@media (max-width: 1280px) {
    .dashboard-grid {
        grid-template-columns: minmax(300px, 330px) minmax(0, 1fr) minmax(280px, 330px);
        gap: 8px;
    }
    .panel {
        padding: 14px !important;
    }
    .mission-flow-strip {
        gap: 6px !important;
    }
    .mission-flow-step {
        padding: 8px 10px !important;
        min-height: 64px !important;
    }
    .flow-title {
        font-size: 11px !important;
    }
    .flow-copy {
        font-size: 10px !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
}

.panel {
    display: flex;
    flex-direction: column;
    background: var(--panel-bg);
    border: 1px solid rgba(200, 200, 204, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), inset 0 -1px 0 rgba(0, 0, 0, 0.55), 0 10px 28px rgba(0, 0, 0, 0.28);
    border-radius: 16px;
    padding: 24px;
    will-change: opacity, transform;
    transition: all 0.3s ease;
    min-height: 0;
    overflow: hidden; /* Contain children */
}

.control-stack, .sentinel-wrapper, .comms-activity-feed {
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.sentinel-scroll-area {
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 0;
    flex: 1;
}

.comms-panel {
    display: none;
    min-height: 0;
}

.comms-panel.active {
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
}

.sentinel-card.is-dock-mode .sentinel-input-top,
.sentinel-card.is-dock-mode #followupSpotlight,
.sentinel-card.is-dock-mode #commsThreadSummary,
.sentinel-card.is-dock-mode #revisionImpactStrip,
.sentinel-card.is-dock-mode #commsActivityFeed,
.sentinel-card.is-dock-mode #commsChatPanel {
    display: none !important;
}

.sentinel-card.is-dock-mode #researchDock {
    display: flex !important;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.dock-toolbar {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}

.followup-spotlight {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px 16px;
    border: 1px solid rgba(232, 232, 236, 0.14);
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(26, 28, 31, 0.98), rgba(14, 15, 18, 0.98));
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.03), 0 10px 26px rgba(0,0,0,0.24);
}

.followup-spotlight-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.followup-spotlight-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.followup-spotlight-label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(245, 168, 0, 0.84);
}

.followup-spotlight-open, .followup-spotlight-dock {
    border: 1px solid rgba(245, 168, 0, 0.25);
    background: rgba(245, 168, 0, 0.08);
    color: #F5A800;
    border-radius: 999px;
    padding: 5px 12px;
    font-size: 10px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.followup-spotlight-dock {
    border-color: rgba(0, 255, 157, 0.25);
    background: rgba(0, 255, 157, 0.08);
    color: var(--accent-green);
}

.followup-spotlight-update {
    border: 1px solid rgba(102, 217, 255, 0.3);
    background: rgba(102, 217, 255, 0.08);
    color: #66D9FF;
    border-radius: 999px;
    padding: 5px 12px;
    font-size: 10px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.followup-spotlight-open:hover, .followup-spotlight-dock:hover, .followup-spotlight-update:hover {
    filter: brightness(1.2);
    box-shadow: 0 0 10px rgba(245, 168, 0, 0.1);
}

.followup-spotlight-dock:disabled,
.followup-spotlight-update:disabled {
    opacity: 0.6;
    cursor: default;
    filter: none;
}

.followup-file-preview {
    margin-top: 10px;
}

.file-preview-bar {
    display: none;
    flex-wrap: wrap;
    gap: 8px;
}

.file-preview-bar.has-files {
    display: flex;
}

.file-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(232, 232, 236, 0.14);
    background: linear-gradient(180deg, rgba(24, 24, 28, 0.94), rgba(12, 12, 14, 0.98));
    color: var(--text-secondary);
    font-size: 11px;
    line-height: 1;
}

.file-icon {
    opacity: 0.85;
}

.file-name {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--text-primary);
}

.file-remove {
    border: 0;
    background: none;
    color: rgba(255, 255, 255, 0.45);
    cursor: pointer;
    padding: 0;
    font-size: 14px;
    line-height: 1;
}

.file-remove:hover {
    color: #FF6B6B;
}

.followup-spotlight-body {
    max-height: 148px;
    overflow-y: auto;
    padding-right: 4px;
    font-size: 13px;
    line-height: 1.65;
    color: rgba(255,255,255,0.88);
    white-space: normal;
    word-break: break-word;
}

.dock-snippets {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 0;
    flex: 1;
    overflow-y: auto;
    padding-right: 4px;
}

.dock-empty {
    border: 1px dashed rgba(245, 168, 0, 0.28);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(245, 168, 0, 0.03));
    border-radius: 12px;
    padding: 18px 16px;
    font-size: 12px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.62);
}

.dock-snippet {
    border: 1px solid rgba(232, 232, 236, 0.12);
    background: linear-gradient(180deg, rgba(24, 25, 28, 0.96), rgba(15, 16, 18, 0.98));
    border-radius: 12px;
    padding: 12px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 10px 24px rgba(0,0,0,0.22);
}

.snippet-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.snippet-icon {
    font-size: 14px;
}

.snippet-label {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.85);
}

.snippet-status-pill {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(0, 255, 157, 0.12);
    border: 1px solid rgba(0, 255, 157, 0.25);
    color: var(--accent-green);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.08em;
}

.snippet-actions {
    margin-left: auto;
    display: flex;
    gap: 6px;
}

.snippet-actions button {
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.8);
    border-radius: 8px;
    padding: 6px 8px;
    cursor: pointer;
}

.snippet-actions button:hover {
    border-color: rgba(245, 168, 0, 0.35);
    color: #F5A800;
}

.activity-item {
    cursor: pointer;
}

.activity-item:hover {
    border-color: rgba(245, 168, 0, 0.22);
    background: rgba(255, 255, 255, 0.04);
}

.activity-item:focus-visible {
    outline: 1px solid rgba(245, 168, 0, 0.55);
    outline-offset: 2px;
}

.activity-modal {
    max-width: 720px;
}

.activity-modal-body {
    white-space: normal;
    word-break: break-word;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.82);
}

.followup-response-modal {
    width: min(1040px, 96vw);
    max-width: 96vw;
    min-height: 72vh;
    max-height: 90vh;
    padding: 28px;
    display: flex;
    flex-direction: column;
}

.followup-response-modal .modal-card-content {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding-right: 10px;
}

@media (max-width: 1024px) {
    .followup-response-modal {
        width: 100vw;
        max-width: 100vw;
        min-height: 78vh;
        max-height: 92vh;
        border-radius: 0;
        padding: 22px 18px;
    }
}

.snippet-preview {
    font-size: 12px;
    line-height: 1.55;
    color: rgba(255,255,255,0.72);
    white-space: pre-wrap;
    word-break: break-word;
}

.snippet-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(245, 168, 0, 0.1);
    border: 1px solid rgba(245, 168, 0, 0.2);
    font-size: 10px;
    color: #F5A800;
}

.tag-close {
    cursor: pointer;
}

.tag-add-input {
    min-width: 72px;
    border: 1px dashed rgba(255,255,255,0.14);
    background: rgba(255,255,255,0.02);
    color: rgba(255,255,255,0.76);
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 10px;
}

/* LEFT PANEL */
.left-panel {
    border: 1px solid rgba(232, 232, 236, 0.22);
    background:
        linear-gradient(180deg, rgba(28, 30, 34, 0.98), rgba(16, 16, 18, 0.99)),
        linear-gradient(90deg, rgba(200, 200, 204, 0.02), rgba(0, 0, 0, 0));
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.05),
        inset 0 -1px 0 rgba(0, 0, 0, 0.55),
        0 0 36px rgba(0, 0, 0, 0.42);
}

.left-panel h1 {
    font-family: var(--font-head);
    font-size: 32px;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text-primary);
    letter-spacing: -0.02em;
}

.subtitle {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.25em;
    color: var(--accent-taupe);
    margin-bottom: 24px;
    display: block;
    font-weight: 500;
}

/* SYSTEM STATUS */
.system-status {
    margin-bottom: auto;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 16px;
    background: linear-gradient(180deg, rgba(30, 32, 36, 0.94), rgba(18, 18, 20, 0.98));
    border-radius: 8px;
    border: 1px solid rgba(232, 232, 236, 0.1);
}

.status-row {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    align-items: center;
}

.status-val {
    color: #FFF;
    font-family: var(--font-mono);
}

.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #222;
    display: inline-block;
    margin-right: 6px;
}

.status-dot.online {
    background: var(--accent-green);
    box-shadow: 0 0 5px rgba(76, 175, 125, 0.35);
}

/* INPUT MODULE */
.input-module {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: linear-gradient(180deg, rgba(36, 38, 42, 0.92), rgba(22, 22, 24, 0.96));
    padding: 16px;
    border-radius: 12px;
    border: 1px solid rgba(232, 232, 236, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.glass-textarea {
    width: 100%;
    height: 100px;
    background: linear-gradient(180deg, rgba(12, 12, 14, 0.92), rgba(8, 8, 10, 0.98));
    border: 1px solid rgba(200, 200, 204, 0.28);
    border-radius: 8px;
    padding: 12px;
    color: var(--text-primary);
    font-weight: 500;
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.5;
    resize: none;
    outline: none;
    transition: all 0.2s;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.glass-textarea:focus {
    background: linear-gradient(180deg, rgba(14, 14, 16, 0.98), rgba(8, 8, 10, 1));
    border-color: rgba(245, 168, 0, 0.6);
    box-shadow: 0 0 0 1px rgba(245, 168, 0, 0.12), 0 0 18px rgba(245, 168, 0, 0.14);
}

/* UPLOAD ZONE */
.upload-zone {
    border: 1px dashed rgba(255, 255, 255, 0.5);
    border-radius: 8px;
    padding: 12px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    background: rgba(0, 0, 0, 0.25);
}

.upload-zone:hover {
    border-color: var(--accent-gold);
    background: rgba(255, 176, 32, 0.1);
}

.upload-label {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 13px;
    color: #DDD;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.icon-upload {
    width: 14px;
    height: 14px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
}

.btn-primary {
    background: linear-gradient(180deg, rgba(50, 52, 58, 0.96), rgba(28, 28, 32, 0.98));
    border: 1px solid rgba(232, 232, 236, 0.18);
    color: var(--text-primary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    padding: 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    font-size: 13px;
    margin-top: 8px;
}

.btn-primary:hover,
.btn-primary:focus-visible {
    background: linear-gradient(180deg, rgba(58, 60, 66, 0.98), rgba(34, 34, 38, 1));
    box-shadow: 0 0 16px rgba(0, 0, 0, 0.24);
    transform: translateY(-1px);
    border-color: rgba(245, 168, 0, 0.42);
    color: var(--text-primary);
    outline: 2px solid rgba(245, 168, 0, 0.24);
    outline-offset: 4px;
}


/* CENTER PANEL: VISUALIZATION */
.center-panel {
    position: relative;
    background:
        linear-gradient(rgba(10, 10, 10, 0.92), rgba(10, 10, 10, 0.92)),
        repeating-linear-gradient(0deg, transparent, transparent 49px, rgba(200, 200, 204, 0.025) 50px),
        repeating-linear-gradient(90deg, transparent, transparent 49px, rgba(200, 200, 204, 0.025) 50px);
    background-size: 100% 100%, 50px 50px, 50px 50px;
    border: 1px solid rgba(232, 232, 236, 0.08);
    backdrop-filter: none;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    gap: 18px;
    box-shadow: inset 0 0 100px rgba(0, 0, 0, 0.8);
    pointer-events: auto;
    border-radius: 16px;
    overflow: hidden;
}

/* Corner Brackets — removed: created visible arc artifact near sphere */

.stage-command-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.stage-command-copy {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.stage-kicker,
.evaluation-kicker {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent-gold);
}

.stage-command-copy h2 {
    margin: 0;
    font-family: var(--font-head);
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
}

.stage-subtitle,
.evaluation-copy {
    color: var(--text-secondary);
    font-size: 13px;
    letter-spacing: 0.04em;
}

.stage-command-state {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.stage-state-chip {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(232, 232, 236, 0.12);
    background: rgba(20, 20, 20, 0.92);
    color: var(--text-secondary);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.stage-state-chip.active {
    border-color: rgba(245, 168, 0, 0.28);
    background: rgba(44, 31, 11, 0.94);
    color: var(--accent-gold-bright);
    box-shadow: inset 0 0 0 1px rgba(255, 209, 102, 0.06);
}

.stage-metric-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.stage-metric-card {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 78px;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid rgba(232, 232, 236, 0.09);
    background: linear-gradient(180deg, rgba(28, 28, 28, 0.96), rgba(18, 18, 18, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.stage-metric-label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--text-tertiary);
}

.stage-metric-card strong {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-primary);
}

.metric-runway strong {
    color: var(--accent-gold-bright);
}

.metric-burn strong {
    color: var(--text-primary);
}

.metric-risk strong {
    color: var(--accent-red);
}

.metric-truth strong {
    color: var(--accent-green);
}

.globe-container {
    width: 100%;
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0.8;
    transform: scale(0.95);
    transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
    will-change: opacity, transform;
    pointer-events: auto;
}

.globe {
    width: 25vw;
    height: 25vw;
    max-width: 480px;
    max-height: 480px;
    min-width: 250px;
    min-height: 250px;
    position: relative;
    filter: drop-shadow(0 24px 60px rgba(0, 0, 0, 0.45));
    perspective: 1200px;
    perspective-origin: 50% 42%;
}

/* Large monitor scaling — globe + typography */
@media (min-width: 2560px) {
    .globe {
        max-width: 620px;
        max-height: 620px;
    }
    .nav-links a {
        font-size: 12px;
        padding: 8px 16px;
    }
    .mission-flow-step .flow-title {
        font-size: 13px;
    }
    .stage-metric-card strong {
        font-size: 22px;
    }
    .evaluation-step strong {
        font-size: 15px;
    }
}
@media (min-width: 3840px) {
    .globe {
        max-width: 780px;
        max-height: 780px;
    }
    .nav-links a {
        font-size: 13px;
        padding: 10px 18px;
    }
    .stage-metric-card strong {
        font-size: 26px;
    }
}

.orbit {
    fill: none;
    stroke: var(--accent-taupe);
    stroke-width: 1.5;
    stroke-dasharray: 4 8;
    transform-origin: center;
    will-change: transform;
    animation: spin 60s linear infinite;
    opacity: 0.8;
    overflow: visible;
}

.orbit-secondary {
    fill: none;
    stroke: var(--accent-taupe);
    stroke-width: 0.5;
    opacity: 0.4;
    animation: spin-rev 40s linear infinite;
    transform-origin: center;
    overflow: visible;
}

.lightning-path {
    fill: none;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    opacity: 0.9;
    filter: drop-shadow(0 0 8px #FFF);
    will-change: d;
    transition: opacity 0.1s;
}

.storm-core {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 332px;
    height: 188px;
    border-radius: 50%;
    transform: translate(-50%, -50%) rotate(-6deg);
    z-index: 5;
    overflow: hidden;
    background:
        radial-gradient(ellipse at 42% 40%, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 10%, rgba(24, 24, 24, 0.9) 34%, rgba(7, 7, 7, 0.98) 68%, rgba(0, 0, 0, 1) 100%);
    border: 1px solid rgba(232, 232, 236, 0.08);
    box-shadow:
        inset 0 0 34px rgba(255, 255, 255, 0.04),
        inset 0 -34px 58px rgba(0, 0, 0, 0.8),
        inset 0 20px 42px rgba(255, 255, 255, 0.02),
        0 0 42px rgba(0, 0, 0, 0.72);
    transition: box-shadow 0.16s ease, filter 0.16s ease, transform 0.16s ease;
}

.storm-core::before,
.storm-core::after {
    content: "";
    position: absolute;
    inset: 10%;
    border-radius: 50%;
    mix-blend-mode: screen;
    pointer-events: none;
}

.storm-core::before {
    background:
        conic-gradient(from 160deg,
            rgba(255, 255, 255, 0.015) 0deg,
            rgba(255, 255, 255, 0.03) 72deg,
            rgba(245, 168, 0, 0.07) 110deg,
            rgba(10, 10, 10, 0) 180deg,
            rgba(255, 209, 102, 0.04) 255deg,
            rgba(255, 255, 255, 0.02) 360deg);
    filter: blur(24px);
    opacity: 0.7;
    animation: stormSpiral 24s linear infinite;
}

.storm-core::after {
    inset: 14%;
    background:
        radial-gradient(circle at 32% 36%, rgba(255, 255, 255, 0.08), transparent 26%),
        radial-gradient(circle at 58% 56%, rgba(255, 255, 255, 0.05), transparent 24%),
        radial-gradient(circle at 48% 50%, rgba(245, 168, 0, 0.04), transparent 22%);
    filter: blur(18px);
    opacity: 0.7;
    animation: stormPulse 8s ease-in-out infinite;
}

.storm-cloud {
    position: absolute;
    inset: 14%;
    border-radius: 50%;
    background:
        radial-gradient(circle at 28% 34%, rgba(255, 255, 255, 0.11), transparent 16%),
        radial-gradient(circle at 54% 44%, rgba(255, 255, 255, 0.08), transparent 20%),
        radial-gradient(circle at 62% 62%, rgba(255, 209, 102, 0.04), transparent 18%),
        radial-gradient(circle at center, rgba(12, 12, 12, 0.24), rgba(0, 0, 0, 0.86) 72%);
    filter: blur(18px);
    opacity: 0.78;
    animation: stormPulse 10s ease-in-out infinite;
    transform: scaleY(0.78);
}

.storm-cloud-secondary {
    inset: 8%;
    opacity: 0.44;
    filter: blur(26px);
    animation: stormSpiralReverse 17s linear infinite;
}

.storm-eye {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 122px;
    height: 78px;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background:
        radial-gradient(ellipse at 38% 38%, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.06) 12%, rgba(30, 30, 30, 0.24) 28%, rgba(4, 4, 4, 0.92) 72%);
    box-shadow:
        inset 0 0 16px rgba(255, 255, 255, 0.04),
        0 0 30px rgba(0, 0, 0, 0.42);
    filter: blur(1.4px);
}

.sphere-orbit {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 420px;
    height: 420px;
    transform: translate(-50%, -50%);
    transform-origin: center;
    z-index: 8;
    pointer-events: none;
    animation: sphereOrbit 22s linear infinite;
}

.sphere-orbit::before {
    content: none;
}

/* Amber ground shadow under sphere for depth */
.sphere-orbit::after {
    content: '';
    position: absolute;
    bottom: 30%;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 18px;
    background: radial-gradient(ellipse at center, rgba(245, 168, 0, 0.22) 0%, transparent 70%);
    border-radius: 50%;
    filter: blur(6px);
    pointer-events: none;
    z-index: -1;
}

.sphere-container {
    width: 158px;
    height: 158px;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 9;
    background:
        radial-gradient(circle at 36% 30%, rgba(255, 255, 255, 1) 0%, rgba(255, 248, 220, 0.96) 18%, rgba(232, 220, 200, 0.88) 32%, rgba(180, 175, 165, 0.68) 48%, rgba(70, 68, 62, 0.86) 72%, rgba(18, 20, 24, 0.98) 100%);
    border: 1px solid rgba(255, 215, 120, 0.22);
    box-shadow:
        inset -20px -20px 30px rgba(20, 18, 12, 0.72),
        inset 10px 10px 22px rgba(255, 248, 220, 0.26),
        inset 0 0 18px rgba(245, 168, 0, 0.08),
        0 0 28px rgba(245, 168, 0, 0.18),
        0 16px 24px rgba(0, 0, 0, 0.35),
        0 0 52px rgba(245, 168, 0, 0.10);
    overflow: hidden;
    transition: box-shadow 0.12s ease, filter 0.12s ease, transform 0.12s ease;
    animation: none;
}

.sphere-container::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background:
        repeating-linear-gradient(180deg, transparent 0 15px, rgba(255, 255, 255, 0.06) 16px 17px),
        radial-gradient(circle at 68% 74%, rgba(245, 168, 0, 0.05), transparent 26%);
    z-index: 1;
}

.sphere-texture {
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background-image:
        radial-gradient(rgba(255, 255, 255, 0.28) 1px, transparent 1px),
        radial-gradient(rgba(200, 200, 204, 0.15) 1px, transparent 1px);
    background-size: 28px 28px, 12px 12px;
    background-position: 0 0, 6px 6px;
    animation: textureSpin 30s linear infinite;
    opacity: 0.38;
    z-index: 2;
}

.sphere-shine {
    position: absolute;
    top: 12%;
    left: 14%;
    width: 56%;
    height: 34%;
    border-radius: 50%;
    background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.96) 0%, rgba(255, 255, 255, 0) 65%);
    opacity: 0.96;
    filter: blur(8px);
    transform: rotate(-28deg);
    z-index: 3;
    pointer-events: none;
}

.orbit-rings {
    transform-origin: center;
    transform: translateZ(0) rotateX(68deg) rotate(-6deg);
}

.orbit-nodes {
    transform-style: preserve-3d;
}

@keyframes textureSpin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes sphereOrbit {
    from {
        transform: translate(-50%, -50%) rotate(0deg);
    }

    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

@keyframes sphereSelfSpin {
    from {
        transform: translateY(-50%) rotate(0deg);
    }

    to {
        transform: translateY(-50%) rotate(360deg);
    }
}

@keyframes stormSpiral {
    from {
        transform: rotate(0deg) scale(1);
    }

    50% {
        transform: rotate(180deg) scale(1.03);
    }

    to {
        transform: rotate(360deg) scale(1);
    }
}

@keyframes stormSpiralReverse {
    from {
        transform: rotate(360deg) scale(1.02);
    }

    50% {
        transform: rotate(180deg) scale(0.98);
    }

    to {
        transform: rotate(0deg) scale(1.02);
    }
}

@keyframes stormPulse {
    0%,
    100% {
        opacity: 0.75;
        filter: blur(14px) brightness(1);
    }

    50% {
        opacity: 1;
        filter: blur(18px) brightness(1.08);
    }
}

.storm-core.impact {
    animation: coreFlash 0.3s ease-out;
}

@keyframes coreFlash {
    0% {
        box-shadow:
            inset 0 0 38px rgba(255, 255, 255, 0.06),
            inset 0 -24px 48px rgba(0, 0, 0, 0.72),
            0 0 36px rgba(0, 0, 0, 0.68);
    }

    10% {
        box-shadow:
            inset 0 0 52px rgba(255, 255, 255, 0.38),
            inset 0 0 18px rgba(255, 209, 102, 0.24),
            0 0 58px rgba(255, 209, 102, 0.32);
        filter: brightness(1.18);
        transform: translate(-50%, -50%) scale(1.02);
    }

    100% {
        box-shadow:
            inset 0 0 38px rgba(255, 255, 255, 0.06),
            inset 0 -24px 48px rgba(0, 0, 0, 0.72),
            0 0 36px rgba(0, 0, 0, 0.68);
        filter: brightness(1);
        transform: translate(-50%, -50%) scale(1);
    }
}

.orbit-nodes {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    will-change: transform;
    animation: spin 60s linear infinite;
    z-index: 15;
}

.node {
    position: absolute;
    width: 14px;
    height: 14px;
    background: var(--node-color, #C8C8CC);
    border: 1.5px solid rgba(245, 168, 0, 0.35);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: all 0.3s;
    cursor: pointer;
    z-index: 20;
    --node-color: #C8C8CC;
    box-shadow: 0 0 8px rgba(245, 168, 0, 0.2), 0 0 2px var(--node-color);
}

.node.gpt {
    --node-color: #C8C8CC;
}

.node.claude {
    --node-color: #F5A800;
}

.node.gemini {
    --node-color: #C47D00;
}

.node.perplexity {
    --node-color: #E8E8EC;
}

.node::after {
    content: attr(data-label);
    position: absolute;
    top: -28px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 11px;
    font-weight: 600;
    color: #E8E8EC;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    opacity: 0.9;
    white-space: nowrap;
    pointer-events: none;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.8);
    /* Gyroscope effect: counter-rotate to keep text upright */
    animation: spin-rev 60s linear infinite;
}

.node.selected {
    box-shadow: 0 0 18px rgba(245, 168, 0, 0.7), 0 0 36px rgba(245, 168, 0, 0.3), 0 0 6px var(--node-color);
    border-color: rgba(245, 168, 0, 0.9);
    width: 17px;
    height: 17px;
}

.node.selected::after {
    opacity: 1;
    top: -32px;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }

    to {
        transform: rotate(360deg);
    }
}

@keyframes spin-rev {
    from {
        transform: translateX(-50%) rotate(360deg);
    }

    to {
        transform: translateX(-50%) rotate(0deg);
    }
}

body.activated .input-module {
    opacity: 0.3;
    pointer-events: none;
    transition: opacity 0.5s ease;
}

body.activated .globe-container {
    opacity: 1;
    transform: scale(1);
}

/* Fix for texture leakage in activated state */
body.activated .globe,
body.activated .sphere-container {
    overflow: hidden !important;
}

.evaluation-track {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 16px 18px;
    border-radius: 14px;
    border: 1px solid rgba(232, 232, 236, 0.08);
    background: linear-gradient(180deg, rgba(18, 18, 18, 0.96), rgba(12, 12, 12, 0.98));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

.evaluation-track-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
}

.evaluation-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.evaluation-step {
    display: flex;
    gap: 10px;
    min-height: 82px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(232, 232, 236, 0.08);
    background: rgba(20, 20, 20, 0.92);
}

.evaluation-step strong {
    display: block;
    margin-bottom: 6px;
    color: var(--text-primary);
    font-size: 14px;
}

.evaluation-step span:last-child {
    color: var(--text-secondary);
    font-size: 12px;
    line-height: 1.45;
}

.evaluation-dot {
    width: 10px;
    height: 10px;
    margin-top: 4px;
    border-radius: 50%;
    flex: 0 0 auto;
    background: var(--disabled);
    box-shadow: 0 0 0 4px rgba(61, 61, 61, 0.18);
}

.evaluation-step.is-complete .evaluation-dot {
    background: var(--accent-green);
    box-shadow: 0 0 0 4px rgba(76, 175, 125, 0.12);
}

.evaluation-step.is-live {
    border-color: rgba(245, 168, 0, 0.18);
    background: linear-gradient(180deg, rgba(42, 31, 11, 0.94), rgba(20, 16, 10, 0.98));
}

.evaluation-step.is-live .evaluation-dot {
    background: var(--accent-gold);
    box-shadow: 0 0 0 4px rgba(245, 168, 0, 0.12);
}

/* Results drawer styles defined in ARTIFACT DOCK section below */

/* Command Console (follow-up / interrogation input) */
.command-console {
    flex-shrink: 0;
    background: rgba(0, 0, 0, 0.6);
    border-top: 1px solid rgba(0, 255, 157, 0.3);
    padding: 12px 16px;
    margin-top: 12px;
    border-radius: 8px;
}

.console-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.console-status {
    color: var(--accent-green);
}

.console-target {
    color: #FF4444;
    font-weight: 700;
}

.console-input-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 4px 8px;
}

.console-prompt {
    color: var(--accent-green);
    font-family: var(--font-mono);
    font-weight: 700;
    font-size: 16px;
}

.console-input-wrapper input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    color: #fff;
    font-family: var(--font-mono);
    font-size: 13px;
    padding: 8px 4px;
}

.console-input-wrapper input::placeholder {
    color: rgba(255, 255, 255, 0.3);
}

.console-input-wrapper button {
    background: rgba(0, 255, 157, 0.15);
    border: 1px solid rgba(0, 255, 157, 0.4);
    color: var(--accent-green);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 8px 16px;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}

.console-input-wrapper button:hover {
    background: rgba(0, 255, 157, 0.3);
    box-shadow: 0 0 12px rgba(0, 255, 157, 0.3);
}

.results-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(450px, 1fr));
    gap: 24px;
    padding-bottom: 40px;
}

.consensus-card {
    grid-column: 1 / -1;
    background: linear-gradient(145deg, rgba(255, 176, 32, 0.08), rgba(0, 0, 0, 0.4));
    border: 1px solid rgba(255, 176, 32, 0.2);
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

/* RECALL BUTTON */
.recall-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background: rgba(0, 0, 0, 0.8);
    border: 1px solid var(--accent-green);
    color: var(--accent-green);
    padding: 10px 20px;
    border-radius: 8px;
    font-family: var(--font-head);
    font-weight: bold;
    cursor: pointer;
    z-index: 999;
    /* Top level */
    display: none;
    /* Hidden by default */
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.2);
    transition: all 0.3s ease;
}

.recall-btn:hover {
    background: rgba(0, 255, 157, 0.1);
    box-shadow: 0 0 25px rgba(0, 255, 157, 0.4);
    transform: translateY(-2px);
}

.consensus-title {
    color: var(--accent-gold);
    font-family: var(--font-head);
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 700;
}

.consensus-body {
    font-size: 15px;
    line-height: 1.6;
    color: #EEE;
    white-space: pre-wrap;
    font-weight: 400;
}

.agent-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    transition: all 0.2s;
    cursor: pointer;
    min-height: 200px;
    overflow: hidden;
    /* Prevent child overflow */
}


.agent-card:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.5);
}

.agent-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.agent-name {
    font-family: var(--font-head);
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #FFF;
}

.agent-model {
    font-size: 10px;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}


.agent-response {
    font-size: 13px;
    line-height: 1.6;
    color: var(--text-secondary);
    max-height: 500px;
    overflow-y: auto;
    overflow-x: hidden;
    /* Prevent horizontal scroll */
    white-space: pre-wrap !important;
    overflow-wrap: break-word !important;
    /* Standard property */
    word-wrap: break-word !important;
    /* Legacy support */
    word-break: break-word !important;
    /* Ensure wrapping */
    margin-top: 8px;
    font-family: var(--font-body);
    width: 100%;
}


.agent-card.openai {
    border-top: 2px solid #C8C8CC;
}

.agent-card.anthropic {
    border-top: 2px solid #F5A800;
}

.agent-card.google {
    border-top: 2px solid #C47D00;
}

.agent-card.perplexity {
    border-top: 2px solid #E8E8EC;
}

.agent-card.mistral {
    border-top: 2px solid #FFD166;
}

.agent-card.local {
    border-top: 2px solid #999;
}

/* FAILED STATE */
.agent-card.failed {
    border-top: 2px solid #FF4444 !important;
    background: rgba(255, 68, 68, 0.05) !important;
    opacity: 0.8;
}

.agent-card.failed .ph-model-name {
    color: #FF4444 !important;
}

.agent-card.failed .agent-response {
    color: #FF8888 !important;
    font-style: italic;
}

.agent-card.failed .precision-header {
    border-bottom: 1px solid rgba(255, 68, 68, 0.2);
}

.agent-meta {
    display: flex;
    gap: 12px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text-tertiary);
}

.bs-meter {
    background: rgba(0, 0, 0, 0.3);
    border-radius: 4px;
    padding: 6px 12px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

/* TELEMETRY FEED */
.telemetry-feed {
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 11.5px;
    overflow: hidden;
    justify-content: flex-end;
}

.log-entry {
    display: flex;
    gap: 8px;
    padding: 6px 8px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 4px;
    border-left: 2px solid #555;
    animation: fadeIn 0.3s ease-out;
}

.timestamp {
    color: var(--text-tertiary);
    min-width: 44px;
}

.log-msg {
    color: #CCC;
    font-weight: 400;
}

.log-entry.openai {
    border-left-color: #C8C8CC;
    background: rgba(200, 200, 204, 0.04);
}

.log-entry.anthropic {
    border-left-color: #F5A800;
    background: rgba(245, 168, 0, 0.05);
}

.log-entry.google {
    border-left-color: #C47D00;
    background: rgba(196, 125, 0, 0.05);
}

.log-entry.perplexity {
    border-left-color: #E8E8EC;
    background: rgba(232, 232, 236, 0.04);
}

.log-entry.system {
    border-left-color: #555;
}

.log-entry.process {
    border-left-color: var(--accent-gold);
    color: #FFF;
    background: rgba(255, 176, 32, 0.05);
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateX(10px);
    }

    to {
        opacity: 1;
        transform: translateX(0);
    }
}

/* Interrogation tooltip replaced by highlight-toolbar (see below) */

.mermaid-container {
    background: linear-gradient(180deg, rgba(42, 38, 34, 0.95), rgba(24, 21, 18, 0.98));
    padding: 20px;
    border-radius: 8px;
    margin: 15px 0;
    border: 1px solid rgba(245, 168, 0, 0.18);
    overflow-x: auto;
    display: flex;
    justify-content: center;
    box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.28);
}

.svg-native-container {
    width: 100%;
    display: flex;
    justify-content: center;
    padding: 20px;
    background: linear-gradient(180deg, rgba(30, 30, 30, 0.98), rgba(20, 20, 20, 0.98));
    border-radius: 8px;
    margin: 15px 0;
    border: 1px solid rgba(0, 255, 157, 0.15);
}
.svg-native-container svg {
    max-width: 100%;
    height: auto;
}

.table-row {
    transition: background 0.2s;
}

.table-row:nth-child(even) {
    background: rgba(255, 255, 255, 0.02);
}

.table-row:hover {
    background: rgba(0, 255, 157, 0.05);
}

.code-block {
    background: #0d0d0d;
    color: var(--accent-green);
    padding: 12px;
    border-radius: 6px;
    font-family: var(--font-mono);
    font-size: 13px;
    margin: 10px 0;
    border: 1px solid rgba(255, 255, 255, 0.1);
    white-space: pre-wrap;
    overflow-x: auto;
}


@keyframes pulse {
    0% {
        opacity: 0.6;
        transform: scale(0.98);
    }

    50% {
        opacity: 1;
        transform: scale(1.02);
        box-shadow: 0 0 15px var(--accent-green);
    }

    100% {
        opacity: 0.6;
        transform: scale(0.98);
    }
}

/* =========================================
   MISSING PRECISION HEADER STYLES (Restored)
   ========================================= */

.precision-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 15px;
    background: rgba(0, 0, 0, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    font-family: 'JetBrains Mono', monospace;
    flex-wrap: wrap;
    gap: 10px;
}

.ph-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.ph-model-name {
    font-size: 14px;
    font-weight: 700;
    color: #FFF;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-family: 'Outfit', sans-serif;
}

.ph-role-label {
    font-size: 10px;
    color: #888;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.ph-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.interrogate-btn {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #FFF;
    font-size: 10px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 4px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s;
    font-family: inherit;
    display: flex;
    align-items: center;
    gap: 4px;
}

.interrogate-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: #FFF;
}

.verify-btn {
    background: transparent;
    border: 1px solid rgba(245, 168, 0, 0.3);
    color: #F5A800;
    font-size: 10px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 4px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s;
    font-family: inherit;
}

.verify-btn:hover {
    background: rgba(245, 168, 0, 0.1);
    border-color: #F5A800;
}

.metric-pill {
    background: rgba(255, 255, 255, 0.05);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 10px;
    color: #AAA;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.metric-pill.time {
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.2);
}

.tool-action {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    transition: all 0.2s;
    font-size: 12px;
}

.tool-action:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: #FFF;
    transform: translateY(-1px);
}

.tool-action.success {
    background: rgba(0, 255, 157, 0.2);
    border-color: var(--accent-green);
    color: var(--accent-green);
    transform: scale(1.1);
}

/* Chart dropdown */
.chart-dropdown-trigger {
    position: relative;
}
.chart-dropdown-trigger.chart-loading {
    opacity: 0.5;
    pointer-events: none;
}
.chart-dropdown {
    display: none;
    position: absolute;
    bottom: 100%;
    right: 0;
    margin-bottom: 6px;
    background: #1a1a2e;
    border: 1px solid rgba(0, 255, 157, 0.3);
    border-radius: 6px;
    padding: 4px 0;
    min-width: 140px;
    z-index: 100;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.6);
}
.chart-dropdown.show {
    display: block;
}
.chart-option {
    padding: 6px 12px;
    font-size: 12px;
    color: #ccc;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s;
}
.chart-option:hover {
    background: rgba(0, 255, 157, 0.15);
    color: #fff;
}

/* Chart modal */
.chart-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}
.chart-modal {
    background: #0d0d1a;
    border: 1px solid rgba(0, 255, 157, 0.25);
    border-radius: 10px;
    width: 90%;
    max-width: 800px;
    max-height: 80vh;
    overflow: auto;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.8);
}
.chart-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    font-size: 13px;
    font-weight: 600;
    color: var(--accent-green);
    letter-spacing: 1px;
}
.chart-modal-close {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #fff;
    cursor: pointer;
    border-radius: 4px;
    padding: 2px 8px;
    font-size: 14px;
}
.chart-modal-close:hover {
    background: rgba(255, 50, 50, 0.3);
    border-color: #f55;
}
.chart-modal-body {
    padding: 20px;
}

.badge-stack {
    display: flex;
    gap: 6px;
    margin-top: 2px;
}

.status-badge {
    font-size: 13px;
    padding: 2px 6px;
    border-radius: 3px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 0.05em;
}

.status-badge.truth {
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #DDD;
}

/* =========================================
   COLOR MATCHING TITLES (User Request)
   ========================================= */

.agent-card.openai .ph-model-name {
    color: #10a37f;
    text-shadow: 0 0 10px rgba(16, 163, 127, 0.4);
}

.agent-card.anthropic .ph-model-name {
    color: #d97757;
    text-shadow: 0 0 10px rgba(217, 119, 87, 0.4);
}

.agent-card.google .ph-model-name {
    color: #4285f4;
    text-shadow: 0 0 10px rgba(66, 133, 244, 0.4);
}

.agent-card.perplexity .ph-model-name {
    color: #00bcd4;
    text-shadow: 0 0 10px rgba(0, 188, 212, 0.4);
}

/* --- EXPORT COMMAND CENTER (Results Panel) --- */
.export-command-center {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 20px;
    background: linear-gradient(135deg, rgba(255, 176, 32, 0.08), rgba(0, 255, 157, 0.04));
    border: 1px solid rgba(255, 176, 32, 0.25);
    border-radius: 10px;
    margin-bottom: 20px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    animation: fadeIn 0.4s ease-out;
}

.ecc-label {
    font-family: var(--font-head);
    font-size: 12px;
    color: var(--accent-gold);
    letter-spacing: 1.5px;
    font-weight: 700;
    text-transform: uppercase;
    white-space: nowrap;
    text-shadow: 0 0 10px rgba(255, 176, 32, 0.3);
}

.ecc-controls {
    display: flex;
    gap: 10px;
    flex: 1;
    flex-wrap: wrap;
}

.export-theme-picker {
    display: flex;
    gap: 8px;
    align-items: stretch;
    flex-wrap: wrap;
}

.export-theme-card {
    min-width: 150px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(0, 0, 0, 0.38);
    color: var(--text-primary);
    cursor: pointer;
    transition: all 0.2s ease;
}

.export-theme-card:hover {
    border-color: rgba(245, 168, 0, 0.35);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
}

.export-theme-card.active {
    border-color: rgba(0, 255, 157, 0.45);
    box-shadow: 0 0 0 1px rgba(0, 255, 157, 0.2), 0 10px 22px rgba(0, 0, 0, 0.28);
}

.export-theme-swatch {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    flex: 0 0 auto;
    border: 1px solid rgba(255, 255, 255, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.export-theme-swatch.neon-desert {
    background: linear-gradient(135deg, #0D1117 0%, #FFB020 55%, #2DD4BF 100%);
}

.export-theme-swatch.carbon-steel {
    background: linear-gradient(135deg, #0D0D0D 0%, #4B5563 55%, #D1D5DB 100%);
}

.export-theme-swatch.architect {
    background: linear-gradient(135deg, #F2F1EF 0%, #A65E46 58%, #636E72 100%);
}

.export-theme-swatch.iron-dispatch {
    background: linear-gradient(135deg, #f8f2ea 0%, #e0d2c5 52%, #b44c3d 100%);
}

.export-theme-swatch.deep-water {
    background: linear-gradient(135deg, #f3eee4 0%, #d8d0bf 52%, #434d3b 100%);
}

.export-theme-swatch.bone-field {
    background: linear-gradient(135deg, #f6f0e3 0%, #d8d0bf 52%, #395e46 100%);
}

.export-theme-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    text-align: left;
}

.export-theme-copy strong {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-primary);
}

.export-theme-copy span {
    font-size: 10px;
    color: rgba(255, 255, 255, 0.58);
}

.export-command-center select {
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: var(--text-primary);
    padding: 8px 14px;
    border-radius: 6px;
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 500;
    outline: none;
    cursor: pointer;
    transition: all 0.25s ease;
    flex: 1;
    min-width: 150px;
}

.export-command-center select:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: var(--accent-gold);
    box-shadow: 0 0 12px rgba(255, 176, 32, 0.15);
}

.export-command-center select:focus {
    border-color: var(--accent-green);
    box-shadow: 0 0 12px rgba(0, 255, 157, 0.2);
}

.export-command-center select option {
    background: #1a1a1a;
    color: var(--text-primary);
    padding: 8px;
}

/* --- PROCESSING STATE (No green glow - just speed changes) --- */

/* Dynamic Spin Speeds - Fast during processing, slow in idle */
body.activated .orbit {
    animation-duration: 12s !important;
}

body.activated .orbit-secondary {
    animation-duration: 8s !important;
}

body.activated .orbit-nodes {
    animation-duration: 12s !important;
}

body.activated .sphere-orbit {
    animation-duration: 8s !important;
}

body.activated .sphere-container {
    animation-duration: 3s !important;
    box-shadow:
        inset -16px -16px 26px rgba(24, 24, 24, 0.74),
        inset 8px 8px 18px rgba(255, 255, 255, 0.28),
        0 0 20px rgba(255, 255, 255, 0.28),
        0 0 40px rgba(255, 209, 102, 0.14);
}

body.activated .storm-core::before {
    animation-duration: 7s;
}

body.activated .storm-cloud-secondary {
    animation-duration: 6s;
}

body.activated .node::after {
    animation-duration: 12s !important;
}

body.activated .sphere-texture {
    animation-duration: 12s !important;
}

/* =========================================
   HIGH-DPI LAPTOP / SHORT VIEWPORT
   ========================================= */
@media (max-height: 800px) {
    .screen-container {
        height: 99%;
        padding: 6px;
    }

    .top-bar {
        margin-bottom: 6px;
    }

    .dashboard-grid {
        gap: 10px;
    }

    .panel {
        padding: 12px;
    }

    .left-panel h1 {
        font-size: 22px !important;
        margin-bottom: 2px !important;
    }

    .left-panel h1+p,
    .left-panel .subtitle {
        font-size: 10px !important;
        margin-bottom: 4px !important;
    }

    .glass-textarea {
        height: 56px !important;
    }

    .deck-card {
        padding: 6px 8px !important;
    }

    .deck-avatar {
        font-size: 10px !important;
    }

    .deck-role {
        font-size: 13px !important;
    }

    .agent-grid {
        gap: 6px !important;
    }

    .mode-selector {
        padding-top: 8px !important;
    }

    .mode-btn {
        padding: 6px 8px !important;
        font-size: 13px !important;
    }

    .trigger-scan {
        margin-top: 6px !important;
        padding: 8px !important;
        font-size: 12px !important;
    }

    .micro-tracker {
        margin-top: 4px !important;
        padding: 4px 8px !important;
        font-size: 10px !important;
    }

    .globe {
        width: 380px;
        height: 380px;
    }

    .sphere-container {
        width: 180px;
        height: 180px;
    }
}

/* =========================================
   MOBILE & TABLET RESPONSIVENESS (Mission 3)
   ========================================= */

@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    body {
        overflow-y: auto !important;
        height: auto !important;
        min-height: 100vh !important;
        align-items: flex-start !important;
        padding: 10px 0 !important;
    }

    .screen-container {
        width: 100% !important;
        height: auto !important;
        padding: 12px !important;
        border-radius: 0 !important;
    }

    .dashboard-grid {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto auto !important;
        gap: 20px !important;
    }

    .center-panel {
        min-height: 380px !important;
        order: 0 !important;
        margin-bottom: 10px !important;
    }

    .globe {
        width: 100% !important;
        max-width: 420px !important;
        height: 420px !important;
    }

    .sphere-container {
        width: 200px !important;
        height: 200px !important;
    }

    .results-container {
        left: 0 !important;
        right: 0 !important;
        height: 82vh !important;
        border-radius: 12px 12px 0 0 !important;
    }

    .results-grid {
        grid-template-columns: 1fr !important;
    }

    /* Mobile hamburger nav */
    .top-bar {
        position: relative;
        flex-wrap: wrap;
    }

    .mobile-nav-toggle {
        display: block;
    }

    .nav-links {
        display: none !important;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: rgba(10, 10, 10, 0.97);
        border: 1px solid rgba(255, 255, 255, 0.1);
        border-radius: 12px;
        padding: 12px;
        flex-direction: column !important;
        flex-wrap: nowrap !important;
        gap: 6px !important;
        z-index: 100;
        backdrop-filter: blur(12px);
        max-height: 70vh;
        overflow-y: auto;
    }

    .nav-links.mobile-open {
        display: flex !important;
    }

    .nav-links a {
        width: 100%;
        text-align: center;
        padding: 10px 16px;
    }
}

@media (max-width: 480px) {
    .left-panel h1 {
        font-size: 22px !important;
    }

    .export-command-center {
        flex-direction: column !important;
        gap: 10px !important;
    }

    .ecc-controls {
        flex-direction: column !important;
    }

    .export-command-center select {
        min-width: 100% !important;
    }

    .panel {
        padding: 16px !important;
    }

    .globe {
        max-width: 320px !important;
        height: 320px !important;
    }

    .sphere-container {
        width: 160px !important;
        height: 160px !important;
    }
}

/* MISSION INTAKE MODAL (Elite Style) */
.intake-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(15px);
    z-index: 11000;
    display: none;
    /* Hidden by default */
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.intake-modal-overlay.visible {
    display: flex;
}

.intake-modal {
    background: rgba(15, 15, 15, 0.95);
    border: 1px solid rgba(255, 176, 32, 0.3);
    width: 100%;
    max-width: 650px;
    border-radius: 12px;
    box-shadow: 0 0 50px rgba(255, 176, 32, 0.15);
    overflow: hidden;
    animation: modalPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes modalPop {
    from {
        opacity: 0;
        transform: scale(0.9);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

.intake-header {
    background: linear-gradient(90deg, rgba(255, 176, 32, 0.1), transparent);
    padding: 25px 30px;
    border-bottom: 1px solid rgba(255, 176, 32, 0.2);
}

.intake-title {
    font-family: var(--font-head);
    font-size: 20px;
    font-weight: 700;
    color: var(--accent-gold);
    letter-spacing: 2px;
}

.intake-subtitle {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 1px;
    margin-top: 5px;
    text-transform: uppercase;
}

.intake-body {
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.intake-row {
    display: flex;
    gap: 20px;
}

.intake-field {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.intake-field label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    color: #888;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.intake-field input,
.intake-field select {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    padding: 12px 14px;
    color: #FFF;
    font-family: var(--font-body);
    font-size: 13px;
    outline: none;
    transition: all 0.3s;
}

.intake-field input:focus,
.intake-field select:focus {
    border-color: var(--accent-gold);
    background: rgba(255, 176, 32, 0.05);
}

.intake-field select option {
    background: #111;
    color: #FFF;
}

.intake-footer {
    padding: 25px 30px;
    background: rgba(0, 0, 0, 0.3);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    display: flex;
    justify-content: flex-end;
    gap: 15px;
}

.intake-cancel-btn {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #888;
    padding: 12px 24px;
    border-radius: 6px;
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s;
}

.intake-cancel-btn:hover {
    background: rgba(255, 255, 255, 0.05);
    color: #FFF;
}

.intake-confirm-btn {
    background: var(--accent-gold);
    border: none;
    color: #000;
    padding: 12px 30px;
    border-radius: 6px;
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(255, 176, 32, 0.3);
    transition: all 0.3s;
}

.intake-confirm-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 176, 32, 0.4);
}

/* SMART SUGGESTION BOX */
.suggestion-box {
    background: linear-gradient(145deg, rgba(255, 176, 32, 0.12), rgba(255, 176, 32, 0.05));
    border: 1px solid rgba(255, 176, 32, 0.3);
    border-radius: 8px;
    padding: 12px;
    margin-top: 12px;
    animation: slideIn 0.3s ease-out;
}

.suggestion-box.hidden {
    display: none;
}

.suggestion-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.suggestion-icon {
    font-size: 18px;
}

.suggestion-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.suggestion-label {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-tertiary);
    font-weight: 600;
}

.suggestion-category {
    font-size: 13px;
    color: var(--accent-gold);
    font-weight: 700;
}

.suggestion-body {
    margin-bottom: 10px;
}

.suggestion-workflow {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0;
}

.suggestion-workflow strong {
    color: var(--text-primary);
}

.suggestion-actions {
    display: flex;
    gap: 6px;
}

.suggestion-btn {
    flex: 1;
    padding: 8px 12px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s;
    border: 1px solid transparent;
}

.suggestion-btn.primary {
    background: var(--accent-gold);
    color: #000;
    border-color: var(--accent-gold);
}

.suggestion-btn.primary:hover {
    background: #FFD060;
    box-shadow: 0 0 15px rgba(255, 176, 32, 0.4);
}

.suggestion-btn.secondary {
    background: rgba(255, 255, 255, 0.1);
    color: var(--text-primary);
    border-color: rgba(255, 255, 255, 0.2);
}

.suggestion-btn.secondary:hover {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(255, 255, 255, 0.3);
}

.suggestion-btn.close {
    flex: 0 0 auto;
    width: 32px;
    background: rgba(255, 0, 0, 0.1);
    color: #ff6b6b;
    border-color: rgba(255, 0, 0, 0.2);
}

.suggestion-btn.close:hover {
    background: rgba(255, 0, 0, 0.2);
}

/* ROLE CUSTOMIZATION PANEL */
.role-customization {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 8px;
    padding: 12px;
    margin-top: 12px;
    animation: slideIn 0.3s ease-out;
}

.role-customization.hidden {
    display: none;
}

.role-custom-header {
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--accent-gold);
    font-weight: 700;
    margin-bottom: 12px;
    border-bottom: 1px solid rgba(255, 176, 32, 0.2);
    padding-bottom: 8px;
}

.role-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.role-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.role-item label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    font-weight: 600;
}

.role-select {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 6px;
    padding: 8px;
    color: #FFF;
    font-size: 13px;
    font-family: var(--font-body);
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    outline: none;
}

.role-select:hover {
    border-color: var(--accent-gold);
    background: rgba(0, 0, 0, 0.5);
}

.role-select:focus {
    border-color: var(--accent-green);
    box-shadow: 0 0 10px rgba(0, 255, 157, 0.2);
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ENHANCE PROMPT PREVIEW MODAL */
.enhance-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(18px);
    z-index: 12000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.enhance-modal-overlay.visible {
    display: flex;
}

.enhance-modal {
    background: rgba(12, 12, 12, 0.97);
    border: 1px solid rgba(0, 255, 157, 0.25);
    width: 100%;
    max-width: 700px;
    border-radius: 12px;
    box-shadow: 0 0 60px rgba(0, 255, 157, 0.1);
    overflow: hidden;
    animation: modalPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.enhance-header {
    background: linear-gradient(90deg, rgba(0, 255, 157, 0.08), transparent);
    padding: 22px 28px;
    border-bottom: 1px solid rgba(0, 255, 157, 0.15);
}

.enhance-title {
    font-family: var(--font-head);
    font-size: 18px;
    font-weight: 700;
    color: var(--accent-green);
    letter-spacing: 2px;
}

.enhance-subtitle {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 1px;
    margin-top: 4px;
    text-transform: uppercase;
}

.enhance-body {
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-height: 60vh;
    overflow-y: auto;
}

.enhance-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.enhance-label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 8px;
}

.enhance-editable-tag {
    font-size: 8px;
    padding: 2px 6px;
    background: rgba(0, 255, 157, 0.12);
    border: 1px solid rgba(0, 255, 157, 0.25);
    border-radius: 4px;
    color: var(--accent-green);
    letter-spacing: 1px;
}

.enhance-original {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    padding: 14px 16px;
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.6;
    white-space: pre-wrap;
    font-style: italic;
}

.enhance-textarea {
    background: rgba(0, 255, 157, 0.03);
    border: 1px solid rgba(0, 255, 157, 0.2);
    border-radius: 8px;
    padding: 14px 16px;
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.92);
    line-height: 1.6;
    min-height: 120px;
    resize: vertical;
    outline: none;
    transition: border-color 0.2s;
}

.enhance-textarea:focus {
    border-color: rgba(0, 255, 157, 0.45);
    box-shadow: 0 0 12px rgba(0, 255, 157, 0.08);
}

.enhance-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 18px 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(0, 0, 0, 0.2);
}

.enhance-action-btn {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    padding: 10px 24px;
    border-radius: 6px;
    border: 1px solid;
    cursor: pointer;
    transition: all 0.2s;
    text-transform: uppercase;
}

.enhance-action-btn.reject {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.5);
}

.enhance-action-btn.reject:hover {
    background: rgba(255, 68, 68, 0.1);
    border-color: rgba(255, 68, 68, 0.4);
    color: #ff5555;
}

.enhance-action-btn.accept {
    background: rgba(0, 255, 157, 0.1);
    border-color: rgba(0, 255, 157, 0.35);
    color: var(--accent-green);
}

.enhance-action-btn.accept:hover {
    background: rgba(0, 255, 157, 0.2);
    border-color: rgba(0, 255, 157, 0.6);
    box-shadow: 0 0 16px rgba(0, 255, 157, 0.15);
}

/* ── FALCON GHOST PREVIEW ──────────────────────────────────────────── */

.ghost-eye-btn {
    background: rgba(255, 140, 50, 0.06);
    border: 1px solid rgba(255, 140, 50, 0.3);
    border-radius: 6px;
    color: rgba(255, 140, 50, 0.8);
    cursor: pointer;
    padding: 8px 14px;
    margin-top: 8px;
    width: 100%;
    transition: all 0.25s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.ghost-eye-btn:hover {
    background: rgba(255, 140, 50, 0.12);
    color: #ff8c32;
    border-color: rgba(255, 140, 50, 0.5);
    box-shadow: 0 0 12px rgba(255, 140, 50, 0.15);
}

.ghost-eye-btn.ghost-loading {
    animation: magicPulse 1.5s infinite;
    cursor: wait;
}

.ghost-modal-overlay {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.88);
    backdrop-filter: blur(18px);
    z-index: 12000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.ghost-modal-overlay.visible {
    display: flex;
}

.ghost-modal {
    background: rgba(12, 12, 12, 0.97);
    border: 1px solid rgba(255, 140, 50, 0.25);
    width: 100%;
    max-width: 750px;
    border-radius: 12px;
    box-shadow: 0 0 60px rgba(255, 140, 50, 0.1);
    overflow: hidden;
    animation: modalPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.ghost-header {
    background: linear-gradient(90deg, rgba(255, 140, 50, 0.08), transparent);
    padding: 22px 28px;
    border-bottom: 1px solid rgba(255, 140, 50, 0.15);
}

.ghost-title {
    font-family: var(--font-head);
    font-size: 18px;
    font-weight: 700;
    color: #ff8c32;
    letter-spacing: 2px;
}

.ghost-subtitle {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 1px;
    margin-top: 4px;
    text-transform: uppercase;
}

.ghost-body {
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-height: 60vh;
    overflow-y: auto;
}

.ghost-section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ghost-label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.5);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: 8px;
}

.ghost-tag {
    font-size: 8px;
    padding: 2px 6px;
    background: rgba(255, 140, 50, 0.12);
    border: 1px solid rgba(255, 140, 50, 0.25);
    border-radius: 4px;
    color: #ff8c32;
    letter-spacing: 1px;
}

.ghost-original {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    padding: 14px 16px;
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.6;
    white-space: pre-wrap;
    font-style: italic;
}

.ghost-redacted {
    background: rgba(255, 140, 50, 0.03);
    border: 1px solid rgba(255, 140, 50, 0.2);
    border-radius: 8px;
    padding: 14px 16px;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.85);
    line-height: 1.6;
    white-space: pre-wrap;
}

.ghost-placeholder {
    color: #ff8c32;
    background: rgba(255, 140, 50, 0.12);
    padding: 1px 4px;
    border-radius: 3px;
    font-weight: 600;
}

.ghost-stats {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px 16px;
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
}

.ghost-stats-row {
    display: flex;
    align-items: center;
    gap: 16px;
    font-family: var(--font-head);
    font-size: 11px;
    letter-spacing: 1px;
}

.ghost-stat-total {
    color: #ff8c32;
    font-weight: 700;
}

.ghost-stat-docs {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
    background: rgba(245, 168, 0, 0.15);
    color: #F5A800;
    border: 1px solid transparent;
    transition: border-color 0.3s, box-shadow 0.3s;
}

/* Active Falcon scan pulse — add/remove .scanning via JS */
.ghost-stat-docs.scanning {
    animation: ghostDocScanPulse 1.6s ease-in-out infinite;
}

@keyframes ghostDocScanPulse {
    0%, 100% {
        opacity: 1;
        border-color: rgba(245, 168, 0, 0.0);
        box-shadow: none;
    }
    50% {
        opacity: 0.75;
        border-color: rgba(245, 168, 0, 0.6);
        box-shadow: 0 0 8px rgba(245, 168, 0, 0.35),
                    inset 0 0 4px rgba(245, 168, 0, 0.1);
    }
}

/* Vault file chip pulse — processing indicator */
.file-chip.vault-pulse {
    animation: vaultChipPulse 1.8s ease-in-out infinite;
    border: 1px solid rgba(240, 160, 48, 0.4);
}

@keyframes vaultChipPulse {
    0%, 100% { opacity: 1; box-shadow: none; }
    50% { opacity: 0.7; box-shadow: 0 0 6px rgba(240, 160, 48, 0.3); }
}

.ghost-stat-time {
    color: rgba(255, 255, 255, 0.35);
    margin-left: auto;
}

.ghost-stat-risk {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
}

.ghost-risk-none           { background: rgba(100,255,100,0.1); color: #66ff66; }
.ghost-risk-low            { background: rgba(100,200,255,0.1); color: #66ccff; }
.ghost-risk-medium         { background: rgba(255,200,50,0.1); color: #ffc832; }
.ghost-risk-high           { background: rgba(255,68,68,0.15); color: #ff5555; }
.ghost-risk-potential_miss { background: rgba(255,200,50,0.15); color: #ffc832; animation: riskPulse 2s infinite; }

@keyframes riskPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

.ghost-cats-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.ghost-cat-chip {
    font-family: var(--font-head);
    font-size: 9px;
    padding: 3px 8px;
    background: rgba(255, 140, 50, 0.08);
    border: 1px solid rgba(255, 140, 50, 0.2);
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.6);
    letter-spacing: 0.5px;
}

.ghost-cat-chip strong {
    color: #ff8c32;
    margin-left: 4px;
}

.ghost-trust-panel {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px 16px;
    background: rgba(31, 24, 18, 0.72);
    border: 1px solid rgba(173, 129, 79, 0.2);
    border-radius: 10px;
}

.ghost-trust-header {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.ghost-trust-title {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.6px;
    color: #d6b07a;
}

.ghost-trust-subtitle {
    font-family: var(--font-body);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.5);
}

.ghost-trust-summary {
    display: grid;
    grid-template-columns: minmax(210px, 1fr) 1.2fr;
    gap: 12px;
}

.ghost-trust-status,
.ghost-trust-metrics,
.ghost-trust-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
}

.ghost-trust-status {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    padding: 14px 16px;
}

.ghost-trust-status-label {
    font-family: var(--font-head);
    font-size: 10px;
    letter-spacing: 1.4px;
    color: rgba(255, 255, 255, 0.58);
}

.ghost-trust-status strong {
    font-family: var(--font-head);
    font-size: 28px;
    line-height: 1;
}

.ghost-trust-status-copy {
    font-family: var(--font-body);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.62);
}

.ghost-trust-clean {
    border-color: rgba(109, 177, 94, 0.35);
    background: rgba(39, 74, 36, 0.35);
    color: #9fdb8f;
}

.ghost-trust-alert {
    border-color: rgba(194, 94, 82, 0.4);
    background: rgba(91, 34, 29, 0.42);
    color: #f1a09a;
}

.ghost-trust-neutral {
    background: rgba(120, 94, 58, 0.28);
    color: #d6b07a;
    border: 1px solid rgba(173, 129, 79, 0.2);
}

.ghost-trust-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    padding: 10px 12px;
}

.ghost-trust-metric {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 8px 10px;
    background: rgba(12, 12, 12, 0.38);
    border-radius: 6px;
}

.ghost-trust-k {
    font-family: var(--font-head);
    font-size: 9px;
    letter-spacing: 1.2px;
    color: rgba(255, 255, 255, 0.42);
}

.ghost-trust-v {
    font-family: var(--font-head);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.88);
}

.ghost-trust-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 12px;
}

.ghost-trust-card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 14px 16px;
}

.ghost-trust-card-label {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.4px;
    color: rgba(255, 255, 255, 0.55);
}

.ghost-inventory-list,
.ghost-readiness-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ghost-inventory-row {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 10px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.ghost-inventory-row:first-child {
    border-top: 0;
    padding-top: 0;
}

.ghost-inventory-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.ghost-inventory-type {
    font-family: var(--font-head);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.82);
    letter-spacing: 0.6px;
}

.ghost-inventory-count {
    min-width: 26px;
    padding: 2px 8px;
    border-radius: 999px;
    background: rgba(173, 129, 79, 0.16);
    color: #d6b07a;
    font-family: var(--font-head);
    font-size: 10px;
    text-align: center;
}

.ghost-token-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.ghost-token-chip,
.ghost-token-more,
.ghost-trust-highrisk,
.ghost-trust-missed {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 2px 8px;
    border-radius: 999px;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 10px;
}

.ghost-token-chip {
    background: rgba(255, 140, 50, 0.1);
    border: 1px solid rgba(255, 140, 50, 0.18);
    color: #efc085;
}

.ghost-token-more {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.48);
}

.ghost-trust-highrisk,
.ghost-trust-missed {
    margin-right: 6px;
}

.ghost-trust-highrisk {
    background: rgba(194, 94, 82, 0.18);
    border: 1px solid rgba(194, 94, 82, 0.28);
    color: #f1a09a;
}

.ghost-trust-missed {
    background: rgba(216, 176, 122, 0.12);
    border: 1px solid rgba(216, 176, 122, 0.18);
    color: #d6b07a;
}

.ghost-readiness-pill {
    display: inline-flex;
    align-self: flex-start;
    padding: 4px 8px;
    border-radius: 999px;
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.1px;
}

.ghost-readiness-copy {
    font-family: var(--font-body);
    font-size: 12px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.75);
}

.ghost-trust-note {
    padding: 10px 12px;
    background: rgba(0, 0, 0, 0.22);
    border-left: 2px solid rgba(216, 176, 122, 0.45);
    border-radius: 6px;
    font-family: var(--font-body);
    font-size: 11px;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.65);
}

.ghost-empty-copy {
    color: rgba(255, 255, 255, 0.42);
    font-style: italic;
}

/* Quick-Protect row inside Ghost Preview */
.ghost-protect-row {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    padding: 10px 14px;
    background: rgba(255, 140, 50, 0.04);
    border: 1px dashed rgba(255, 140, 50, 0.25);
    border-radius: 8px;
}

.ghost-protect-input {
    flex: 1;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    padding: 7px 12px;
    color: #fff;
    font-family: var(--font-head);
    font-size: 11px;
    letter-spacing: 0.5px;
    outline: none;
    transition: border-color 0.2s;
}

.ghost-protect-input:focus {
    border-color: rgba(255, 140, 50, 0.5);
}

.ghost-protect-input::placeholder {
    color: rgba(255, 255, 255, 0.3);
    font-style: italic;
}

.ghost-protect-add {
    background: rgba(255, 140, 50, 0.12);
    border: 1px solid rgba(255, 140, 50, 0.35);
    border-radius: 5px;
    padding: 7px 16px;
    color: #ff8c32;
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
}

.ghost-protect-add:hover {
    background: rgba(255, 140, 50, 0.22);
    border-color: #ff8c32;
}

.ghost-footer {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    padding: 18px 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(0, 0, 0, 0.2);
}

.ghost-action-btn {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    padding: 10px 24px;
    border-radius: 6px;
    border: 1px solid;
    cursor: pointer;
    transition: all 0.2s;
    text-transform: uppercase;
}

.ghost-action-btn.dismiss {
    background: transparent;
    border-color: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.5);
}

.ghost-action-btn.dismiss:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.3);
    color: rgba(255, 255, 255, 0.8);
}

.ghost-action-btn.execute {
    background: rgba(255, 140, 50, 0.1);
    border-color: rgba(255, 140, 50, 0.35);
    color: #ff8c32;
}

.ghost-action-btn.execute:hover {
    background: rgba(255, 140, 50, 0.2);
    border-color: rgba(255, 140, 50, 0.6);
    box-shadow: 0 0 16px rgba(255, 140, 50, 0.15);
}

.ghost-action-btn.execute.warning {
    background: rgba(194, 94, 82, 0.14);
    border-color: rgba(194, 94, 82, 0.38);
    color: #f1a09a;
}

.ghost-action-btn.execute.warning:hover {
    background: rgba(194, 94, 82, 0.22);
    border-color: rgba(194, 94, 82, 0.52);
    box-shadow: 0 0 16px rgba(194, 94, 82, 0.12);
}

@media (max-width: 820px) {
    .ghost-trust-summary,
    .ghost-trust-grid {
        grid-template-columns: 1fr;
    }

    .ghost-trust-metrics {
        grid-template-columns: 1fr;
    }
}

/* EXECUTIVE BRIEF PANEL */
.exec-brief {
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(0, 255, 157, 0.15);
    border-radius: 10px;
    overflow: hidden;
}

.exec-brief-header {
    background: linear-gradient(135deg, rgba(0, 255, 157, 0.08), rgba(255, 176, 32, 0.05));
    padding: 20px 24px;
    border-bottom: 1px solid rgba(0, 255, 157, 0.12);
}

.exec-brief-title {
    font-family: var(--font-head);
    font-size: 16px;
    font-weight: 700;
    color: var(--accent-green);
    letter-spacing: 1.5px;
    margin-bottom: 8px;
}

.exec-brief-meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.exec-brief-meta span {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 3px 8px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 4px;
}

.exec-brief-summary {
    padding: 18px 24px;
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.85);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.exec-brief-sections {
    padding: 8px 0;
}

.exec-brief-section {
    padding: 14px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-brief-section:last-child {
    border-bottom: none;
}

.exec-brief-section-title {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 600;
    color: var(--accent-green);
    letter-spacing: 1.5px;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid rgba(0, 255, 157, 0.1);
}

.exec-brief-section-body {
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.75);
}

.exec-brief-metrics {
    padding: 14px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-brief-metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
    margin-top: 10px;
}

.exec-metric-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 14px;
}

.exec-metric-label {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.exec-metric-value {
    font-family: var(--font-head);
    font-size: 20px;
    font-weight: 700;
    color: var(--accent-green);
    margin: 6px 0 4px;
}

.exec-metric-context {
    font-family: var(--font-body);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.4);
}

.exec-brief-actions {
    padding: 14px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-action-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-action-item:last-child {
    border-bottom: none;
}

.exec-action-priority {
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 3px 8px;
    border-radius: 4px;
    white-space: nowrap;
}

.exec-action-task {
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.8);
    flex: 1;
}

.exec-action-timeline {
    font-family: var(--font-body);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.35);
    white-space: nowrap;
}

.exec-brief-risks {
    padding: 14px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-risk-item {
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.exec-risk-item:last-child {
    border-bottom: none;
}

.exec-risk-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}

.exec-risk-label {
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.8);
}

.exec-risk-severity {
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #FF4444;
    text-transform: uppercase;
}

.exec-risk-mitigation {
    font-family: var(--font-body);
    font-size: 11px;
    color: rgba(0, 255, 157, 0.6);
    padding-left: 12px;
    border-left: 2px solid rgba(0, 255, 157, 0.2);
}

.exec-brief-decisions {
    padding: 14px 24px;
}

.exec-decision-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.exec-decision-list li {
    font-family: var(--font-body);
    font-size: 13px;
    color: rgba(255, 255, 255, 0.75);
    padding: 8px 0 8px 16px;
    border-left: 2px solid var(--accent-gold);
    margin-bottom: 8px;
}

.exec-decision-list li:last-child {
    margin-bottom: 0;
}

.exec-brief-card {
    grid-column: 1 / -1;
    padding: 0;
    border: 1px solid rgba(0, 255, 157, 0.2);
    background: transparent;
    cursor: default;
    min-height: auto;
}

.exec-brief-card:hover {
    transform: none;
    background: transparent;
    border-color: rgba(0, 255, 157, 0.3);
}

/* INTELLIGENCE TAG HIGHLIGHTS */
.intel-tag {
    display: inline;
    padding: 2px 6px;
    border-radius: 3px;
    border-left: 3px solid;
    margin: 0 2px;
    font-size: 0.95em;
}

.tag-decision {
    background: rgba(255, 176, 32, 0.12);
    border-left-color: var(--accent-gold);
    color: #FFD080;
}

.tag-risk {
    background: rgba(255, 68, 68, 0.12);
    border-left-color: #FF4444;
    color: #FF8888;
}

.tag-metric {
    background: rgba(0, 255, 157, 0.12);
    border-left-color: var(--accent-green);
    color: #80FFD0;
}

.tag-truth {
    background: rgba(0, 188, 212, 0.12);
    border-left-color: #00BCD4;
    color: #80E8F0;
}

/* FALCON CUSTOM TERMS PANEL */
.falcon-terms-panel {
    margin-top: 6px;
    padding: 8px;
    background: rgba(255, 176, 32, 0.05);
    border: 1px solid rgba(255, 176, 32, 0.15);
    border-radius: 6px;
}

.falcon-terms-label {
    display: block;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: rgba(255, 176, 32, 0.6);
    margin-bottom: 5px;
}

.falcon-terms-input-row {
    display: flex;
    gap: 4px;
}

.falcon-term-input {
    flex: 1;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    color: #FFF;
    padding: 5px 8px;
    font-size: 11px;
    font-family: var(--font-mono);
    outline: none;
}

.falcon-term-input:focus {
    border-color: rgba(255, 176, 32, 0.4);
}

.falcon-term-add {
    background: rgba(255, 176, 32, 0.15);
    border: 1px solid rgba(255, 176, 32, 0.3);
    color: #FFB020;
    width: 28px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
}

.falcon-term-add:hover {
    background: rgba(255, 176, 32, 0.25);
}

.falcon-terms-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}

.falcon-term-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255, 176, 32, 0.1);
    border: 1px solid rgba(255, 176, 32, 0.25);
    border-radius: 3px;
    padding: 2px 6px;
    font-size: 10px;
    color: #FFD080;
    font-family: var(--font-mono);
}

.falcon-term-remove {
    cursor: pointer;
    color: rgba(255, 255, 255, 0.4);
    font-size: 12px;
    line-height: 1;
}

.falcon-term-remove:hover {
    color: #FF4444;
}

/* CARD EXPANSION MODAL */
.card-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.92);
    backdrop-filter: blur(10px);
    z-index: 9500;
    display: none;
    justify-content: center;
    align-items: center;
    animation: fadeIn 0.3s ease-out;
}

.card-modal-overlay.visible {
    display: flex;
}

.card-modal {
    background: linear-gradient(145deg, rgba(20, 20, 20, 0.95), rgba(10, 10, 10, 0.98));
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: 16px;
    padding: 40px;
    max-width: 900px;
    width: 90%;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 20px 80px rgba(0, 0, 0, 0.9);
    animation: modalSlideIn 0.4s cubic-bezier(0.19, 1, 0.22, 1);
    position: relative;
}

/* fadeIn defined earlier */

@keyframes modalSlideIn {
    from {
        opacity: 0;
        transform: translateY(30px) scale(0.95);
    }

    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.modal-close-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    background: rgba(255, 0, 0, 0.15);
    border: 1px solid rgba(255, 0, 0, 0.3);
    color: #ff6b6b;
    font-size: 24px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 300;
}

.modal-close-btn:hover {
    background: rgba(255, 0, 0, 0.25);
    border-color: rgba(255, 0, 0, 0.5);
    transform: rotate(90deg);
}

.modal-card-header {
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.1);
}

.modal-card-title {
    font-family: var(--font-head);
    font-size: 28px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 8px;
}

.modal-card-meta {
    display: flex;
    gap: 16px;
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--text-tertiary);
    flex-wrap: wrap;
}

.modal-card-content {
    font-size: 15px;
    line-height: 1.8;
    color: var(--text-secondary);
    margin-bottom: 32px;
    white-space: pre-wrap;
}

.modal-actions {
    display: flex;
    gap: 12px;
    padding-top: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    flex-wrap: wrap;
}

.modal-action-btn {
    flex: 1;
    min-width: 150px;
    padding: 14px 20px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s;
    border: 1px solid transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.modal-action-btn.copy {
    background: rgba(0, 255, 157, 0.1);
    border-color: rgba(0, 255, 157, 0.3);
    color: var(--accent-green);
}

.modal-action-btn.copy:hover {
    background: rgba(0, 255, 157, 0.2);
    box-shadow: 0 0 20px rgba(0, 255, 157, 0.3);
}

.modal-action-btn.visualize {
    background: rgba(255, 176, 32, 0.1);
    border-color: rgba(255, 176, 32, 0.3);
    color: var(--accent-gold);
}

.modal-action-btn.visualize:hover {
    background: rgba(255, 176, 32, 0.2);
    box-shadow: 0 0 20px rgba(255, 176, 32, 0.3);
}

.modal-action-btn.download {
    background: rgba(66, 133, 244, 0.1);
    border-color: rgba(66, 133, 244, 0.3);
    color: #4285f4;
}

.modal-action-btn.download:hover {
    background: rgba(66, 133, 244, 0.2);
    box-shadow: 0 0 20px rgba(66, 133, 244, 0.3);
}

/* SMART ROUTING SUGGESTION BOX */
.suggestion-box {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 10px;
    padding: 8px 14px;
    background: rgba(0, 255, 157, 0.08);
    border: 1px solid rgba(0, 255, 157, 0.3);
    border-radius: 6px;
    animation: fadeIn 0.3s ease-out;
}

.suggestion-box.hidden {
    display: none;
}

.suggestion-label {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(255, 255, 255, 0.5);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.suggestion-category {
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    color: var(--accent-green);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-shadow: 0 0 8px rgba(0, 255, 157, 0.4);
}

.suggestion-apply-btn {
    margin-left: auto;
    background: rgba(0, 255, 157, 0.15);
    border: 1px solid var(--accent-green);
    color: var(--accent-green);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 4px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: all 0.2s;
}

.suggestion-apply-btn:hover {
    background: rgba(0, 255, 157, 0.3);
    color: #FFF;
    box-shadow: 0 0 10px rgba(0, 255, 157, 0.3);
}

.suggestion-dismiss-btn {
    background: transparent;
    border: none;
    color: rgba(255, 255, 255, 0.3);
    font-size: 14px;
    cursor: pointer;
    padding: 2px 4px;
    transition: color 0.2s;
}

.suggestion-dismiss-btn:hover {
    color: #FFF;
}

/* COMMAND DECK (Left Panel) */

.command-deck {
    margin-top: 24px;
    background: rgba(0, 0, 0, 0.2);
    border-radius: 12px;
    padding: 16px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.deck-title {
    font-size: 10px;
    color: var(--text-tertiary);
    letter-spacing: 0.15em;
    margin-bottom: 12px;
    text-transform: uppercase;
}

.agent-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.deck-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    padding: 12px;
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    overflow: hidden;
}

.deck-card:hover {
    background: rgba(255, 255, 255, 0.08);
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.3);
}

/* Mute affordance — subtle × hint on hover to show card is clickable to silence */
.deck-card:not(.silenced):hover::before {
    content: '×';
    position: absolute;
    bottom: 6px;
    right: 8px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.2);
    font-weight: 300;
    line-height: 1;
    pointer-events: none;
    transition: color 0.2s;
}

.deck-card:not(.silenced):hover:hover::before {
    color: rgba(255, 80, 80, 0.5);
}

/* Silenced: show a « restore » hint */
.deck-card.silenced::before {
    content: '+';
    position: absolute;
    bottom: 6px;
    right: 8px;
    font-size: 14px;
    color: rgba(0, 255, 157, 0.4);
    font-weight: 300;
    line-height: 1;
    pointer-events: none;
}

.deck-card:active {
    transform: scale(0.98);
}

/* Provider Accents */
.deck-card.openai {
    border-left: 3px solid #10a37f;
}

.deck-card.anthropic {
    border-left: 3px solid #d97757;
}

.deck-card.google {
    border-left: 3px solid #4285f4;
}

.deck-card.perplexity {
    border-left: 3px solid #00bcd4;
}

.deck-avatar {
    font-size: 13px;
    font-weight: 700;
    color: #FFF;
    opacity: 0.6;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.deck-role {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    transition: color 0.3s ease;
}

/* === HEALTH STATUS COLORS === */
/* Healthy State - Provider brand colors */
.deck-card.openai .deck-role {
    color: #10a37f;
}

.deck-card.anthropic .deck-role {
    color: #d97757;
}

.deck-card.google .deck-role {
    color: #4285f4;
}

.deck-card.perplexity .deck-role {
    color: #00bcd4;
}

.deck-card.mistral .deck-role {
    color: #facc15;
}

.deck-card.local .deck-role {
    color: #a855f7;
}

/* Warning State - White/Dim */
.deck-card.status-warning .deck-role {
    color: #ffffff !important;
}

.deck-card.status-warning {
    opacity: 0.7;
}

/* Error State - Red with pulse */
.deck-card.status-error .deck-role {
    color: #ff4444 !important;
}

.deck-card.status-error {
    animation: errorPulse 1.5s ease-in-out infinite;
    border-color: rgba(255, 68, 68, 0.5) !important;
}

/* Offline/Disabled State */
.deck-card.status-offline {
    opacity: 1;
    filter: none;
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(150, 150, 150, 0.45) !important;
    border-left-color: #8f8f8f !important;
    pointer-events: auto;
}

.deck-card.status-offline .deck-role {
    color: inherit !important;
}

.deck-card.status-offline .deck-avatar {
    color: inherit !important;
    opacity: 0.8;
}

/* User-silenced state (player toggled off) */
.deck-card.silenced {
    opacity: 1;
    filter: none;
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(150, 150, 150, 0.45) !important;
    border-left-color: #8f8f8f !important;
    cursor: pointer;
    transition: all 0.3s ease;
}

.deck-card.silenced:hover {
    opacity: 1;
    filter: none;
}

.deck-card.silenced .deck-role {
    color: inherit !important;
}

.deck-card.silenced .deck-avatar {
    color: inherit !important;
    opacity: 0.8;
}

.deck-card.silenced::after {
    background: #333;
    box-shadow: none;
}

/* === DECK X (DISABLE) BUTTON === */
.deck-x {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 18px;
    height: 18px;
    background: rgba(255, 68, 68, 0.15);
    border: 1px solid rgba(255, 68, 68, 0.3);
    border-radius: 50%;
    color: #FF4444;
    font-size: 14px;
    line-height: 16px;
    text-align: center;
    cursor: pointer;
    padding: 0;
    z-index: 10;
    opacity: 0.5;
    transition: all 0.2s;
}
.deck-x:hover {
    opacity: 1;
    background: rgba(255, 68, 68, 0.3);
    transform: scale(1.1);
}
.deck-card.silenced .deck-x {
    background: rgba(0, 200, 255, 0.15);
    border-color: rgba(0, 200, 255, 0.3);
    color: #00C8FF;
}
.deck-card.silenced .deck-x:hover {
    background: rgba(0, 200, 255, 0.3);
}

/* === STATUS DOT INDICATOR === */
.deck-card::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 6px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #10a37f;
    /* Default: healthy green */
    box-shadow: 0 0 4px #10a37f;
    transition: all 0.3s ease;
}

.deck-card.status-warning::after {
    background: #ffb020;
    box-shadow: 0 0 4px #ffb020;
}

.deck-card.status-error::after {
    background: #ff4444;
    box-shadow: 0 0 6px #ff4444;
    animation: dotPulse 0.8s ease-in-out infinite;
}

.deck-card.status-offline::after {
    background: #444;
    box-shadow: none;
}

/* === ACTIVE/RESPONDING STATE === */
.deck-card.responding {
    animation: respondingPulse 0.6s ease-in-out infinite;
}

.deck-card.responding::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 8px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
    animation: shimmer 1s linear infinite;
}

@keyframes errorPulse {

    0%,
    100% {
        box-shadow: 0 0 5px rgba(255, 68, 68, 0.2);
    }

    50% {
        box-shadow: 0 0 15px rgba(255, 68, 68, 0.5);
    }
}

@keyframes dotPulse {

    0%,
    100% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(1.3);
        opacity: 0.7;
    }
}

@keyframes respondingPulse {

    0%,
    100% {
        box-shadow: 0 0 10px rgba(255, 255, 255, 0.1);
    }

    50% {
        box-shadow: 0 0 20px rgba(255, 255, 255, 0.3);
    }
}

@keyframes shimmer {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

/* Active State glow */
.deck-card.active {
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.1);
}

/* === EXECUTE PROTOCOL BUTTON STATES === */
.trigger-scan.loading {
    background: linear-gradient(135deg, rgba(0, 255, 157, 0.2), rgba(0, 255, 157, 0.08));
    border-color: var(--accent-green);
    color: var(--accent-green);
    box-shadow: 0 0 20px rgba(0, 255, 157, 0.3);
    cursor: wait;
    position: relative;
    overflow: hidden;
}

.trigger-scan.loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, rgba(0, 255, 157, 0.15) 50%, transparent 100%);
    animation: executeSweep 1.2s linear infinite;
}

@keyframes executeSweep {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

.trigger-scan.complete {
    background: linear-gradient(135deg, rgba(0, 255, 157, 0.25), rgba(0, 255, 157, 0.1));
    border-color: var(--accent-green);
    color: var(--accent-green);
    box-shadow: 0 0 25px rgba(0, 255, 157, 0.4);
}

/* NEW SESSION RESET BUTTON */
.btn-reset-session {
    display: none;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    padding: 10px;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.25s ease;
    font-size: 11px;
    margin-top: 4px;
    width: 100%;
}

.btn-reset-session:hover {
    background: rgba(255, 68, 68, 0.08);
    border-color: rgba(255, 68, 68, 0.4);
    color: #FF6B6B;
    box-shadow: 0 0 12px rgba(255, 68, 68, 0.15);
}

/* MODE SELECTOR (Left Panel Bottom) */
.mode-selector {
    margin-top: auto;
    padding-top: 20px;
    display: flex;
    gap: 10px;
}

.mode-btn {
    flex: 1;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--text-secondary);
    padding: 10px;
    border-radius: 6px;
    cursor: pointer;
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.05em;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.mode-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #FFF;
}

/* V2 Active State */
.mode-btn.active[data-mode-toggle="v2"] {
    background: rgba(0, 255, 157, 0.1);
    border-color: var(--accent-green);
    color: var(--accent-green);
    box-shadow: 0 0 10px rgba(0, 255, 157, 0.2);
}

/* Red Team Active State */
.mode-btn.active[data-mode-toggle="red"] {
    background: rgba(255, 40, 40, 0.2) !important;
    border-color: #ff2828 !important;
    color: #ff5555 !important;
    box-shadow: 0 0 20px rgba(255, 40, 40, 0.6), inset 0 0 14px rgba(255, 40, 40, 0.15) !important;
    animation: redTeamPulse 2.5s ease-in-out infinite;
}

@keyframes redTeamPulse {

    0%,
    100% {
        box-shadow: 0 0 14px rgba(255, 40, 40, 0.5), inset 0 0 6px rgba(255, 40, 40, 0.1);
    }

    50% {
        box-shadow: 0 0 32px rgba(255, 40, 40, 0.9), inset 0 0 14px rgba(255, 40, 40, 0.25);
    }
}

/* LIVE Data (SerpAPI) Active State */
.mode-btn.active[data-mode-toggle="serp"] {
    background: rgba(0, 188, 212, 0.2) !important;
    border-color: #00bcd4 !important;
    color: #F5A800 !important;
    box-shadow: 0 0 20px rgba(0, 188, 212, 0.6), inset 0 0 14px rgba(0, 188, 212, 0.15) !important;
    animation: livePulse 2s ease-in-out infinite;
}

@keyframes livePulse {

    0%,
    100% {
        box-shadow: 0 0 8px rgba(0, 188, 212, 0.2);
    }

    50% {
        box-shadow: 0 0 16px rgba(0, 188, 212, 0.4);
    }
}

/* Falcon Protocol Active State */
.mode-btn.active[data-mode-toggle="falcon"] {
    background: rgba(255, 176, 32, 0.2) !important;
    border-color: #FFB020 !important;
    color: #FFD060 !important;
    box-shadow: 0 0 20px rgba(255, 176, 32, 0.6), inset 0 0 14px rgba(255, 176, 32, 0.15) !important;
    animation: falconPulse 2s ease-in-out infinite;
}

@keyframes falconPulse {
    0%, 100% { box-shadow: 0 0 10px rgba(255, 176, 32, 0.3); }
    50% { box-shadow: 0 0 28px rgba(255, 176, 32, 0.8), inset 0 0 12px rgba(255, 176, 32, 0.2); }
}

/* Falcon Level Picker */
.falcon-level-picker {
    background: rgba(255, 176, 32, 0.1);
    border: 1px solid rgba(255, 176, 32, 0.3);
    color: #FFD060;
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 6px 10px;
    border-radius: 4px;
    cursor: pointer;
    text-transform: uppercase;
    margin-left: 4px;
    vertical-align: middle;
}

.falcon-level-picker:focus {
    outline: 1px solid #FFB020;
    box-shadow: 0 0 8px rgba(255, 176, 32, 0.4);
}

.falcon-level-picker option {
    background: #1a1a2e;
    color: #FFD060;
}

/* Falcon Summary Card */
.falcon-card {
    border: 1px solid rgba(255, 176, 32, 0.3) !important;
    background: rgba(255, 176, 32, 0.04) !important;
}

.falcon-card:hover {
    border-color: rgba(255, 176, 32, 0.5) !important;
    background: rgba(255, 176, 32, 0.08) !important;
}

.falcon-cat {
    background: rgba(255, 176, 32, 0.15);
    border: 1px solid rgba(255, 176, 32, 0.25);
    border-radius: 4px;
    padding: 4px 10px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: #FFD060;
    letter-spacing: 0.05em;
}

.mode-icon {
    font-size: 14px;
}

/* Mistral Deck Card */
.deck-card.mistral {
    border-left: 2px solid #facc15;
}

.deck-card.mistral.active {
    background: rgba(250, 204, 21, 0.1);
    box-shadow: 0 0 15px rgba(250, 204, 21, 0.2);
}

.deck-card.mistral .deck-role {
    color: #facc15;
}

/* Local Deck Card */
.deck-card.local {
    border-left: 2px solid #a855f7;
    /* Purple for Local/Oracle */
}

.deck-card.local.active {
    background: rgba(168, 85, 247, 0.1);
    box-shadow: 0 0 15px rgba(168, 85, 247, 0.2);
}

.deck-card.local .deck-role {
    color: #a855f7;
}

/* Active Agent Card - DISABLED (not needed) */
.active-agent-card {
    display: none !important;
}

.agent-avatar-sm {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #333;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 8px;
    font-weight: 700;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

.agent-info {
    display: flex;
    flex-direction: column;
}

.agent-info .label {
    font-size: 8px;
    color: #666;
    letter-spacing: 0.05em;
    display: none;
    /* Hide label to save space */
}

.agent-info .value {
    font-size: 10px;
    font-weight: 600;
    color: #aaa;
}

/* Provider Specific Colors */
.active-agent-card[data-provider="openai"] .agent-avatar-sm {
    background: var(--openai-color);
    box-shadow: 0 0 10px var(--openai-color);
    color: #000;
}

.active-agent-card[data-provider="openai"] .value {
    color: var(--openai-color);
}

.active-agent-card[data-provider="anthropic"] .agent-avatar-sm {
    background: var(--anthropic-color);
    box-shadow: 0 0 10px var(--anthropic-color);
    color: #000;
}

.active-agent-card[data-provider="anthropic"] .value {
    color: var(--anthropic-color);
}

.active-agent-card[data-provider="google"] .agent-avatar-sm {
    background: var(--google-color);
    box-shadow: 0 0 10px var(--google-color);
    color: #000;
}

.active-agent-card[data-provider="google"] .value {
    color: var(--google-color);
}

.active-agent-card[data-provider="perplexity"] .agent-avatar-sm {
    background: var(--perplexity-color);
    box-shadow: 0 0 10px var(--perplexity-color);
    color: #000;
}

.active-agent-card[data-provider="perplexity"] .value {
    color: var(--perplexity-color);
}

.active-agent-card[data-provider="mistral"] .agent-avatar-sm {
    background: var(--mistral-color, #facc15);
    box-shadow: 0 0 10px var(--mistral-color, #facc15);
    color: #000;
}

.active-agent-card[data-provider="mistral"] .value {
    color: var(--mistral-color, #facc15);
}

.active-agent-card[data-provider="local"] .agent-avatar-sm {
    background: var(--local-color, #a855f7);
    box-shadow: 0 0 10px var(--local-color, #a855f7);
    color: #fff;
}

.active-agent-card[data-provider="local"] .value {
    color: var(--local-color, #a855f7);
}

/* Brand Colors & Node Styling */
.node.gpt {
    --node-color: #C8C8CC;
}

/* OpenAI Green */
.node.claude {
    --node-color: #F5A800;
}

/* Anthropic Orange */
.node.gemini {
    --node-color: #C47D00;
}

/* Google Blue */
.node.perplexity {
    --node-color: #E8E8EC;
}

/* Perplexity Cyan */
.node.mistral {
    --node-color: #facc15;
}

/* Mistral Yellow/Gold */

/* Node Appearance */
.node {
    position: absolute;
    width: 16px;
    height: 16px;
    background: var(--node-color);
    /* Default off state */
    border: 2px solid var(--text-tertiary);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    z-index: 20;
}

/* Hover State */
.node:hover {
    transform: translate(-50%, -50%) scale(1.3);
    border-color: #FFF;
}

/* Active/Selected State (User clicked it) */
.node.selected {
    background: var(--node-color);
    border-color: #FFF;
    box-shadow: 0 0 15px var(--node-color);
}

/* Labels */
.node::after {
    content: attr(data-label);
    position: absolute;
    top: -24px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    color: var(--text-tertiary);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    pointer-events: none;
    opacity: 0.7;
    transition: all 0.3s;
    white-space: nowrap;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8);
}

.node.selected::after {
    color: #FFF;
    opacity: 1;
    top: -28px;
}

/* Energy beam removed - using SVG lightning bolts only */

/* Pulse animation when energized (responding) */
.node.energized {
    animation: pulseNode 0.5s infinite alternate;
}

@keyframes pulseNode {
    0% {
        box-shadow: 0 0 10px var(--node-color);
    }

    100% {
        box-shadow: 0 0 25px var(--node-color);
    }
}

/* MICRO-TRACKER (Left Panel) */
.micro-tracker {
    margin-top: 16px;
    background: linear-gradient(180deg, rgba(34, 36, 40, 0.96), rgba(18, 18, 20, 0.98));
    backdrop-filter: none;
    border-radius: 12px;
    padding: 12px 16px;
    border: 1px solid rgba(232, 232, 236, 0.1);
    display: none;
    /* Hidden by default */
    align-items: center;
    gap: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}

.micro-tracker.active {
    display: flex;
    animation: slideIn 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.tracker-loader {
    width: 8px;
    height: 8px;
    background: var(--accent-green);
    border-radius: 50%;
    animation: premiumPulse 1.5s infinite;
    box-shadow: 0 0 10px var(--accent-green);
}

.tracker-status {
    flex-grow: 1;
    font-size: 13px;
    font-family: var(--font-mono);
    color: #CCC;
    letter-spacing: 0.05em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.tracker-agent {
    font-size: 13px;
    font-weight: 800;
    color: #FFF;
    background: rgba(0, 255, 157, 0.15);
    border: 1px solid rgba(0, 255, 157, 0.3);
    padding: 3px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

@keyframes premiumPulse {
    0% {
        opacity: 0.4;
        transform: scale(0.9);
        box-shadow: 0 0 5px var(--accent-green);
    }

    50% {
        opacity: 1;
        transform: scale(1.3);
        box-shadow: 0 0 15px var(--accent-green);
    }

    100% {
        opacity: 0.4;
        transform: scale(0.9);
        box-shadow: 0 0 5px var(--accent-green);
    }
}

/* slideIn and pulse defined earlier */

/* KORUM-OS: AI ACCOUNTABILITY & TRUTH STYLES */

/* 1. TRUTH METER (Vertical or Card Based) */
.status-badge.truth {
    border-color: var(--accent-gold);
    color: var(--accent-gold);
    position: relative;
    overflow: hidden;
}

.truth-bar-container {
    width: 100%;
    height: 4px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 2px;
    margin-top: 4px;
    overflow: hidden;
}

.truth-fill {
    height: 100%;
    background: linear-gradient(90deg, #FF4444 0%, #FFB020 50%, #00FF9D 100%);
    background-size: 200% 100%;
    transition: width 1s ease-out;
}

/* 2. CLAIM HIGHLIGHTING */
.claim {
    position: relative;
    cursor: help;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.3);
    transition: all 0.2s;
}

.claim:hover {
    background: rgba(255, 255, 255, 0.05);
}

.claim.confirmed {
    border-bottom: 1px solid #00FF9D;
    background: rgba(0, 255, 157, 0.05);
}

.claim.suspect {
    border-bottom: 1px dashed #FF4444;
    background: rgba(255, 68, 68, 0.05);
}

.claim.unverified {
    border-bottom: 1px dotted #AAA;
}

/* 3. TRUTH TOOLTIP (Custom for claims) */
.claim::after {
    content: attr(data-status);
    position: absolute;
    bottom: 100%;
    left: 0;
    font-size: 13px;
    font-family: var(--font-mono);
    padding: 2px 6px;
    border-radius: 3px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s;
    white-space: nowrap;
    z-index: 10;
}

.claim.confirmed::after {
    background: var(--accent-green);
    color: #000;
}

.claim.suspect::after {
    background: #FF4444;
    color: #FFF;
}

.claim:hover::after {
    opacity: 1;
}

/* 4. TRUTH METER ON CARD */
.ph-truth-container {
    display: flex;
    flex-direction: column;
    min-width: 100px;
}

.truth-score-val {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.05em;
    margin-bottom: 2px;
}

/* REPORT LIBRARY - Slide-out Panel */

.report-library {
    position: fixed;
    top: 0;
    right: -380px;
    width: 370px;
    height: 100vh;
    background: rgba(10, 10, 15, 0.97);
    border-left: 1px solid rgba(255, 255, 255, 0.08);
    z-index: 1000;
    transition: right 0.3s ease;
    display: flex;
    flex-direction: column;
    backdrop-filter: blur(20px);
}

.report-library.visible {
    right: 0;
}

.library-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.library-overlay.visible {
    opacity: 1;
    pointer-events: auto;
}

.library-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.library-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.library-action-btn {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #aaa;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 6px 10px;
    border-radius: 5px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: var(--font-body, 'Inter', sans-serif);
}

.library-action-btn:hover:not(:disabled),
.library-action-btn.active {
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.28);
    background: rgba(0, 255, 157, 0.08);
}

.library-action-btn.danger:hover:not(:disabled) {
    color: #ff8e8e;
    border-color: rgba(255, 84, 84, 0.28);
    background: rgba(255, 84, 84, 0.08);
}

.library-action-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.library-header h3 {
    font-family: var(--font-display, 'Outfit', sans-serif);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #888;
    margin: 0;
}

.close-library {
    background: none;
    border: none;
    color: #555;
    font-size: 22px;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}

.close-library:hover {
    color: #fff;
}

.library-list {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.library-empty {
    color: #444;
    font-size: 13px;
    text-align: center;
    padding: 40px 20px;
    font-family: var(--font-body, 'Inter', sans-serif);
}

/* Saved Report Card */
.report-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 12px 14px;
    cursor: pointer;
    transition: all 0.2s;
}

.report-card:hover {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(0, 255, 157, 0.2);
}

.report-card.selection-mode {
    padding-left: 46px;
    position: relative;
}

.report-card.selected {
    border-color: rgba(0, 255, 157, 0.45);
    background: rgba(0, 255, 157, 0.08);
    box-shadow: inset 0 0 0 1px rgba(0, 255, 157, 0.18);
}

.report-card-selector {
    position: absolute;
    left: 14px;
    top: 14px;
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(0, 0, 0, 0.18);
    display: flex;
    align-items: center;
    justify-content: center;
    color: transparent;
    font-size: 11px;
    line-height: 1;
}

.report-card.selected .report-card-selector {
    border-color: rgba(0, 255, 157, 0.42);
    background: rgba(0, 255, 157, 0.16);
    color: var(--accent-green);
}

.report-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 6px;
}

.report-card-role {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    color: var(--accent-green);
    text-transform: uppercase;
    font-family: var(--font-body, 'Inter', sans-serif);
}

.report-card-time {
    font-size: 13px;
    color: #444;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
}

.report-card-query {
    font-size: 13px;
    color: #aaa;
    line-height: 1.4;
    margin-bottom: 8px;
    font-family: var(--font-body, 'Inter', sans-serif);
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.report-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.report-card-providers {
    font-size: 13px;
    color: #555;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
}

.report-card-delete {
    background: none;
    border: none;
    color: #333;
    font-size: 12px;
    cursor: pointer;
    padding: 2px 6px;
    border-radius: 3px;
    transition: all 0.2s;
}

.report-card-delete:hover {
    color: #FF4444;
    background: rgba(255, 68, 68, 0.1);
}

/* Save Button in Export Toolbar */
.ecc-save-btn {
    background: rgba(0, 255, 157, 0.08);
    border: 1px solid rgba(0, 255, 157, 0.25);
    color: var(--accent-green);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.1em;
    padding: 6px 14px;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
    font-family: var(--font-body, 'Inter', sans-serif);
}

.ecc-save-btn:hover {
    background: rgba(0, 255, 157, 0.15);
    border-color: var(--accent-green);
}

/* Health Check Button */
.health-check-btn {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #555;
    cursor: pointer;
    padding: 3px 5px;
    border-radius: 3px;
    margin-left: 8px;
    vertical-align: middle;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
}

.health-check-btn:hover {
    color: var(--accent-green);
    border-color: rgba(0, 255, 157, 0.3);
}

.health-check-btn.checking {
    animation: spin 1s linear infinite;
}

/* spin defined earlier */

/* Hamburger hover */
#hamburgerBtn:hover svg line {
    stroke: #00FF9D;
    transition: stroke 0.2s;
}

/* --- UTILITIES & LAYOUT (Phase 5) --- */
.flex-column {
    display: flex;
    flex-direction: column;
}

.flex-fill {
    flex: 1;
}

.mt-auto {
    margin-top: auto;
}

.pt-20 {
    padding-top: 20px;
}

.gap-10 {
    gap: 10px;
}

/* MISSION TELEMETRY SYSTEM */
.aux-header {
    margin-bottom: 8px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.aux-title {
    font-size: 11px;
    opacity: 0.8;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.live-dot {
    width: 6px;
    height: 6px;
    background: var(--accent-green);
    border-radius: 50%;
    box-shadow: 0 0 5px #00FF9D;
}

.provider-status-strip {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    padding: 0 2px;
}

.provider-pill {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    font-family: var(--font-mono);
    font-size: 10px;
    border: 1px solid transparent;
}

.provider-pill .pill-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #555;
}

.provider-pill[data-provider="openai"] {
    background: rgba(16, 163, 127, 0.08);
    border-color: rgba(16, 163, 127, 0.2);
    color: #10a37f;
}

.provider-pill[data-provider="anthropic"] {
    background: rgba(217, 119, 87, 0.08);
    border-color: rgba(217, 119, 87, 0.2);
    color: #d97757;
}

.provider-pill[data-provider="google"] {
    background: rgba(66, 133, 244, 0.08);
    border-color: rgba(66, 133, 244, 0.2);
    color: #4285f4;
}

.provider-pill[data-provider="perplexity"] {
    background: rgba(0, 188, 212, 0.08);
    border-color: rgba(0, 188, 212, 0.2);
    color: #00bcd4;
}

.provider-pill[data-provider="mistral"] {
    background: rgba(255, 120, 50, 0.08);
    border-color: rgba(255, 120, 50, 0.2);
    color: #ff7832;
}

.session-stats {
    display: flex;
    gap: 16px;
    margin-bottom: 10px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.session-stat {
    text-align: center;
    flex: 1;
}

.session-stat-value {
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 700;
}

.session-stat-label {
    font-size: 9px;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.telemetry-log {
    flex: 1;
    font-family: var(--font-mono);
    font-size: 11px;
    color: rgba(255, 255, 255, 0.6);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 4px;
}

.w-full {
    width: 100%;
}

.h-full {
    height: 100%;
}

.cursor-pointer {
    cursor: pointer;
}

.pos-relative {
    position: relative;
}

.abs-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.mode-selector {
    margin-top: auto;
    padding-top: 20px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.mode-btn {
    flex: 1;
    min-width: 80px;
}

.panel-header-alt {
    margin-bottom: 8px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.provider-pill-strip {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    padding: 0 2px;
}

.session-stats-grid {
    display: flex;
    gap: 16px;
    margin-bottom: 10px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.stat-item {
    text-align: center;
    flex: 1;
}

.stat-val {
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 700;
}

.stat-label {
    font-size: 11px;
    color: #555;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

/* Better nav behavior on mid widths */
@media (max-width: 1440px) {
    .nav-links {
        gap: 4px;
    }
    .nav-group-btn {
        padding: 6px 12px;
        font-size: 10px;
    }
}

/* Mid-range and Large Monitor Nav Calibration */
@media (max-width: 1800px) {
    .nav-group-btn {
        padding: 6px 10px !important;
        font-size: 10px !important;
    }
    .auth-user-email {
        max-width: 80px !important;
    }
}

@media (max-width: 1366px) {
    .top-bar {
        gap: 8px;
    }
    .nav-group-btn {
        padding: 5px 8px !important;
        font-size: 9px !important;
        letter-spacing: 0.05em;
    }
    .auth-user-email {
        max-width: 60px !important;
    }
}

/* Rhythm + Active-State Polish */
.input-module {
    margin-top: 20px;
    gap: 10px;
}

.command-deck {
    margin-top: 20px;
}

.mode-selector {
    padding-top: 16px;
    gap: 8px;
}

.trigger-scan {
    margin-top: 6px;
}

.nav-links .nav-dropdown a.active,
.mode-btn.active {
    position: relative;
}

.nav-links .nav-dropdown a.active::after,
.mode-btn.active::after {
    content: '';
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    border: 1px solid rgba(0, 255, 157, 0.38);
    box-shadow: 0 0 12px var(--active-glow);
    pointer-events: none;
}

.mode-btn.active#btn-mode-red::after {
    border-color: rgba(255, 68, 68, 0.45);
    box-shadow: 0 0 14px rgba(255, 68, 68, 0.35);
}

.mode-btn.active#btn-mode-serp::after {
    border-color: rgba(0, 188, 212, 0.45);
    box-shadow: 0 0 14px rgba(0, 188, 212, 0.35);
}

/* Hard override for mode activation visuals (prevents cascade conflicts) */
#btn-mode-v2.mode-btn.active,
#btn-mode-v2.mode-btn.mode-active-v2 {
    background: rgba(0, 255, 157, 0.14) !important;
    border-color: #00ff9d !important;
    color: #00ff9d !important;
    box-shadow: 0 0 14px rgba(0, 255, 157, 0.42), inset 0 0 10px rgba(0, 255, 157, 0.12) !important;
}

#btn-mode-red.mode-btn.active,
#btn-mode-red.mode-btn.mode-active-red {
    background: rgba(255, 44, 44, 0.2) !important;
    border-color: #ff2c2c !important;
    color: #ff5a5a !important;
    box-shadow: 0 0 18px rgba(255, 44, 44, 0.55), inset 0 0 12px rgba(255, 44, 44, 0.15) !important;
}

#btn-mode-serp.mode-btn.active,
#btn-mode-serp.mode-btn.mode-active-serp {
    background: rgba(0, 188, 212, 0.2) !important;
    border-color: #00bcd4 !important;
    color: #F5A800 !important;
    box-shadow: 0 0 18px rgba(0, 188, 212, 0.55), inset 0 0 12px rgba(0, 188, 212, 0.15) !important;
}

.active-agent-card {
    display: flex !important;
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 7;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(6, 10, 12, 0.78);
    border: 1px solid rgba(0, 255, 157, 0.22);
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.active-agent-card.visible {
    opacity: 1;
    transform: translateY(0);
    box-shadow: 0 0 12px var(--active-glow), inset 0 0 0 1px rgba(0, 255, 157, 0.18);
}

.active-agent-card .label {
    display: block;
}

/* --- ENHANCE BUTTON (Magic Wand) - base styles in input wrapper section below --- */

.enhance-btn.enhancing {
    animation: magicPulse 1.5s infinite;
    opacity: 1;
    color: var(--neon-blue);
    cursor: wait;
}

@keyframes magicPulse {
    0% {
        transform: scale(1);
        filter: drop-shadow(0 0 0px var(--neon-blue));
    }

    50% {
        transform: scale(1.1);
        filter: drop-shadow(0 0 8px var(--neon-blue));
    }

    100% {
        transform: scale(1);
        filter: drop-shadow(0 0 0px var(--neon-blue));
    }
}

.spinner-sm {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    border-top-color: var(--neon-blue);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* --- INPUT WRAPPER POSITIONING FIX --- */
.input-wrapper {
    position: relative;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.input-wrapper .glass-textarea {
    flex: 0 0 100%;
}

/* Input action buttons row below textarea */
.clear-btn,
.attach-btn,
.enhance-btn {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    padding: 6px;
    transition: all 0.2s;
    position: static;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.clear-btn:hover,
.attach-btn:hover {
    color: #FFF;
    background: rgba(255, 255, 255, 0.08);
}

.enhance-btn {
    color: var(--accent-gold, #FFB020);
    border-color: rgba(255, 176, 32, 0.3);
}

.enhance-btn:hover {
    opacity: 1;
    background: rgba(255, 176, 32, 0.1);
    transform: scale(1.1);
    box-shadow: 0 0 10px rgba(255, 176, 32, 0.2);
}

/* ============================================================
   AUTH MODAL & STATUS
   ============================================================ */
.auth-modal-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0, 0, 0, 0.92);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(20px);
}

.auth-modal {
    background: linear-gradient(145deg, rgba(30, 30, 30, 0.95), rgba(15, 15, 15, 0.98));
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    width: 420px;
    max-width: 90vw;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.6), 0 0 60px rgba(197, 179, 150, 0.05);
    overflow: hidden;
}

.auth-header {
    text-align: center;
    padding: 32px 24px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.auth-logo {
    font-family: var(--font-head);
    font-size: 28px;
    font-weight: 700;
    color: var(--accent-taupe);
    letter-spacing: 4px;
}

.auth-subtitle {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text-tertiary);
    letter-spacing: 3px;
    margin-top: 8px;
}

.auth-body {
    padding: 24px;
}

.auth-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 24px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    overflow: hidden;
}

.auth-tab {
    flex: 1;
    padding: 10px;
    background: transparent;
    border: none;
    color: var(--text-tertiary);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 2px;
    cursor: pointer;
    transition: all 0.2s;
}

.auth-tab.active {
    background: rgba(197, 179, 150, 0.15);
    color: var(--accent-taupe);
}

.auth-field {
    margin-bottom: 16px;
}

.auth-field label {
    display: block;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text-tertiary);
    letter-spacing: 2px;
    margin-bottom: 6px;
}

.auth-field input {
    width: 100%;
    padding: 12px 14px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: var(--text-primary);
    font-family: var(--font-mono);
    font-size: 13px;
    outline: none;
    transition: border-color 0.2s;
}

.auth-field input:focus {
    border-color: var(--accent-taupe);
}

.auth-error {
    padding: 10px 14px;
    background: rgba(255, 68, 68, 0.1);
    border: 1px solid rgba(255, 68, 68, 0.3);
    border-radius: 8px;
    color: var(--accent-red);
    font-family: var(--font-mono);
    font-size: 11px;
    margin-bottom: 16px;
}

.auth-submit-btn {
    width: 100%;
    padding: 14px;
    background: linear-gradient(135deg, var(--accent-taupe), #a89478);
    border: none;
    border-radius: 8px;
    color: #000;
    font-family: var(--font-head);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 3px;
    cursor: pointer;
    transition: all 0.2s;
}

.auth-submit-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(197, 179, 150, 0.3);
}

.auth-submit-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.auth-footer {
    text-align: center;
    padding: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.auth-security-badge {
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--accent-green);
    letter-spacing: 2px;
    opacity: 0.6;
}

/* SSO Section */
.auth-divider {
    display: flex;
    align-items: center;
    margin: 20px 0 16px;
}
.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.auth-divider-text {
    padding: 0 12px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text-tertiary);
    letter-spacing: 2px;
}
.auth-sso-btn {
    width: 100%;
    padding: 12px 14px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    color: var(--text-primary);
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 1.5px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}
.auth-sso-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(0, 164, 239, 0.4);
}

/* Auth Status in Navbar */
.auth-status {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-left: 0;
    margin-right: 0;
    flex-shrink: 0;
}

.nav-right {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(232, 232, 236, 0.12);
    border-radius: 8px;
    background: rgba(20, 20, 20, 0.92);
    cursor: pointer;
}

.auth-user-email {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text-secondary);
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.auth-logout-btn {
    background: none;
    border: 1px solid rgba(255, 68, 68, 0.3);
    border-radius: 6px;
    padding: 4px 8px;
    color: var(--accent-red);
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    align-items: center;
}

.auth-logout-btn:hover {
    background: rgba(255, 68, 68, 0.1);
}

@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    .auth-user-email { display: none; }
    .auth-status { margin-right: 4px; }
}

/* ── AUDIT LOG PANEL ── */
.audit-nav-btn {
    background: none;
    border: 1px solid rgba(0, 200, 255, 0.2);
    color: #00C8FF;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    transition: all 0.2s;
    margin-right: 4px;
}
.audit-nav-btn:hover {
    background: rgba(0, 200, 255, 0.1);
    border-color: rgba(0, 200, 255, 0.4);
}
.audit-panel {
    position: fixed;
    top: 0;
    right: -480px;
    width: 480px;
    height: 100vh;
    background: #0A0E14;
    border-left: 1px solid rgba(0, 200, 255, 0.15);
    z-index: 9000;
    transition: right 0.3s ease;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.audit-panel.open { right: 0; }
.audit-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9999;
    display: none;
}
.audit-overlay.active { display: block; }
.audit-header {
    padding: 16px 20px;
    border-bottom: 1px solid rgba(0, 200, 255, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}
.audit-header h3 {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    letter-spacing: 2px;
    color: #00C8FF;
    margin: 0;
}
.audit-controls {
    display: flex;
    align-items: center;
    gap: 8px;
}
.audit-filter {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #ccc;
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    padding: 4px 8px;
    border-radius: 4px;
    cursor: pointer;
}
.audit-refresh {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #00C8FF;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 14px;
}
.audit-refresh:hover { background: rgba(0, 200, 255, 0.1); }
.audit-stats {
    padding: 12px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    display: flex;
    gap: 16px;
    flex-shrink: 0;
}
.audit-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.audit-stat-value {
    font-family: 'Outfit', sans-serif;
    font-size: 20px;
    font-weight: 700;
    color: #00C8FF;
}
.audit-stat-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 9px;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.4);
    text-transform: uppercase;
}
.audit-list {
    flex: 1;
    overflow-y: auto;
    padding: 12px 20px;
}
.audit-entry {
    padding: 12px 14px;
    margin-bottom: 8px;
    border-radius: 6px;
    border-left: 3px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.02);
    transition: background 0.2s;
}
.audit-entry:hover { background: rgba(255, 255, 255, 0.04); }
.audit-entry.council_query { border-left-color: #00C8FF; }
.audit-entry.interrogation { border-left-color: #FF4444; }
.audit-entry.verify_claim { border-left-color: #4488FF; }
.audit-entry.login { border-left-color: #44FF88; }
.audit-entry.login_failed { border-left-color: #FF8844; }
.audit-entry.register { border-left-color: #AA44FF; }
.audit-entry.logout { border-left-color: #888; }
.audit-entry.access_denied { border-left-color: #FF0000; }
.audit-entry-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
.audit-event-type {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
}
.audit-entry.council_query .audit-event-type { color: #00C8FF; }
.audit-entry.interrogation .audit-event-type { color: #FF4444; }
.audit-entry.verify_claim .audit-event-type { color: #4488FF; }
.audit-entry.login .audit-event-type { color: #44FF88; }
.audit-entry.login_failed .audit-event-type { color: #FF8844; }
.audit-entry.register .audit-event-type { color: #AA44FF; }
.audit-entry.access_denied .audit-event-type { color: #FF0000; }
.audit-timestamp {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: rgba(255, 255, 255, 0.35);
}
.audit-user {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 4px;
}
.audit-details {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.5;
    word-break: break-word;
}
.audit-ip {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px;
    color: rgba(255, 255, 255, 0.25);
    margin-top: 4px;
}

@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    .audit-panel { width: 100%; right: -100%; }
    .audit-nav-btn span { display: none; }
}

/* ── PROPRIETARY FOOTER ── */
.korum-legal-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 50;
    text-align: center;
    padding: 6px 16px;
    font-size: 10px;
    font-family: 'JetBrains Mono', monospace;
    letter-spacing: 0.5px;
    color: rgba(255, 255, 255, 0.35);
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.6));
    pointer-events: none;
}

/* ── TERMS OF DEMO SPLASH ── */
.demo-terms-overlay {
    position: fixed;
    inset: 0;
    z-index: 100000;
    background: rgba(0, 0, 0, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(12px);
}
.demo-terms-overlay.dismissed { display: none; }
.demo-terms-modal {
    max-width: 520px;
    width: 90%;
    text-align: center;
    padding: 48px 40px;
    border: 1px solid rgba(0, 200, 255, 0.15);
    border-radius: 8px;
    background: rgba(10, 14, 20, 0.95);
}
.demo-terms-logo {
    font-family: 'Outfit', sans-serif;
    font-size: 32px;
    font-weight: 700;
    color: #00C8FF;
    letter-spacing: 4px;
    margin-bottom: 8px;
}
.demo-terms-subtitle {
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px;
    letter-spacing: 3px;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 32px;
}
.demo-terms-text {
    font-family: 'Inter', sans-serif;
    font-size: 13px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 32px;
}
.demo-terms-accept {
    display: inline-block;
    padding: 12px 40px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 2px;
    color: #0A0E14;
    background: #00C8FF;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}
.demo-terms-accept:hover {
    background: #F5A800;
    box-shadow: 0 0 20px rgba(0, 200, 255, 0.3);
}
.demo-terms-badge {
    margin-top: 24px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 9px;
    letter-spacing: 2px;
    color: rgba(255, 200, 0, 0.5);
}

/* ═══════════════════════════════════════════════════════════
   ANALYTIC DIVERGENCE LAYER
   ═══════════════════════════════════════════════════════════ */

/* Protocol Variance Stat */
.protocol-variance-stat { transition: all 0.3s ease; }
.protocol-variance-stat.variance-active {
    animation: variancePulse 2s ease-in-out infinite;
}
@keyframes variancePulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* Divergence Card */
.divergence-card {
    grid-column: 1 / -1;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    cursor: pointer;
    transition: all 0.3s ease;
}
.divergence-card:hover { transform: translateY(-2px); box-shadow: 0 6px 30px rgba(0, 0, 0, 0.5); }
.divergence-card.consensus-strong {
    background: linear-gradient(145deg, rgba(0, 255, 157, 0.06), rgba(0, 0, 0, 0.4));
    border: 1px solid rgba(0, 255, 157, 0.2);
}
.divergence-card.variance-detected {
    background: linear-gradient(145deg, rgba(255, 176, 32, 0.08), rgba(255, 68, 68, 0.04), rgba(0, 0, 0, 0.4));
    border: 1px solid rgba(255, 176, 32, 0.3);
}

/* Header */
.divergence-header {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 16px; padding-bottom: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.divergence-title-row { display: flex; align-items: center; gap: 8px; }
.divergence-icon { font-size: 18px; }
.divergence-label {
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 12px; font-weight: 700;
    letter-spacing: 2px; color: rgba(255, 255, 255, 0.9);
}
.divergence-scores { display: flex; gap: 16px; }
.div-score {
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 10px; font-weight: 700; letter-spacing: 1px;
    padding: 4px 10px; border-radius: 4px;
}
.consensus-score { color: var(--accent-green); background: rgba(0, 255, 157, 0.1); border: 1px solid rgba(0, 255, 157, 0.2); }
.divergence-score-val { color: #FFB020; background: rgba(255, 176, 32, 0.1); border: 1px solid rgba(255, 176, 32, 0.2); }

/* Summary */
.divergence-summary {
    font-size: 13px; line-height: 1.6; color: rgba(255, 255, 255, 0.7);
    margin-bottom: 16px; padding: 12px;
    background: rgba(0, 0, 0, 0.2); border-radius: 8px;
}

/* Sections */
.div-section { margin-top: 16px; }
.div-section-title {
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 10px; font-weight: 700; letter-spacing: 2px;
    color: #F5A800; margin-bottom: 10px;
    padding-bottom: 4px; border-bottom: 1px solid rgba(245, 168, 0, 0.15);
}
.div-section-title.contested { color: #FF8844; border-bottom-color: rgba(255, 136, 68, 0.15); }

/* Agreement Items */
.div-agreement-item {
    padding: 10px; margin-bottom: 8px;
    background: rgba(0, 255, 157, 0.04); border-radius: 6px;
    border-left: 3px solid rgba(0, 255, 157, 0.3);
}
.div-confidence-badge {
    display: inline-block; font-size: 9px; font-weight: 700;
    letter-spacing: 1px; padding: 2px 8px; border-radius: 3px;
    margin-right: 8px;
}
.confidence-high { color: var(--accent-green); background: rgba(0, 255, 157, 0.15); }
.confidence-moderate { color: #FFB020; background: rgba(255, 176, 32, 0.15); }
.confidence-low { color: #FF4444; background: rgba(255, 68, 68, 0.15); }
.div-topic-name { font-weight: 600; font-size: 12px; color: rgba(255, 255, 255, 0.9); }
.div-topic-detail { font-size: 11px; color: rgba(255, 255, 255, 0.6); margin-top: 4px; }
.div-providers { font-size: 10px; color: rgba(245, 168, 0, 0.6); margin-top: 4px; letter-spacing: 0.5px; }

/* Contested Items */
.div-contested-item {
    padding: 12px; margin-bottom: 10px;
    background: rgba(255, 136, 68, 0.04); border-radius: 6px;
    border-left: 3px solid rgba(255, 136, 68, 0.3);
}
.div-contested-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.div-severity {
    font-size: 9px; font-weight: 700; letter-spacing: 1px;
    padding: 2px 8px; border-radius: 3px;
}
.severity-critical { color: #FF4444; background: rgba(255, 68, 68, 0.15); }
.severity-high { color: #FF8844; background: rgba(255, 136, 68, 0.15); }
.severity-medium { color: #FFB020; background: rgba(255, 176, 32, 0.15); }
.severity-low { color: var(--accent-green); background: rgba(0, 255, 157, 0.15); }

.div-position {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 6px 0; border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.div-provider-badge {
    font-size: 9px; font-weight: 700; letter-spacing: 1px;
    padding: 2px 8px; border-radius: 3px;
    color: #F5A800; background: rgba(245, 168, 0, 0.1);
    white-space: nowrap; flex-shrink: 0;
}
.div-position-text { font-size: 11px; color: rgba(255, 255, 255, 0.7); }
.div-impact {
    margin-top: 8px; font-size: 10px; font-weight: 600;
    color: #FF8844; letter-spacing: 0.5px;
}

/* Confidence Gaps */
.div-gap-item {
    padding: 8px 12px; margin-bottom: 6px; border-radius: 4px;
    font-size: 11px; color: rgba(255, 255, 255, 0.7);
    background: rgba(0, 0, 0, 0.2);
}
.div-gap-severity {
    font-size: 9px; font-weight: 700; margin-right: 8px;
    padding: 1px 6px; border-radius: 3px;
}
.div-gap-spread { font-size: 10px; color: rgba(255, 176, 32, 0.6); margin-left: 4px; }

/* Resolution Items */
.div-resolution-item {
    padding: 8px 12px; margin-bottom: 6px;
    font-size: 11px; color: rgba(255, 255, 255, 0.7);
    background: rgba(245, 168, 0, 0.04); border-radius: 4px;
}
.div-resolution-priority {
    font-size: 9px; font-weight: 700; margin-right: 8px;
    padding: 1px 6px; border-radius: 3px;
}
.priority-high { color: #FF4444; background: rgba(255, 68, 68, 0.15); }
.priority-medium { color: #FFB020; background: rgba(255, 176, 32, 0.15); }
.priority-low { color: var(--accent-green); background: rgba(0, 255, 157, 0.15); }

/* ═══════════════════════════════════════════════════════════
   DIVERGENCE MODAL
   ═══════════════════════════════════════════════════════════ */
.divergence-modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.8); backdrop-filter: blur(8px);
    z-index: 9500; display: flex; align-items: center; justify-content: center;
}
.divergence-modal-content {
    width: 90%; max-width: 800px; max-height: 85vh;
    background: linear-gradient(145deg, #0D1117, #161B22);
    border: 1px solid rgba(245, 168, 0, 0.2);
    border-radius: 16px; overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8);
}
.divergence-modal-header {
    padding: 24px; border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    position: sticky; top: 0; background: #0D1117; z-index: 1;
}
.divergence-modal-title {
    display: flex; justify-content: space-between; align-items: center;
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 14px; font-weight: 700; letter-spacing: 2px;
    color: rgba(255, 255, 255, 0.95);
}
.divergence-modal-close {
    font-size: 24px; cursor: pointer; color: rgba(255, 255, 255, 0.5);
    transition: color 0.2s;
}
.divergence-modal-close:hover { color: #FF4444; }
.divergence-modal-scores {
    display: flex; gap: 24px; margin-top: 16px;
}
.modal-score-block { text-align: center; }
.modal-score-value {
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 28px; font-weight: 700;
}
.modal-score-label {
    font-size: 9px; letter-spacing: 2px; color: rgba(255, 255, 255, 0.4);
    margin-top: 4px;
}
.variance-flash { animation: varianceFlash 1s ease-in-out infinite; }
@keyframes varianceFlash {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

.divergence-modal-body { padding: 24px; }
.modal-div-summary {
    font-size: 13px; line-height: 1.6; color: rgba(255, 255, 255, 0.7);
    margin-bottom: 20px; padding: 14px;
    background: rgba(0, 0, 0, 0.3); border-radius: 8px;
    border-left: 3px solid rgba(245, 168, 0, 0.3);
}
.modal-div-section { margin-bottom: 24px; }
.modal-div-section-title {
    font-family: var(--font-head, 'JetBrains Mono', monospace);
    font-size: 11px; font-weight: 700; letter-spacing: 2px;
    color: #F5A800; margin-bottom: 12px;
    padding-bottom: 6px; border-bottom: 1px solid rgba(245, 168, 0, 0.1);
}
.modal-div-section-title.contested { color: #FF8844; border-bottom-color: rgba(255, 136, 68, 0.1); }

.modal-agreement-item, .modal-contested-item {
    padding: 12px; margin-bottom: 10px;
    border-radius: 8px; transition: background 0.2s;
}
.modal-agreement-item { background: rgba(0, 255, 157, 0.04); border-left: 3px solid rgba(0, 255, 157, 0.3); }
.modal-agreement-item:hover { background: rgba(0, 255, 157, 0.08); }
.modal-contested-item { background: rgba(255, 136, 68, 0.04); border-left: 3px solid rgba(255, 136, 68, 0.3); }
.modal-contested-item:hover { background: rgba(255, 136, 68, 0.08); }

.modal-item-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.modal-confidence {
    font-size: 9px; font-weight: 700; letter-spacing: 1px;
    padding: 2px 8px; border-radius: 3px;
}
.modal-item-detail { font-size: 12px; color: rgba(255, 255, 255, 0.6); line-height: 1.5; }
.modal-item-providers { margin-top: 6px; display: flex; gap: 6px; flex-wrap: wrap; }
.modal-provider-chip {
    font-size: 9px; font-weight: 700; letter-spacing: 1px;
    padding: 2px 8px; border-radius: 3px;
    color: #F5A800; background: rgba(245, 168, 0, 0.1);
}
.modal-provider-chip.contested { color: #FF8844; background: rgba(255, 136, 68, 0.1); }

.modal-contested-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.modal-severity {
    font-size: 9px; font-weight: 700; letter-spacing: 1px;
    padding: 2px 8px; border-radius: 3px;
}
.modal-position {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 8px 0; font-size: 12px; color: rgba(255, 255, 255, 0.7);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.modal-evidence {
    font-size: 11px; color: rgba(255, 176, 32, 0.6);
    padding-left: 60px; margin-top: 2px;
}
.modal-impact {
    margin-top: 10px; font-size: 11px; font-weight: 600;
    color: #FF8844; letter-spacing: 0.5px;
    padding: 8px; background: rgba(255, 136, 68, 0.06); border-radius: 4px;
}
.modal-gap-item, .modal-resolution-item {
    padding: 10px 12px; margin-bottom: 8px;
    font-size: 12px; color: rgba(255, 255, 255, 0.7);
    background: rgba(0, 0, 0, 0.2); border-radius: 6px;
}
.modal-priority {
    font-size: 9px; font-weight: 700; margin-right: 8px;
    padding: 2px 6px; border-radius: 3px;
}
@media (min-width: 769px) and (max-width: 1024px) {
    .dashboard-grid {
        grid-template-columns: minmax(360px, 390px) minmax(0, 1fr) minmax(360px, 400px) !important;
    }
}

/* Desktop guard:
   If viewport width dips below 768px (zoom/devtools/layout jitter) on a desktop-class
   device, keep desktop layout instead of switching to mobile UI chrome. */
@media (max-width: 768px) and (hover: hover) and (pointer: fine) {
    body {
        overflow-y: hidden !important;
        height: 100vh !important;
        align-items: center !important;
        padding: 0 !important;
    }

    .screen-container {
        width: 100vw !important;
        height: 100vh !important;
        max-width: 100% !important;
        padding: 12px !important;
        border-radius: 0 !important;
    }

    .dashboard-grid {
        display: grid !important;
        grid-template-columns: minmax(360px, 390px) minmax(0, 1fr) minmax(360px, 400px) !important;
        grid-template-rows: none !important;
        gap: 12px !important;
    }

    .mobile-nav-toggle {
        display: none !important;
    }

    .nav-links {
        display: flex !important;
        grid-column: 2 !important;
        justify-self: center !important;
        position: static !important;
        background: transparent !important;
        border: 0 !important;
        border-radius: 0 !important;
        padding: 0 !important;
        flex-direction: row !important; /* FORCE ROW ON DESKTOP */
        flex-wrap: nowrap !important;
        overflow: visible !important;
        gap: 8px !important;
        max-height: none !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        pointer-events: auto !important;
    }

    .top-bar-utilities {
        grid-column: 3 !important;
        justify-self: end !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .nav-links a {
        width: auto !important;
        text-align: left !important;
        padding: 8px 16px !important;
    }
}

/* Final touch-device mobile nav/layout override */
@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    body {
        overflow-y: auto !important;
        height: auto !important;
        min-height: 100vh !important;
        align-items: flex-start !important;
        padding: 10px 0 !important;
    }

    body.mobile-nav-open {
        overflow: hidden !important;
    }

    .screen-container {
        width: 100% !important;
        height: auto !important;
        padding: 12px !important;
    }

    .dashboard-grid {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto !important;
        height: auto !important;
        overflow: visible !important;
        gap: 20px !important;
    }

    .top-bar {
        position: relative !important;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto auto !important;
        align-items: center !important;
        gap: 10px !important;
        margin-bottom: 14px !important;
    }

    .logo {
        font-size: 20px !important;
        letter-spacing: 0.1em !important;
        min-width: 0 !important;
    }

    .mobile-nav-toggle {
        display: inline-flex !important;
        width: 38px !important;
        height: 38px !important;
        align-items: center !important;
        justify-content: center !important;
        z-index: 1102 !important;
    }

    #hamburgerBtn {
        display: inline-flex !important;
        width: 38px;
        height: 38px;
        align-items: center;
        justify-content: center;
        border: 1px solid rgba(255, 255, 255, 0.15);
        border-radius: 8px;
        background: rgba(255, 255, 255, 0.02);
    }

    .auth-status {
        margin-right: 0 !important;
    }

    .top-bar-utilities {
        grid-column: 2 / 4 !important;
        justify-self: end !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .nav-links {
        position: fixed !important;
        inset: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: flex-start !important;
        align-items: stretch !important;
        gap: 12px !important;
        padding: 88px 20px 20px !important;
        background: rgba(8, 8, 12, 0.97) !important;
        border: 0 !important;
        border-radius: 0 !important;
        max-height: none !important;
        overflow-y: auto !important;
        z-index: 1101 !important;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transform: translateY(-8px);
        transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;

        /* Enable visible scrollbar for mobile nav */
        scrollbar-width: thin;
        scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
    }

    .nav-links::-webkit-scrollbar {
        display: block;
        width: 4px;
    }

    .nav-links::-webkit-scrollbar-thumb {
        background: rgba(255, 255, 255, 0.15);
        border-radius: 10px;
    }

    .nav-links.mobile-open {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        transform: translateY(0);
    }

    .nav-links a {
        width: 100% !important;
        text-align: center !important;
        padding: 12px 16px !important;
        font-size: 15px !important;
    }
}

/* ===================================================================
   CARD SELECTION & ANALYSIS ACTION BAR
   =================================================================== */

.agent-card.card-selected {
    border-color: rgba(0, 255, 157, 0.6) !important;
    box-shadow: 0 0 25px rgba(0, 255, 157, 0.12),
                inset 0 0 1px rgba(0, 255, 157, 0.25),
                0 0 0 1px rgba(0, 255, 157, 0.15) !important;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.analysis-action-bar {
    display: flex;
    gap: 3px;
    padding: 8px 14px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.35) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    animation: aabSlideIn 0.25s ease-out forwards;
    position: relative;
    z-index: 4;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
}

.analysis-action-bar::-webkit-scrollbar {
    display: none;
}

.aab-btn {
    flex: 1 1 auto;
    min-width: 90px;
    padding: 7px 6px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.55);
    font-family: var(--font-head), 'Inter', monospace;
    font-size: 9.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    cursor: pointer;
    border-radius: 3px;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    white-space: nowrap;
}

.aab-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
    border-color: rgba(255, 255, 255, 0.25);
    transform: translateY(-1px);
}

.aab-btn:active {
    transform: translateY(0);
}

.aab-icon {
    font-size: 12px;
    line-height: 1;
}

/* Per-action accent colors */
.aab-interrogate:hover {
    border-color: #FF6B35;
    color: #FF6B35;
    background: rgba(255, 107, 53, 0.1);
    box-shadow: 0 0 12px rgba(255, 107, 53, 0.15);
}

.aab-verify:hover {
    border-color: #F5A800;
    color: #F5A800;
    background: rgba(245, 168, 0, 0.1);
    box-shadow: 0 0 12px rgba(245, 168, 0, 0.15);
}

.aab-defend:hover {
    border-color: var(--accent-green);
    color: var(--accent-green);
    background: rgba(0, 255, 157, 0.1);
    box-shadow: 0 0 12px rgba(0, 255, 157, 0.15);
}

.aab-visualize:hover {
    border-color: #A855F7;
    color: #A855F7;
    background: rgba(168, 85, 247, 0.1);
    box-shadow: 0 0 12px rgba(168, 85, 247, 0.15);
}

.aab-document:hover {
    border-color: #FFB020;
    color: #FFB020;
    background: rgba(255, 176, 32, 0.1);
    box-shadow: 0 0 12px rgba(255, 176, 32, 0.15);
}

@keyframes aabSlideIn {
    from {
        opacity: 0;
        max-height: 0;
        padding-top: 0;
        padding-bottom: 0;
    }
    to {
        opacity: 1;
        max-height: 60px;
        padding-top: 8px;
        padding-bottom: 8px;
    }
}

/* ===================================================================
   TEXT HIGHLIGHT TOOLBAR
   =================================================================== */

.highlight-toolbar {
    position: fixed;
    display: flex;
    gap: 4px;
    background: rgba(0, 0, 0, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 4px;
    border-radius: 8px;
    z-index: 10000;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.8), 0 0 0 1px rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px);
    pointer-events: auto;
    animation: toolbarPop 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform-origin: bottom center;
}

.ht-btn {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #FFF;
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 700;
    padding: 6px 10px;
    border-radius: 4px;
    cursor: pointer;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 4px;
}

.ht-btn:hover {
    background: rgba(255, 255, 255, 0.1);
    border-color: #FFF;
}

/* Highlight toolbar chart dropdown */
.ht-chart-trigger {
    position: relative;
}
.ht-chart-dropdown {
    display: none;
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.95);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 6px;
    padding: 4px;
    margin-bottom: 6px;
    min-width: 100px;
    z-index: 2001;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.8);
}
.ht-chart-dropdown.show {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ht-chart-opt {
    padding: 5px 10px;
    font-size: 9px;
    font-weight: 700;
    font-family: var(--font-head);
    color: #FFF;
    cursor: pointer;
    border-radius: 3px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    white-space: nowrap;
}
.ht-chart-opt:hover {
    background: rgba(255, 255, 255, 0.15);
}

/* XLS export button accent */
.ht-btn.export-xls {
    color: #4ADE80;
    border-color: rgba(74, 222, 128, 0.3);
}
.ht-btn.export-xls:hover {
    background: rgba(74, 222, 128, 0.15);
    border-color: #4ADE80;
}

@keyframes toolbarPop {
    from { transform: scale(0.8) translateY(10px); opacity: 0; }
    to { transform: scale(1) translateY(0); opacity: 1; }
}

/* ===================================================================
   ARTIFACT DOCK (RESULTS CONTAINER REFACTOR)
   =================================================================== */

.results-container {
    position: fixed;
    bottom: 0;
    left: 12px;
    right: 12px;
    height: 78vh;
    max-height: calc(100dvh - 12px);
    background: linear-gradient(180deg, rgba(16, 16, 16, 0.98), rgba(0, 0, 0, 1));
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-bottom: 0;
    border-radius: 20px 20px 0 0;
    display: flex;
    flex-direction: column;
    z-index: 1000;
    transform: translateY(calc(100% - 64px)); /* Tab view by default */
    transition: transform 0.4s cubic-bezier(0.19, 1, 0.22, 1), background 0.3s, right 0.3s ease;
    box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(30px);
}

body.report-library-open .results-container {
    right: 390px;
}

@media (max-width: 1200px) {
    body.report-library-open .results-container {
        right: 12px;
    }
}

@media (max-height: 900px) {
    .results-container {
        height: min(84dvh, calc(100dvh - 8px));
    }

    .results-header {
        min-height: 56px;
        padding: 8px 18px;
    }

    .dock-tab-bar {
        padding: 0 18px;
    }

    .dock-pane {
        padding: 18px;
    }

    .dock-pane.workspace-pane {
        padding: 0;
    }
}

.results-container.active,
.results-container.visible {
    transform: translateY(0);
    background: linear-gradient(180deg, rgba(20, 20, 24, 0.99), rgba(10, 10, 12, 1));
}

.results-container.has-results:not(.active):not(.visible) .results-header {
    border-bottom-color: rgba(245, 168, 0, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 209, 102, 0.04);
}

.results-header {
    min-height: 64px;
    padding: 10px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.results-header-copy {
    display: flex;
    align-items: center;
    gap: 16px;
    min-width: 0;
}

.results-header h3 {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 3px;
    color: var(--accent-taupe);
    text-transform: uppercase;
}

.results-header-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.results-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(232, 232, 236, 0.1);
    background: rgba(24, 24, 24, 0.92);
    color: var(--text-secondary);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.results-status-pill.is-ready {
    border-color: rgba(245, 168, 0, 0.22);
    background: rgba(44, 31, 11, 0.94);
    color: var(--accent-gold-bright);
}

.results-status-text {
    color: var(--text-secondary);
    font-size: 12px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.close-results {
    color: rgba(255, 255, 255, 0.3);
    font-size: 18px;
    cursor: pointer;
    transition: color 0.2s;
}

.close-results:hover {
    color: #FF4444;
}

.results-content {
    flex: 1;
    overflow-y: hidden;
    padding: 0;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

/* ── DOCK TAB BAR ──────────────────────────────────── */

.dock-tab-bar {
    display: flex;
    gap: 0;
    padding: 0 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(0, 0, 0, 0.3);
    flex-shrink: 0;
}

.dock-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: #666;
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.15em;
    padding: 10px 20px;
    cursor: pointer;
    transition: all 0.2s;
    text-transform: uppercase;
    position: relative;
}

.dock-tab:hover {
    color: #AAA;
    background: rgba(255, 255, 255, 0.03);
}

.dock-tab.active {
    color: var(--accent-green);
    border-bottom-color: var(--accent-green);
}

.dock-tab-badge {
    background: #FF4444;
    color: #FFF;
    font-size: 9px;
    font-weight: 800;
    padding: 1px 5px;
    border-radius: 8px;
    margin-left: 6px;
    min-width: 16px;
    text-align: center;
    animation: badge-pulse 2s infinite;
}

@keyframes badge-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(255, 68, 68, 0.4); }
    50% { box-shadow: 0 0 8px 2px rgba(255, 68, 68, 0.6); }
}

/* ── DOCK PANES ────────────────────────────────────── */

.dock-pane {
    display: none;
    flex-direction: column;
    min-height: 0;
    padding: 24px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
}

.dock-pane.workspace-pane {
    padding: 0;
    overflow-x: hidden;
    overflow-y: scroll;
    scrollbar-gutter: stable;
}

.dock-pane::-webkit-scrollbar {
    width: 6px;
}

.dock-pane::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
}

.dock-pane.active {
    display: flex;
    flex: 1;
}

.interrogation-empty-state {
    color: #555;
    font-family: var(--font-head);
    font-size: 11px;
    text-align: center;
    padding: 40px 20px;
    letter-spacing: 0.05em;
}

@media (max-width: 768px) and (hover: none), (max-width: 768px) and (pointer: coarse) {
    .dock-tab-bar {
        padding: 0 12px;
    }
    .dock-tab {
        padding: 8px 12px;
        font-size: 9px;
    }
}

/* ── WORKSPACE SHELL ─────────────────────── */
.dock-workspace {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr) 300px;
    grid-template-rows: auto minmax(0, 1fr);
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

.dock-summary-strip {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.32), rgba(255, 255, 255, 0.02));
    flex-wrap: wrap;
}

.dock-summary-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 88px;
}

.dock-summary-label {
    color: rgba(255, 255, 255, 0.42);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dock-summary-value {
    color: #fff;
    font-family: var(--font-head);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.03em;
}

.dock-summary-item.consensus {
    flex: 1 1 240px;
}

.dock-summary-item.consensus .dock-summary-value {
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
    line-height: 1.45;
}

.dock-summary-value.is-good {
    color: #4CAF7D;
}

.dock-summary-value.is-warning {
    color: #FFB020;
}

.dock-summary-value.is-danger {
    color: #FF6B6B;
}

.dock-roster {
    grid-column: 1;
    min-height: 0;
    overflow-y: auto;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
    padding: 12px 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.dock-reader {
    grid-column: 2;
    min-height: 0;
    overflow-y: auto;
    padding: 20px 24px 28px;
}

.dock-inspector {
    grid-column: 3;
    min-height: 0;
    overflow-y: auto;
    border-left: 1px solid rgba(255, 255, 255, 0.06);
    padding: 14px 12px 18px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.01), rgba(0, 0, 0, 0.18));
}

.dock-roster::-webkit-scrollbar,
.dock-reader::-webkit-scrollbar,
.dock-inspector::-webkit-scrollbar {
    width: 6px;
}

.dock-roster::-webkit-scrollbar-thumb,
.dock-reader::-webkit-scrollbar-thumb,
.dock-inspector::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
}

.roster-card {
    padding: 12px 12px 11px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-left-width: 3px;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.18s ease;
    background: rgba(255, 255, 255, 0.02);
}

.roster-card:hover {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.18);
    transform: translateX(2px);
}

.roster-card.selected {
    border-color: rgba(0, 255, 157, 0.45);
    background: rgba(0, 255, 157, 0.08);
    box-shadow: inset 0 0 0 1px rgba(0, 255, 157, 0.12);
}

.roster-card.failed {
    border-color: rgba(255, 68, 68, 0.4);
    background: rgba(255, 68, 68, 0.04);
    opacity: 0.82;
}

.roster-card.skeleton {
    cursor: default;
    animation: pulse 1.6s infinite;
}

.roster-card.openai {
    border-left-color: #C8C8CC;
}

.roster-card.anthropic {
    border-left-color: #F5A800;
}

.roster-card.google {
    border-left-color: #C47D00;
}

.roster-card.perplexity {
    border-left-color: #E8E8EC;
}

.roster-card.mistral {
    border-left-color: #FFD166;
}

.roster-card.local {
    border-left-color: #999;
}

.roster-card.red_team {
    border-left-color: #FF4444;
}

.roster-card-name {
    font-family: var(--font-head);
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.roster-card-model {
    font-size: 9px;
    color: #777;
    margin-top: 3px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.roster-card-preview {
    margin-top: 8px;
    color: var(--text-secondary);
    font-size: 11px;
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.roster-card-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 9px;
}

.roster-card-pill {
    font-size: 9px;
    color: #b5b5b8;
    background: rgba(255, 255, 255, 0.04);
    padding: 2px 6px;
    border-radius: 999px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.workspace-empty-state {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    color: rgba(255, 255, 255, 0.45);
    font-family: var(--font-head);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.reader-shell {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.reader-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.reader-provider {
    color: #fff;
    font-family: var(--font-head);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.reader-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}

.reader-meta-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
    color: #d8d8db;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.reader-body {
    color: var(--text-secondary);
    font-size: 13px;
    line-height: 1.7;
}

.reader-body .agent-response {
    max-height: none;
    overflow: visible;
    margin-top: 0;
}

.reader-citations {
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    padding-top: 14px;
}

.reader-section-label,
.inspector-section-label {
    color: rgba(255, 255, 255, 0.42);
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.15em;
    text-transform: uppercase;
}

.reader-citations-list {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.reader-citation-link {
    color: #00DCFF;
    font-size: 12px;
    text-decoration: none;
    opacity: 0.82;
}

.reader-citation-link:hover {
    opacity: 1;
    text-decoration: underline;
}

.inspector-card {
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.02);
    padding: 12px;
}

.inspector-selection-meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.inspector-selection-name {
    color: #fff;
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.inspector-selection-copy {
    color: var(--text-secondary);
    font-size: 11px;
    line-height: 1.5;
}

.inspector-actions {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.inspector-btn {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.03);
    color: #d0d0d3;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    cursor: pointer;
    text-align: left;
    transition: all 0.15s ease;
}

.inspector-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
}

.inspector-btn .btn-icon {
    margin-right: 8px;
}

.inspector-panel {
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.02);
}

.inspector-panel-header {
    width: 100%;
    padding: 10px 12px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0.14em;
    color: var(--accent-green);
    cursor: pointer;
    background: rgba(0, 0, 0, 0.3);
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-transform: uppercase;
}

.inspector-panel-chevron {
    color: rgba(255, 255, 255, 0.55);
    transition: transform 0.18s ease;
}

.inspector-panel.open .inspector-panel-chevron {
    transform: rotate(180deg);
}

.inspector-panel-body {
    padding: 12px;
    font-size: 12px;
    line-height: 1.6;
    color: rgba(255, 255, 255, 0.78);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.22s ease;
}

.inspector-panel.open .inspector-panel-body {
    max-height: 260px;
    overflow-y: auto;
}

.inspector-panel-body .consensus-body,
.inspector-panel-body .exec-brief-summary,
.inspector-panel-body .divergence-summary {
    font-size: 12px;
}

.inspector-panel-body .exec-brief-section,
.inspector-panel-body .div-section,
.inspector-panel-body .falcon-counts {
    margin-top: 10px;
}

.inspector-panel-body .exec-brief,
.inspector-panel-body .divergence-summary {
    color: inherit;
}

@media (max-width: 1200px) {
    .dock-workspace {
        grid-template-columns: 200px minmax(0, 1fr) 270px;
    }
}

@media (max-width: 920px) {
    .results-container {
        left: 8px;
        right: 8px;
        height: min(88dvh, calc(100dvh - 8px));
    }

    .results-header {
        padding: 8px 16px;
        align-items: flex-start;
        gap: 10px;
    }

    .results-header-copy,
    .results-header-meta {
        flex-wrap: wrap;
        gap: 8px 12px;
    }

    .results-status-text {
        white-space: normal;
    }

    .dock-workspace {
        grid-template-columns: 1fr;
        grid-template-rows: auto auto minmax(200px, auto) minmax(0, 1fr) auto;
    }

    .dock-roster,
    .dock-reader,
    .dock-inspector {
        grid-column: 1;
        border: 0;
    }

    .dock-roster {
        grid-row: 2;
        padding: 10px 12px 0;
        overflow-x: auto;
        overflow-y: hidden;
        flex-direction: row;
    }

    .roster-card {
        min-width: 220px;
        flex: 0 0 220px;
    }

    .dock-reader {
        grid-row: 3 / 5;
        padding: 16px 16px 22px;
    }

    .dock-inspector {
        grid-row: 5;
        padding: 0 12px 14px;
    }
}

@media (max-width: 640px) {
    .results-container {
        left: 0;
        right: 0;
        height: min(92dvh, 100dvh);
        max-height: 100dvh;
        border-radius: 14px 14px 0 0;
    }

    .results-header {
        min-height: 52px;
        padding: 8px 12px;
    }

    .results-header h3 {
        font-size: 10px;
        letter-spacing: 0.2em;
    }

    .results-status-text {
        font-size: 11px;
    }

    .dock-tab-bar {
        padding: 0 12px;
        overflow-x: auto;
        overflow-y: hidden;
        scrollbar-width: thin;
    }

    .dock-tab {
        flex: 0 0 auto;
        padding: 10px 12px;
        font-size: 9px;
    }

    .dock-pane {
        padding: 14px 12px 18px;
    }

    .dock-pane.workspace-pane {
        padding: 0;
    }

    .rfp-intel-report {
        gap: 12px;
    }

    .rfp-intel-hero {
        padding: 14px;
    }

    .rfp-intel-hero h2 {
        font-size: 18px;
    }

    .rfp-stat-card {
        padding: 12px 14px;
    }

    .rfp-stat-value {
        font-size: 22px;
    }

    .rfp-panel,
    .rfp-response-card {
        padding: 14px;
    }
}

/* ═══════════════════════════════════════════════════════════
   CARD EXPANSION MODAL (inner content box)
   Overlay is .card-modal-overlay — see above for z-index/display rules
   ═══════════════════════════════════════════════════════════ */

.modal-content-wrapper {
    background: linear-gradient(180deg, rgba(20, 20, 24, 0.99), rgba(10, 10, 12, 1));
    border: 1px solid rgba(255, 255, 255, 0.12);
    width: 100%;
    max-width: 800px;
    max-height: 85vh;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8), 0 0 0 1px rgba(255, 255, 255, 0.05);
    animation: modalPop 0.3s cubic-bezier(0.19, 1, 0.22, 1);
}

.modal-header {
    padding: 24px 30px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.modal-title-area h2 {
    font-family: var(--font-head);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #FFF;
    margin: 0;
}

.modal-meta {
    margin-top: 6px;
}

.agent-meta {
    display: flex;
    gap: 12px;
}

.agent-meta span {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--text-tertiary);
}

.brand-hero-container {
    position: relative;
    width: 130px;
    height: 130px;
    margin-bottom: 0px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
}

.brand-hero-logo {
    width: 130px;
    height: 130px;
    object-fit: contain;
    filter: drop-shadow(0 0 10px rgba(255, 176, 32, 0.2));
    z-index: 2;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.brand-hero-container:hover .brand-hero-logo {
    transform: translateY(-2px);
    filter: drop-shadow(0 0 20px rgba(255, 176, 32, 0.4));
}

/* Eye Pulse target - positioned over the amber eye relative to container */
.hero-eye-pulse {
    position: absolute;
    top: 24%;
    left: 48%;
    width: 10px;
    height: 10px;
    background: radial-gradient(circle, rgba(255, 176, 32, 0.8) 0%, rgba(255, 176, 32, 0) 70%);
    border-radius: 50%;
    z-index: 3;
    pointer-events: none;
    opacity: 0.6;
    animation: eyeBreathe 4s infinite ease-in-out;
}

@keyframes eyeBreathe {
    0%, 100% { transform: scale(1); opacity: 0.4; }
    50% { transform: scale(1.8); opacity: 1; }
}

.modal-close {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.4);
    font-size: 28px;
    cursor: pointer;
    line-height: 1;
    transition: color 0.2s;
    padding: 0;
}

.modal-close:hover {
    color: #FF4444;
}

.modal-card-content {
    flex: 1;
    padding: 30px;
    overflow-y: auto;
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.85);
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.1) transparent;
}

.modal-card-content::-webkit-scrollbar {
    width: 6px;
}

.modal-card-content::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 10px;
}

.modal-actions {
    display: flex;
    gap: 10px;
    padding: 20px 30px;
    background: rgba(0, 0, 0, 0.3);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    overflow-x: auto;
    scrollbar-width: none;
}

.modal-action-btn {
    flex: 1;
    min-width: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.7);
    font-family: var(--font-head);
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.19, 1, 0.22, 1);
    white-space: nowrap;
}

.modal-action-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.3);
    color: #FFF;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
}

.modal-action-btn.interrogate:hover {
    background: rgba(255, 107, 53, 0.15);
    border-color: #FF6B35;
    color: #FF6B35;
    box-shadow: 0 0 15px rgba(255, 107, 53, 0.2);
}

.modal-action-btn.verify:hover {
    background: rgba(245, 168, 0, 0.15);
    border-color: #F5A800;
    color: #F5A800;
    box-shadow: 0 0 15px rgba(245, 168, 0, 0.2);
}

.modal-action-btn.copy:hover {
    background: rgba(0, 255, 157, 0.1);
    border-color: var(--accent-green);
    color: var(--accent-green);
    box-shadow: 0 0 15px rgba(0, 255, 157, 0.2);
}

.modal-action-btn.visualize:hover {
    background: rgba(168, 85, 247, 0.1);
    border-color: #A855F7;
    color: #A855F7;
    box-shadow: 0 0 15px rgba(168, 85, 247, 0.2);
}

@keyframes modalPop {
    from { opacity: 0; transform: scale(0.96) translateY(10px); }
    to { opacity: 1; transform: scale(1) translateY(0); }
}

@media (max-width: 600px) {
    .modal-actions {
        flex-wrap: wrap;
    }
    .modal-action-btn {
        flex: 1 1 45%;
    }
}


/* ═══════════════════════════════════════════════════════════
   FINAL RESPONSIVE CALIBRATION (V3.2) - ULTRA COMPRESSION
   ═══════════════════════════════════════════════════════════ */

/* Short monitors/laptops: compress vertical spacing aggressively */
@media (max-height: 800px) {
    .screen-container {
        padding: 6px !important;
    }
    .top-bar {
        margin-bottom: 8px !important;
        grid-template-columns: auto minmax(0, 1fr) auto !important; /* Allow nav to compress */
    }
    .top-bar-wordmark-img {
        height: 24px !important;
    }
    .nav-links {
        max-width: calc(100vw - 350px) !important;
    }
    .nav-links a {
        min-height: 28px !important;
        padding: 4px 10px !important;
        font-size: 9px !important;
    }
    .dashboard-grid {
        height: calc(100% - 70px - var(--dock-resting-height)) !important; /* More space for grid */
        gap: 6px !important;
    }
    .panel {
        padding: 12px !important;
    }
    .panel-header {
        margin-bottom: 8px !important;
    }
    .brand-hero-container, .brand-hero-logo {
        width: 70px !important;
        height: 70px !important;
    }
    .left-panel h1 {
        font-size: 20px !important;
        margin-bottom: 2px !important;
    }
    .subtitle {
        font-size: 9px !important;
        margin-bottom: 12px !important;
    }
    .input-module {
        margin-top: 8px !important;
        padding: 10px !important;
        gap: 8px !important;
    }
    .glass-textarea {
        height: 64px !important;
        font-size: 12px !important;
    }
    .command-deck {
        margin-top: 10px !important;
    }
    .agent-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 6px !important;
    }
    .deck-card {
        padding: 4px !important;
    }
    .deck-avatar {
        font-size: 9px !important;
        height: 24px !important;
        line-height: 24px !important;
    }
    .deck-role {
        font-size: 8px !important;
    }
    .mode-selector {
        padding-top: 8px !important;
        gap: 4px !important;
    }
    .mode-btn {
        padding: 6px 8px !important;
        font-size: 9px !important;
    }
    .trigger-scan {
        padding: 12px !important;
        font-size: 11px !important;
        margin-top: 8px !important;
    }
    
    /* Ensure the left panel can scroll to reach the button if still overflown */
    .left-panel {
        max-height: 100% !important;
    }
    .control-stack {
        flex: 1 !important;
        min-height: 0 !important;
        display: block !important; /* Stack them for better scrolling */
    }

    /* Globe compression — use flex shrink instead of negative margins */
    .globe-container {
        transform: scale(0.8) !important;
        flex: 0 1 auto !important;
        max-height: 280px !important;
    }
    .stage-metric-strip {
        gap: 6px !important;
    }
    .stage-metric-card {
        min-height: 54px !important;
        padding: 8px 10px !important;
    }
    .stage-metric-label {
        font-size: 9px !important;
    }
    .stage-metric-card strong {
        font-size: 14px !important;
    }
    
    /* Comms compression */
    .comms-thread-summary {
        margin-bottom: 6px !important;
    }
    .thread-summary-block {
        padding: 6px !important;
    }
    .sentinel-card h2 {
        font-size: 14px !important;
    }
}

/* ===== RED TEAM STRIKE CARD ===== */
.rt-strike-card {
    background: rgba(255, 40, 40, 0.04);
    border: 1px solid rgba(255, 40, 40, 0.25);
    border-radius: 8px;
    margin: 12px 0;
    padding: 16px 20px;
    font-family: var(--font-body);
}

.rt-strike-card.rt-fail {
    border-color: rgba(255, 40, 40, 0.5);
    background: rgba(255, 40, 40, 0.08);
    box-shadow: 0 0 20px rgba(255, 40, 40, 0.1);
}

.rt-strike-card.rt-pass {
    border-color: rgba(76, 175, 125, 0.4);
    background: rgba(76, 175, 125, 0.04);
}

.rt-strike-detail {
    transition: max-height 0.3s ease, opacity 0.3s ease;
    overflow: hidden;
}

.rt-strike-card.rt-collapsed .rt-strike-detail {
    max-height: 0;
    opacity: 0;
}

.rt-strike-toggle {
    font-size: 10px;
    color: #888;
    transition: transform 0.3s ease;
}

.rt-strike-card.rt-collapsed .rt-strike-toggle {
    transform: rotate(-90deg);
}

.rt-strike-card.rt-collapsed .rt-strike-header {
    margin-bottom: 0;
}

.rt-strike-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
}

.rt-strike-title {
    font-family: var(--font-head);
    font-size: 12px;
    font-weight: 700;
    color: #FF5555;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}

.rt-strike-card.rt-pass .rt-strike-title {
    color: #4CAF7D;
}

.rt-strike-badge {
    font-family: var(--font-head);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 3px 10px;
    border-radius: 4px;
    text-transform: uppercase;
}

.rt-strike-badge.rt-fail {
    background: rgba(255, 40, 40, 0.2);
    color: #FF5555;
    border: 1px solid rgba(255, 40, 40, 0.4);
    animation: redTeamPulse 2.5s ease-in-out infinite;
}

.rt-strike-badge.rt-pass {
    background: rgba(76, 175, 125, 0.15);
    color: #4CAF7D;
    border: 1px solid rgba(76, 175, 125, 0.3);
}

.rt-strike-target {
    font-size: 11px;
    color: #b0b0b0;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    font-style: italic;
}

.rt-strike-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.rt-strike-field {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    padding: 10px 12px;
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.rt-strike-label {
    font-family: var(--font-head);
    font-size: 9px;
    font-weight: 700;
    color: #FF8888;
    letter-spacing: 0.8px;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.rt-strike-card.rt-pass .rt-strike-label {
    color: #7ecfa5;
}

.rt-strike-text {
    font-size: 11px;
    color: #ccc;
    line-height: 1.5;
    margin: 0;
}

.rt-strike-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.rt-strike-list li {
    font-size: 11px;
    color: #ccc;
    line-height: 1.5;
    padding-left: 12px;
    position: relative;
}

.rt-strike-list li::before {
    content: "\2022";
    position: absolute;
    left: 0;
    color: #FF5555;
}

.rt-strike-card.rt-pass .rt-strike-list li::before {
    color: #4CAF7D;
}

.rt-strike-bottom-line {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    font-size: 11px;
    color: #e6edf3;
    font-weight: 600;
    line-height: 1.6;
}

.rt-strike-failures {
    margin-top: 10px;
    padding: 10px 12px;
    background: rgba(255, 40, 40, 0.1);
    border: 1px solid rgba(255, 40, 40, 0.3);
    border-radius: 6px;
    font-size: 11px;
    color: #FF8888;
}

.rt-strike-failures strong {
    font-family: var(--font-head);
    font-size: 10px;
    letter-spacing: 0.5px;
    display: block;
    margin-bottom: 6px;
}

@media (max-width: 768px) {
    .rt-strike-body {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   ATL DASHBOARD — Decision Ledger Audit Transparency Layer
   ============================================================ */

.atl-nav-btn {
    background: none;
    border: 1px solid rgba(255,255,255,0.15);
    color: #C47D00;
    cursor: pointer;
    padding: 6px 8px;
    border-radius: 4px;
    transition: all 0.2s;
}
.atl-nav-btn:hover {
    background: rgba(196,125,0,0.15);
    border-color: #C47D00;
}

.atl-dashboard-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.85);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.atl-dashboard {
    width: 90vw;
    max-width: 1100px;
    height: 85vh;
    background: #111118;
    border: 1px solid rgba(196,125,0,0.3);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.atl-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px 12px;
    border-bottom: 1px solid rgba(196,125,0,0.25);
}
.atl-header h3 {
    margin: 0;
    font-size: 14px;
    letter-spacing: 2px;
    color: #C47D00;
}
.atl-header p {
    margin: 2px 0 0;
    font-size: 10px;
    letter-spacing: 3px;
    color: rgba(255,255,255,0.4);
}
.atl-close-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.5);
    font-size: 24px;
    cursor: pointer;
    padding: 4px 8px;
}
.atl-close-btn:hover { color: #fff; }

.atl-tab-bar {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    padding: 0 24px;
}
.atl-tab {
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-size: 11px;
    letter-spacing: 1.5px;
    padding: 12px 20px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
}
.atl-tab:hover { color: rgba(255,255,255,0.7); }
.atl-tab.active {
    color: #C47D00;
    border-bottom-color: #C47D00;
}

.atl-content {
    flex: 1;
    overflow-y: auto;
    padding: 20px 24px;
}

.atl-tab-panel { display: none; }
.atl-tab-panel.active { display: block; }

/* Tables */
.atl-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}
.atl-table thead th {
    text-align: left;
    padding: 10px 12px;
    font-size: 10px;
    letter-spacing: 1.5px;
    color: rgba(255,255,255,0.4);
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.atl-table tbody td {
    padding: 10px 12px;
    color: rgba(255,255,255,0.8);
    border-bottom: 1px solid rgba(255,255,255,0.04);
}
.atl-mission-row { cursor: pointer; transition: background 0.15s; }
.atl-mission-row:hover { background: rgba(196,125,0,0.08); }

/* Hash display */
.atl-hash {
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 11px;
    opacity: 0.7;
    color: #C47D00;
}

/* Status badges */
.atl-badge-valid {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 3px;
    font-size: 10px;
    letter-spacing: 1px;
    background: rgba(68,255,136,0.12);
    color: #44FF88;
    border: 1px solid rgba(68,255,136,0.25);
}
.atl-badge-tampered {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 3px;
    font-size: 10px;
    letter-spacing: 1px;
    background: rgba(255,68,68,0.12);
    color: #FF4444;
    border: 1px solid rgba(255,68,68,0.25);
}

/* Chain detail */
.atl-chain-header {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 20px;
}
.atl-back-btn {
    background: none;
    border: 1px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.6);
    cursor: pointer;
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
}
.atl-back-btn:hover { color: #fff; border-color: rgba(255,255,255,0.3); }
.atl-chain-title {
    font-size: 13px;
    color: rgba(255,255,255,0.7);
    letter-spacing: 1px;
}

/* Chain event cards */
.atl-chain-event {
    display: flex;
    gap: 16px;
    margin-bottom: 4px;
}
.atl-chain-seq {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 40px;
}
.atl-chain-seq-num {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(196,125,0,0.15);
    border: 1px solid rgba(196,125,0,0.4);
    color: #C47D00;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 600;
}
.atl-chain-arrow {
    width: 2px;
    height: 20px;
    background: rgba(196,125,0,0.25);
    margin-bottom: 4px;
}
.atl-chain-genesis {
    font-size: 8px;
    letter-spacing: 1px;
    color: rgba(196,125,0,0.5);
    margin-bottom: 4px;
}
.atl-chain-body {
    flex: 1;
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 6px;
    padding: 12px 16px;
    margin-bottom: 8px;
}
.atl-chain-event-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}
.atl-event-type {
    font-size: 11px;
    letter-spacing: 1px;
    color: #C47D00;
    font-weight: 600;
}
.atl-event-ts {
    font-size: 10px;
    color: rgba(255,255,255,0.35);
}
.atl-chain-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 11px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 6px;
}
.atl-hmac-badge {
    font-size: 9px;
    letter-spacing: 1px;
    padding: 1px 6px;
    border-radius: 3px;
    background: rgba(68,255,136,0.1);
    color: #44FF88;
}
.atl-chain-record-hash {
    font-size: 10px;
    color: rgba(255,255,255,0.3);
}

/* Integrity tab */
.atl-integrity-controls {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
}
.atl-verify-all-btn {
    background: rgba(196,125,0,0.15);
    border: 1px solid rgba(196,125,0,0.4);
    color: #C47D00;
    padding: 10px 20px;
    font-size: 11px;
    letter-spacing: 2px;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.2s;
}
.atl-verify-all-btn:hover {
    background: rgba(196,125,0,0.25);
}
.atl-integrity-row {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    font-size: 12px;
    color: rgba(255,255,255,0.7);
}
.atl-failure {
    font-size: 11px;
    color: #FF4444;
    margin-top: 4px;
    padding-left: 12px;
}

/* Evidence vault tab */
.atl-evidence-controls {
    margin-bottom: 20px;
}
.atl-evidence-label {
    font-size: 10px;
    letter-spacing: 2px;
    color: rgba(255,255,255,0.4);
    display: block;
    margin-bottom: 8px;
}
.atl-evidence-input-row {
    display: flex;
    gap: 8px;
}
.atl-evidence-input {
    flex: 1;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    color: #C47D00;
    padding: 10px 14px;
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 12px;
    border-radius: 4px;
}
.atl-evidence-input:focus {
    outline: none;
    border-color: rgba(196,125,0,0.4);
}
.atl-reveal-btn {
    background: rgba(196,125,0,0.15);
    border: 1px solid rgba(196,125,0,0.4);
    color: #C47D00;
    padding: 10px 20px;
    font-size: 11px;
    letter-spacing: 2px;
    cursor: pointer;
    border-radius: 4px;
}
.atl-reveal-btn:hover { background: rgba(196,125,0,0.25); }
.atl-evidence-meta {
    display: flex;
    gap: 24px;
    font-size: 11px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 12px;
}
.atl-evidence-block {
    background: rgba(0,0,0,0.4);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 6px;
    padding: 16px;
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 11px;
    color: rgba(255,255,255,0.7);
    overflow-x: auto;
    white-space: pre-wrap;
    max-height: 400px;
    overflow-y: auto;
}

/* Footer */
.atl-footer {
    padding: 12px 24px;
    border-top: 1px solid rgba(255,255,255,0.06);
    text-align: right;
}
.atl-footer-status {
    font-size: 10px;
    letter-spacing: 2px;
    color: rgba(255,255,255,0.3);
}
.atl-footer-valid { color: #44FF88; }
.atl-footer-tampered { color: #FF4444; }

/* Utility */
.atl-loading { color: rgba(255,255,255,0.4); font-size: 12px; }
.atl-empty { color: rgba(255,255,255,0.3); font-size: 12px; font-style: italic; }
.atl-error { color: #FF4444; font-size: 12px; }

/* =========================================================================
   SETTINGS PANEL
   ========================================================================= */

.settings-nav-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.5);
    cursor: pointer;
    padding: 6px;
    transition: color 0.2s;
}
.settings-nav-btn:hover { color: #FFB020; }

.settings-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.85);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.settings-modal {
    background: #1A1D24;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    width: 90%;
    max-width: 700px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}

.settings-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px 12px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.settings-header h3 {
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #FFB020;
}
.settings-close-btn {
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-size: 24px;
    cursor: pointer;
    padding: 0 4px;
}
.settings-close-btn:hover { color: #fff; }

.settings-tab-bar {
    display: flex;
    gap: 0;
    padding: 0 24px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.settings-tab {
    padding: 12px 20px;
    border: none;
    background: transparent;
    color: rgba(255,255,255,0.4);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.2s;
}
.settings-tab:hover { color: rgba(255,255,255,0.7); }
.settings-tab.active {
    color: #FFB020;
    border-bottom-color: #FFB020;
}

.settings-content { padding: 20px 24px; }

.settings-tab-panel { display: none; }
.settings-tab-panel.active,
.settings-tab-panel[style*="block"] { display: block; }

.settings-section {
    margin-bottom: 28px;
}
.settings-section h4 {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 2px;
    color: rgba(255,255,255,0.5);
    margin: 0 0 14px 0;
    padding-bottom: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.settings-form-group {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.settings-form-group label {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.5);
    min-width: 160px;
}
.settings-value {
    font-size: 13px;
    color: rgba(255,255,255,0.85);
}

.settings-role-badge {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 3px 10px;
    border-radius: 4px;
}
.role-admin { background: rgba(255,176,32,0.15); color: #FFB020; }
.role-compliance { background: rgba(68,255,136,0.12); color: #44FF88; }
.role-user { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.6); }

.settings-input {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 6px;
    padding: 8px 12px;
    color: #fff;
    font-size: 13px;
    width: 280px;
    transition: border-color 0.2s;
}
.settings-input:focus {
    outline: none;
    border-color: #FFB020;
}

.settings-save-btn {
    background: #FFB020;
    color: #000;
    border: none;
    border-radius: 6px;
    padding: 10px 20px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    cursor: pointer;
    margin-top: 8px;
    transition: background 0.2s;
}
.settings-save-btn:hover { background: #FFC040; }

.settings-msg {
    font-size: 12px;
    margin-top: 8px;
    min-height: 18px;
}
.settings-msg.success { color: #44FF88; }
.settings-msg.error { color: #FF4444; }

/* API Status Grid */
.settings-api-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.settings-api-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: rgba(255,255,255,0.03);
    border-radius: 6px;
    border: 1px solid rgba(255,255,255,0.06);
}
.settings-api-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.settings-api-dot.active { background: #44FF88; box-shadow: 0 0 6px rgba(68,255,136,0.4); }
.settings-api-dot.missing { background: #FF4444; box-shadow: 0 0 6px rgba(255,68,68,0.3); }
.settings-api-label {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255,255,255,0.8);
    flex: 1;
}
.settings-api-status {
    font-size: 10px;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.4);
}

/* User Management Table */
.settings-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}
.settings-table th {
    text-align: left;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: rgba(255,255,255,0.4);
    padding: 8px 10px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
}
.settings-table td {
    padding: 10px;
    color: rgba(255,255,255,0.8);
    border-bottom: 1px solid rgba(255,255,255,0.04);
}
.settings-table tr:hover td { background: rgba(255,255,255,0.03); }

.settings-role-select {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 4px;
    color: #fff;
    padding: 4px 8px;
    font-size: 11px;
    cursor: pointer;
}
.settings-role-select:focus { outline: none; border-color: #FFB020; }

/* Falcon Config */
.settings-falcon-section {
    margin-bottom: 14px;
}
.settings-falcon-section label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 4px;
}
.settings-falcon-textarea {
    width: 100%;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 6px;
    color: rgba(255,255,255,0.85);
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    padding: 8px 12px;
    resize: vertical;
    box-sizing: border-box;
}
.settings-falcon-textarea:focus {
    outline: none;
    border-color: #FFB020;
}

/* Utility */
.settings-loading { color: rgba(255,255,255,0.4); font-size: 12px; }
.settings-error { color: #FF4444; font-size: 12px; }

/* Add User Row */
.settings-add-user { margin-bottom: 16px; }
.settings-add-user-row {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-wrap: wrap;
}
.settings-input-sm { width: 180px; }
.settings-add-btn {
    margin-top: 0;
    padding: 8px 16px;
    font-size: 10px;
    white-space: nowrap;
}

/* =========================================================================
   INTELLIGENCE FEED — Unified Follow-Up / Verification / Interrogation
   ========================================================================= */

.followup-spotlight-expand {
    background: rgba(255,176,32,0.12);
    border: 1px solid rgba(255,176,32,0.3);
    color: #FFB020;
    padding: 4px 12px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}
.followup-spotlight-expand:hover {
    background: rgba(255,176,32,0.2);
    border-color: #FFB020;
}

.intel-feed-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.88);
    z-index: 11000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.intel-feed-modal {
    background: #1A1D24;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    width: 92%;
    max-width: 900px;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 20px 60px rgba(0,0,0,0.6);
}

.intel-feed-header {
    display: flex;
    align-items: center;
    padding: 18px 24px 14px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    flex-shrink: 0;
}
.intel-feed-header-left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}
.intel-feed-header h3 {
    margin: 0;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 2px;
    color: #FFB020;
}
.intel-feed-count {
    font-size: 11px;
    color: rgba(255,255,255,0.35);
    letter-spacing: 1px;
}
.intel-feed-close {
    background: none;
    border: none;
    color: rgba(255,255,255,0.4);
    font-size: 24px;
    cursor: pointer;
    padding: 0 4px;
}
.intel-feed-close:hover { color: #fff; }

.intel-feed-cards {
    flex: 1;
    overflow-y: auto;
    padding: 16px 24px;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.1) transparent;
}

.intel-feed-empty {
    color: rgba(255,255,255,0.3);
    font-size: 12px;
    font-style: italic;
    text-align: center;
    padding: 40px 0;
}

/* Individual Cards */
.intel-feed-card {
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.06);
    border-left: 3px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    margin-bottom: 12px;
    overflow: hidden;
}
.intel-feed-card.type-followup { border-left-color: #FFB020; }
.intel-feed-card.type-verification { border-left-color: #F5A800; }
.intel-feed-card.type-interrogation { border-left-color: #FF4444; }

.intel-feed-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
}

.intel-feed-badge {
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1.5px;
    padding: 3px 8px;
    border-radius: 3px;
    flex-shrink: 0;
}
.intel-feed-badge.badge-followup {
    background: rgba(255,176,32,0.12);
    color: #FFB020;
}
.intel-feed-badge.badge-verification {
    background: rgba(245,168,0,0.12);
    color: #F5A800;
}
.intel-feed-badge.badge-interrogation {
    background: rgba(255,68,68,0.12);
    color: #FF4444;
}

.intel-feed-title {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255,255,255,0.8);
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.intel-feed-time {
    font-size: 10px;
    color: rgba(255,255,255,0.25);
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

.intel-feed-dock-btn {
    background: rgba(0,255,157,0.08);
    border: 1px solid rgba(0,255,157,0.25);
    color: #00FF9D;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 1px;
    cursor: pointer;
    flex-shrink: 0;
    font-family: inherit;
    transition: all 0.2s;
}
.intel-feed-dock-btn:hover {
    background: rgba(0,255,157,0.15);
    border-color: #00FF9D;
}
.intel-feed-dock-btn.docked {
    opacity: 0.4;
    cursor: default;
}

/* Score Delta Pills */
.intel-feed-delta {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.5px;
    padding: 2px 8px;
    border-radius: 10px;
    flex-shrink: 0;
}
.intel-feed-delta.delta-up {
    background: rgba(0,255,157,0.12);
    color: #00FF9D;
}
.intel-feed-delta.delta-down {
    background: rgba(255,68,68,0.12);
    color: #FF4444;
}

.intel-feed-card-body {
    padding: 12px 16px;
    font-size: 13px;
    line-height: 1.7;
    color: rgba(255,255,255,0.82);
    word-break: break-word;
}

/* Mobile */
@media (max-width: 768px) {
    .intel-feed-modal {
        width: 100%;
        max-width: 100%;
        max-height: 94vh;
        border-radius: 8px 8px 0 0;
    }
    .intel-feed-cards { padding: 12px 14px; }
    .intel-feed-card-header { flex-wrap: wrap; gap: 6px; }
}

/* --- Settings: API Keys + Invite Reveal Box --- */
.settings-hint {
    font-size: 12px;
    color: rgba(255,255,255,0.35);
    margin: -8px 0 14px;
    line-height: 1.6;
}
.settings-key-reveal {
    background: rgba(76,175,125,0.07);
    border: 1px solid rgba(76,175,125,0.25);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 12px;
}
.settings-key-reveal-label {
    font-size: 10px;
    letter-spacing: 1.5px;
    color: #4CAF7D;
    margin-bottom: 8px;
}
.settings-key-reveal-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.settings-key-value {
    flex: 1;
    font-family: 'Courier New', monospace;
    font-size: 12px;
    color: #e0e0e0;
    word-break: break-all;
    background: rgba(0,0,0,0.3);
    padding: 6px 10px;
    border-radius: 4px;
}
.settings-copy-key-btn {
    background: rgba(76,175,125,0.15);
    border: 1px solid rgba(76,175,125,0.3);
    border-radius: 5px;
    color: #4CAF7D;
    font-family: var(--font-mono, monospace);
    font-size: 11px;
    letter-spacing: 1px;
    padding: 6px 14px;
    cursor: pointer;
    white-space: nowrap;
}
.settings-copy-key-btn:hover { background: rgba(76,175,125,0.25); }
.settings-user-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}
.settings-user-table th {
    text-align: left;
    font-size: 10px;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.3);
    padding: 6px 8px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.settings-user-table td {
    padding: 8px;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    color: rgba(255,255,255,0.7);
    vertical-align: middle;
}
