/* ═══════════════════════════════════════════════════════════════════════
   Enrichment // Compare — "intelligence console" theme
   Dark, dense, monospaced data with verdict-coded signal colors.
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  --ink:        #0a0d13;
  --panel:      #11161f;
  --panel-2:    #161c27;
  --line:       #232c3a;
  --line-soft:  #1a212d;
  --text:       #cdd6e3;
  --text-dim:   #7c8799;
  --text-faint: #515c6e;
  --accent:     #46c8d8;   /* cyan signal */
  --accent-dim: #2a7a85;

  --malicious:  #ff5b6e;
  --suspicious: #f5a623;
  --benign:     #3fd99b;
  --unknown:    #5d6677;
  --nodata:     #39414f;

  --display: 'Archivo', sans-serif;
  --mono: 'IBM Plex Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(70,200,216,0.07), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(70,200,216,0.04), transparent 55%),
    var(--ink);
  color: var(--text);
  font-family: var(--mono);
  font-size: 13.5px;
  line-height: 1.5;
  min-height: 100vh;
  letter-spacing: 0.01em;
}

/* faint grid + scanline atmosphere */
.scanlines {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size: 44px 44px;
  opacity: 0.25;
  mask-image: radial-gradient(circle at 50% 30%, black, transparent 95%);
}

/* ── top bar ─────────────────────────────────────────────────────────── */
.topbar {
  position: relative; z-index: 3;
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  padding: 18px 28px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(17,22,31,0.9), rgba(10,13,19,0.6));
  backdrop-filter: blur(6px);
  flex-wrap: wrap;
}
.brand { display: flex; align-items: center; gap: 14px; }
.logo-mark {
  font-size: 30px; color: var(--accent);
  text-shadow: 0 0 18px rgba(70,200,216,0.55);
}
.topbar h1 {
  font-family: var(--display); font-weight: 900; font-size: 22px;
  margin: 0; letter-spacing: 0.06em; color: var(--text);
}
.topbar h1 .slash { color: var(--accent); margin: 0 2px; }
.tagline { margin: 2px 0 0; font-size: 11.5px; color: var(--text-dim); letter-spacing: 0.02em; }

.topbar-right { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }

/* mode radio — the mock/live switch */
.mode-switch {
  border: 1px solid var(--line); border-radius: 8px;
  padding: 6px 12px 8px; margin: 0; position: relative;
  background: var(--panel);
}
.mode-switch legend {
  font-size: 9px; letter-spacing: 0.2em; color: var(--text-faint);
  padding: 0 6px;
}
.mode-switch { display: flex; gap: 6px; align-items: center; }
.radio { display: inline-flex; align-items: center; cursor: pointer; }
.radio input { position: absolute; opacity: 0; }
.radio span {
  display: inline-block; padding: 4px 14px; border-radius: 5px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.12em;
  color: var(--text-dim); border: 1px solid transparent; transition: all .15s;
}
.radio input:checked + span {
  color: var(--ink); background: var(--accent); border-color: var(--accent);
  box-shadow: 0 0 14px rgba(70,200,216,0.4);
}
.radio:hover span { color: var(--text); }
.mode-switch.live-armed { border-color: var(--suspicious); }

/* tabs */
.tabs { display: flex; gap: 4px; }
.tabs button {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em;
  background: transparent; border: 1px solid transparent; color: var(--text-dim);
  padding: 8px 16px; border-radius: 6px; cursor: pointer; transition: all .15s;
}
.tabs button:hover { color: var(--text); border-color: var(--line); }
.tabs button.active { color: var(--accent); border-color: var(--accent-dim); background: rgba(70,200,216,0.06); }

