:root {
    color-scheme: dark;
    --bg: #07080a;
    --bg-rgb: 7, 8, 10;
    --bg-lift: #111318;
    --surface: rgba(22, 24, 29, 0.9);
    --surface-strong: rgba(31, 34, 40, 0.96);
    --surface-soft: rgba(205, 213, 224, 0.065);
    --surface-panel: linear-gradient(180deg, rgba(37, 40, 47, 0.94), rgba(13, 15, 19, 0.95));
    --sidebar-bg: rgba(10, 11, 14, 0.97);
    --tooltip-bg: rgba(25, 28, 34, 0.98);
    --border: rgba(205, 213, 224, 0.18);
    --border-strong: rgba(138, 166, 192, 0.48);
    --text: #f4f6f8;
    --muted: #aab2bd;
    --soft: #77818d;
    --cyan: #9fb5c8;
    --cyan-rgb: 159, 181, 200;
    --cyan-strong: #6f879d;
    --cyan-strong-rgb: 111, 135, 157;
    --cyan-soft: rgba(159, 181, 200, 0.15);
    --silver: #e8edf2;
    --warning: #ffd166;
    --warning-bg: rgba(255, 209, 102, 0.12);
    --danger: #e53947;
    --code-bg: #0d0f13;
    --code-text: #edf1f5;
    --button-text: #fff7f8;
    --shadow: 0 24px 80px rgba(0, 0, 0, 0.52);
    --glow: 0 0 34px rgba(159, 181, 200, 0.2);
    --brand-glow: drop-shadow(0 0 22px rgba(229, 57, 71, 0.24));
}

* {
    box-sizing: border-box;
}


[hidden] {
    display: none !important;
}

body {
    margin: 0;
    min-height: 100vh;
    background:
        linear-gradient(180deg, rgba(var(--cyan-strong-rgb), 0.16) 0, rgba(var(--bg-rgb), 0) 340px),
        radial-gradient(circle at 50% -20%, rgba(var(--cyan-rgb), 0.22), rgba(var(--bg-rgb), 0) 360px),
        var(--bg);
    color: var(--text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.5;
}

a {
    color: inherit;
    text-decoration: none;
}

.page {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: 28px 0 52px;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 28px;
}

.brand {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    border-radius: 8px;
}

.brand:hover .brand-title,
.brand:focus-visible .brand-title {
    color: var(--cyan);
}

.brand:focus-visible {
    outline: 2px solid var(--cyan);
    outline-offset: 6px;
}


.brand-logo {
    width: 48px;
    height: 48px;
    object-fit: contain;
    filter: var(--brand-glow);
}

.brand-title {
    margin: 0;
    color: var(--silver);
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.brand-subtitle {
    margin: 2px 0 0;
    color: var(--cyan);
    font-size: 13px;
    font-weight: 750;
    letter-spacing: 0.26em;
    text-transform: uppercase;
}

.top-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}


.top-account-menu {
    position: relative;
}

.top-account-menu summary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 7px 11px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--cyan-soft);
    color: var(--silver);
    cursor: pointer;
    max-width: 100%;
    min-width: 0;
    font-size: 13px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    list-style: none;
    white-space: normal;
    overflow-wrap: anywhere;
}

.top-help-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 7px 11px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(148, 163, 184, 0.08);
    max-width: 100%;
    min-width: 0;
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    white-space: normal;
    overflow-wrap: anywhere;
}

.top-help-link:hover,
.top-help-link:focus {
    border-color: var(--cyan);
    color: var(--cyan);
}

.top-account-menu summary::-webkit-details-marker {
    display: none;
}

.top-account-panel {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    z-index: 60;
    display: grid;
    gap: 8px;
    width: 230px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--tooltip-bg);
    box-shadow: var(--shadow);
}

.top-account-panel a {
    padding: 7px 0;
    color: var(--cyan);
    font-size: 13px;
    font-weight: 800;
}

.top-account-panel form,
.top-account-panel button {
    width: 100%;
}

@media (max-width: 620px) {
    .top-account-menu,
    .top-account-menu summary {
        width: 100%;
    }

    .top-account-panel {
        position: static;
        width: 100%;
        margin-top: 8px;
    }
}

.status-pill,
.back-link,
.primary-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    border-radius: 8px;
    max-width: 100%;
    min-width: 0;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    white-space: normal;
    overflow-wrap: anywhere;
}

.status-pill,
.back-link {
    gap: 8px;
    padding: 9px 13px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.045);
    color: var(--silver);
}

.primary-link,
button {
    padding: 11px 18px;
    border: 1px solid rgba(var(--cyan-rgb), 0.55);
    background: linear-gradient(135deg, var(--cyan), var(--cyan-strong));
    color: var(--button-text);
    box-shadow: 0 16px 34px rgba(var(--cyan-strong-rgb), 0.28);
}

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--cyan);
    box-shadow: 0 0 0 5px var(--cyan-soft), 0 0 20px rgba(var(--cyan-rgb), 0.7);
}

.hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 22px;
    align-items: stretch;
    margin-bottom: 22px;
}

.hero-main,
.panel,
.section,
.list-panel,
.summary-panel,
.guide-panel,
.builder-panel {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-panel);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
}

.hero-main {
    position: relative;
    overflow: hidden;
    padding: 30px;
}

.hero-main::before {
    content: "";
    position: absolute;
    inset: 0;
    border-top: 1px solid rgba(var(--cyan-rgb), 0.45);
    background: linear-gradient(110deg, rgba(var(--cyan-rgb), 0.11), rgba(255, 255, 255, 0) 48%);
    pointer-events: none;
}

.hero-content {
    position: relative;
    z-index: 1;
    min-width: 0;
}


.hero-brand-lockup {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 18px;
}

.hero-logo {
    width: 78px;
    height: 78px;
    object-fit: contain;
    filter: var(--brand-glow);
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    color: var(--cyan);
    font-size: 12px;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

h1 {
    max-width: 820px;
    margin: 0;
    color: var(--silver);
    font-size: clamp(32px, 4vw, 54px);
    line-height: 1.04;
    letter-spacing: 0;
}

.product-name {
    color: var(--cyan);
    text-shadow: 0 0 24px rgba(var(--cyan-rgb), 0.32);
}

.hero-copy {
    max-width: 760px;
    margin: 16px 0 0;
    color: var(--muted);
    font-size: 16px;
}

.layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.9fr);
    gap: 22px;
    align-items: start;
}

.stack {
    display: grid;
    gap: 22px;
}

.panel-header,
.section-header,
.list-panel h2 {
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015));
}

.panel-header,
.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 20px;
}

.section-header h2,
.section-header h3 {
    min-width: 0;
}

.section-actions {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.export-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.export-action-grid form {
    min-width: 0;
}

.export-action-grid .primary-link,
.export-action-grid .secondary-button,
.export-action-grid button {
    width: 100%;
}

.secondary-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 6px 11px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
    color: var(--silver);
    box-shadow: none;
    font: inherit;
    max-width: 100%;
    min-width: 0;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    cursor: pointer;
    white-space: normal;
    overflow-wrap: anywhere;
}



.sigma-row-custom {
    border-left: 4px solid var(--cyan);
    background: linear-gradient(90deg, rgba(159, 181, 200, 0.13), rgba(255, 255, 255, 0.035));
}

.sigma-source-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 100%;
    min-height: 24px;
    margin-left: 8px;
    padding: 3px 8px;
    border: 1px solid rgba(159, 181, 200, 0.54);
    border-radius: 999px;
    background: rgba(159, 181, 200, 0.13);
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    vertical-align: middle;
    white-space: normal;
    overflow-wrap: anywhere;
}

.sigma-context-custom {
    border-color: rgba(159, 181, 200, 0.42);
    background: rgba(159, 181, 200, 0.08);
}

.sigma-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.sigma-hero-actions .primary-link,
.sigma-hero-actions .secondary-button,
.sigma-rule-submit-actions button {
    min-width: 170px;
    min-height: 44px;
    padding: 11px 18px;
    border: 1px solid rgba(var(--cyan-rgb), 0.55);
    border-radius: 8px;
    background: linear-gradient(135deg, var(--cyan), var(--cyan-strong));
    color: var(--button-text);
    box-shadow: 0 16px 34px rgba(var(--cyan-strong-rgb), 0.28);
    font-size: 13px;
    font-weight: 850;
}

.sigma-hero-actions .primary-link:hover,
.sigma-hero-actions .secondary-button:hover,
.sigma-rule-submit-actions button:hover {
    transform: translateY(-1px);
}

.secondary-button[hidden] {
    display: none;
}

.reset-filter-button {
    border-color: rgba(255, 209, 102, 0.72) !important;
    background: rgba(255, 209, 102, 0.16) !important;
    color: var(--warning) !important;
    box-shadow: 0 0 0 1px rgba(255, 209, 102, 0.16), 0 12px 24px rgba(255, 209, 102, 0.08) !important;
}

.reset-filter-button:hover,
.reset-filter-button:focus-visible {
    background: rgba(255, 209, 102, 0.24) !important;
    box-shadow: 0 0 0 4px rgba(255, 209, 102, 0.1), 0 14px 28px rgba(255, 209, 102, 0.1) !important;
}

.power-enrichment-button {
    border-color: rgba(59, 255, 143, 0.78) !important;
    background: linear-gradient(135deg, rgba(46, 255, 126, 0.95), rgba(13, 184, 94, 0.95)) !important;
    color: #04150b !important;
    box-shadow: 0 0 0 1px rgba(59, 255, 143, 0.34), 0 0 28px rgba(59, 255, 143, 0.46), 0 16px 34px rgba(13, 184, 94, 0.24) !important;
}

.power-enrichment-button:hover,
.power-enrichment-button:focus-visible {
    background: linear-gradient(135deg, rgba(89, 255, 166, 1), rgba(19, 207, 112, 1)) !important;
    box-shadow: 0 0 0 4px rgba(59, 255, 143, 0.16), 0 0 38px rgba(59, 255, 143, 0.62), 0 18px 38px rgba(13, 184, 94, 0.28) !important;
}

.is-submitting .power-enrichment-button,
.power-enrichment-button.power-enrichment-running,
.power-enrichment-button[aria-busy="true"] {
    animation: power-enrichment-blink 760ms ease-in-out infinite alternate;
    opacity: 1 !important;
}

@keyframes power-enrichment-blink {
    from {
        filter: brightness(0.9) saturate(1);
        box-shadow: 0 0 0 1px rgba(59, 255, 143, 0.26), 0 0 18px rgba(59, 255, 143, 0.3), 0 12px 26px rgba(13, 184, 94, 0.18) !important;
    }
    to {
        filter: brightness(1.24) saturate(1.25);
        box-shadow: 0 0 0 5px rgba(59, 255, 143, 0.2), 0 0 48px rgba(59, 255, 143, 0.82), 0 20px 42px rgba(13, 184, 94, 0.32) !important;
    }
}

.danger-button {
    border-color: rgba(255, 88, 116, 0.55) !important;
    color: var(--danger) !important;
}

.danger-button:hover,
.danger-button:focus-visible {
    background: rgba(255, 88, 116, 0.12) !important;
    box-shadow: 0 0 0 4px rgba(255, 88, 116, 0.08);
}

.panel-header {
    display: block;
    padding: 20px 22px;
}

h2 {
    margin: 0;
    color: var(--silver);
    font-size: 16px;
    line-height: 1.25;
}

.panel-header h2 {
    font-size: 18px;
}

.panel-header p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 14px;
}

.pill {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    background: var(--cyan-soft);
    color: var(--cyan);
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.section {
    overflow: hidden;
}

.section-body {
    padding: 20px;
}

.quick-reference-stack {
    display: grid;
    gap: 10px;
    margin-top: 22px;
}

.compact-disclosure > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    min-height: 50px;
    padding: 12px 18px;
    border-bottom: 0;
    color: var(--silver);
    cursor: pointer;
    font-size: 14px;
    font-weight: 850;
    list-style: none;
}

.compact-disclosure > summary::-webkit-details-marker {
    display: none;
}

.compact-disclosure > summary::before {
    content: "+";
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    width: 22px;
    height: 22px;
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    color: var(--cyan);
    font-size: 15px;
    line-height: 1;
}

.compact-disclosure[open] > summary {
    border-bottom: 1px solid var(--border);
}

.compact-disclosure[open] > summary::before {
    content: "-";
}

.compact-disclosure > summary span:first-child {
    flex: 1;
    min-width: 0;
    overflow-wrap: anywhere;
}

.confidence-context {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 0;
    padding: 12px 14px;
    border-width: 2px;
    background: rgba(255, 255, 255, 0.035);
}

.confidence-heading {
    display: grid;
    gap: 2px;
    min-width: 150px;
}

.confidence-context .label,
.confidence-context .value,
.confidence-summary {
    color: inherit;
}

.confidence-summary {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    font-weight: 750;
    line-height: 1.35;
}

.confidence-high {
    border-color: rgba(255, 88, 116, 0.95);
    background: rgba(255, 88, 116, 0.09);
    color: #ff8fa1;
}

.confidence-medium {
    border-color: rgba(255, 209, 102, 0.95);
    background: rgba(255, 209, 102, 0.1);
    color: var(--warning);
}

.confidence-low {
    border-color: rgba(168, 85, 247, 0.95);
    background: rgba(168, 85, 247, 0.1);
    color: #c4a1ff;
}

.full-width-section {
    margin-top: 22px;
}

.context-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
    gap: 12px;
    margin-top: 24px;
}

.scope-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 0;
}

