:root {
  --bg: #0b0f14;
  --bg-elev: #121821;
  --bg-panel: #161d27;
  --border: #222c3a;
  --text: #e6edf3;
  --text-dim: #8591a2;
  --text-strong: #ffffff;
  --accent: #5bc0eb;
  --accent-soft: rgba(91, 192, 235, 0.12);
  --warn: #f5a623;
  --danger: #ef5350;
  --safe: #6bcf7f;
  --critical: #ff3b30;
  --think: #a78bfa;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.55;
}

/* On desktop we lock the layout to the viewport so the grid rows stay fixed
   and each panel scrolls internally — otherwise a long report or a noisy
   activity stream pushes the left-column panels down the page. On narrower
   screens we revert to natural page scroll since the grid stacks. */
@media (min-width: 901px) {
  html, body {
    height: 100vh;
    overflow: hidden;
  }
}

body {
  display: flex;
  flex-direction: column;
}

/* ----- Header ---------------------------------------------------------- */
.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev);
}

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

.brand-mark {
  font-size: 22px;
  color: var(--accent);
}

.brand h1 {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.02em;
  margin: 0;
  color: var(--text-strong);
}

.brand-tag {
  font-size: 12px;
  color: var(--text-dim);
  border-left: 1px solid var(--border);
  padding-left: 12px;
}

.health {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-dim);
}

.health .dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #555;
}
.health .dot[data-state="ok"] { background: var(--safe); box-shadow: 0 0 8px var(--safe); }
.health .dot[data-state="error"] { background: var(--danger); }

/* ----- Header extras --------------------------------------------------- */
.header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.repo-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-dim);
  text-decoration: none;
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: 3px;
  transition: all 0.15s;
}

.repo-link:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.repo-link svg {
  flex-shrink: 0;
}

.intro-toggle {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
  font-family: var(--mono);
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 3px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
}

.intro-toggle:hover {
  color: var(--accent);
  border-color: var(--accent);
}

.intro-toggle .toggle-icon {
  transition: transform 0.2s;
  font-size: 10px;
}

.intro-toggle[aria-expanded="false"] .toggle-icon {
  transform: rotate(-90deg);
}

/* ----- Intro section --------------------------------------------------- */
.intro {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border-bottom: 1px solid var(--border);
  max-height: 320px;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.2s;
  opacity: 1;
}

.intro[hidden] {
  display: none !important;
}

.intro.collapsed {
  max-height: 0;
  opacity: 0;
  border-bottom: none;
}

.intro-col {
  background: var(--bg-elev);
  padding: 16px 22px;
}

.intro-col h3 {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin: 0 0 8px 0;
}

.intro-col p {
  margin: 0 0 8px 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text);
}

.intro-col p.muted {
  color: var(--text-dim);
  font-size: 12px;
}

.intro-col code {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--accent);
  background: var(--bg);
  padding: 1px 5px;
  border-radius: 3px;
}

.intro-steps {
  margin: 0 0 10px 0;
  padding-left: 18px;
  font-size: 13px;
}

.intro-steps li {
  margin-bottom: 4px;
}

.legend {
  display: flex;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.legend-pill {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}

.legend-pill[data-level="low"] { background: rgba(107, 207, 127, 0.15); color: var(--safe); }
.legend-pill[data-level="medium"] { background: rgba(245, 166, 35, 0.15); color: var(--warn); }
.legend-pill[data-level="high"] { background: rgba(239, 83, 80, 0.15); color: var(--danger); }
.legend-pill[data-level="critical"] { background: rgba(255, 59, 48, 0.2); color: var(--critical); }

@media (max-width: 900px) {
  .intro {
    grid-template-columns: 1fr;
    max-height: 800px;
  }
}

/* ----- Grid ------------------------------------------------------------ */
.grid {
  flex: 1;
  display: grid;
  grid-template-columns: 320px 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  min-height: 0;
  transition: grid-template-rows 0.2s ease;
}

/* When there's no report yet (idle or investigation running), the top row
   matters more: that's where the input form and the streaming activity live.
   The bottom row is reference-only (history list + empty report placeholder)
   so we shrink it. Once a report lands, we rebalance to 50/50 so the report
   has room to breathe. */
body.report-empty .grid {
  grid-template-rows: 2fr 1fr;
}

/* Email Triage mode: the input panel has a textarea + extracted list +
   progress bar and needs even more vertical space. */
body.triage-mode .grid {
  grid-template-rows: 2.5fr 1fr;
}

.panel {
  background: var(--bg-panel);
  padding: 18px 22px;
  overflow-y: auto;
  min-height: 0;
}

.panel h2 {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin: 0 0 14px 0;
}

.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.panel-header h2 { margin: 0; }

.panel-input { grid-column: 1; grid-row: 1; }
.panel-activity {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  flex-direction: column;
}
.panel-activity .panel-header { flex-shrink: 0; }
.panel-activity .activity-stream {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}
.panel-history { grid-column: 1; grid-row: 2; }
.panel-report {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  flex-direction: column;
}
.panel-report .panel-header { flex-shrink: 0; }
.panel-report .report {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}

/* ----- Mode switch ----------------------------------------------------- */
.mode-switch {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.mode-tab {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-dim);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  padding: 8px 4px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.15s;
  margin-bottom: -1px;
}

.mode-tab:hover { color: var(--text); }

.mode-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.mode-panel[hidden] { display: none !important; }

.mode-help {
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.5;
  margin: 0 0 10px 0;
}

#email-raw {
  width: 100%;
  min-height: 160px;
  padding: 8px 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  line-height: 1.45;
  border-radius: 3px;
  resize: vertical;
  box-sizing: border-box;
  transition: min-height 0.2s, height 0.2s;
}