/* ── layout ──────────────────────────────────────────────────────────── */
main { position: relative; z-index: 2; max-width: 1280px; margin: 0 auto; padding: 28px; }
.view { display: none; animation: fade .25s ease; }
.view.active { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* ── search ──────────────────────────────────────────────────────────── */
.search-block { margin-bottom: 26px; }
.search-row { display: flex; gap: 10px; align-items: center; }
input[type=text], #histSearch {
  flex: 1; background: var(--panel); border: 1px solid var(--line);
  color: var(--text); font-family: var(--mono); font-size: 15px;
  padding: 13px 16px; border-radius: 8px; outline: none; transition: border .15s;
}
input[type=text]:focus { border-color: var(--accent-dim); box-shadow: 0 0 0 3px rgba(70,200,216,0.08); }
.type-chip {
  font-size: 10px; letter-spacing: 0.14em; color: var(--accent);
  border: 1px solid var(--accent-dim); padding: 5px 10px; border-radius: 5px;
  text-transform: uppercase; background: rgba(70,200,216,0.05);
}
button.primary {
  font-family: var(--mono); font-weight: 600; font-size: 12px; letter-spacing: 0.1em;
  background: var(--accent); color: var(--ink); border: none; padding: 13px 22px;
  border-radius: 8px; cursor: pointer; transition: all .15s; white-space: nowrap;
}
button.primary:hover { box-shadow: 0 0 20px rgba(70,200,216,0.45); transform: translateY(-1px); }
button.ghost {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  background: transparent; color: var(--text-dim); border: 1px solid var(--line);
  padding: 11px 16px; border-radius: 7px; cursor: pointer; transition: all .15s;
}
button.ghost:hover { color: var(--text); border-color: var(--accent-dim); }