.scope-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.scope-list li {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
    padding: 13px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.scope-label {
    color: var(--soft);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.scope-value {
    overflow-wrap: anywhere;
    color: var(--silver);
    font-size: 14px;
    font-weight: 750;
}

.context-item,
.summary-row,
.metric,
.guide-list li {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.context-item {
    min-width: 0;
    padding: 14px;
}

.context-grid .confidence-context {
    grid-column: 1 / span 3;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 16px;
    min-height: 0;
    padding: 12px 14px;
    border-width: 2px;
}

.context-grid .confidence-context.confidence-high {
    border-color: rgba(255, 88, 116, 0.95);
    background: rgba(255, 88, 116, 0.1);
    color: #ff8fa1;
}

.context-grid .confidence-context.confidence-medium {
    border-color: rgba(255, 209, 102, 0.95);
    background: rgba(255, 209, 102, 0.11);
    color: var(--warning);
}

.context-grid .confidence-context.confidence-low {
    border-color: rgba(168, 85, 247, 0.95);
    background: rgba(168, 85, 247, 0.12);
    color: #c4a1ff;
}

.context-grid .confidence-context .label,
.context-grid .confidence-context .value,
.context-grid .confidence-context .confidence-summary {
    color: inherit;
}

.label,
.summary-label {
    display: block;
    margin-bottom: 5px;
    color: var(--soft);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.value,
.summary-value {
    display: block;
    overflow-wrap: anywhere;
    color: var(--silver);
    font-size: 14px;
    font-weight: 750;
}

.summary-value.empty,
.muted {
    color: var(--muted);
}

.summary-panel,
.guide-panel {
    padding: 22px;
}

.summary-title,
.guide-panel h2 {
    margin: 0 0 16px;
}

.metric {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    padding: 13px 14px;
    margin-top: 10px;
}

.metric:first-of-type {
    margin-top: 0;
}

.metric-name {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

.metric-value {
    color: var(--cyan);
    font-size: 22px;
    font-weight: 850;
}

.guide-list {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.guide-list li {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 11px;
    align-items: start;
    padding: 12px;
    color: var(--muted);
    font-size: 14px;
}

.step-number {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: var(--cyan-soft);
    color: var(--cyan);
    font-size: 12px;
    font-weight: 850;
}

.input-warning {
    margin: 18px 22px 0;
    padding: 14px 16px;
    border: 1px solid rgba(255, 209, 102, 0.5);
    border-radius: 8px;
    background: var(--warning-bg);
    color: var(--silver);
    font-size: 13px;
}

.input-warning ul {
    display: grid;
    gap: 6px;
    margin: 10px 0 0;
    padding-left: 20px;
}

.hunt-form {
    display: grid;
    gap: 20px;
    padding: 22px;
}

.field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.field {
    display: grid;
    gap: 8px;
}

.field.full {
    grid-column: 1 / -1;
}

.time-range-custom {
    margin-top: -2px;
}

.custom-time-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

@media (max-width: 720px) {
    .custom-time-grid {
        grid-template-columns: 1fr;
    }
}


label {
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.hint,
#technique_search_status {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
}

select,
input,
textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(2, 8, 18, 0.72);
    color: var(--text);
    font: inherit;
    font-size: 14px;
    outline: none;
    transition: border-color 140ms ease, box-shadow 140ms ease, background 140ms ease;
}

select,
input {
    padding: 10px 12px;
}

textarea {
    min-height: 132px;
    padding: 12px;
    resize: vertical;
}


select:focus,
input:focus,
textarea:focus {
    border-color: var(--cyan);
    box-shadow: 0 0 0 4px var(--cyan-soft), var(--glow);
}

select:disabled,
input:disabled,
textarea:disabled {
    background: rgba(255, 255, 255, 0.035);
    color: var(--soft);
    cursor: not-allowed;
}

option {
    background: #07111d;
    color: var(--text);
}

.form-actions,
.footer-actions {
    display: flex;
    justify-content: flex-end;
}

.form-actions {
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 4px;
}


.sigma-builder-actions {
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.sigma-builder-actions button {
    min-width: 150px;
}

.sigma-rule-submit-actions button {
    min-width: 170px;
}

.sigma-source-context {
    display: grid;
    gap: 14px;
}


.multi-entry {
    display: grid;
    gap: 10px;
}

.multi-entry-control {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
}

.multi-entry-control button {
    min-width: 86px;
}

.multi-entry-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-height: 36px;
}

.multi-entry-chip {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    gap: 8px;
    padding: 7px 8px 7px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(159, 181, 200, 0.08);
    color: var(--silver);
    font-size: 13px;
    font-weight: 800;
}

.multi-entry-chip span {
    overflow-wrap: anywhere;
}

.multi-entry-chip button {
    display: inline-grid;
    place-items: center;
    width: 22px;
    min-width: 22px;
    height: 22px;
    min-height: 22px;
    padding: 0;
    border-radius: 999px;
    font-size: 12px;
    line-height: 1;
}


.submit-status {
    display: none;
    align-items: center;
    min-height: 46px;
    margin: 0;
    color: var(--silver);
    font-size: 13px;
    font-weight: 800;
}

.submit-status.active,
.submit-status:not(:empty) {
    display: inline-flex;
}

.is-submitting button[type="submit"],
button[aria-busy="true"],
.primary-link[aria-busy="true"],
.primary-link.is-submitting {
    animation: analyst-button-pulse 820ms ease-in-out infinite alternate;
    cursor: wait;
    opacity: 1;
}

.is-submitting .power-enrichment-button,
.power-enrichment-button.power-enrichment-running,
.power-enrichment-button[aria-busy="true"] {
    animation: power-enrichment-blink 760ms ease-in-out infinite alternate;
    opacity: 1 !important;
}

@keyframes analyst-button-pulse {
    from {
        filter: brightness(0.94) saturate(1);
        transform: translateY(0) scale(1);
        box-shadow: 0 0 0 1px rgba(103, 232, 249, 0.16), 0 8px 18px rgba(15, 23, 42, 0.12);
    }
    to {
        filter: brightness(1.16) saturate(1.18);
        transform: translateY(-1px) scale(1.015);
        box-shadow: 0 0 0 4px rgba(159, 181, 200, 0.13), 0 0 26px rgba(103, 232, 249, 0.32), 0 14px 30px rgba(15, 23, 42, 0.18);
    }
}


.ttp-action-stack {
    display: grid;
    gap: 10px;
    margin-top: 16px;
}

.saved-hunt-action-stack {
    gap: 14px;
    margin-top: 20px;
}

.saved-hunt-hero-actions {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    align-items: stretch;
    gap: 12px;
    margin-top: 24px;
}

.generated-hunt-hero-actions {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.saved-hunt-hero-actions .inline-action-form {
    display: flex;
    margin: 0;
}

.saved-hunt-hero-actions .inline-action-form,
.saved-hunt-hero-actions button,
.saved-hunt-hero-actions .primary-link,
.saved-hunt-hero-actions .secondary-button {
    width: 100%;
    height: 100%;
    min-width: 0;
}

.saved-hunt-hero-actions button,
.saved-hunt-hero-actions .primary-link,
.saved-hunt-hero-actions .secondary-button {
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 11px 14px;
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.2;
    text-align: center;
}


.timeline-analyzer-page .timeline-canvas::before {
    display: none;
}

.timeline-analyzer-page .timeline-event {
    position: relative;
    display: block;
    width: 100%;
    min-height: 0;
}

.timeline-analyzer-page .timeline-event-card {
    grid-column: auto;
    width: 100%;
    margin: 0;
    padding-left: 54px;
}

.timeline-analyzer-page .timeline-event-card::after {
    display: none;
}

.timeline-analyzer-page .timeline-marker {
    position: absolute;
    top: 9px;
    left: 10px;
    z-index: 2;
}

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

.ttp-action-stack .primary-link,
.ttp-action-stack .inline-action-form,
.ttp-action-stack button {
    width: 100%;
}

.ttp-action-stack .inline-action-form {
    margin-top: 0;
}

.inline-action-form {
    display: grid;
    margin-top: 16px;
}

.footer-actions {
    margin-top: 24px;
}

button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    border-radius: 8px;
    font: inherit;
    max-width: 100%;
    min-width: 0;
    font-size: 14px;
    font-weight: 850;
    line-height: 1.2;
    text-align: center;
    cursor: pointer;
    white-space: normal;
    overflow-wrap: anywhere;
}

button:hover,
.primary-link:hover {
    filter: brightness(1.08);
}

.summary-body {
    display: grid;
    gap: 12px;
    padding: 20px;
}

.summary-row {
    display: grid;
    gap: 4px;
    padding: 14px;
}

.prose {
    margin: 0;
    color: var(--text);
    font-size: 15px;
    white-space: pre-wrap;
}

.code-block,

.query-results-details {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.query-results-details > summary {
    cursor: pointer;
    padding: 14px 16px;
    color: var(--cyan);
    font-size: 13px;
    font-weight: 850;
    list-style-position: inside;
}

.query-results-details[open] > summary {
    border-bottom: 1px solid var(--border);
}

.query-results-details .result-filter-bar,
.query-results-details .results-table-wrap,
.query-results-details .raw-results-details {
    margin: 14px;
}

.results-block {
    margin: 0;
    overflow: auto;
    border: 1px solid rgba(18, 191, 255, 0.22);
    border-radius: 8px;
    background: var(--code-bg);
    color: var(--code-text);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 13px;
    line-height: 1.55;
    tab-size: 4;
}

.code-block {
    padding: 18px;
    min-height: 104px;
    max-width: 100%;
    overflow: auto;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.query-grid {
    display: grid;
    gap: 14px;
}

.query-panel {
    display: grid;
    gap: 10px;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.query-panel h3 {
    margin: 0;
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.query-panel .code-block {
    min-height: 72px;
    width: 100%;
}

.results-block {
    max-height: 440px;
    padding: 16px;
}

.results-table-wrap {
    overflow: auto;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.results-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    font-size: 13px;
}

.results-table th,
.results-table td {
    max-width: 240px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: top;
    white-space: nowrap;
}

.results-table th {
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-align: left;
    text-transform: uppercase;
}

.raw-results-details {
    margin-top: 14px;
}

.raw-results-details summary {
    cursor: pointer;
    color: var(--cyan);
    font-size: 13px;
    font-weight: 800;
}

.candidate-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.candidate-card {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.candidate-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.candidate-label {
    display: block;
    margin-bottom: 5px;
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.candidate-card h3 {
    margin: 0;
    overflow-wrap: anywhere;
    color: var(--silver);
    font-size: 15px;
    line-height: 1.35;
}

.candidate-score {
    display: inline-grid;
    flex: 0 0 auto;
    place-items: center;
    min-width: 46px;
    height: 38px;
    padding: 0 10px;
    border: 1px solid rgba(59, 255, 143, 0.54);
    border-radius: 8px;
    background: rgba(59, 255, 143, 0.12);
    color: #7dffb2;
    font-size: 18px;
    font-weight: 900;
}

.candidate-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.candidate-reasons {
    display: grid;
    gap: 6px;
    margin: 0;
    padding-left: 18px;
    color: var(--silver);
    font-size: 13px;
}


.candidate-model-adjustment {
    display: grid;
    gap: 6px;
    padding: 10px 12px;
    border: 1px solid rgba(125, 211, 252, 0.28);
    border-radius: 8px;
    background: rgba(14, 165, 233, 0.08);
}

.candidate-model-score {
    color: #bae6fd;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.candidate-model-adjustment .candidate-reasons {
    color: var(--muted);
    font-size: 12px;
}

.candidate-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: stretch;
}

.candidate-actions .inline-action-form,
.candidate-actions .secondary-button,
.candidate-actions button {
    min-width: 110px;
}

.candidate-sigma-button {
    border-color: rgba(18, 191, 255, 0.46);
    color: var(--cyan);
}

.sigma-rule-dialog {
    width: min(960px, calc(100vw - 32px));
    max-height: min(760px, calc(100vh - 32px));
    overflow: auto;
    border: 1px solid rgba(18, 191, 255, 0.36);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(13, 27, 45, 0.98), rgba(7, 16, 28, 0.98));
    color: var(--text);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5), 0 0 42px rgba(18, 191, 255, 0.14);
}

.sigma-rule-dialog::backdrop {
    background: rgba(2, 8, 18, 0.72);
    backdrop-filter: blur(4px);
}

.sigma-rule-dialog-shell,
.sigma-rule-dialog-body,
.sigma-rule-detail-card {
    display: grid;
    gap: 16px;
}

.sigma-rule-dialog-shell {
    padding: 22px;
}

.sigma-rule-dialog-header,
.sigma-rule-detail-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.sigma-rule-dialog-header h2,
.sigma-rule-dialog-header p,
.sigma-rule-detail-card-header h3 {
    margin: 0;
}

.sigma-rule-dialog-header p {
    margin-top: 6px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.sigma-rule-detail-card {
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.sigma-rule-detail-card h3 {
    color: var(--silver);
    font-size: 18px;
    line-height: 1.3;
}

.sigma-rule-metadata {
    display: grid;
    grid-template-columns: minmax(110px, 0.25fr) minmax(0, 1fr);
    gap: 8px 12px;
    margin: 0;
    font-size: 13px;
}

.sigma-rule-metadata dt {
    color: var(--muted);
    font-weight: 900;
}

.sigma-rule-metadata dd {
    margin: 0;
    color: var(--silver);
    overflow-wrap: anywhere;
}

.sigma-rule-detail-section h4 {
    margin: 0 0 8px;
    color: var(--cyan);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.sigma-rule-code-block {
    min-height: 0;
    max-height: 300px;
    font-size: 12px;
}

.sigma-triggered-rows-section {
    display: grid;
    gap: 12px;
}

.sigma-triggered-row-card {
    display: grid;
    gap: 10px;
    padding: 12px;
    border: 1px solid rgba(255, 209, 102, 0.28);
    border-radius: 8px;
    background: rgba(255, 209, 102, 0.055);
}

.sigma-triggered-row-card h5 {
    margin: 0;
    color: var(--warning);
    font-size: 13px;
    font-weight: 900;
}

.sigma-inline-trigger-note {
    margin: -2px 0 0;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.sigma-inline-trigger-json {
    max-height: 420px;
}

.sigma-json-line {
    display: block;
    min-height: 1.45em;
    padding: 0 6px;
    border-left: 3px solid transparent;
    white-space: pre-wrap;
}

.sigma-json-line-trigger {
    border-left-color: var(--warning);
    background: rgba(255, 209, 102, 0.16);
    color: #fff1b8;
    font-weight: 850;
}

.candidate-feedback-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 12px;
    font-weight: 900;
}

.candidate-feedback-history {
    display: grid;
    gap: 5px;
    color: var(--muted);
    font-size: 12px;
}

.candidate-feedback-history p {
    margin: 0;
}

.candidate-feedback-form {
    display: grid;
    gap: 8px;
    padding-top: 4px;
    border-top: 1px solid rgba(148, 163, 184, 0.16);
}

.candidate-feedback-form select,
.candidate-feedback-form input {
    width: 100%;
    min-height: 36px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(8, 13, 24, 0.72);
    color: var(--silver);
    font-size: 13px;
}

.candidate-feedback-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.candidate-feedback-actions .secondary-button {
    min-width: 0;
    justify-content: center;
}

@media (max-width: 860px) {
    .candidate-grid {
        grid-template-columns: 1fr;
    }
}

.recommendation-grid,
.analysis-section-grid {
    display: grid;
    gap: 14px;
}

.recommendation-card {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.analysis-section-card {
    display: grid;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.recommendation-card h3 {
    margin: 0;
    color: var(--silver);
    font-size: 15px;
}

.defensive-guidance-list {
    display: grid;
    gap: 10px;
}

.defensive-guidance-header,
.defensive-guidance-row {
    display: grid;
    grid-template-columns: minmax(220px, 0.85fr) minmax(140px, 0.45fr) minmax(0, 1.4fr);
    gap: 14px;
    align-items: start;
}

.defensive-guidance-header {
    padding: 0 14px;
    color: var(--soft);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.defensive-guidance-row {
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.defensive-guidance-ttp,
.defensive-guidance-d3fend,
.defensive-guidance-links {
    min-width: 0;
}

.defensive-guidance-ttp h3 {
    margin: 0;
    color: var(--silver);
    font-size: 14px;
    overflow-wrap: anywhere;
}

.defensive-guidance-d3fend {
    display: flex;
}

.defensive-guidance-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
}

.defensive-guidance-empty {
    align-self: center;
    font-size: 13px;
}

.framework-link {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    max-width: 100%;
    padding: 7px 11px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.framework-link:hover,
.framework-link:focus-visible {
    background: var(--cyan-soft);
    color: var(--cyan);
    outline: none;
}

.d3fend-link {
    border-color: rgba(18, 191, 255, 0.34);
}

.cref-link {
    border-color: rgba(255, 209, 102, 0.34);
}

.analysis-section-heading {
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018));
    color: var(--silver);
    font-size: 14px;
    font-weight: 900;
}

.analysis-section-card .prose {
    margin: 0;
    padding: 16px;
}

.analysis-card-list {
    gap: 8px;
    padding: 16px;
}

.analysis-card-actions {
    padding: 12px 16px 0;
}

.reference-action-row {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 12px;
}

.dfir-playbook-index,
.dfir-playbook-list {
    display: grid;
    gap: 12px;
}

.dfir-playbook-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 16px 0;
}

.dfir-playbook-grid h3 {
    margin: 0 0 10px;
    color: var(--cyan);
    font-size: 12px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dfir-playbook-card {
    scroll-margin-top: 18px;
}

.playbook-living-note {
    margin: 12px 0 0;
    padding: 12px 14px;
    border: 1px solid rgba(18, 191, 255, 0.24);
    border-radius: 8px;
    background: rgba(18, 191, 255, 0.08);
    color: var(--muted);
    font-size: 13px;
    line-height: 1.5;
}

.dfir-action-card {
    align-content: start;
}

.dfir-action-link-list {
    display: grid;
    gap: 10px;
}

.dfir-action-link {
    display: grid;
    gap: 5px;
    padding: 11px 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--text);
    text-decoration: none;
}

.dfir-action-link:hover,
.dfir-action-link:focus-visible {
    border-color: rgba(18, 191, 255, 0.58);
    color: var(--cyan);
}

.dfir-action-link span {
    font-size: 13px;
    font-weight: 850;
}

.dfir-action-link small {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}

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

.recommendation-columns h4 {
    margin: 0 0 8px;
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.compact-list li {
    padding: 9px 12px 9px 30px;
    font-size: 13px;
}

.compact-list li::before {
    left: 13px;
    top: 15px;
    width: 6px;
    height: 6px;
}

.empty-state {
    margin: 0;
    padding: 18px;
    border: 1px solid rgba(255, 209, 102, 0.42);
    border-radius: 8px;
    background: var(--warning-bg);
    color: var(--warning);
    font-size: 14px;
    font-weight: 750;
}

.success-state {
    margin: 0;
    padding: 18px;
    border: 1px solid rgba(18, 191, 255, 0.34);
    border-radius: 8px;
    background: var(--cyan-soft);
    color: var(--cyan);
    font-size: 14px;
    font-weight: 750;
}

.analysis-text {
    margin: 0;
    color: var(--text);
    font-family: inherit;
    font-size: 14px;
    line-height: 1.65;
    white-space: pre-wrap;
}

.entity-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.entity-panel {
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.entity-panel-wide {
    grid-column: 1 / -1;
}

.entity-panel h3 {
    margin: 0;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.entity-list {
    display: grid;
    gap: 0;
    max-height: 220px;
    margin: 0;
    padding: 0;
    overflow-y: auto;
    list-style: none;
}

.entity-list li {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    padding: 11px 14px;
    border-top: 1px solid var(--border);
}

.entity-list li:first-child {
    border-top: 0;
}

.entity-filter-button {
    display: grid;
    justify-content: stretch;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: inherit;
    box-shadow: none;
    text-align: left;
}

.entity-filter-button:hover .entity-value {
    color: var(--cyan);
}

.entity-filter-button.reputation-bad {
    gap: 5px;
    padding: 6px 8px;
    border: 1px solid rgba(255, 88, 116, 0.48);
    border-radius: 8px;
    background: rgba(255, 88, 116, 0.1);
}

.entity-filter-button.reputation-bad .entity-value {
    color: var(--danger);
}

.entity-filter-button.risk-high {
    gap: 5px;
    padding: 6px 8px;
    border: 1px solid rgba(255, 88, 116, 0.52);
    border-radius: 8px;
    background: rgba(255, 88, 116, 0.12);
}

.entity-filter-button.risk-high .entity-value {
    color: var(--danger);
}

.entity-filter-button.reputation-unknown {
    gap: 5px;
    padding: 6px 8px;
    border: 1px solid rgba(250, 204, 21, 0.44);
    border-radius: 8px;
    background: rgba(250, 204, 21, 0.1);
}

.entity-filter-button.reputation-unknown .entity-value {
    color: #facc15;
}

.entity-filter-button.reputation-clean {
    gap: 5px;
    padding: 6px 8px;
    border: 1px solid rgba(34, 197, 94, 0.42);
    border-radius: 8px;
    background: rgba(34, 197, 94, 0.08);
}

.entity-filter-button.reputation-clean .entity-value {
    color: #86efac;
}

.reputation-badge,
.risk-badge {
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    padding: 2px 6px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 850;
    line-height: 1.2;
    text-transform: uppercase;
}

.reputation-badge-malicious,
.reputation-badge-new_domain,
.risk-badge-high_risk {
    border: 1px solid rgba(255, 88, 116, 0.55);
    background: rgba(255, 88, 116, 0.16);
    color: var(--danger);
}

.reputation-badge-unknown {
    border: 1px solid rgba(250, 204, 21, 0.5);
    background: rgba(250, 204, 21, 0.15);
    color: #facc15;
}

.reputation-badge-clean {
    border: 1px solid rgba(34, 197, 94, 0.5);
    background: rgba(34, 197, 94, 0.14);
    color: #86efac;
}

.entity-value {
    overflow-wrap: anywhere;
    color: var(--text);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    line-height: 1.45;
}

.entity-count {
    display: inline-flex;
    justify-content: center;
    min-width: 28px;
    padding: 2px 7px;
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    background: var(--cyan-soft);
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
}

.relationship-kind {
    width: fit-content;
    max-width: 100%;
    padding: 2px 7px;
    border: 1px solid var(--border-strong);
    border-radius: 999px;
    background: rgba(125, 211, 252, 0.1);
    color: var(--cyan);
    font-size: 10px;
    font-weight: 850;
    line-height: 1.2;
    text-transform: uppercase;
}

.process-relationship-suspicious .relationship-kind {
    border-color: rgba(255, 88, 116, 0.55);
    background: rgba(255, 88, 116, 0.14);
    color: var(--danger);
}

.relationship-processes {
    margin-top: 5px;
}

.relationship-detail {
    margin-top: 5px;
    overflow-wrap: anywhere;
    color: var(--muted);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    line-height: 1.45;
}

.relationship-detail-row {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 6px;
}

.relationship-detail-row span {
    max-width: 100%;
    padding: 2px 6px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 750;
    line-height: 1.2;
}


.entity-timeline {
    margin-bottom: 16px;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.entity-timeline[hidden] {
    display: none;
}

.entity-timeline-header {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: start;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border);
}

.entity-timeline-header h3 {
    margin: 0 0 4px;
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.entity-timeline-header p {
    margin: 0;
    color: var(--muted);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
}

.entity-timeline-list {
    display: grid;
    gap: 0;
    max-height: 360px;
    margin: 0;
    padding: 0;
    overflow-y: auto;
    list-style: none;
}

.entity-timeline-list li {
    display: grid;
    grid-template-columns: minmax(150px, 220px) minmax(0, 1fr);
    gap: 16px;
    padding: 14px 16px;
    border-top: 1px solid var(--border);
}

.entity-timeline-list li:first-child {
    border-top: 0;
}

.entity-timeline-list time {
    color: var(--cyan);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.entity-timeline-event {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.entity-timeline-event strong {
    color: var(--text);
    font-size: 13px;
    line-height: 1.35;
}

.entity-timeline-event > span {
    color: var(--muted);
    font-size: 12px;
}

.entity-timeline-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.entity-timeline-tags span {
    display: inline-flex;
    gap: 5px;
    max-width: 100%;
    padding: 4px 7px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--text);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    overflow-wrap: anywhere;
}

.entity-timeline-tags b {
    color: var(--muted);
    font-family: inherit;
}

@media (max-width: 720px) {
    .entity-timeline-header,
    .entity-timeline-list li {
        grid-template-columns: 1fr;
    }

    .entity-timeline-header {
        display: grid;
    }
}

.result-filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
    padding: 10px 12px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--cyan-soft);
    color: var(--cyan);
    font-size: 13px;
    font-weight: 800;
}

.result-filter-bar[hidden] {
    display: none;
}

.result-filter-bar button {
    min-height: 30px;
    padding: 5px 10px;
    font-size: 12px;
}

.entity-empty {
    margin: 0;
    padding: 14px;
    color: var(--muted);
    font-size: 13px;
}

.list-panel {
    overflow: hidden;
}

.list-panel h2 {
    padding: 18px 20px;
}

.clean-list {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.clean-list li {
    position: relative;
    padding: 14px 20px 14px 42px;
    border-top: 1px solid var(--border);
    color: var(--text);
    font-size: 14px;
}

.clean-list li:first-child {
    border-top: 0;
}

.clean-list li::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 20px;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--cyan);
    box-shadow: 0 0 14px rgba(18, 191, 255, 0.55);
}

.sigma-rule-list {
    display: grid;
    gap: 0;
    max-height: 360px;
    margin: 0;
    padding: 0;
    overflow-y: auto;
    list-style: none;
}

.sigma-rule-list li {
    border-top: 1px solid var(--border);
}

.sigma-rule-list li:first-child {
    border-top: 0;
}

.sigma-rule-list a,
.sigma-rule-list li {
    display: grid;
    gap: 5px;
    padding: 13px 16px;
}

.sigma-rule-title {
    overflow-wrap: anywhere;
    color: var(--text);
    font-size: 13px;
    font-weight: 800;
}

.sigma-rule-meta {
    overflow-wrap: anywhere;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
    text-transform: capitalize;
}

.feedback-loop-grid {
    display: grid;
    gap: 16px;
}

.feedback-form {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.feedback-signal-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.feedback-signal-row label {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 34px;
    padding: 7px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
    color: var(--silver);
    cursor: pointer;
}

.feedback-signal-row input {
    width: auto;
    min-height: 0;
}

.feedback-field-grid {
    grid-template-columns: 220px minmax(0, 1fr);
}

.feedback-actions {
    justify-content: flex-start;
}

.feedback-history {
    display: grid;
    gap: 10px;
}

.feedback-item {
    display: grid;
    gap: 4px;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-left-width: 3px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
}

.feedback-positive {
    border-left-color: rgba(59, 255, 143, 0.82);
}

.feedback-negative {
    border-left-color: var(--danger);
}

.feedback-neutral {
    border-left-color: var(--warning);
}

.feedback-item span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.feedback-item p {
    margin: 0;
    color: var(--silver);
    font-size: 13px;
}

.run-feedback-form {
    padding: 12px;
}

.compact-feedback-history {
    gap: 8px;
}

.saved-run-list {
    display: grid;
    gap: 14px;
}

.saved-run {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.saved-run-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--silver);
    font-size: 13px;
}

.reference-scroll {
    max-height: 280px;
    overflow: auto;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.reference-list {
    display: grid;
    gap: 0;
    min-width: max-content;
    margin: 0;
    padding: 0;
    list-style: none;
}

.reference-list li {
    padding: 12px 14px;
    border-top: 1px solid var(--border);
}

.reference-list li:first-child {
    border-top: 0;
}

.reference-list a {
    color: var(--cyan);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    font-weight: 750;
    white-space: nowrap;
}

.kev-results {
    display: grid;
    gap: 10px;
}

.kev-row {
    display: grid;
    grid-template-columns: 150px minmax(0, 1.3fr) minmax(180px, 0.8fr) 110px;
    gap: 14px;
    align-items: center;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.saved-hunt-results {
    gap: 10px;
}

.saved-hunt-row {
    grid-template-columns: 118px minmax(230px, 1.45fr) minmax(150px, 0.7fr) minmax(84px, max-content) minmax(112px, 0.45fr) minmax(118px, max-content);
    gap: 10px;
    cursor: context-menu;
}

.saved-hunt-row:focus-visible {
    border-color: var(--cyan);
    box-shadow: 0 0 0 4px var(--cyan-soft), var(--glow);
    outline: none;
}

.saved-hunt-title-link {
    color: var(--silver);
}

.saved-hunt-pin-form {
    justify-self: end;
    align-self: center;
    margin: 0;
}

.saved-hunt-actions {
    display: grid;
    grid-template-columns: repeat(3, 34px);
    align-items: center;
    justify-content: end;
    gap: 8px;
    min-width: 118px;
}


.saved-hunt-pin-toggle {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    color: var(--muted);
    cursor: pointer;
}

.saved-hunt-pin-toggle .pin-icon {
    margin-right: 0;
    transform: translate(-1px, -1px);
}

.saved-hunt-pin-toggle.is-pinned {
    border-color: rgba(18, 191, 255, 0.52);
    background: var(--cyan-soft);
    color: var(--cyan);
}

.saved-hunt-pin-toggle:hover,
.saved-hunt-pin-toggle:focus-visible {
    border-color: var(--cyan);
    color: var(--cyan);
    outline: none;
}


.saved-hunt-schedule-chip {
    justify-self: start;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 7px 10px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.035);
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.saved-hunt-schedule-chip.is-scheduled {
    border-color: rgba(18, 191, 255, 0.42);
    background: var(--cyan-soft);
    color: var(--cyan);
}

.saved-hunt-handoff-chip {
    max-width: 150px;
}


.saved-hunt-schedule-icon {
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    justify-self: end;
    width: 32px;
    height: 32px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    color: var(--muted);
    cursor: pointer;
}

.saved-hunt-schedule-icon.is-scheduled {
    border-color: rgba(18, 191, 255, 0.52);
    background: var(--cyan-soft);
    color: var(--cyan);
}

.saved-hunt-schedule-icon:hover,
.saved-hunt-schedule-icon:focus-visible {
    border-color: var(--cyan);
    color: var(--cyan);
    outline: none;
}

.clock-icon {
    display: block;
    width: 20px;
    height: 20px;
    color: currentColor;
    font-size: 20px;
    line-height: 20px;
    text-align: center;
}


.saved-hunt-row .kev-date {
    white-space: nowrap;
}

.schedule-dialog {
    width: min(720px, calc(100vw - 32px));
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(13, 27, 45, 0.98), rgba(7, 16, 28, 0.98));
    color: var(--text);
    box-shadow: var(--shadow);
}

.schedule-dialog::backdrop {
    background: rgba(2, 8, 18, 0.72);
    backdrop-filter: blur(4px);
}

.schedule-dialog-form {
    padding: 22px;
}

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

.schedule-dialog-header h2,
.schedule-dialog-header p {
    margin: 0;
}

.schedule-dialog-header p {
    margin-top: 6px;
    color: var(--muted);
    font-size: 13px;
}

.icon-button {
    width: 40px;
    min-height: 40px;
    padding: 0;
}

.schedule-field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.schedule-field-grid .field.full {
    grid-column: 1 / -1;
}

.schedule-dialog-actions {
    gap: 10px;
}

@media (max-width: 980px) {
    .saved-hunt-row {
        grid-template-columns: 1fr;
    }

    .saved-hunt-actions {
        justify-content: start;
    }
}

@media (max-width: 720px) {
    .schedule-field-grid {
        grid-template-columns: 1fr;
    }
}

.kev-host-detail {
    grid-column: 1 / -1;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    overflow-wrap: anywhere;
}


[data-dashboard-card="environment-kevs"] .section-body {
    padding-top: 14px;
}

[data-dashboard-card="environment-kevs"] .kev-results {
    max-height: 360px;
    overflow-y: auto;
    padding-right: 12px;
    scrollbar-gutter: stable;
}

[data-dashboard-card="environment-kevs"] .kev-row {
    grid-template-columns: minmax(118px, 0.8fr) minmax(220px, 2.2fr) minmax(150px, 1fr) minmax(88px, 0.6fr);
    gap: 4px 12px;
    padding: 10px 12px;
    align-items: center;
}

[data-dashboard-card="environment-kevs"] .kev-cve,
[data-dashboard-card="environment-kevs"] .kev-title {
    font-size: 13px;
    line-height: 1.25;
}

[data-dashboard-card="environment-kevs"] .kev-meta,
[data-dashboard-card="environment-kevs"] .kev-date {
    font-size: 12px;
    line-height: 1.25;
}

[data-dashboard-card="environment-kevs"] .kev-date {
    justify-self: end;
    white-space: nowrap;
}

[data-dashboard-card="environment-kevs"] .kev-host-detail {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 11px;
    line-height: 1.25;
}

@media (max-width: 920px) {
    [data-dashboard-card="environment-kevs"] .kev-row {
        grid-template-columns: 1fr;
    }

    [data-dashboard-card="environment-kevs"] .kev-date {
        justify-self: start;
    }
}

.kev-row:hover,
.dashboard-kev-row:focus-visible {
    border-color: var(--border-strong);
    box-shadow: var(--glow);
    outline: none;
}

.dashboard-kev-row {
    cursor: pointer;
}

.kev-cve,
.kev-title {
    color: var(--silver);
    font-weight: 850;
}

.kev-title,
.kev-meta {
    overflow-wrap: anywhere;
}

.kev-meta,
.kev-date {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

@media (max-width: 920px) {
    .dfir-playbook-grid {
        grid-template-columns: 1fr;
    }

    .defensive-guidance-header {
        display: none;
    }

    .defensive-guidance-row {
        grid-template-columns: 1fr;
    }

    .context-grid .confidence-context {
        grid-column: 1 / -1;
        align-items: flex-start;
        flex-direction: column;
    }

    .hero,
    .layout,
    .field-grid,
    .entity-grid,
    .scope-list li,
    .kev-row {
        grid-template-columns: 1fr;
    }

    .context-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 620px) {
    .page {
        width: min(100% - 24px, 1180px);
        padding-top: 18px;
    }

    .topbar,
    .hero-brand-lockup,
    .section-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .top-actions,
    .status-pill,
    .back-link,
    .primary-link,
    .form-actions,
    button {
        width: 100%;
    }


    .saved-hunt-hero-actions {
        grid-template-columns: 1fr;
    }

    .hero-main,
    .guide-panel,
    .summary-panel,
    .hunt-form,
    .section-body {
        padding: 18px;
    }


    .panel-header,
    .section-header {
        padding: 18px;
    }

    h1 {
        font-size: 32px;
    }
}


.attack-path-page .compact-hero {
    margin-bottom: 22px;
}

.attack-path-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.75fr);
    gap: 22px;
    align-items: start;
    margin-bottom: 22px;
}

.attack-path-controls {
    display: grid;
    gap: 16px;
}

.split-actions {
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}

.path-editor-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.42fr);
    gap: 18px;
    align-items: start;
}


.usage-note {
    margin-bottom: 16px;
    padding: 12px 14px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--cyan-soft);
    color: var(--silver);
    font-size: 13px;
}

.usage-note strong {
    color: var(--cyan);
}

.path-node-list {
    display: grid;
    gap: 12px;
}

.path-node-card {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    padding: 14px;
}

.path-node-card[draggable="true"] {
    cursor: grab;
}

.path-node-card.dragging {
    opacity: 0.58;
    border-color: var(--cyan);
    box-shadow: var(--glow);
}

.path-node-card.drag-over {
    border-color: var(--cyan);
    background: rgba(18, 191, 255, 0.1);
}

.drag-handle {
    display: inline-flex;
    align-items: center;
    color: var(--muted);
    font-size: 15px;
    line-height: 1;
    cursor: grab;
}

.path-node-card:active .drag-handle {
    cursor: grabbing;
}

.path-node-card h3 {
    margin: 9px 0 8px;
    color: var(--silver);
    font-size: 15px;
    line-height: 1.3;
}

.path-node-card p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.55;
}

.path-node-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    color: var(--cyan);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    font-weight: 800;
}

.node-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.node-actions .secondary-button {
    min-height: 28px;
    padding: 4px 9px;
}

.edge-panel {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    overflow: hidden;
}

.edge-panel h3 {
    margin: 0;
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.edge-controls {
    display: grid;
    gap: 10px;
    padding: 14px;
}

.edge-list {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.edge-list li {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 11px 14px;
    border-top: 1px solid var(--border);
    color: var(--text);
    font-size: 12px;
}




.admin-panel {
    display: grid;
    gap: 16px;
    margin-bottom: 18px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.admin-panel h3,
.role-card h3 {
    margin: 0;
    color: var(--silver);
    font-size: 15px;
}

.compact-automation-panel {
    gap: 10px;
    margin-top: 16px;
    padding: 12px 14px;
}

.compact-automation-header {
    margin: 0;
}

.compact-automation-row {
    display: grid;
    grid-template-columns: minmax(130px, max-content) minmax(160px, 220px) minmax(190px, 260px) max-content;
    align-items: end;
    gap: 12px;
}

.compact-automation-toggle {
    min-height: 38px;
}

.compact-automation-lookback {
    display: grid;
    grid-template-columns: max-content 84px max-content;
    align-items: center;
    gap: 8px;
}

.compact-automation-lookback label,
.compact-automation-lookback .hint {
    margin: 0;
}

.compact-automation-lookback input {
    min-width: 0;
}

.compact-automation-output select {
    min-width: 0;
    width: 100%;
}

.compact-automation-actions {
    justify-content: flex-start;
    padding-top: 0;
}

.compact-automation-actions button {
    min-height: 36px;
}

.compact-automation-last-run {
    margin: 0;
}

@media (max-width: 760px) {
    .compact-automation-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .compact-automation-lookback {
        grid-template-columns: max-content minmax(0, 1fr) max-content;
    }
}

.admin-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.admin-table {
    width: 100%;
    min-width: 920px;
    border-collapse: collapse;
    font-size: 13px;
}

.admin-table th,
.admin-table td {
    padding: 11px 12px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: top;
}

.admin-table th {
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.admin-table input,
.admin-table select {
    min-height: 36px;
    font-size: 13px;
}

.admin-table .secondary-button,
.admin-table button {
    min-width: 64px;
    margin-top: 0;
    white-space: nowrap;
    overflow-wrap: normal;
}

.admin-table td:has(.secondary-button),
.admin-table td:has(button) {
    white-space: nowrap;
}

.admin-subtext {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.admin-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.compact-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text);
    font-size: 13px;
    font-weight: 750;
}

.compact-check input {
    width: auto;
    min-height: 0;
}

.role-grid {
    display: grid;
    gap: 16px;
}

.role-card {
    display: grid;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.role-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.role-card-header p {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 13px;
}

.permission-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px 14px;
}

@media (max-width: 920px) {
    .permission-grid {
        grid-template-columns: 1fr;
    }
}

.embedded-config-form {
    display: grid;
    gap: 18px;
}

.account-actions {
    display: grid;
    justify-items: start;
    gap: 16px;
}

.config-tabs-panel {
    overflow: hidden;
}

.config-tab-list {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px 14px;
    padding: 16px 22px 0;
    border-top: 1px solid var(--border);
}

.config-tab-group {
    --config-group-accent: var(--cyan);
    --config-group-accent-rgb: var(--cyan-rgb);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    min-width: 0;
    padding-right: 14px;
    border-right: 1px solid var(--border);
}

.config-tab-group:nth-child(1) {
    --config-group-accent: #9fb5c8;
    --config-group-accent-rgb: 159, 181, 200;
}

.config-tab-group:nth-child(2) {
    --config-group-accent: #8fc7ad;
    --config-group-accent-rgb: 143, 199, 173;
}

.config-tab-group:nth-child(3) {
    --config-group-accent: #d7bd82;
    --config-group-accent-rgb: 215, 189, 130;
}

.config-tab-group:nth-child(4) {
    --config-group-accent: #b8a7d9;
    --config-group-accent-rgb: 184, 167, 217;
}

.config-tab-group:last-child {
    padding-right: 0;
    border-right: 0;
}

.config-tab-group-label {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid rgba(var(--config-group-accent-rgb), 0.56);
    border-radius: 999px;
    background: rgba(var(--config-group-accent-rgb), 0.14);
    color: var(--config-group-accent);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.config-tab-group-buttons {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px 12px;
}

.config-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 28px;
    padding: 2px 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--silver);
    box-shadow: none;
    font-size: 13px;
    text-decoration: none;
    text-underline-offset: 4px;
}

.config-tab::before {
    content: "";
    flex: 0 0 auto;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(var(--config-group-accent-rgb), 0.64);
    box-shadow: 0 0 0 3px rgba(var(--config-group-accent-rgb), 0.12);
}

.config-tab:hover,
.config-tab:focus-visible {
    color: var(--config-group-accent);
    outline: none;
    text-decoration: underline;
}

.config-tab.active {
    color: var(--config-group-accent);
    text-decoration: underline;
}

.config-tab.active::before {
    background: var(--config-group-accent);
    box-shadow: 0 0 0 4px rgba(var(--config-group-accent-rgb), 0.18), 0 0 14px rgba(var(--config-group-accent-rgb), 0.4);
}

.config-form {
    padding-top: 16px;
}

.config-tab-panel {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.config-tab-panel[hidden],
.tool-config-panel[hidden],
.vendor-config-panel[hidden] {
    display: none;
}

.config-disclosure {
    overflow: hidden;
}

.config-disclosure summary {
    cursor: pointer;
    list-style: none;
}

.config-disclosure summary::-webkit-details-marker {
    display: none;
}

.config-disclosure summary::before {
    content: "+";
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--cyan);
    font-size: 14px;
    font-weight: 900;
}

.config-disclosure[open] summary::before {
    content: "-";
}

.config-disclosure > summary.section-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 12px;
}

.config-disclosure > summary.section-header h2 {
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
}

.config-disclosure > summary.section-header .pill {
    justify-self: end;
    flex: 0 0 auto;
    max-width: max-content;
}

.open-source-connect {
    display: grid;
    gap: 18px;
}

.connector-picker {
    align-items: end;
}

.connector-category-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.connector-category {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.connector-category.active {
    border-color: var(--border-strong);
    background: var(--cyan-soft);
}

.connector-category h3 {
    margin: 0;
    color: var(--silver);
    font-size: 14px;
}

.connector-category p,
.compact-section-header p {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 13px;
}

.tool-config-list {
    display: grid;
    gap: 16px;
}

.tool-config-panel,
.vendor-config-panel {
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(2, 8, 18, 0.38);
}

.compact-section-header {
    align-items: flex-start;
}

@media (max-width: 920px) {
    .connector-category-list {
        grid-template-columns: 1fr;
    }

    .config-tab-list {
        gap: 12px;
    }

    .config-tab-group {
        width: 100%;
        padding-right: 0;
        padding-bottom: 10px;
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }

    .config-tab-group:last-child {
        padding-bottom: 0;
        border-bottom: 0;
    }
}

@media (max-width: 620px) {
    .config-tab-list {
        padding: 14px 18px 0;
    }

    .config-tab-group {
        align-items: stretch;
        flex-direction: column;
    }

    .config-tab-group-buttons {
        flex-direction: column;
    }

    .config-tab {
        width: auto;
        align-self: flex-start;
    }

    .connector-category {
        flex-direction: column;
    }
}

.config-group {
    overflow: hidden;
    border-top: 1px solid var(--border);
}

.config-group:first-of-type {
    border-top: 0;
}

.config-description {
    margin-bottom: 16px;
}

.config-group input[type="password"] {
    letter-spacing: 0.08em;
}

.prompt-policy-limit-grid {
    margin-top: 20px;
    margin-bottom: 18px;
}

.priority-vertical-grid,
.priority-weight-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}

.priority-weight-field {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 44px;
    align-items: center;
    gap: 8px 12px;
}

.priority-weight-field label {
    grid-column: 1 / -1;
}

.priority-weight-field input[type="range"] {
    width: 100%;
}

.priority-weight-field output {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border: 1px solid var(--border);
    border-radius: 8px;
    color: var(--silver);
    font-weight: 900;
}

.resource-warning {
    margin-top: 16px;
    padding: 12px 14px;
    border: 1px solid var(--warning);
    border-radius: 8px;
    background: var(--warning-bg);
    color: var(--silver);
    font-size: 13px;
}

.resource-warning.danger-warning {
    border-color: var(--danger);
    background: rgba(127, 29, 29, 0.24);
    color: var(--silver);
}

button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    filter: grayscale(0.35);
}

.attack-output {
    display: grid;
    gap: 16px;
}

.attack-output > h3 {
    margin: 0;
    color: var(--silver);
    font-size: 18px;
}

.attack-path-results {
    display: grid;
    gap: 18px;
}

.attack-coverage-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.stage-output {
    display: grid;
    gap: 14px;
}

.stage-panel h3,
.query-panel h3 {
    margin: 0 0 10px;
    color: var(--silver);
    font-size: 14px;
}

.stage-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.stage-detail-grid > div {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.028);
}

.stage-detail-grid h4 {
    margin: 0 0 8px;
    color: var(--cyan);
    font-size: 11px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.stage-detail-grid li,
.attack-output .prose,
.attack-output .clean-list li {
    overflow-wrap: anywhere;
    word-break: break-word;
}

.attack-output .code-block,
.combined-result-panel .code-block {
    max-width: 100%;
    overflow: auto;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.combined-result-panel .results-table {
    min-width: 720px;
}

@media (max-width: 900px) {
    .attack-path-layout,
    .path-editor-grid,
    .stage-detail-grid,
    .attack-coverage-grid,
    .recommendation-columns {
        grid-template-columns: 1fr;
    }
}


.phishing-page .large-textarea {
    min-height: 190px;
}

.section-divider {
    height: 1px;
    margin: 4px 0 2px;
    background: var(--border);
}

.risk-summary {
    display: grid;
    gap: 14px;
}

.risk-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    border-radius: 8px;
    font-size: 22px;
    font-weight: 900;
    letter-spacing: 0.08em;
}

.risk-low {
    border: 1px solid rgba(68, 214, 137, 0.42);
    background: rgba(68, 214, 137, 0.14);
    color: #7dffb2;
}

.risk-medium {
    border: 1px solid rgba(255, 209, 102, 0.48);
    background: rgba(255, 209, 102, 0.14);
    color: var(--warning);
}

.risk-high {
    border: 1px solid rgba(255, 145, 77, 0.55);
    background: rgba(255, 145, 77, 0.15);
    color: #ffb17d;
}

.risk-critical {
    border: 1px solid rgba(255, 88, 116, 0.62);
    background: rgba(255, 88, 116, 0.16);
    color: #ff8da1;
}

.observable-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.compact-list li {
    grid-template-columns: minmax(0, 1fr);
}

.framed-query {
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.query-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.query-title-row h3 {
    margin: 0;
}

details summary {
    cursor: pointer;
    color: var(--cyan);
    font-weight: 850;
}

details .code-block {
    margin-top: 14px;
}

@media (max-width: 920px) {
    .observable-grid {
        grid-template-columns: 1fr;
    }
}

.hero.full-hero {
    grid-template-columns: 1fr;
}

.hero.full-hero .hero-main {
    min-height: 210px;
}

.pagination-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 20px 20px;
}

.pagination-label {
    color: var(--muted);
    font-size: 13px;
    font-weight: 850;
}

.disabled-link {
    opacity: 0.46;
    pointer-events: none;
}

.ransomware-kev {
    border-color: rgba(255, 88, 116, 0.66);
    background: linear-gradient(90deg, rgba(255, 88, 116, 0.18), var(--surface-soft));
}

.ransomware-kev .kev-cve,
.ransomware-kev .kev-title {
    color: #ff8da1;
}

.ransomware-label {
    display: inline-flex;
    margin-top: 5px;
    padding: 3px 7px;
    border: 1px solid rgba(255, 88, 116, 0.6);
    border-radius: 999px;
    background: rgba(255, 88, 116, 0.16);
    color: #ff8da1;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
}

.path-node-card {
    position: relative;
    overflow: hidden;
}

.path-node-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 5px;
    background: var(--tactic-color, var(--cyan));
    box-shadow: 0 0 18px color-mix(in srgb, var(--tactic-color, var(--cyan)) 65%, transparent);
}

.tactic-chip {
    border: 1px solid color-mix(in srgb, var(--tactic-color, var(--cyan)) 70%, transparent);
    border-radius: 999px;
    padding: 2px 8px;
    background: color-mix(in srgb, var(--tactic-color, var(--cyan)) 16%, transparent);
    color: var(--tactic-color, var(--cyan));
}

@media (max-width: 620px) {
    .pagination-bar {
        align-items: stretch;
        flex-direction: column;
    }
}



.auth-body {
    display: grid;
    place-items: center;
    padding: 28px;
}

.auth-shell {
    width: min(520px, 100%);
}

.login-shell {
    width: min(560px, 100%);
}

.auth-panel {
    display: grid;
    gap: 22px;
    padding: 28px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-panel);
    box-shadow: var(--shadow);
}

.auth-brand {
    display: flex;
    align-items: center;
    gap: 14px;
}

.auth-brand img {
    width: 76px;
    height: 52px;
    object-fit: contain;
    filter: var(--brand-glow);
}

.auth-brand-text {
    display: grid;
    gap: 2px;
}


.auth-form {
    padding: 0;
}

.login-panel {
    gap: 24px;
    padding: 0;
    overflow: hidden;
}

.login-logo-top {
    display: block;
    width: 100%;
    padding: 0;
    border-bottom: 1px solid var(--border);
    background: rgba(var(--cyan-rgb), 0.08);
}

.login-logo-top img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: var(--brand-glow);
}

.login-content {
    display: grid;
    gap: 22px;
    min-width: 0;
    padding: 0 clamp(22px, 5vw, 34px);
}

.login-logo-bottom {
    display: grid;
    justify-items: center;
    gap: 2px;
    padding: 18px clamp(22px, 5vw, 34px) 24px;
    border-top: 1px solid var(--border);
}

.login-logo-bottom .brand-title,
.login-logo-bottom .brand-subtitle {
    text-align: center;
}

@media (max-width: 520px) {
    .auth-body {
        padding: 16px;
    }

    .login-panel {
        gap: 20px;
    }

    .login-logo-bottom {
        padding: 16px 20px 20px;
    }
}

.account-menu {
    position: relative;
    margin-bottom: 8px;
}

.account-menu summary {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--silver);
    cursor: pointer;
    font-size: 13px;
    font-weight: 850;
    list-style: none;
}

.account-menu summary::-webkit-details-marker {
    display: none;
}

.account-name {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.account-menu-panel {
    display: grid;
    gap: 8px;
    margin-top: 8px;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--tooltip-bg);
    box-shadow: var(--shadow);
}

.account-menu-user,
.account-menu-role {
    margin: 0;
}

.account-menu-user {
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.account-menu-role {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.account-menu-panel a {
    padding: 7px 0;
    color: var(--cyan);
    font-size: 13px;
    font-weight: 800;
}

.account-menu-panel form,
.account-menu-panel button {
    width: 100%;
}

@media (max-width: 820px) {
    .account-menu {
        min-width: 170px;
        margin-bottom: 0;
    }
}

.app-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 40;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    width: 230px;
    padding: 22px 12px 18px;
    overflow-y: auto;
    overscroll-behavior: contain;
    border-right: 1px solid var(--border);
    background: var(--sidebar-bg);
    backdrop-filter: blur(18px);
    box-shadow: 14px 0 42px rgba(0, 0, 0, 0.28);
}

.sidebar-brand,
.sidebar-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    border-radius: 8px;
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
}

.sidebar-brand {
    justify-content: center;
    min-height: 132px;
    margin: -4px -12px 16px;
    padding: 10px 0 14px;
    border-radius: 0;
}

.sidebar-brand img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: var(--brand-glow);
}

.sidebar-link {
    padding: 8px 10px;
    border: 1px solid transparent;
}

.sidebar-group {
    display: block;
    flex: 0 0 auto;
    width: 100%;
    min-height: 42px;
    overflow: visible;
}

.sidebar-group[open] {
    height: auto;
    padding-bottom: 8px;
}

.sidebar-group > summary {
    cursor: pointer;
    list-style: none;
}

.sidebar-group > summary::-webkit-details-marker {
    display: none;
}

.sidebar-group-summary {
    width: 100%;
}

.sidebar-chevron {
    margin-left: auto;
    color: var(--muted);
    font-size: 18px;
    line-height: 1;
    transform: rotate(90deg);
    transition: transform 0.16s ease, color 0.16s ease;
}

.sidebar-group:not([open]) .sidebar-chevron {
    transform: rotate(0deg);
}

.sidebar-group-summary:hover .sidebar-chevron,
.sidebar-group-summary:focus-visible .sidebar-chevron {
    color: var(--cyan);
}

.sidebar-subnav {
    position: static;
    display: flex;
    flex: 0 0 auto;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    padding-top: 6px;
    overflow: visible;
}

.sidebar-subnav-label {
    margin: 8px 8px 0 18px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.sidebar-subnav-label:first-child {
    margin-top: 2px;
}

.sidebar-sublink {
    box-sizing: border-box;
    flex: 0 0 auto;
    width: calc(100% - 18px);
    min-height: 36px;
    height: auto;
    margin-left: 18px;
    padding: 6px 8px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.25;
    white-space: normal;
}

.sidebar-sublink::before {
    content: "";
    position: absolute;
    left: -9px;
    top: 8px;
    bottom: 8px;
    width: 2px;
    border-radius: 999px;
    background: rgba(var(--cyan-rgb), 0.26);
}

.sidebar-sublink .sidebar-icon {
    width: 22px;
    height: 22px;
    border-radius: 7px;
    font-size: 10px;
}

.sidebar-link:hover,
.sidebar-link:focus-visible {
    border-color: var(--border-strong);
    background: var(--cyan-soft);
    color: var(--cyan);
    outline: none;
}

.sidebar-icon {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--cyan);
    font-size: 11px;
    font-weight: 900;
}

.sidebar-link:hover::after,
.sidebar-link:focus-visible::after {
    content: attr(data-tooltip);
    position: absolute;
    left: calc(100% + 12px);
    top: 50%;
    width: 260px;
    transform: translateY(-50%);
    padding: 9px 11px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--tooltip-bg);
    color: var(--silver);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.35;
    box-shadow: var(--shadow);
    pointer-events: none;
}

.page {
    width: min(1180px, calc(100% - 366px));
    margin-left: 326px;
    margin-right: 40px;
}

.top-actions .back-link {
    display: none;
}

.dashboard-layout-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 22px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.dashboard-layout-copy {
    display: grid;
    gap: 3px;
}

.dashboard-layout-copy strong {
    color: var(--silver);
    font-size: 13px;
}

.dashboard-layout-copy span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.dashboard-layout-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.dashboard-layout-actions select {
    min-height: 36px;
    min-width: 180px;
    padding: 7px 10px;
}

.dashboard-secondary-layout {
    display: grid;
    gap: 22px;
}

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.dashboard-card.span-2 {
    grid-column: 1 / -1;
}

.dashboard-card-controls {
    display: none;
    position: absolute;
    right: 10px;
    top: 10px;
    z-index: 4;
}

.dashboard-remove-card {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: transparent;
    color: var(--danger);
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
}

.dashboard-remove-card:hover,
.dashboard-remove-card:focus-visible {
    background: transparent;
    color: #ff7a90;
    outline: 2px solid rgba(255, 88, 116, 0.5);
    outline-offset: 2px;
}

.dashboard-editing [data-dashboard-card] {
    position: relative;
    border-color: rgba(18, 191, 255, 0.42);
    cursor: grab;
}

.dashboard-editing [data-dashboard-card].is-dragging {
    opacity: 0.55;
}

.dashboard-editing .dashboard-card-controls {
    display: flex;
}


.compact-dashboard-list {
    display: grid;
    gap: 10px;
}

.dashboard-priority-list {
    min-height: 430px;
    max-height: 430px;
    overflow-y: auto;
    align-content: start;
    padding-right: 12px;
}

.dashboard-hunts-list {
    --dashboard-hunt-row-height: 78px;
    min-height: calc((var(--dashboard-hunt-row-height) * 5) + 40px);
    max-height: calc((var(--dashboard-hunt-row-height) * 5) + 40px);
    scrollbar-gutter: stable;
}

.dashboard-hunts-list .dashboard-hunt-row {
    box-sizing: border-box;
    min-height: var(--dashboard-hunt-row-height);
    max-height: var(--dashboard-hunt-row-height);
    align-content: center;
    overflow: hidden;
}

.dashboard-hunts-list .dashboard-hunt-row strong,
.dashboard-hunts-list .dashboard-hunt-row span,
.dashboard-hunts-list .dashboard-hunt-row small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dashboard-hunts-list .dashboard-hunt-row.dashboard-hunt-confidence-high {
    border-color: rgba(255, 88, 116, 0.72);
    background: linear-gradient(90deg, rgba(255, 88, 116, 0.2), rgba(255, 88, 116, 0.08) 34%, var(--surface-soft));
    box-shadow: inset 5px 0 0 rgba(255, 88, 116, 0.95);
}

.dashboard-hunts-list .dashboard-hunt-row.dashboard-hunt-confidence-medium {
    border-color: rgba(255, 209, 102, 0.72);
    background: linear-gradient(90deg, rgba(255, 209, 102, 0.2), rgba(255, 209, 102, 0.08) 34%, var(--surface-soft));
    box-shadow: inset 5px 0 0 rgba(255, 209, 102, 0.95);
}

.dashboard-hunts-list .dashboard-hunt-row.dashboard-hunt-confidence-low {
    border-color: rgba(168, 85, 247, 0.72);
    background: linear-gradient(90deg, rgba(168, 85, 247, 0.2), rgba(168, 85, 247, 0.08) 34%, var(--surface-soft));
    box-shadow: inset 5px 0 0 rgba(168, 85, 247, 0.95);
}

.pin-icon {
    position: relative;
    display: inline-block;
    flex: 0 0 auto;
    width: 13px;
    height: 13px;
    margin-right: 7px;
    vertical-align: -2px;
}

.pin-icon::before {
    content: "";
    position: absolute;
    left: 3px;
    top: 1px;
    width: 7px;
    height: 7px;
    border: 1px solid currentColor;
    border-radius: 2px;
    background: currentColor;
    transform: rotate(45deg);
}

.pin-icon::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 7px;
    width: 1px;
    height: 7px;
    background: currentColor;
    transform: rotate(45deg);
    transform-origin: top center;
}


.compact-dashboard-list a,
.dashboard-list-item {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.compact-dashboard-list a:hover {
    border-color: var(--border-strong);
    box-shadow: var(--glow);
}

.compact-dashboard-list strong,
.dashboard-list-item strong {
    color: var(--silver);
    font-size: 13px;
}

.compact-dashboard-list span,
.dashboard-list-item span {
    color: var(--text);
    font-size: 13px;
}

.compact-dashboard-list small,
.dashboard-list-item small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.dashboard-source-header {
    align-items: center;
}

.dashboard-source-actions {
    align-items: center;
}

.dashboard-run-daily-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 36px;
    color: var(--silver);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.dashboard-run-daily-toggle input {
    width: auto;
}

.dashboard-source-run-status {
    margin: 0 0 10px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.dashboard-source-items-list {
    --dashboard-source-row-height: 74px;
    grid-template-columns: 1fr;
    max-height: calc((var(--dashboard-source-row-height) * 5) + 48px);
    overflow-y: auto;
    align-content: start;
    padding-right: 12px;
    scrollbar-gutter: stable;
}

.dashboard-source-item-row {
    box-sizing: border-box;
    min-height: var(--dashboard-source-row-height);
    max-height: var(--dashboard-source-row-height);
    grid-template-columns: 42px minmax(0, 1fr) auto;
    align-items: center;
    overflow: hidden;
    border-left: 4px solid var(--cyan);
}

.dashboard-source-item-critical {
    border-left-color: var(--danger);
}

.dashboard-source-item-high {
    border-left-color: #facc15;
}

.dashboard-hunt-confidence-high {
    border-left: 4px solid rgba(255, 88, 116, 0.95);
    background: rgba(255, 88, 116, 0.09);
}

.dashboard-hunt-confidence-medium {
    border-left: 4px solid rgba(255, 209, 102, 0.95);
    background: rgba(255, 209, 102, 0.1);
}

.dashboard-hunt-confidence-low {
    border-left: 4px solid rgba(168, 85, 247, 0.95);
    background: rgba(168, 85, 247, 0.1);
}

.dashboard-source-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--surface);
    color: var(--silver);
    font-weight: 900;
}

.dashboard-source-main {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.dashboard-source-main strong,
.dashboard-source-main span,
.dashboard-source-main small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.dashboard-source-date {
    text-align: right;
    white-space: nowrap;
}

@media (max-width: 680px) {
    .dashboard-source-item-row {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .dashboard-source-date {
        grid-column: 2;
        text-align: left;
    }
}

[data-dashboard-card="recent-sigma"] .compact-dashboard-list {
    gap: 7px;
}

[data-dashboard-card="recent-sigma"] .dashboard-sigma-row {
    padding: 9px 11px;
}

[data-dashboard-card="recent-sigma"] .dashboard-sigma-row strong,
[data-dashboard-card="recent-sigma"] .dashboard-sigma-row span,
[data-dashboard-card="recent-sigma"] .dashboard-sigma-row small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

[data-dashboard-card="recent-sigma"] .dashboard-sigma-row strong,
[data-dashboard-card="recent-sigma"] .dashboard-sigma-row span {
    font-size: 12px;
}

[data-dashboard-card="recent-sigma"] .dashboard-sigma-row small {
    font-size: 11px;
}

.danger-list a {
    border-color: rgba(255, 88, 116, 0.44);
    background: rgba(255, 88, 116, 0.1);
}

.dashboard-tooltip {
    position: relative;
    cursor: help;
}

.dashboard-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    right: 0;
    top: calc(100% + 10px);
    z-index: 70;
    display: none;
    width: min(420px, calc(100vw - 48px));
    padding: 11px 13px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--tooltip-bg);
    color: var(--silver);
    box-shadow: var(--shadow);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.45;
    text-align: left;
    text-transform: none;
    white-space: pre-line;
}

.dashboard-tooltip:hover::after,
.dashboard-tooltip:focus-visible::after {
    display: block;
}

.quick-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}



.edr-filter-actions {
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
}

.edr-alert-list {
    display: grid;
    gap: 10px;
    max-height: 420px;
    overflow-y: auto;
    padding-right: 4px;
}

.edr-alert-row {
    display: grid;
    grid-template-columns: minmax(100px, 0.9fr) minmax(150px, 1.4fr) minmax(72px, 0.55fr) minmax(140px, 1fr) 42px;
    gap: 8px 10px;
    align-items: center;
    padding: 11px 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.edr-alert-row:hover,
.edr-alert-row:focus-visible {
    border-color: var(--cyan);
    box-shadow: var(--glow);
    outline: none;
}

.edr-alert-row strong,
.edr-tool {
    color: var(--silver);
    font-size: 13px;
}

.edr-alert-row span,
.edr-alert-row a {
    min-width: 0;
    color: var(--text);
    font-size: 12px;
    overflow-wrap: anywhere;
}

.edr-alert-row a {
    color: var(--cyan);
    font-weight: 850;
}

.edr-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 30px;
    border-radius: 999px;
    background: rgba(255, 209, 102, 0.12);
    color: var(--warning) !important;
    font-weight: 900;
}

.connector-feed-toggle {
    align-self: start;
}


.ttp-toolbar,
.feed-limit-form,
.billing-month-form {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}


.billing-date-range {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.feed-limit-form label,
.billing-month-form label {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.feed-limit-form select,
.billing-month-form input[type="date"] {
    min-height: 34px;
    padding: 6px 10px;
}

.ttp-scroll-list {
    display: grid;
    gap: 8px;
    max-height: 330px;
    overflow-y: auto;
    padding-right: 8px;
    scrollbar-gutter: stable;
}

.ttp-row {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 5px 9px;
    align-items: center;
    width: 100%;
    min-height: 58px;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--text);
    text-align: left;
    cursor: pointer;
}

.ttp-row:hover,
.ttp-row.is-selected {
    border-color: var(--cyan);
    box-shadow: var(--glow);
}

.ttp-rank {
    grid-row: span 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: rgba(18, 191, 255, 0.12);
    color: var(--cyan);
    font-size: 12px;
    font-weight: 850;
}

.ttp-main {
    display: grid;
    gap: 3px;
    min-width: 0;
}

.ttp-main strong {
    color: var(--silver);
    font-size: 12px;
}

.ttp-main span,
.ttp-meta {
    color: var(--text);
    font-size: 11px;
}

.ttp-main strong,
.ttp-main span,
.ttp-meta {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ttp-meta {
    grid-column: 2;
    color: var(--muted);
    font-weight: 750;
}


.ttp-context-menu {
    position: fixed;
    z-index: 1000;
    display: grid;
    gap: 4px;
    min-width: 190px;
    padding: 6px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--tooltip-bg);
    box-shadow: var(--shadow);
}

.ttp-context-menu[hidden] {
    display: none;
}

.ttp-context-menu button[hidden] {
    display: none;
}

.ttp-context-menu button {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 9px 10px;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: var(--silver);
    text-align: left;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
}

.ttp-context-menu button:hover,
.ttp-context-menu button:focus-visible {
    background: rgba(18, 191, 255, 0.12);
    color: var(--cyan);
    outline: none;
}

.ttp-context-menu .danger-menu-item {
    color: var(--danger);
}

.ttp-context-menu .danger-menu-item:hover,
.ttp-context-menu .danger-menu-item:focus-visible {
    background: rgba(255, 88, 116, 0.12);
    color: var(--danger);
}


.power-enrichment-dialog {
    width: min(620px, calc(100vw - 32px));
    max-height: min(520px, calc(100vh - 32px));
    overflow: auto;
    border: 1px solid rgba(59, 255, 143, 0.58);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(13, 27, 45, 0.98), rgba(7, 16, 28, 0.98));
    color: var(--text);
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5), 0 0 42px rgba(59, 255, 143, 0.18);
}