/* Once extraction succeeds, collapse the textarea to reclaim vertical space
   for the IOC checklist. User can still edit or re-paste; the field just
   doesn't dominate the panel anymore. */
body.has-extraction #email-raw {
  min-height: 60px;
  height: 60px;
}

#email-raw:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.email-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}

.email-actions button {
  flex: 1;
  padding: 8px 10px;
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}

.email-actions button.secondary {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
}

.email-actions button:hover { opacity: 0.85; }

.extracted {
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

.extracted-summary {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-dim);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.extracted-list {
  max-height: 220px;
  overflow-y: auto;
  margin-bottom: 10px;
  border: 1px solid var(--border);
  border-radius: 3px;
  background: var(--bg);
}

.extracted-group {
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
}

.extracted-group:last-child { border-bottom: none; }

.extracted-group-header {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin-bottom: 4px;
}

.extracted-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 3px 0;
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
}

.extracted-item input[type="checkbox"] { flex-shrink: 0; }

.extracted-item .value {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--text);
}

#investigate-all-btn {
  width: 100%;
  padding: 10px 14px;
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}

#investigate-all-btn:hover { opacity: 0.85; }
#investigate-all-btn[disabled] { opacity: 0.5; cursor: wait; }

.batch-progress {
  margin-top: 14px;
}

.progress-bar {
  width: 100%;
  height: 6px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 6px;
}

.progress-fill {
  height: 100%;
  background: var(--accent);
  width: 0%;
  transition: width 0.3s;
}

.progress-text {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-dim);
  margin: 0;
}

/* ----- Input panel ----------------------------------------------------- */
.field {
  display: block;
  margin-bottom: 12px;
}

.field > span {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin-bottom: 4px;
}

.field input,
.field select {
  width: 100%;
  padding: 8px 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13px;
  border-radius: 3px;
}

.field input:focus,
.field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

#submit-btn {
  width: 100%;
  padding: 10px 14px;
  margin-top: 4px;
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: opacity 0.15s;
}

#submit-btn:hover { opacity: 0.85; }
#submit-btn:disabled {
  background: var(--border);
  color: var(--text-dim);
  cursor: not-allowed;
}

.examples {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.examples h3 {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin: 0 0 8px 0;
  font-weight: 500;
}

#example-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#example-list li { margin-bottom: 4px; }

#example-list button {
  background: none;
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 10px;
  font-family: var(--mono);
  font-size: 12px;
  cursor: pointer;
  width: 100%;
  text-align: left;
  border-radius: 3px;
  transition: all 0.15s;
}

#example-list button:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* ----- Activity stream ------------------------------------------------- */
.status {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-dim);
  padding: 3px 8px;
  background: var(--bg);
  border-radius: 3px;
}

.status[data-state="running"] { color: var(--accent); }
.status[data-state="done"] { color: var(--safe); }
.status[data-state="error"] { color: var(--danger); }

.activity-stream .empty {
  color: var(--text-dim);
  font-style: italic;
}

.activity-item {
  display: flex;
  gap: 12px;
  padding: 6px 0;
  animation: fadein 0.25s ease-out;
}

@keyframes fadein {
  from { opacity: 0; transform: translateY(-2px); }
  to { opacity: 1; transform: none; }
}