/* sample sets */
.sample-sets { margin-top: 14px; display: flex; gap: 22px; flex-wrap: wrap; }
.seed-group { border-left: 2px solid var(--line); padding-left: 12px; }
.seed-group .seed-label { font-size: 10px; letter-spacing: 0.12em; color: var(--text-faint); margin-bottom: 6px; text-transform: uppercase; }
.seed-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.seed-chip {
  font-size: 11.5px; background: var(--panel); border: 1px solid var(--line);
  color: var(--text-dim); padding: 5px 10px; border-radius: 5px; cursor: pointer; transition: all .12s;
}
.seed-chip:hover { color: var(--accent); border-color: var(--accent-dim); }
.seed-chip.live-feed { color: var(--suspicious); border-color: #5c4a1f; }

/* ── results ─────────────────────────────────────────────────────────── */
.empty-state { text-align: center; padding: 80px 20px; }
.empty-state .big { font-family: var(--display); font-size: 26px; font-weight: 700; color: var(--text-faint); margin: 0 0 10px; }
.empty-state .dim { color: var(--text-dim); max-width: 520px; margin: 0 auto; }
.dim { color: var(--text-dim); }
.small { font-size: 11px; }

.result-header {
  display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap;
  padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 22px;
}
.result-header .ind { font-family: var(--display); font-size: 26px; font-weight: 700; color: var(--text); }
.badge {
  font-size: 10px; letter-spacing: 0.12em; padding: 3px 9px; border-radius: 4px;
  border: 1px solid var(--line); color: var(--text-dim); text-transform: uppercase;
}
.badge.mock { color: var(--accent); border-color: var(--accent-dim); }
.badge.live { color: var(--suspicious); border-color: #5c4a1f; }
.badge.cached { color: var(--text-faint); }

.panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 20px 22px; margin-bottom: 20px;
}
.panel-title { font-size: 10px; letter-spacing: 0.18em; color: var(--text-faint); text-transform: uppercase; margin: 0 0 16px; }

/* consensus strip */
.consensus-strip { display: flex; gap: 8px; flex-wrap: wrap; }
.cchip {
  display: flex; flex-direction: column; gap: 2px; min-width: 92px;
  padding: 10px 12px; border-radius: 8px; border: 1px solid var(--line);
  background: var(--panel-2);
}
.cchip-name { font-size: 11px; color: var(--text); font-weight: 600; }
.cchip-verdict { font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; }
.cchip-bar { height: 3px; border-radius: 2px; margin-top: 4px; background: var(--nodata); }
.v-malicious  { color: var(--malicious); }  .bar-malicious  { background: var(--malicious); }
.v-suspicious { color: var(--suspicious); } .bar-suspicious { background: var(--suspicious); }
.v-benign     { color: var(--benign); }     .bar-benign     { background: var(--benign); }
.v-unknown    { color: var(--unknown); }    .bar-unknown    { background: var(--unknown); }
.cchip-na { opacity: 0.5; }
.cchip-na .cchip-verdict { color: var(--text-faint); }

/* aggregate + divergence */
.agg-row { display: grid; grid-template-columns: 220px 1fr; gap: 20px; }
@media (max-width: 720px) { .agg-row { grid-template-columns: 1fr; } }
.gauge-wrap { display: flex; flex-direction: column; align-items: center; justify-content: center; }
.gauge { position: relative; width: 160px; height: 160px; }
.gauge svg { transform: rotate(-90deg); }
.gauge .gauge-val { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.gauge .num { font-family: var(--display); font-size: 42px; font-weight: 900; line-height: 1; }
.gauge .lbl { font-size: 9px; letter-spacing: 0.18em; color: var(--text-faint); margin-top: 4px; }
.divergence-box { display: flex; flex-direction: column; justify-content: center; gap: 12px; }
.divergence-meter { height: 8px; background: var(--panel-2); border-radius: 4px; overflow: hidden; border: 1px solid var(--line); }
.divergence-fill { height: 100%; background: linear-gradient(90deg, var(--benign), var(--suspicious), var(--malicious)); }
.headline { font-family: var(--display); font-size: 17px; font-weight: 700; }
.headline.alert { color: var(--suspicious); }
.headline.agree { color: var(--benign); }

/* attribute matrix */
.matrix-scroll { overflow-x: auto; }
table.matrix { border-collapse: collapse; width: 100%; font-size: 12px; }
table.matrix th, table.matrix td { border: 1px solid var(--line-soft); padding: 8px 10px; text-align: left; vertical-align: top; }
table.matrix thead th { background: var(--panel-2); color: var(--text); font-weight: 600; position: sticky; top: 0; }
table.matrix tbody th { color: var(--text-dim); font-weight: 500; white-space: nowrap; background: var(--panel-2); }
table.matrix td { color: var(--text); max-width: 220px; overflow-wrap: anywhere; }
table.matrix td.na { color: var(--text-faint); }

/* provider cards */
.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.pcard { background: var(--panel-2); border: 1px solid var(--line); border-radius: 10px; padding: 16px; border-top: 3px solid var(--nodata); }
.pcard.b-malicious  { border-top-color: var(--malicious); }
.pcard.b-suspicious { border-top-color: var(--suspicious); }
.pcard.b-benign     { border-top-color: var(--benign); }
.pcard.b-unknown    { border-top-color: var(--unknown); }
.pcard-head { display: flex; justify-content: space-between; align-items: baseline; }
.pcard-name { font-weight: 700; font-size: 14px; }
.pcard-lane { font-size: 9px; letter-spacing: 0.12em; color: var(--text-faint); text-transform: uppercase; }
.pcard-verdict { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; margin: 8px 0; font-weight: 600; }
.pcard-native { font-size: 11px; color: var(--text-dim); margin-bottom: 10px; }
.pcard-attrs { font-size: 11.5px; }
.pcard-attrs div { display: flex; justify-content: space-between; gap: 8px; padding: 2px 0; border-bottom: 1px dashed var(--line-soft); }
.pcard-attrs .k { color: var(--text-faint); }
.pcard-attrs .v { color: var(--text); text-align: right; overflow-wrap: anywhere; }
.pcard-foot { margin-top: 10px; display: flex; justify-content: space-between; align-items: center; }
.pcard-status { font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.pcard-link { font-size: 11px; color: var(--accent); text-decoration: none; }
.pcard-link:hover { text-decoration: underline; }
.pcard.muted { opacity: 0.6; }

/* history */
.history-list { margin-top: 18px; display: flex; flex-direction: column; gap: 6px; }
.hrow { display: grid; grid-template-columns: 1fr 90px 110px 80px 180px; gap: 10px; align-items: center;
        padding: 11px 14px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; cursor: pointer; transition: all .12s; }
.hrow:hover { border-color: var(--accent-dim); background: var(--panel-2); }
.hrow .h-ind { font-weight: 600; color: var(--text); }
.hrow .h-meta { font-size: 11px; color: var(--text-dim); }
.hrow .h-risk { font-weight: 700; }

/* settings */
.settings-head { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.settings-head h2 { font-family: var(--display); font-size: 18px; letter-spacing: 0.06em; margin: 0; }
.settings-actions { display: flex; gap: 8px; }
.settings-intro { margin: 8px 0 20px; max-width: 760px; }
.provider-table { display: flex; flex-direction: column; gap: 8px; }
.prow { display: grid; grid-template-columns: 30px 1fr 120px 90px 130px 1fr; gap: 12px; align-items: center;
        padding: 12px 14px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; }
.prow.disabled { opacity: 0.5; }
.prow .p-name { font-weight: 600; }
.prow .p-name small { display: block; color: var(--text-faint); font-weight: 400; font-size: 10px; }
.prow .p-lane { font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); }
.prow input[type=number] { width: 60px; background: var(--panel-2); border: 1px solid var(--line); color: var(--text); padding: 5px; border-radius: 5px; font-family: var(--mono); }
.prow .p-secret { font-size: 10px; letter-spacing: 0.08em; }
.secret-ok { color: var(--benign); }
.secret-missing { color: var(--suspicious); }
.secret-none { color: var(--text-faint); }
.p-verify { font-size: 10px; color: var(--suspicious); }

/* toggle */
.toggle { position: relative; width: 38px; height: 20px; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle .track { position: absolute; inset: 0; background: var(--nodata); border-radius: 12px; transition: .15s; cursor: pointer; }
.toggle .track::before { content: ''; position: absolute; width: 14px; height: 14px; left: 3px; top: 3px; background: var(--text-dim); border-radius: 50%; transition: .15s; }
.toggle input:checked + .track { background: var(--accent-dim); }
.toggle input:checked + .track::before { transform: translateX(18px); background: var(--accent); }

/* admin banner */
.admin-warn { background: rgba(245,166,35,0.08); border: 1px solid #5c4a1f; color: var(--suspicious);
  padding: 12px 16px; border-radius: 8px; margin-bottom: 18px; font-size: 12px; }
.admin-locked { background: rgba(63,217,155,0.06); border: 1px solid #1f5c43; color: var(--benign);
  padding: 10px 16px; border-radius: 8px; margin-bottom: 18px; font-size: 12px; }

/* custom form */
.custom-form { margin-top: 22px; background: var(--panel); border: 1px solid var(--accent-dim); border-radius: 12px; padding: 20px 22px; }
.custom-form h3 { font-family: var(--display); margin: 0 0 16px; font-size: 15px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 640px) { .grid2 { grid-template-columns: 1fr; } }
.grid2 label { display: flex; flex-direction: column; gap: 5px; font-size: 11px; letter-spacing: 0.04em; color: var(--text-dim); }
.grid2 label code { color: var(--accent); }
.grid2 input, .grid2 select { background: var(--panel-2); border: 1px solid var(--line); color: var(--text);
  padding: 9px 10px; border-radius: 6px; font-family: var(--mono); font-size: 12px; }
.custom-form-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 16px; }

.hidden { display: none; }

/* toast */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--panel-2); border: 1px solid var(--accent-dim); color: var(--text);
  padding: 12px 20px; border-radius: 8px; font-size: 12px; opacity: 0; pointer-events: none;
  transition: all .25s; z-index: 10; box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.err { border-color: var(--malicious); color: var(--malicious); }

/* loading */
.loading { text-align: center; padding: 60px; color: var(--accent); font-size: 13px; letter-spacing: 0.1em; }
.loading::after { content: '▌'; animation: blink 1s steps(2) infinite; }
@keyframes blink { 50% { opacity: 0; } }

/* ═══════════════════════════════════════════════════════════════════════
   Censys-as-baseline framing + freshness  (added)
   ═══════════════════════════════════════════════════════════════════════ */

/* consensus strip: set Censys apart from the field */
.consensus-strip { align-items: stretch; }
.cstrip-label {
  align-self: center; font-size: 9px; letter-spacing: 0.18em; color: var(--text-faint);
  text-transform: uppercase; padding: 0 4px; white-space: nowrap;
}
.cstrip-divider { width: 1px; align-self: stretch; background: var(--line); margin: 0 6px; }
.cchip-baseline { border-color: var(--accent-dim); background: rgba(70,200,216,0.07); box-shadow: 0 0 14px rgba(70,200,216,0.12); }
.cchip-fresh { font-size: 9px; color: var(--text-faint); margin-top: 3px; }

/* aggregate: 3-up — field gauge | Censys readout | headline */
.agg-row3 { display: grid; grid-template-columns: 200px 168px 1fr; gap: 18px; align-items: center; }
@media (max-width: 820px) { .agg-row3 { grid-template-columns: 1fr; } }

.censys-readout {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px;
  padding: 16px 12px; border: 1px solid var(--accent-dim); border-radius: 12px;
  background: rgba(70,200,216,0.05); position: relative;
}
.censys-badge { font-size: 9px; letter-spacing: 0.2em; color: var(--accent); }
.censys-score { font-family: var(--display); font-size: 46px; font-weight: 900; line-height: 1; }
.censys-vd { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; }
.censys-delta { font-size: 11px; margin-top: 4px; padding: 2px 8px; border-radius: 4px; }
.censys-delta.alert { color: var(--suspicious); border: 1px solid #5c4a1f; }
.censys-delta.agree { color: var(--benign); border: 1px solid #1f5c43; }
.censys-na { font-size: 11px; color: var(--text-faint); }

/* matrix: highlight + rule on the Censys column */
table.matrix th.col-censys, table.matrix td.col-censys {
  background: rgba(70,200,216,0.06);
  border-left: 2px solid var(--accent-dim); border-right: 2px solid var(--accent-dim);
}
table.matrix thead th.col-censys { background: rgba(70,200,216,0.12); }
.th-base { font-size: 8px; letter-spacing: 0.12em; color: var(--accent); display: block; font-weight: 400; }

/* cards: pinned Censys baseline + labeled divider */
.baseline-wrap { position: relative; margin-bottom: 6px; }
.baseline-tag { font-size: 9px; letter-spacing: 0.2em; color: var(--accent); margin-bottom: 6px; }
.pcard-baseline {
  border: 1px solid var(--accent-dim); border-top-width: 3px;
  background: rgba(70,200,216,0.05); box-shadow: 0 0 22px rgba(70,200,216,0.12);
  max-width: 340px;
}
.field-divider { display: flex; align-items: center; gap: 12px; margin: 14px 0 16px; }
.field-divider::before, .field-divider::after { content: ''; height: 1px; background: var(--line); flex: 1; }
.field-divider span { font-size: 9px; letter-spacing: 0.2em; color: var(--text-faint); }
.pcard-fresh { font-size: 10.5px; color: var(--text-faint); margin-bottom: 8px; }

/* ═══════════════════════════════════════════════════════════════════════
   History sub-views: contested leaderboard + diff panel  (added)
   ═══════════════════════════════════════════════════════════════════════ */

.hist-modes { display: flex; gap: 4px; margin-bottom: 14px; }
.hist-modes button {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em;
  background: transparent; border: 1px solid var(--line); color: var(--text-dim);
  padding: 8px 16px; border-radius: 6px; cursor: pointer; transition: all .15s;
}
.hist-modes button:hover { color: var(--text); }
.hist-modes button.active { color: var(--accent); border-color: var(--accent-dim); background: rgba(70,200,216,0.06); }

/* contested leaderboard rows */
.crow {
  display: grid; grid-template-columns: 28px 1fr 200px 1fr 90px; gap: 12px; align-items: center;
  padding: 11px 14px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px;
  cursor: pointer; transition: all .12s; margin-bottom: 6px;
}
.crow:hover { border-color: var(--accent-dim); background: var(--panel-2); }
.c-rank { font-family: var(--display); font-weight: 900; color: var(--text-faint); text-align: center; }
.c-divwrap { display: flex; align-items: center; gap: 8px; }
.c-divbar { flex: 1; height: 7px; background: var(--panel-2); border: 1px solid var(--line); border-radius: 4px; overflow: hidden; }
.c-divfill { display: block; height: 100%; background: linear-gradient(90deg, var(--suspicious), var(--malicious)); }
.c-divpct { font-size: 11px; color: var(--text); width: 34px; text-align: right; }

/* diff panel */
.diff-panel { border-color: var(--accent-dim); background: rgba(70,200,216,0.04); }
.diff-row { display: flex; justify-content: space-between; gap: 14px; padding: 7px 0; border-bottom: 1px dashed var(--line-soft); font-size: 13px; }
.diff-row:last-child { border-bottom: none; }
.diff-k { color: var(--text-faint); letter-spacing: 0.04em; }
.diff-delta { font-weight: 600; padding: 1px 7px; border-radius: 4px; font-size: 11.5px; }
.diff-delta.up { color: var(--malicious); border: 1px solid #5c2230; }
.diff-delta.down { color: var(--benign); border: 1px solid #1f5c43; }

@media (max-width: 640px) {
  .crow { grid-template-columns: 24px 1fr 120px; }
  .crow .h-meta:nth-child(4), .crow .h-meta:last-child { display: none; }
}