.power-enrichment-dialog::backdrop {
    background: rgba(2, 8, 18, 0.72);
    backdrop-filter: blur(4px);
}

.power-enrichment-dialog-shell {
    display: grid;
    gap: 16px;
    padding: 22px;
}

.power-enrichment-dialog-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.power-enrichment-dialog-header h2,
.power-enrichment-dialog-header p {
    margin: 0;
}

.power-enrichment-dialog-header p {
    margin-top: 6px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.hunt-status-dialog.is-running {
    animation: hunt-dialog-glow 2.4s ease-in-out infinite;
}

.hunt-status-dialog .submit-status {
    display: inline-flex;
    min-height: 0;
    margin-top: 8px;
}

.hunt-status-pulse {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-width: 56px;
    justify-content: flex-end;
    padding-top: 5px;
}

.hunt-status-pulse span {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--green);
    box-shadow: 0 0 16px rgba(59, 255, 143, 0.72);
    opacity: 0.38;
    transform: scale(0.72);
    animation: hunt-status-dot 1.2s ease-in-out infinite;
}

.hunt-status-pulse span:nth-child(2) {
    animation-delay: 0.16s;
}

.hunt-status-pulse span:nth-child(3) {
    animation-delay: 0.32s;
}

.hunt-status-progress {
    height: 4px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.14);
}