.activity-item .marker {
  flex-shrink: 0;
  width: 18px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-dim);
  text-align: center;
  padding-top: 1px;
}

.activity-item .body {
  flex: 1;
  min-width: 0;
  font-size: 13px;
}

.activity-item.thinking .body {
  color: var(--think);
  font-style: italic;
  line-height: 1.5;
}

.activity-item.thinking .marker { color: var(--think); }

.activity-item.tool-use .body {
  font-family: var(--mono);
  color: var(--text-strong);
}

.activity-item.tool-use .marker { color: var(--accent); }

.activity-item.tool-use code {
  color: var(--accent);
}

.activity-item.tool-result .body {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-dim);
  padding-left: 4px;
  border-left: 2px solid var(--border);
}

.activity-item.tool-result .marker { color: var(--safe); }

.activity-item.error .marker { color: var(--danger); }
.activity-item.error .body { color: var(--danger); }

/* ----- Report ---------------------------------------------------------- */
.report .empty {
  color: var(--text-dim);
  font-style: italic;
}

.report h1, .report h2, .report h3 {
  font-family: var(--sans);
  color: var(--text-strong);
  margin-top: 1.2em;
  margin-bottom: 0.4em;
  line-height: 1.25;
}

.report h2 {
  font-size: 18px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 6px;
}

.report h3 {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-dim);
}

.report p { margin: 0.6em 0; }

.report ol, .report ul {
  padding-left: 1.5em;
  margin: 0.6em 0;
}

.report li { margin-bottom: 4px; }

.report strong { color: var(--text-strong); }

.report code {
  font-family: var(--mono);
  font-size: 12px;
  background: var(--bg);
  padding: 1px 5px;
  border-radius: 3px;
  color: var(--accent);
}

.badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.risk-badge,
.threat-badge,
.family-badge,
.confidence-badge {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}

/* Threat category colors — map SOC mental model onto colors. */
.threat-badge[data-type="malware_c2"],
.threat-badge[data-type="malware_delivery"] {
  background: rgba(239, 83, 80, 0.15);
  color: var(--danger);
  border: 1px solid rgba(239, 83, 80, 0.4);
}

.threat-badge[data-type="phishing"],
.threat-badge[data-type="weaponized_document"] {
  background: rgba(245, 166, 35, 0.15);
  color: var(--warn);
  border: 1px solid rgba(245, 166, 35, 0.4);
}

.threat-badge[data-type="scam_spam"] {
  background: rgba(167, 139, 250, 0.15);
  color: var(--think);
  border: 1px solid rgba(167, 139, 250, 0.4);
}

.threat-badge[data-type="scanner"] {
  background: rgba(133, 145, 162, 0.15);
  color: var(--text-dim);
  border: 1px solid rgba(133, 145, 162, 0.4);
}

.threat-badge[data-type="benign"] {
  background: rgba(107, 207, 127, 0.15);
  color: var(--safe);
  border: 1px solid rgba(107, 207, 127, 0.4);
}

.threat-badge[data-type="unknown"] {
  background: var(--bg);
  color: var(--text-dim);
  border: 1px solid var(--border);
}

.family-badge {
  background: var(--accent-soft);
  color: var(--accent);
  border: 1px solid var(--accent);
}

.confidence-badge {
  background: var(--bg);
  color: var(--text-dim);
  border: 1px solid var(--border);
  font-weight: 500;
  text-transform: lowercase;
}

.risk-badge[data-level="low"] {
  background: rgba(107, 207, 127, 0.15);
  color: var(--safe);
}
.risk-badge[data-level="medium"] {
  background: rgba(245, 166, 35, 0.15);
  color: var(--warn);
}
.risk-badge[data-level="high"] {
  background: rgba(239, 83, 80, 0.15);
  color: var(--danger);
}
.risk-badge[data-level="critical"] {
  background: rgba(255, 59, 48, 0.2);
  color: var(--critical);
}

/* ----- Actions panel (below report) ------------------------------------ */
.actions {
  flex-shrink: 0;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.actions h3 {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin: 0 0 6px 0;
}

.actions-intro {
  margin: 0 0 10px 0;
  color: var(--text-dim);
  font-size: 12px;
}

.action-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 7px 12px;
  font-family: var(--mono);
  font-size: 12px;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.15s;
  text-decoration: none;
}

.action-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.action-btn[data-severity="primary"] {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
  font-weight: 600;
}

.action-btn[data-severity="primary"]:hover {
  opacity: 0.85;
  color: var(--bg);
}

.action-btn[disabled],
.action-btn[data-state="pending"] {
  opacity: 0.6;
  cursor: wait;
}