.hunt-status-progress span {
    display: block;
    width: 42%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, transparent, var(--green), var(--cyan), transparent);
    box-shadow: 0 0 18px rgba(18, 191, 255, 0.36);
    animation: hunt-status-progress 1.35s ease-in-out infinite;
}

.hunt-status-dialog-actions {
    justify-content: flex-end;
    margin-top: 0;
}

@keyframes hunt-status-dot {
    0%, 80%, 100% {
        opacity: 0.38;
        transform: scale(0.72);
    }

    40% {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes hunt-status-progress {
    0% {
        transform: translateX(-110%);
    }

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

@keyframes hunt-dialog-glow {
    0%, 100% {
        box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5), 0 0 32px rgba(59, 255, 143, 0.14);
    }

    50% {
        box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5), 0 0 52px rgba(59, 255, 143, 0.28);
    }
}

@media (prefers-reduced-motion: reduce) {
    .hunt-status-dialog.is-running,
    .hunt-status-pulse span,
    .hunt-status-progress span {
        animation: none;
    }

    .hunt-status-pulse span {
        opacity: 0.82;
        transform: none;
    }

    .hunt-status-progress span {
        width: 100%;
    }
}

.reputation-dialog {
    width: min(860px, calc(100vw - 32px));
    max-height: min(760px, calc(100vh - 32px));
    overflow: auto;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(13, 27, 45, 0.98), rgba(7, 16, 28, 0.98));
    color: var(--text);
    box-shadow: var(--shadow);
}

.reputation-dialog::backdrop {
    background: rgba(2, 8, 18, 0.72);
    backdrop-filter: blur(4px);
}

.reputation-dialog-shell {
    display: grid;
    gap: 16px;
    padding: 22px;
}

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

.reputation-dialog-header h2,
.reputation-dialog-header p {
    margin: 0;
}

.reputation-dialog-header p {
    margin-top: 6px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.reputation-dialog-body {
    display: grid;
    gap: 14px;
}

.reputation-summary {
    margin: 0;
}

.reputation-source {
    display: grid;
    gap: 8px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.reputation-source h3,
.reputation-source p {
    margin: 0;
}


.dns-record-section {
    overflow-x: auto;
}

.dns-record-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.dns-record-table th,
.dns-record-table td {
    padding: 10px 8px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: top;
}

.dns-record-table th {
    color: var(--silver);
    font-weight: 850;
}

.dns-record-table td {
    color: var(--text);
}

.dns-record-values {
    margin: 0;
}

.dns-record-values li + li {
    margin-top: 5px;
}


.feed-issues-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.feed-issue-item {
    display: grid;
    gap: 4px;
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.feed-issue-item.feed-issue-stale,
.feed-issue-item.feed-issue-failed {
    border-color: rgba(255, 88, 116, 0.44);
    background: rgba(255, 88, 116, 0.1);
}

.feed-issue-item strong {
    color: var(--silver);
    font-size: 13px;
}

.feed-issue-item span,
.feed-issue-item small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

@media (max-width: 1180px) {
    .page {
        width: calc(100% - 270px);
        margin-left: 250px;
        margin-right: 20px;
    }

    .feed-issues-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .app-sidebar {
        position: static;
        width: auto;
        flex-direction: row;
        overflow-x: auto;
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }

    .sidebar-brand {
        min-height: 54px;
        margin: 0;
        padding: 4px 0;
        border-radius: 8px;
    }

    .sidebar-brand img {
        width: 94px;
        height: auto;
    }


    .sidebar-brand span,
    .sidebar-link span:not(.sidebar-icon) {
        display: none;
    }

    .page {
        width: min(100% - 24px, 1180px);
        margin: 0 auto;
    }

    .dashboard-layout-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .dashboard-layout-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .dashboard-layout-actions select,
    .dashboard-layout-actions button {
        width: 100%;
    }

    .dashboard-grid,
    .feed-issues-grid,
    .quick-action-grid {
        grid-template-columns: 1fr;
    }
}

.mfa-setup-grid {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    margin-bottom: 18px;
}

.mfa-qr-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: #ffffff;
}

.mfa-qr-panel img {
    display: block;
    width: 190px;
    max-width: 100%;
    height: auto;
}

@media (max-width: 720px) {
    .mfa-setup-grid {
        grid-template-columns: 1fr;
    }

    .mfa-qr-panel {
        min-height: 180px;
    }
}



.demo-mode-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: rgba(18, 191, 255, 0.08);
}

.demo-mode-toggle h3 {
    margin: 0 0 4px;
    color: var(--silver);
    font-size: 15px;
}

.demo-mode-toggle .config-description {
    margin: 0;
}

@media (max-width: 680px) {
    .demo-mode-toggle {
        align-items: flex-start;
        flex-direction: column;
    }
}

.capability-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.capability-table-wrap {
    max-height: 620px;
}

.capability-table th,
.capability-table td {
    white-space: nowrap;
}

.capability-table td:first-child,
.capability-table td:nth-child(3) {
    white-space: normal;
    min-width: 150px;
}

.capability-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 4px 8px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.045);
    color: var(--muted);
    font-size: 11px;
    font-weight: 850;
    line-height: 1.2;
}