.action-btn[data-state="success"] {
  border-color: var(--safe);
  color: var(--safe);
  background: rgba(107, 207, 127, 0.08);
}

.action-btn[data-state="error"] {
  border-color: var(--danger);
  color: var(--danger);
}

.action-btn .icon {
  font-size: 14px;
  line-height: 1;
}

/* ----- Submission modal ------------------------------------------------ */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
}

.modal-backdrop[hidden] {
  display: none;
}

.modal {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 5px;
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6);
  animation: modal-in 0.15s ease-out;
}

@keyframes modal-in {
  from { opacity: 0; transform: translateY(10px) scale(0.98); }
  to { opacity: 1; transform: none; }
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
}

.modal-header h2 {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0.02em;
  color: var(--text-strong);
  margin: 0;
}

.modal-close {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
}

.modal-close:hover { color: var(--text); }

.modal-body {
  padding: 18px 20px;
  overflow-y: auto;
  flex: 1;
}

.modal-body p {
  margin: 0 0 10px 0;
  font-size: 13px;
}

.modal-body .modal-subtitle {
  color: var(--text-dim);
  margin-bottom: 16px;
  font-size: 13px;
}

.modal-body .modal-ioc {
  font-family: var(--mono);
  color: var(--accent);
  font-size: 13px;
  background: var(--bg);
  padding: 6px 10px;
  border-radius: 3px;
  border: 1px solid var(--border);
  margin-bottom: 16px;
  display: inline-block;
}

.modal-field {
  margin-bottom: 14px;
}

.modal-field > label {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  margin-bottom: 6px;
}

.modal-field input[type="text"],
.modal-field select,
.modal-field textarea {
  width: 100%;
  padding: 8px 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  border-radius: 3px;
  resize: vertical;
}

.modal-field textarea { min-height: 80px; font-family: var(--sans); font-size: 13px; }

.modal-checklist {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 10px;
  max-height: 180px;
  overflow-y: auto;
  padding: 8px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 3px;
}

.modal-checklist label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-family: var(--mono);
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 3px;
}

.modal-checklist label:hover { background: var(--bg-elev); }

.modal-checklist input[type="checkbox"] { cursor: pointer; }

.modal-status {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 3px;
  font-size: 13px;
  font-family: var(--mono);
  line-height: 1.5;
}

.modal-status[data-state="success"] {
  background: rgba(107, 207, 127, 0.1);
  border: 1px solid var(--safe);
  color: var(--safe);
}

.modal-status[data-state="error"] {
  background: rgba(239, 83, 80, 0.1);
  border: 1px solid var(--danger);
  color: var(--danger);
}

.modal-status a { color: inherit; text-decoration: underline; }

.modal-footer {
  padding: 12px 20px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.modal-footer button {
  padding: 8px 14px;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  transition: all 0.15s;
}

.modal-footer button:hover { border-color: var(--text); }

.modal-footer button.primary {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
}

.modal-footer button.primary:hover { opacity: 0.85; }
.modal-footer button[disabled] { opacity: 0.5; cursor: not-allowed; }

/* ----- History --------------------------------------------------------- */
.history-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: item;
}

.history-list .empty {
  color: var(--text-dim);
  font-style: italic;
}

.history-list li {
  padding: 8px 10px;
  border: 1px solid transparent;
  margin-bottom: 4px;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.history-list li:not(.empty):hover {
  border-color: var(--border);
  background: var(--bg);
}

.history-list li.active {
  border-color: var(--accent);
  background: var(--accent-soft);
}

.history-list .history-ioc {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.history-list .history-meta {
  display: flex;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
}

.history-list .history-meta .score[data-level="low"] { color: var(--safe); }
.history-list .history-meta .score[data-level="medium"] { color: var(--warn); }
.history-list .history-meta .score[data-level="high"] { color: var(--danger); }
.history-list .history-meta .score[data-level="critical"] { color: var(--critical); }

/* ----- Footer ---------------------------------------------------------- */
.app-footer {
  border-top: 1px solid var(--border);
  padding: 10px 24px;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-dim);
  background: var(--bg-elev);
}

.app-footer a {
  color: var(--accent);
  text-decoration: none;
}

.app-footer a:hover { text-decoration: underline; }

/* ----- Responsive ------------------------------------------------------ */
@media (max-width: 900px) {
  .grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto auto;
  }
  .panel-input, .panel-activity, .panel-report, .panel-history {
    grid-column: 1;
    grid-row: auto;
  }
}