.capability-live {
    border-color: rgba(125, 255, 178, 0.45);
    background: rgba(125, 255, 178, 0.12);
    color: var(--success);
}

.capability-demo {
    border-color: rgba(255, 209, 102, 0.45);
    background: rgba(255, 209, 102, 0.12);
    color: var(--warning);
}

.capability-configured {
    border-color: rgba(18, 191, 255, 0.45);
    background: rgba(18, 191, 255, 0.12);
    color: var(--cyan);
}

.capability-planned {
    border-color: var(--border);
    background: var(--surface-soft);
    color: var(--silver);
}

.capability-ok {
    border-color: rgba(125, 255, 178, 0.45);
    background: rgba(125, 255, 178, 0.12);
    color: var(--success);
}

.capability-error {
    border-color: rgba(255, 111, 97, 0.5);
    background: rgba(255, 111, 97, 0.12);
    color: var(--danger);
}

.capability-never {
    border-color: var(--border);
    background: var(--surface-soft);
    color: var(--muted);
}

.capability-none {
    opacity: 0.48;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.help-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.75fr);
    gap: 22px;
    align-items: start;
}

.help-workspace {
    display: grid;
    gap: 22px;
    min-width: 0;
}

.help-chat-panel {
    overflow: hidden;
}

.help-chat-body {
    display: grid;
    align-content: start;
    gap: 14px;
    min-height: 420px;
    max-height: 560px;
    padding: 20px;
    overflow-y: auto;
}

.help-message {
    max-width: min(760px, 92%);
    padding: 13px 15px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.help-message p {
    margin: 0;
    color: var(--text);
    font-size: 14px;
    line-height: 1.6;
}

.help-message-user {
    justify-self: end;
    border-color: var(--border-strong);
    background: var(--cyan-soft);
}

.help-message-assistant {
    justify-self: start;
}

.help-chat-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: end;
    padding: 18px 20px 20px;
    border-top: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.025);
}

.help-chat-form textarea {
    min-height: 78px;
}

.field-normalization-builder {
    overflow: hidden;
}

.field-normalization-form {
    display: grid;
    gap: 16px;
    padding: 20px;
}

.field-normalization-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.field-normalization-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.field-normalization-actions select {
    width: auto;
    min-width: 160px;
}

.field-normalization-status {
    min-height: 22px;
    padding: 0 20px 14px;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.5;
}

.field-normalization-status[data-tone="success"] {
    color: var(--success);
}

.field-normalization-status[data-tone="warning"] {
    color: var(--warning);
}

.field-normalization-preview-wrap {
    margin: 0 20px 20px;
}

.field-normalization-preview {
    min-width: 960px;
}

.field-normalization-preview input,
.field-normalization-preview select {
    min-width: 150px;
}

.help-source-panel {
    position: sticky;
    top: 20px;
}

.help-citations {
    display: grid;
    gap: 12px;
    margin-top: 16px;
}

.help-citation {
    display: grid;
    gap: 8px;
    padding: 13px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.help-citation h3 {
    margin: 0;
    color: var(--cyan);
    font-size: 13px;
    line-height: 1.35;
}

.help-citation p {
    display: -webkit-box;
    -webkit-line-clamp: 7;
    -webkit-box-orient: vertical;
    margin: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.55;
    white-space: pre-wrap;
}

@media (max-width: 920px) {
    .help-layout,
    .help-chat-form,
    .field-normalization-grid {
        grid-template-columns: 1fr;
    }

    .help-source-panel {
        position: static;
    }

    .field-normalization-actions select,
    .field-normalization-actions button {
        width: 100%;
    }
}

.guide-list a,
.help-citation a {
    color: var(--cyan);
    font-weight: 850;
}

.guide-list a:hover,
.help-citation a:hover {
    color: var(--silver);
}

.help-doc-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.75fr);
    gap: 22px;
    align-items: start;
}

.help-doc-content {
    overflow: hidden;
}

.markdown-help-body {
    display: grid;
    gap: 14px;
}

.markdown-help-body h1,
.markdown-help-body h2,
.markdown-help-body h3,
.markdown-help-body h4 {
    scroll-margin-top: 24px;
}

.markdown-help-body h1 {
    font-size: 32px;
}

.markdown-help-body h2 {
    margin-top: 12px;
    padding-top: 18px;
    border-top: 1px solid var(--border);
    font-size: 22px;
}

.markdown-help-body h3 {
    margin: 8px 0 0;
    color: var(--silver);
    font-size: 17px;
}

.markdown-help-body h4 {
    margin: 6px 0 0;
    color: var(--cyan);
    font-size: 14px;
}

.markdown-help-body p,
.markdown-help-body li {
    color: var(--text);
    font-size: 14px;
    line-height: 1.7;
}

.markdown-help-body ul,
.markdown-help-body ol {
    display: grid;
    gap: 8px;
    margin: 0;
    padding-left: 22px;
}

.markdown-help-body pre {
    overflow: auto;
    margin: 0;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--code-bg);
    color: var(--code-text);
}

.markdown-help-body code {
    padding: 1px 5px;
    border-radius: 5px;
    background: var(--code-bg);
    color: var(--code-text);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 0.92em;
}

.markdown-help-body pre code {
    padding: 0;
    background: transparent;
}

.active-guide {
    border-color: var(--border-strong) !important;
    background: var(--cyan-soft) !important;
}

@media (max-width: 920px) {
    .help-doc-layout {
        grid-template-columns: 1fr;
    }
}

.help-doc-toc {
    padding: 14px 18px 14px 34px !important;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.help-doc-toc a {
    color: var(--cyan);
    font-weight: 850;
}

.help-doc-toc a:hover,
.help-doc-toc a:focus-visible {
    color: var(--silver);
}

.prompt-source-table-wrap {
    max-height: 680px;
    overflow: auto;
}

.prompt-source-table {
    min-width: 1120px;
}

.prompt-source-table td {
    max-width: 280px;
    overflow-wrap: anywhere;
}


.playbook-intro-grid,
.playbook-detail-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.playbook-intro-grid div,
.playbook-detail-grid div {
    display: grid;
    gap: 6px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.playbook-intro-grid strong,
.playbook-detail-grid h3 {
    margin: 0;
    color: var(--silver);
    font-size: 13px;
}

.playbook-intro-grid span,
.playbook-detail-grid p,
.playbook-summary {
    margin: 0;
    color: var(--text);
    font-size: 13px;
    line-height: 1.55;
}

.playbook-single-view {
    display: grid;
    gap: 22px;
}

.playbook-selector-body {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.clone-playbook-form {
    display: inline-flex;
}

.playbook-selector-body label {
    color: var(--muted);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
}

.playbook-selector-body select {
    min-height: 42px;
    padding: 9px 12px;
}

.custom-playbook-template[hidden] {
    display: none;
}

.playbook-template-body {
    display: grid;
    gap: 16px;
}

.playbook-template-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.playbook-template-grid .field.full {
    grid-column: 1 / -1;
}

.playbook-template-grid textarea {
    min-height: 118px;
}

.playbook-template-grid .playbook-large-textarea {
    min-height: 180px;
}

.custom-playbook-list {
    display: grid;
    gap: 16px;
}

.custom-playbook-card {
    display: grid;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.custom-playbook-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.custom-playbook-card h3,
.custom-playbook-card p {
    margin: 0;
}

.custom-playbook-card h3 {
    color: var(--silver);
    font-size: 15px;
}

.custom-playbook-card p {
    color: var(--text);
    font-size: 13px;
    line-height: 1.55;
}

.delete-playbook-form {
    display: flex;
    justify-content: flex-end;
}

.playbook-form-actions {
    gap: 12px;
}

.playbook-card .section-header h2 {
    display: flex;
    align-items: center;
    gap: 10px;
}

.playbook-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(18, 191, 255, 0.12);
    color: var(--cyan);
    font-size: 13px;
    font-weight: 900;
}

.playbook-body {
    display: grid;
    gap: 16px;
}

.playbook-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.playbook-pivot-action {
    margin-left: auto;
}

.playbook-ttp-panel {
    display: grid;
    gap: 10px;
}

.playbook-ttp-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.playbook-ttp-header h3 {
    margin: 0;
    color: var(--silver);
    font-size: 14px;
}

.playbook-detail-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.playbook-details {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.playbook-details summary {
    padding: 12px 14px;
    color: var(--silver);
    font-size: 13px;
    font-weight: 850;
    cursor: pointer;
}

.playbook-details ol,
.playbook-details ul {
    margin: 0;
    padding: 0 18px 14px 34px;
    color: var(--text);
    font-size: 13px;
    line-height: 1.55;
}

.playbook-details li + li {
    margin-top: 8px;
}

@media (max-width: 820px) {
    .playbook-intro-grid,
    .playbook-detail-grid,
    .playbook-template-grid,
    .playbook-selector-body {
        grid-template-columns: 1fr;
    }

    .custom-playbook-card-header,
    .playbook-ttp-header,
    .delete-playbook-form {
        align-items: stretch;
        flex-direction: column;
    }
}


.billing-chart-section {
    display: grid;
    gap: 18px;
    background: var(--surface);
}

.billing-summary-row {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
}

.billing-summary-row div {
    min-width: 0;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.billing-summary-row span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    text-transform: uppercase;
}

.billing-summary-row strong {
    display: block;
    margin-top: 6px;
    color: var(--text);
    font-size: 20px;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.billing-chart-wrap {
    min-height: 320px;
    border-radius: 8px;
    background: var(--surface-soft);
}

.billing-line-chart {
    width: 100%;
    height: 320px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.billing-gridline {
    stroke: rgba(148, 163, 184, 0.22);
    stroke-width: 1;
}

.billing-axis-label {
    fill: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.billing-legend {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}

.billing-legend-item {
    display: grid;
    grid-template-columns: 12px minmax(0, 1fr);
    gap: 8px 10px;
    align-items: center;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.billing-legend-item span {
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: var(--legend-color);
}

.billing-legend-item strong,
.billing-legend-item small {
    min-width: 0;
    overflow-wrap: anywhere;
}

.billing-legend-item small {
    grid-column: 2;
    color: var(--muted);
    font-size: 12px;
}

@media (max-width: 760px) {
    .billing-summary-row {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 520px) {
    .billing-summary-row {
        grid-template-columns: 1fr;
    }
}


.entities-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 18px;
    row-gap: 12px;
}

.entities-header .section-actions,
.entities-header > .pill {
    justify-self: end;
}

.entities-header .section-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-left: 8px;
}

.entity-analyzer-launch {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
    gap: 12px;
    justify-self: stretch;
    width: 100%;
}

.entity-analyzer-launch .inline-action-form {
    display: flex;
    margin: 0;
}

.entity-analyzer-launch .secondary-button,
.entity-analyzer-launch button {
    width: 100%;
    justify-content: center;
}

.entity-analyzer-page {
    width: calc(100% - 366px);
    max-width: none;
}

.entity-analyzer-hero {
    grid-template-columns: minmax(0, 1fr) 280px;
}

.entity-analyzer-shell .section-body {
    padding: 0;
}

.entity-analyzer-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
}

.entity-analyzer-header .section-actions {
    justify-self: end;
}

.entity-analyzer-return {
    justify-self: center;
}

.entity-analyzer-body {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
}

.entity-graph-filters {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(7, minmax(120px, 1fr)) auto;
    gap: 12px;
    align-items: end;
    padding: 16px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--surface-muted);
}

.entity-graph-filters label {
    display: grid;
    gap: 6px;
    min-width: 0;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.entity-graph-filters select,
.entity-graph-filters input[type=text],
.entity-graph-filters input[type=number] {
    width: 100%;
    min-height: 38px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    color: var(--text);
    font: inherit;
    font-size: 13px;
    text-transform: none;
}

.entity-checkbox-filter {
    align-content: center;
    grid-template-columns: auto minmax(0, 1fr);
    text-transform: none;
}

.entity-graph-stage {
    position: relative;
    min-height: 620px;
    overflow: auto;
    overscroll-behavior: contain;
    border-bottom: 1px solid var(--border);
    background: #f8fafc;
}

.entity-graph {
    display: block;
    min-width: 1500px;
    width: max-content;
    min-height: 620px;
}

.entity-edge {
    fill: none;
    stroke: #64748b;
    stroke-width: 2.5;
    opacity: 0.78;
    cursor: pointer;
}

.entity-edge:hover {
    opacity: 1;
    stroke-width: 4;
}

.entity-edge.malicious {
    stroke: #dc2626;
    stroke-width: 3.5;
}

.entity-edge-label {
    fill: #000000;
    font-size: 12px;
    font-weight: 800;
    paint-order: stroke;
    stroke: #ffffff;
    stroke-width: 5px;
    stroke-linejoin: round;
    text-anchor: middle;
}

.entity-node {
    cursor: pointer;
}


.entity-node-group {
    cursor: pointer;
}

.entity-node-group .entity-node {
    fill: #ffffff;
    stroke: var(--border-strong);
    stroke-width: 2;
    filter: drop-shadow(0 8px 16px rgba(15, 23, 42, 0.12));
}

.entity-node-group .entity-node-host {
    stroke: var(--cyan);
}

.entity-node-group .entity-node-dns {
    stroke: var(--accent);
}

.entity-node-group.reputation-bad .entity-node {
    fill: rgba(255, 88, 116, 0.18);
    stroke: var(--danger);
}

.entity-node-group.reputation-bad .entity-node-label {
    fill: var(--danger);
}

.entity-node-group.reputation-unknown .entity-node {
    fill: rgba(250, 204, 21, 0.18);
    stroke: #facc15;
}

.entity-node-group.reputation-unknown .entity-node-label {
    fill: #b45309;
}

.entity-node-group.reputation-clean .entity-node {
    fill: rgba(34, 197, 94, 0.14);
    stroke: #22c55e;
}

.entity-node-group.reputation-clean .entity-node-label {
    fill: #166534;
}

.entity-node-label {
    fill: #000000;
    font-size: 13px;
    font-weight: 850;
    paint-order: stroke;
    stroke: #ffffff;
    stroke-width: 5px;
    stroke-linejoin: round;
    pointer-events: none;
}

.entity-node rect {
    fill: #ffffff;
    stroke: var(--border-strong);
    stroke-width: 1.5;
    filter: drop-shadow(0 8px 16px rgba(15, 23, 42, 0.12));
}

.entity-node.source rect,
.entity-node.focused rect {
    stroke: var(--cyan);
}

.entity-node.destination rect {
    stroke: var(--accent);
}

.entity-node.focused rect {
    stroke: var(--cyan);
    stroke-width: 2.5;
}

.entity-node rect.entity-node-hitbox {
    fill: transparent;
    stroke: transparent;
    stroke-width: 0;
    pointer-events: all;
    filter: none;
}

.entity-node text {
    fill: #000000;
    font-size: 13px;
    font-weight: 850;
    pointer-events: none;
}

.entity-node-meta {
    fill: #000000;
    font-size: 10px;
    text-transform: uppercase;
}

.entity-graph-tooltip {
    position: fixed;
    left: 50vw;
    top: 50vh;
    z-index: 80;
    width: min(560px, calc(100vw - 24px));
    transform: translate(-50%, -50%);
    max-height: min(520px, calc(100vh - 24px));
    overflow: auto;
    overflow-wrap: anywhere;
    word-break: break-word;
    padding: 12px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: var(--shadow);
    color: var(--text);
    font-size: 12px;
}

.entity-tooltip-header {
    position: sticky;
    top: -12px;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: -12px -12px 10px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    background: var(--surface);
}

.entity-tooltip-close {
    display: inline-grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 1px solid var(--border-strong);
    border-radius: 6px;
    background: #ffffff;
    color: #000000;
    font: inherit;
    font-weight: 900;
    cursor: pointer;
}

.entity-tooltip-content {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.entity-graph-tooltip p,
.entity-detail-content p {
    max-width: 100%;
    margin: 0 0 8px;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.entity-graph-tooltip ul,
.entity-detail-content ul {
    display: grid;
    max-width: 100%;
    gap: 6px;
    margin: 8px 0 0;
    padding-left: 18px;
}

.entity-graph-tooltip li,
.entity-detail-content li {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.entity-risk {
    color: #dc2626;
    font-weight: 900;
}

.entity-detail-panel {
    min-width: 0;
    padding: 18px;
    background: var(--surface);
}

.entity-detail-panel h3 {
    margin: 0 0 12px;
    color: var(--silver);
    font-size: 14px;
}

.entity-detail-content {
    max-height: 320px;
    overflow: auto;
    color: var(--text);
    font-size: 13px;
}

@media (max-width: 1100px) {
    .entity-analyzer-body,
    .entity-analyzer-hero {
        grid-template-columns: 1fr;
    }


    .entity-graph-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1180px) {
    .entity-analyzer-page {
        width: calc(100% - 270px);
    }
}

@media (max-width: 820px) {
    .entity-analyzer-page {
        width: min(100% - 24px, 1180px);
    }
}

@media (max-width: 700px) {
    .entities-header {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .entities-header .section-actions,
    .entities-header > .pill,
    .entity-analyzer-launch {
        justify-self: stretch;
    }

    .entity-graph-filters {
        grid-template-columns: 1fr;
    }
}

.modal-dialog {
    border: 0;
    border-radius: 8px;
    max-width: 560px;
    width: min(560px, calc(100vw - 32px));
    padding: 0;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28);
}

.modal-dialog::backdrop {
    background: rgba(15, 23, 42, 0.46);
}

.modal-panel {
    padding: 24px;
    background: var(--panel-bg, #fff);
}

.modal-panel h2 {
    margin-top: 0;
}

.saved-hunt-search-panel {
    display: grid;
    gap: 16px;
}

.saved-hunt-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.saved-hunt-filter {
    width: auto;
    min-height: 36px;
    padding: 8px 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.saved-hunt-filter span {
    margin-left: 6px;
    color: var(--text);
}

.saved-hunt-filter.active,
.saved-hunt-filter:hover {
    border-color: var(--cyan);
    color: var(--text);
    box-shadow: 0 0 0 3px var(--cyan-soft);
}

.saved-hunt-search-field {
    max-width: 720px;
}

.saved-hunt-search-field input[type="search"] {
    width: 100%;
}

.saved-hunt-row[hidden] {
    display: none;
}

.operations-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 22px 0;
}

.operations-kpi-grid div {
    display: grid;
    gap: 6px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.operations-kpi-grid span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 850;
    text-transform: uppercase;
}

.operations-kpi-grid strong {
    color: var(--silver);
    font-size: 28px;
    line-height: 1;
}

.operations-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.operations-card {
    min-width: 0;
}

.operations-list {
    display: grid;
    gap: 10px;
}

.operations-row {
    display: grid;
    gap: 5px;
    padding: 13px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.operations-row:hover,
.operations-row:focus-visible {
    border-color: var(--border-strong);
    box-shadow: var(--glow);
    outline: none;
}

.operations-row strong {
    color: var(--silver);
    font-size: 13px;
}

.operations-row span {
    color: var(--text);
    font-size: 13px;
    overflow-wrap: anywhere;
}

.operations-row small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    overflow-wrap: anywhere;
}

.operations-row.is-warning {
    border-color: rgba(255, 191, 87, 0.42);
    background: rgba(255, 191, 87, 0.08);
}

.operations-row.is-danger {
    border-color: rgba(255, 92, 122, 0.48);
    background: rgba(255, 92, 122, 0.09);
}

@media (max-width: 980px) {
    .operations-kpi-grid,
    .operations-grid {
        grid-template-columns: 1fr;
    }
}

.lateral-analysis-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.lateral-card {
    display: grid;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.lateral-card.possible-lateral {
    border-color: rgba(255, 209, 102, 0.46);
    background: linear-gradient(180deg, rgba(255, 209, 102, 0.08), var(--surface-soft));
}

.lateral-card-header,
.lateral-card-meta,
.lateral-columns {
    display: flex;
    gap: 12px;
}

.lateral-card-header {
    align-items: center;
    justify-content: space-between;
}

.lateral-card-header h3 {
    margin: 0;
    color: var(--silver);
    font-size: 15px;
}

.lateral-card-meta {
    flex-wrap: wrap;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.lateral-card-meta strong {
    color: var(--warning);
}

.lateral-columns {
    align-items: start;
}

.lateral-columns > div {
    flex: 1 1 0;
    min-width: 0;
}

.lateral-columns h4 {
    margin: 0 0 8px;
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

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

.lateral-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.lateral-table th,
.lateral-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    text-align: left;
    vertical-align: top;
}

.lateral-table th {
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.possible-lateral-row td {
    background: rgba(255, 209, 102, 0.08);
}

@media (max-width: 980px) {
    .lateral-analysis-grid,
    .lateral-columns {
        grid-template-columns: 1fr;
        display: grid;
    }
}


.timeline-analyzer-page .entity-analyzer-hero {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 440px);
}

.timeline-workbench .section-header .muted {
    margin: 4px 0 0;
    color: var(--muted);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 12px;
}

.timeline-layout {
    display: grid;
    grid-template-columns: 300px minmax(0, 1fr);
    min-height: 680px;
}

.timeline-filter-panel {
    display: grid;
    align-content: start;
    gap: 16px;
    padding: 16px;
    border-right: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.02);
}

.timeline-filter-panel label,
.timeline-filter-group {
    display: grid;
    gap: 7px;
}

.timeline-filter-panel span,
.timeline-filter-group > span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: uppercase;
}

.timeline-filter-panel input,
.timeline-filter-panel select {
    width: 100%;
    min-width: 0;
    padding: 9px 10px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--surface);
    color: var(--text);
    font: inherit;
    font-size: 13px;
}

.timeline-chip-list,
.timeline-datapoint-list {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.timeline-chip-list.scrollable,
.timeline-datapoint-list {
    max-height: 190px;
    overflow-y: auto;
}

.timeline-filter-chip,
.timeline-datapoint-filter {
    min-width: 0;
    max-width: 100%;
    padding: 6px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--text);
    font-size: 12px;
    line-height: 1.25;
    text-align: left;
    overflow-wrap: anywhere;
}

.timeline-datapoint-filter {
    width: 100%;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

.timeline-filter-chip.active,
.timeline-datapoint-filter.active {
    border-color: rgba(18, 191, 255, 0.65);
    background: var(--cyan-soft);
    color: var(--cyan);
}

.timeline-canvas-wrap {
    position: relative;
    min-width: 0;
    padding: 14px;
    overflow: auto;
}

.timeline-empty {
    margin: 96px auto 0;
    max-width: 520px;
    padding: 18px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
    color: var(--muted);
    text-align: center;
}

.timeline-canvas {
    display: grid;
    gap: 6px;
    min-width: 860px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.timeline-canvas::before {
    display: none;
}

.timeline-event {
    position: relative;
    display: block;
    min-height: 0;
}

.timeline-marker {
    position: absolute;
    top: 9px;
    left: 10px;
    z-index: 2;
    width: 32px;
    height: 28px;
    padding: 0;
    border: 1px solid rgba(18, 191, 255, 0.5);
    border-radius: 8px;
    background: rgba(18, 191, 255, 0.12);
    color: var(--cyan);
    font-size: 12px;
    font-weight: 900;
    box-shadow: none;
}

.timeline-event-card {
    display: grid;
    grid-template-columns: minmax(145px, 0.2fr) minmax(0, 0.42fr) minmax(0, 1fr) max-content;
    gap: 8px 12px;
    align-items: start;
    width: 100%;
    min-width: 0;
    padding: 9px 10px 9px 54px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.timeline-event.left .timeline-event-card,
.timeline-event.right .timeline-event-card {
    grid-column: auto;
    margin: 0;
}

.timeline-event-card::after,
.timeline-event.left .timeline-event-card::after,
.timeline-event.right .timeline-event-card::after {
    display: none;
}

.timeline-event-card time {
    min-width: 0;
    color: var(--cyan);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.timeline-event-card h3 {
    min-width: 0;
    margin: 0;
    color: var(--silver);
    font-size: 13px;
    line-height: 1.3;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.timeline-event-card p {
    min-width: 0;
    margin: 0;
    color: var(--text);
    font-size: 12px;
    line-height: 1.4;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.timeline-event-meta {
    justify-self: end;
    min-width: max-content;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.35;
    text-align: right;
}

.timeline-event-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.timeline-event-tags button {
    max-width: 100%;
    padding: 3px 6px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--text);
    font-size: 10px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.timeline-event-details {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 8px;
}

.timeline-detail-row {
    display: grid;
    grid-template-columns: minmax(90px, 0.32fr) minmax(0, 1fr);
    gap: 8px;
    padding: 5px 8px;
    border-top: 1px solid var(--border);
}

.timeline-detail-row:first-child,
.timeline-detail-row:nth-child(2) {
    border-top: 0;
}

.timeline-detail-row:nth-child(odd) {
    border-right: 1px solid var(--border);
}

.timeline-detail-row span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 850;
    overflow-wrap: anywhere;
}

.timeline-detail-row code {
    color: var(--text);
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 10px;
    line-height: 1.35;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.timeline-more-button {
    grid-column: 1 / -1;
    justify-content: center;
    padding: 7px 10px;
    border: 0;
    border-top: 1px solid var(--border);
    border-radius: 0;
    background: rgba(18, 191, 255, 0.08);
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
}

.timeline-event-tags button:hover,
.timeline-marker:hover,
.timeline-filter-chip:hover,
.timeline-datapoint-filter:hover {
    border-color: rgba(18, 191, 255, 0.65);
    color: var(--cyan);
}

@media (max-width: 980px) {
    .timeline-analyzer-page .entity-analyzer-hero,
    .timeline-layout {
        grid-template-columns: 1fr;
    }

    .timeline-filter-panel {
        border-right: 0;
        border-bottom: 1px solid var(--border);
    }
}

@media (max-width: 760px) {
    .timeline-canvas {
        min-width: 0;
    }

    .timeline-marker {
        top: 8px;
        left: 8px;
        width: 30px;
        height: 26px;
    }

    .timeline-event-card {
        grid-template-columns: 1fr;
        padding-left: 48px;
    }

    .timeline-event-details {
        grid-template-columns: 1fr;
    }

    .timeline-detail-row:nth-child(2) {
        border-top: 1px solid var(--border);
    }

    .timeline-detail-row:nth-child(odd) {
        border-right: 0;
    }
}


.collapsible-section {
    overflow: hidden;
}

.collapsible-summary {
    cursor: pointer;
    list-style: none;
}

.collapsible-summary::-webkit-details-marker {
    display: none;
}

.collapsible-summary::after {
    content: "Open";
    min-height: 28px;
    padding: 4px 10px;
    border: 1px solid var(--border);
    border-radius: 999px;
    color: var(--cyan);
    font-size: 11px;
    font-weight: 850;
}

.collapsible-section[open] .collapsible-summary::after {
    content: "Close";
}

.threat-library-tabs .section-body {
    display: grid;
    gap: 16px;
}

.library-tab-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    border-bottom: 1px solid var(--border);
}

.library-tab {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    padding: 0 14px;
    border: 1px solid transparent;
    border-bottom: 0;
    border-radius: 8px 8px 0 0;
    background: transparent;
    color: var(--muted);
    font-size: 13px;
    font-weight: 850;
    cursor: pointer;
}

.library-tab span {
    display: inline-grid;
    place-items: center;
    min-width: 24px;
    height: 22px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--silver);
    font-size: 12px;
}

.library-tab[aria-selected="true"] {
    border-color: var(--border);
    background: var(--surface-soft);
    color: var(--cyan);
}

.library-tab-panel {
    min-width: 0;
}

.library-filter-bar {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) 140px 180px auto auto;
    gap: 12px;
    align-items: end;
    margin-bottom: 16px;
}

.library-filter-bar .field {
    margin: 0;
}

.library-queue-summary {
    margin: -8px 0 2px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.library-result-summary {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

@media (max-width: 760px) {
    .library-filter-bar {
        grid-template-columns: 1fr;
    }
}

.library-list {
    display: grid;
    gap: 12px;
}

.library-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) max-content;
    gap: 14px;
    align-items: start;
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.library-card > div:first-child {
    min-width: 0;
}

.library-card .candidate-actions {
    grid-column: 2;
    grid-row: 1;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: nowrap;
}

.library-card .candidate-actions .primary-link,
.library-card .candidate-actions .secondary-button,
.library-card .candidate-actions button {
    min-height: 36px;
    padding-top: 0;
    padding-bottom: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.2;
    text-align: center;
}

.library-card h3 {
    margin: 0 0 6px;
    overflow-wrap: anywhere;
    color: var(--silver);
    font-size: 15px;
}

.library-review-flag {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 24px;
    margin: 0 0 8px;
    padding: 4px 8px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.2;
}

.library-review-reviewed_not_actioned {
    border-color: rgba(255, 193, 7, 0.45);
    background: rgba(255, 193, 7, 0.12);
    color: #f8d27a;
}

.library-review-reviewed_hunted {
    border-color: rgba(74, 222, 128, 0.48);
    background: rgba(74, 222, 128, 0.13);
    color: #9df2b4;
}

.library-review-not_reviewed {
    border-color: rgba(148, 163, 184, 0.34);
}

.library-review-not_relevant {
    border-color: rgba(248, 113, 113, 0.45);
    background: rgba(248, 113, 113, 0.12);
    color: #ffb4b4;
}

.library-not-relevant-action {
    border-color: rgba(248, 113, 113, 0.4);
    color: #ffb4b4;
}

.candidate-actions form {
    display: inline-flex;
    margin: 0;
}

.library-card p {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
}

@media (max-width: 720px) {
    .library-card {
        grid-template-columns: 1fr;
    }

    .library-card .candidate-actions {
        grid-column: 1;
        grid-row: auto;
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

.threat-library-source-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.library-indicator-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

@media (max-width: 920px) {
    .library-indicator-grid {
        grid-template-columns: 1fr;
    }
}


.cti-review-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 280px;
    gap: 16px;
    align-items: start;
}

.cti-review-form textarea {
    min-height: 92px;
}

.cti-review-actions {
    justify-content: space-between;
    gap: 20px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

.cti-review-actions .cti-create-hunt-link {
    margin-left: auto;
}

.inline-select-label {
    align-self: center;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.compact-select {
    min-height: 38px;
    width: auto;
}

.cti-review-assist {
    position: sticky;
    top: 16px;
}

.cti-review-assist form {
    margin: 10px 0;
}

.cti-review-builder-summary {
    margin-bottom: 16px;
}

.compact-section-header {
    padding: 0 0 10px;
}

.compact-section-header h3 {
    margin: 0;
    color: var(--silver);
    font-size: 16px;
}

@media (max-width: 980px) {
    .cti-review-grid {
        grid-template-columns: 1fr;
    }

    .cti-review-assist {
        position: static;
    }
}


.cti-quality-panel,
.automation-grid,
.diamond-grid {
    display: grid;
    gap: 1rem;
}

.cti-quality-panel {
    grid-template-columns: minmax(220px, 0.8fr) minmax(280px, 1.4fr);
    border-top: 1px solid var(--border);
}

.quality-check-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.7rem;
}

.quality-check,
.automation-panel,
.diamond-card {
    border: 1px solid var(--border);
    background: var(--surface-soft);
    border-radius: 8px;
    padding: 0.85rem;
}

.quality-check strong,
.quality-check span,
.diamond-card li strong,
.diamond-card li span,
.diamond-bridges strong,
.diamond-bridges span {
    display: block;
}

.quality-check span,
.diamond-card li span,
.diamond-bridges span {
    color: var(--muted);
    font-size: 0.88rem;
    margin-top: 0.2rem;
}

.quality-pass {
    border-color: rgba(34, 197, 94, 0.38);
}

.quality-warn {
    border-color: rgba(255, 209, 102, 0.42);
}

.quality-missing {
    border-color: rgba(255, 88, 116, 0.36);
}

.handoff-workflow {
    display: grid;
    gap: 18px;
}

.handoff-field-grid {
    align-items: start;
}

.handoff-field-grid textarea {
    min-height: 118px;
}

.handoff-ready-check {
    align-self: end;
}

.handoff-review-grid {
    padding-top: 4px;
}

.handoff-workflow-summary {
    display: grid;
    gap: 12px;
}

.handoff-guardrail-panel {
    display: grid;
    gap: 12px;
}

.handoff-guardrail-panel .prose {
    color: var(--muted);
    font-size: 0.92rem;
}

.automation-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.automation-panel h3,
.diamond-card h3 {
    margin-top: 0;
}

.diamond-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.diamond-card li,
.diamond-bridges li {
    padding: 0.45rem 0;
    border-bottom: 1px solid rgba(173, 202, 229, 0.12);
}

.diamond-card li:last-child,
.diamond-bridges li:last-child {
    border-bottom: 0;
}

@media (max-width: 760px) {
    .cti-quality-panel {
        grid-template-columns: 1fr;
    }
}


.automation-list {
    display: grid;
    gap: 0.55rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.automation-list li {
    min-width: 0;
    padding: 0.55rem 0;
    border-top: 1px solid rgba(173, 202, 229, 0.12);
    color: var(--text);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.automation-list li:first-child {
    border-top: 0;
}

.automation-panel,
.diamond-card,
.quality-check {
    min-width: 0;
    overflow: hidden;
}

.automation-panel h3,
.automation-panel h4,
.diamond-card h3,
.diamond-card .prose {
    overflow-wrap: anywhere;
    word-break: break-word;
}

.diamond-list strong,
.diamond-bridges strong {
    line-height: 1.35;
}

.diamond-list span,
.diamond-bridges span {
    line-height: 1.35;
}


.evaluated-candidate-state span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border: 1px solid rgba(34, 197, 94, 0.38);
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.12);
    color: #bbf7d0;
}


.evaluated-candidate-state .inline-action-form {
    margin: 0;
}

.compact-button {
    min-height: 28px;
    padding: 0 10px;
    font-size: 12px;
}

.telemetry-readiness-result {
    display: grid;
    gap: 16px;
}

.telemetry-family-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.telemetry-family {
    display: grid;
    gap: 6px;
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.035);
}

.telemetry-family strong {
    color: var(--silver);
    font-size: 13px;
}

.telemetry-family span {
    overflow-wrap: anywhere;
    color: var(--muted);
    font-size: 12px;
}

.telemetry-family-present {
    border-color: rgba(34, 197, 94, 0.52);
    background: rgba(34, 197, 94, 0.08);
}

.telemetry-family-missing {
    border-color: rgba(245, 158, 11, 0.45);
    background: rgba(245, 158, 11, 0.08);
}

.telemetry-fields-disclosure {
    border: 1px solid var(--border);
    border-radius: 8px;
}

.telemetry-field-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.telemetry-field-list span {
    max-width: 100%;
    padding: 5px 8px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--silver);
    font-size: 12px;
    overflow-wrap: anywhere;
}

@media (max-width: 920px) {
    .telemetry-family-grid {
        grid-template-columns: 1fr;
    }
}

.dfir-evidence-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.dfir-evidence-summary {
    border-color: rgba(125, 211, 252, 0.36);
}

.dfir-evidence-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.dfir-evidence-card-header h3 {
    margin: 0;
}

.dfir-evidence-card h4 {
    margin: 10px 0 0;
    color: var(--silver);
    font-size: 13px;
}

.dfir-evidence-priority {
    border-color: rgba(34, 197, 94, 0.45);
}

.dfir-evidence-review {
    border-color: rgba(245, 158, 11, 0.45);
}

.dfir-evidence-optional {
    opacity: 0.86;
}

.dfir-tool-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.dfir-tool-list span {
    max-width: 100%;
    padding: 5px 8px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--silver);
    font-size: 12px;
    overflow-wrap: anywhere;
}

.run-comparison-panel {
    display: grid;
    gap: 14px;
    margin-top: 14px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.028);
}

.run-comparison-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.run-comparison-header h3 {
    margin: 0;
    color: var(--silver);
    font-size: 15px;
}

.run-comparison-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.run-change-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}

.run-change-card {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.run-change-card h4 {
    margin: 0 0 8px;
    color: var(--silver);
    font-size: 13px;
}

.run-change-card p,
.run-change-counts span {
    overflow-wrap: anywhere;
}

.run-change-card p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 12px;
}

.run-change-counts {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.run-change-counts span {
    padding: 4px 7px;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--muted);
    font-size: 11px;
}

@media (max-width: 920px) {
    .run-comparison-header {
        flex-direction: column;
    }

    .run-comparison-metrics {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 620px) {
    .run-comparison-metrics {
        grid-template-columns: 1fr;
    }
}

.cti-quality-queue {
    display: grid;
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.025);
}

.cti-quality-queue-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.cti-quality-bucket {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.cti-quality-bucket-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.cti-quality-bucket h3 {
    margin: 0;
    color: var(--silver);
    font-size: 14px;
}

.cti-quality-hunt_ready {
    border-color: rgba(34, 197, 94, 0.45);
}

.cti-quality-review_first {
    border-color: rgba(245, 158, 11, 0.45);
}

.cti-quality-needs_triage {
    border-color: rgba(148, 163, 184, 0.34);
}

.cti-quality-not_actionable {
    border-color: rgba(248, 113, 113, 0.45);
}

.cti-quality-item-list {
    display: grid;
    gap: 9px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cti-quality-item-list li {
    min-width: 0;
    padding-top: 9px;
    border-top: 1px solid rgba(173, 202, 229, 0.12);
}

.cti-quality-item-list li:first-child {
    padding-top: 0;
    border-top: 0;
}

.cti-quality-item-list a,
.cti-quality-item-list span,
.cti-quality-item-list small {
    display: block;
    overflow-wrap: anywhere;
}

.cti-quality-item-list a {
    color: var(--cyan);
    font-size: 13px;
    font-weight: 850;
    text-decoration: none;
}

.cti-quality-item-list span,
.cti-quality-item-list small,
.cti-quality-empty {
    margin-top: 4px;
    color: var(--muted);
    font-size: 12px;
}

@media (max-width: 1100px) {
    .cti-quality-queue-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 680px) {
    .cti-quality-queue-grid {
        grid-template-columns: 1fr;
    }
}
.daily-brief-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
    padding: 14px 16px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface-soft);
}

.daily-brief-header h3 {
    margin: 4px 0;
    color: var(--silver);
    font-size: 16px;
}

.daily-brief-header p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    font-weight: 750;
}

.daily-brief-list {
    display: grid;
    gap: 12px;
}

.daily-brief-card {
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr) auto;
    gap: 14px;
    align-items: start;
    padding: 16px;
    border: 1px solid var(--border);
    border-left: 4px solid var(--cyan);
    border-radius: 8px;
    background: var(--surface-soft);
}

.daily-brief-critical {
    border-left-color: var(--danger);
}

.daily-brief-high {
    border-left-color: #facc15;
}

.daily-brief-medium {
    border-left-color: var(--cyan);
}

.daily-brief-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--border-strong);
    border-radius: 8px;
    background: var(--surface);
    color: var(--silver);
    font-size: 15px;
    font-weight: 900;
}

.daily-brief-main {
    display: grid;
    gap: 7px;
    min-width: 0;
}

.daily-brief-title-row,
.daily-brief-signals {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.daily-brief-main h3 {
    margin: 0;
    color: var(--silver);
    font-size: 15px;
    line-height: 1.3;
}

.daily-brief-main p {
    margin: 0;
    color: var(--text);
    font-size: 13px;
    line-height: 1.45;
}

.daily-brief-main small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.daily-brief-signals span {
    padding: 4px 8px;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: var(--surface);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

@media (max-width: 760px) {
    .daily-brief-header,
    .daily-brief-card {
        grid-template-columns: 1fr;
    }

    .daily-brief-header {
        display: grid;
    }
}


/* Threat Triage */
.triage-condensed-panel,
.triage-jira-panel {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.triage-condensed-panel h3,
.triage-jira-panel h3 {
    margin: 0 0 6px;
    color: var(--silver);
    font-size: 17px;
}

.triage-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.triage-meta-row span {
    display: inline-flex;
    min-height: 28px;
    align-items: center;
    padding: 4px 9px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(148, 163, 184, 0.08);
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.saved-hunt-triage-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
    min-width: min(100%, 430px);
}

.saved-hunt-triage-actions form {
    margin: 0;
}



.triage-record-actions {
    align-items: center;
}

.triage-record-actions .inline-action-form {
    display: inline-flex;
    align-items: center;
    margin: 0;
}

.triage-record-actions .pill,
.triage-record-actions .secondary-button {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
}

.triage-record-actions .secondary-button {
    padding-top: 0;
    padding-bottom: 0;
}

.triage-form textarea {
    min-height: 110px;
}
.triage-hero-copy {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
}


.triage-table td:first-child {
    min-width: 260px;
}

.triage-status-new,
.triage-status-open,
.triage-status-scoping,
.triage-status-investigating,
.triage-status-reporting {
    border-color: rgba(var(--cyan-rgb), 0.45);
    background: rgba(var(--cyan-rgb), 0.14);
    color: var(--silver);
}

.triage-status-confirmed,
.triage-severity-critical,
.triage-severity-high {
    border-color: rgba(229, 57, 71, 0.55);
    background: rgba(229, 57, 71, 0.16);
    color: #ffb5bd;
}

.triage-status-benign,
.triage-status-closed,
.triage-severity-low,
.triage-severity-informational {
    border-color: rgba(120, 190, 150, 0.45);
    background: rgba(120, 190, 150, 0.12);
    color: #bde8ca;
}

.triage-severity-medium {
    border-color: rgba(255, 209, 102, 0.45);
    background: var(--warning-bg);
    color: var(--warning);
}

.triage-history-list li {
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
}

.triage-history-list li:last-child {
    border-bottom: 0;
}

.triage-action-step-list {
    display: grid;
    gap: 12px;
}

.triage-action-step {
    display: grid;
    gap: 10px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(148, 163, 184, 0.07);
}

.triage-action-step .compact-check {
    color: var(--silver);
    font-size: 15px;
    font-weight: 900;
}

.triage-action-step h3 {
    margin: 0;
    color: var(--cyan);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.triage-similar-table td:first-child {
    min-width: 280px;
}

.triage-similar-reasons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.triage-similar-reasons span {
    display: inline-flex;
    min-height: 26px;
    align-items: center;
    padding: 3px 8px;
    border: 1px solid rgba(var(--cyan-rgb), 0.35);
    border-radius: 8px;
    background: rgba(var(--cyan-rgb), 0.1);
    color: var(--silver);
    font-size: 12px;
    font-weight: 800;
}


.triage-history-list span,
.triage-history-list small {
    display: block;
    color: var(--muted);
    font-size: 12px;
}

.case-form textarea {
    min-height: 96px;
}

.case-table td:first-child {
    min-width: 280px;
}

.case-link-list li {
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
}

.case-link-list li::before {
    content: none;
}

.case-link-list li:last-child {
    border-bottom: 0;
}

.case-link-list span {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 12px;
}

.case-entity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
}

.case-entity-card {
    min-width: 0;
    overflow: hidden;
}

.case-entity-list li {
    min-width: 0;
    align-items: flex-start;
}

.case-entity-list strong,
.case-entity-list .admin-subtext {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}

.case-timeline {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.case-timeline li {
    padding: 12px 14px;
    border: 1px solid var(--border);
    border-left: 3px solid var(--cyan);
    border-radius: 8px;
    background: rgba(148, 163, 184, 0.06);
}

.case-timeline span {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 12px;
}

.case-timeline p {
    margin: 8px 0 0;
    color: var(--muted);
}

.table-action-stack {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.table-action-stack form {
    margin: 0;
}

.small-metric {
    font-size: clamp(18px, 2vw, 28px);
    overflow-wrap: anywhere;
}

@media (max-width: 780px) {
    .triage-condensed-panel,
    .triage-jira-panel {
        flex-direction: column;
    }

    .saved-hunt-triage-actions {
        justify-content: flex-start;
        min-width: 0;
    }
}

.reporting-scroll-table {
    max-height: 360px;
    overflow: auto;
    scrollbar-gutter: stable;
}

.reporting-scroll-table .admin-table thead th {
    position: sticky;
    top: 0;
    z-index: 1;
    background: var(--panel);
}

.reporting-chart {
    display: grid;
    gap: 12px;
    margin: 14px 0 18px;
}

.reporting-chart-row {
    display: grid;
    gap: 7px;
}

.reporting-chart-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--muted);
    font-size: 12px;
}

.reporting-chart-label span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.reporting-chart-label strong {
    color: var(--text);
    font-size: 13px;
    white-space: nowrap;
}

.reporting-chart-track {
    height: 10px;
    overflow: hidden;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.035);
}

.reporting-chart-track span {
    display: block;
    min-width: 3px;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--accent), var(--accent-strong));
}

.reporting-chart-card .admin-table {
    min-width: 760px;
}

.reporting-tile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 12px;
    margin: 14px 0 18px;
}

.reporting-metric-tile {
    appearance: none;
    display: grid;
    gap: 10px;
    min-height: 126px;
    padding: 14px;
    border: 1px solid color-mix(in srgb, var(--slice-color), var(--border) 45%);
    border-top: 4px solid var(--slice-color);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.025));
    color: inherit;
    cursor: pointer;
    text-align: left;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.reporting-metric-tile span {
    min-width: 0;
    overflow: hidden;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.reporting-metric-tile strong {
    align-self: center;
    color: var(--text);
    font-size: clamp(26px, 3vw, 42px);
    line-height: 1;
}

.reporting-metric-tile small {
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
}

.reporting-metric-tile[aria-pressed="true"] {
    background: color-mix(in srgb, var(--slice-color), transparent 88%);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--slice-color), transparent 35%);
}

.reporting-card-actions {
    align-items: center;
    flex-wrap: wrap;
}

.reporting-filter-pill {
    border-color: rgba(56, 189, 248, 0.45);
    color: var(--text);
}

.reporting-chart-row {
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    text-align: left;
    cursor: pointer;
}

.reporting-chart-row[aria-pressed="true"] .reporting-chart-label strong,
.reporting-legend-item[aria-pressed="true"] strong {
    color: var(--accent-strong);
}

.reporting-chart-row[aria-pressed="true"] .reporting-chart-track {
    border-color: rgba(56, 189, 248, 0.65);
    box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.15);
}

.reporting-donut-layout {
    display: grid;
    grid-template-columns: minmax(150px, 210px) minmax(0, 1fr);
    gap: 18px;
    align-items: center;
    margin: 14px 0 18px;
}

.reporting-donut {
    position: relative;
    display: grid;
    place-items: center;
    width: min(100%, 210px);
    aspect-ratio: 1;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 50%;
    background: conic-gradient(var(--reporting-donut));
    color: var(--text);
    cursor: pointer;
    box-shadow: 0 20px 45px rgba(0, 0, 0, 0.24), inset 0 0 28px rgba(255, 255, 255, 0.06);
}

.reporting-donut::after {
    content: "";
    position: absolute;
    inset: 23%;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 50%;
    background: var(--panel);
    box-shadow: inset 0 0 18px rgba(255, 255, 255, 0.035);
}

.reporting-donut span,
.reporting-donut small {
    position: relative;
    z-index: 1;
}

.reporting-donut span {
    font-size: clamp(24px, 4vw, 42px);
    font-weight: 800;
    line-height: 1;
}

.reporting-donut small {
    margin-top: 5px;
    color: var(--muted);
    font-size: 11px;
    text-transform: uppercase;
}

.reporting-donut-legend {
    display: grid;
    gap: 8px;
}

.reporting-legend-item {
    display: grid;
    grid-template-columns: 9px minmax(0, 1fr) max-content max-content;
    gap: 10px;
    align-items: center;
    width: 100%;
    padding: 9px 10px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.03);
    color: var(--muted);
    cursor: pointer;
    text-align: left;
}

.reporting-legend-item::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--slice-color);
    box-shadow: 0 0 12px color-mix(in srgb, var(--slice-color), transparent 45%);
}

.reporting-legend-item span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.reporting-legend-item strong {
    color: var(--text);
}

.reporting-legend-item small {
    color: var(--muted);
}

.reporting-legend-item[aria-pressed="true"] {
    border-color: rgba(56, 189, 248, 0.55);
    background: rgba(56, 189, 248, 0.08);
}

.reporting-scroll-table tr[hidden] {
    display: none;
}

@media (max-width: 760px) {
    .reporting-donut-layout {
        grid-template-columns: 1fr;
        justify-items: center;
    }

    .reporting-donut-legend {
        width: 100%;
    }
}

.reporting-chart {
    align-items: stretch;
}

.reporting-chart-row {
    appearance: none;
    display: grid !important;
    justify-items: stretch;
    padding: 10px 0;
    font: inherit;
}

.reporting-chart-label {
    width: 100%;
}

.reporting-chart-track {
    width: 100%;
}

.reporting-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px;
    margin: 14px 0 18px;
}

.reporting-kpi-tile {
    display: grid;
    gap: 8px;
    min-height: 132px;
    padding: 16px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.reporting-kpi-tile span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.reporting-kpi-tile strong {
    align-self: center;
    color: var(--text);
    font-size: clamp(24px, 3vw, 38px);
    line-height: 1;
}

.reporting-kpi-tile small {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}
