:root {
  --bg: #0d0d0f;
  --surface: #161619;
  --surface-2: #1d1d22;
  --surface-3: #25252b;
  --border: #2a2a31;
  --border-soft: #222228;

  --primary: #b21e2b;
  --primary-hover: #cf2436;
  --accent: #e85d04;
  --accent-soft: #f48c06;
  --blue: #244a73;
  --blue-soft: #4a82bf;

  --text: #ececee;
  --text-2: #b6b6bd;
  --muted: #85858f;

  --ind: #e85d04;
  --per: #4a82bf;
  --org: #cf3a44;
  --inf: #7b8794;
  --plc: #2a9d8f;

  --radius: 10px;
  --gap: 16px;
  --mono: ui-monospace, "SF Mono", "Cascadia Code", "JetBrains Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; }

/* --- Scrollbars --- */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--surface-3) transparent;
}
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--surface-3);
  border-radius: 8px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--accent); background-clip: padding-box; }
::-webkit-scrollbar-corner { background: transparent; }
body {
  background: var(--bg); color: var(--text);
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
code { font-family: var(--mono); font-size: 0.92em; color: var(--accent-soft);
       background: var(--surface-2); padding: 1px 5px; border-radius: 4px;
       word-break: break-all; }

/* --- Layout --- */
.layout { display: grid; grid-template-columns: 232px 1fr; min-height: 100vh; }
.rail {
  background: #111114; border-right: 1px solid var(--border);
  padding: 18px 14px; display: flex; flex-direction: column; gap: 22px;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.brand { display: flex; align-items: center; gap: 9px; font-weight: 600;
         letter-spacing: 2.5px; font-size: 15px; }
.rail nav { display: flex; flex-direction: column; gap: 1px; }
.rail nav a { padding: 8px 11px; border-radius: 7px; color: var(--text-2);
              font-size: 13.5px; }
.rail nav a:hover { background: var(--surface-2); color: var(--text); }
.rail nav a.on { background: var(--surface-3); color: var(--text);
                 box-shadow: inset 2px 0 0 var(--accent); }
.rail-label { font-size: 11px; text-transform: uppercase; letter-spacing: 1.4px;
              color: var(--muted); display: block; margin-bottom: 9px; }
.rail-new { display: flex; flex-direction: column; gap: 6px; }
.chip { font-size: 12.5px; padding: 5px 10px; border-radius: 6px;
        background: var(--surface-2); border-left: 3px solid var(--border);
        color: var(--text-2); }
.chip:hover { background: var(--surface-3); color: var(--text); }
.chip-indicator { border-left-color: var(--ind); }
.chip-person { border-left-color: var(--per); }
.chip-organization { border-left-color: var(--org); }
.chip-infrastructure { border-left-color: var(--inf); }
.chip-place { border-left-color: var(--plc); }

.main { min-width: 0; }
.topbar { padding: 14px 28px; border-bottom: 1px solid var(--border);
          position: sticky; top: 0; background: rgba(13,13,15,0.85);
          backdrop-filter: blur(8px); z-index: 5;
          display: flex; align-items: center; gap: 12px; }
.globalsearch { flex: 1; min-width: 0; }
.globalsearch input { width: 100%; max-width: 560px; }
.content { padding: 24px 32px 60px; }
/* Lesbarkeitsbegrenzung nur für textlastige Seiten (opt-in via block content_class). */
.content.content-narrow { max-width: 1180px; }

/* Mobile nav controls — hidden on desktop, shown in the mobile media query. */
.nav-toggle { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.nav-burger, .nav-backdrop, .topbar-brand { display: none; }
.scroll-x { overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }

/* --- Typo --- */
h1 { font-size: 22px; font-weight: 600; margin: 0 0 18px; letter-spacing: -0.2px; }
h1.inline { display: inline; margin: 0; }
h2 { font-size: 15px; font-weight: 600; margin: 0 0 14px;
     letter-spacing: 0.2px; }
h3 { font-size: 12px; font-weight: 600; text-transform: uppercase;
     letter-spacing: 1px; color: var(--muted); margin: 18px 0 8px; }
.muted { color: var(--muted); }
.strong { font-weight: 500; }
.nowrap { white-space: nowrap; }
.hint { font-weight: 400; color: var(--muted); font-size: 12px; }
.r { text-align: right; }

/* --- Cards / grid --- */
.card { background: var(--surface); border: 1px solid var(--border-soft);
        border-radius: var(--radius); padding: 18px 20px; margin-bottom: 18px; }
.cols { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 1000px) { .cols { grid-template-columns: minmax(0,1.6fr) minmax(0,1fr); } }
.col-main, .col-side { min-width: 0; }

.grid { display: grid; gap: 12px; }
.grid-stats { grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)); }
.grid-stats.secondary { margin-top: 12px; opacity: 0.92; }
.stat { display: flex; flex-direction: column; gap: 3px; padding: 16px 18px;
        margin: 0; border-left: 3px solid var(--border); }
.stat-n { font-size: 26px; font-weight: 600; font-variant-numeric: tabular-nums; }
.stat-l { font-size: 12.5px; color: var(--muted); }
.stat-indicator { border-left-color: var(--ind); }
.stat-person { border-left-color: var(--per); }
.stat-organization { border-left-color: var(--org); }
.stat-infrastructure { border-left-color: var(--inf); }
.stat-place { border-left-color: var(--plc); }

/* --- Badges / dots --- */
.badge { font-size: 11px; padding: 2px 7px; border-radius: 5px; font-weight: 500;
         letter-spacing: 0.2px; white-space: nowrap; }
.badge-indicator { background: rgba(232,93,4,0.16); color: #f7a35a; }
.badge-person { background: rgba(74,130,191,0.16); color: #8fc0f5; }
.badge-organization { background: rgba(207,58,68,0.16); color: #f08891; }
.badge-infrastructure { background: rgba(123,135,148,0.18); color: #b6c0cb; }
.badge-place { background: rgba(42,157,143,0.16); color: #6fd3c4; }
.dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%;
       margin-right: 7px; vertical-align: middle; }
.dot-indicator { background: var(--ind); } .dot-person { background: var(--per); }
.dot-organization { background: var(--org); } .dot-infrastructure { background: var(--inf); }
.dot-place { background: var(--plc); }

/* --- TLP --- */
.tlp { font-size: 10.5px; font-weight: 600; padding: 2px 6px; border-radius: 4px;
       letter-spacing: 0.4px; }
.tlp-clear { background: #2a2a31; color: #c8c8d0; }
.tlp-green { background: rgba(76,174,76,0.18); color: #6cd06c; }
.tlp-amber { background: rgba(224,168,46,0.18); color: #edbf57; }
.tlp-amber-strict { background: rgba(217,131,36,0.2); color: #f0a44a; }
.tlp-red { background: rgba(215,38,61,0.2); color: #f0697c; }

.status { font-size: 11px; padding: 2px 8px; border-radius: 10px; font-weight: 500; }
.status-open { background: rgba(232,93,4,0.16); color: #f7a35a; }
.status-monitoring { background: rgba(74,130,191,0.16); color: #8fc0f5; }
.status-closed { background: var(--surface-3); color: var(--muted); }
.adm { font-family: var(--mono); background: var(--surface-2); padding: 1px 6px;
       border-radius: 4px; }

/* --- Tables --- */
table.data { width: 100%; border-collapse: collapse; }
table.data th { text-align: left; font-size: 11px; text-transform: uppercase;
                letter-spacing: 0.8px; color: var(--muted); font-weight: 500;
                padding: 6px 10px; border-bottom: 1px solid var(--border); }
table.data td { padding: 9px 10px; border-bottom: 1px solid var(--border-soft);
                vertical-align: middle; }
table.data tbody tr { cursor: default; }
table.data tr[onclick] { cursor: pointer; }
table.data tr[onclick]:hover td { background: var(--surface-2); }
table.compact td { padding: 6px 8px; }

ul.tight { list-style: none; margin: 0; padding: 0; }
ul.tight li { display: flex; align-items: center; gap: 8px; padding: 5px 0;
              border-bottom: 1px solid var(--border-soft); flex-wrap: wrap; }
ul.tight li:last-child { border-bottom: 0; }
ul.tight time { margin-left: auto; color: var(--muted); font-size: 12px; }
.via { color: var(--muted); font-size: 11.5px; margin-left: auto; }
.empty { color: var(--muted); font-size: 13px; padding: 6px 0; }

/* --- Forms --- */
.head-row { display: flex; justify-content: space-between; align-items: flex-start;
            gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.head-actions { display: flex; gap: 8px; align-items: center; }
.head-actions form { display: inline; }
.filters { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.tags-filter { margin-bottom: 16px; }
.pill { font-size: 12.5px; padding: 5px 12px; border-radius: 20px;
        background: var(--surface-2); color: var(--text-2); }
.pill:hover { background: var(--surface-3); }
.pill.on { background: var(--primary); color: #fff; }

input, select, textarea {
  background: var(--surface-2); border: 1px solid var(--border);
  color: var(--text); border-radius: 7px; padding: 8px 11px;
  font-family: var(--sans); font-size: 13.5px; outline: none;
}
input:focus, select:focus, textarea:focus { border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(232,93,4,0.16); }
textarea { resize: vertical; font-family: var(--mono); font-size: 13px; }
.form { display: flex; flex-direction: column; gap: 13px; }
.form label { display: flex; flex-direction: column; gap: 5px; font-size: 12.5px;
              color: var(--text-2); }
.form label.check { flex-direction: row; align-items: center; gap: 8px; }
.form label.check input { width: auto; }
.inline-form { flex-direction: row; flex-wrap: wrap; align-items: center; }
.inline-form input, .inline-form select { flex: 1; min-width: 140px; }
.form-actions { display: flex; gap: 10px; margin-top: 4px; }

.btn { background: var(--surface-3); color: var(--text); border: 1px solid var(--border);
       padding: 8px 16px; border-radius: 7px; font-size: 13px; cursor: pointer;
       font-family: var(--sans); }
.btn:hover { background: #2e2e35; }
.btn-primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-hover); }
.btn-ghost { background: transparent; }
.btn-danger { background: transparent; border-color: rgba(215,38,61,0.5); color: #f0697c; }
.btn-danger:hover { background: rgba(215,38,61,0.14); }
.btn-sm { padding: 5px 10px; font-size: 12px; }

.fields { display: grid; grid-template-columns: minmax(110px,150px) 1fr;
          gap: 7px 16px; margin: 0; }
.fields dt { color: var(--muted); font-size: 12.5px; }
.fields dd { margin: 0; word-break: break-word; }
.desc { margin: 14px 0 0; color: var(--text-2); border-top: 1px solid var(--border-soft);
        padding-top: 12px; }

/* --- Relationship / pivot widgets --- */
.tags-row { display: flex; flex-wrap: wrap; gap: 7px; align-items: center;
            margin: -6px 0 18px; }
.tag { display: inline-flex; align-items: center; gap: 4px; font-size: 12px;
       background: var(--surface-2); border: 1px solid var(--border);
       padding: 3px 9px; border-radius: 14px; color: var(--text-2); }
.inline-x { display: inline; }
.inline-x button { background: none; border: 0; color: var(--muted); cursor: pointer;
                   font-size: 14px; padding: 0 2px; line-height: 1; }
.inline-x button:hover { color: #f0697c; }
.inline-add { display: flex; gap: 6px; align-items: center; margin-top: 8px; }
.inline-add input, .inline-add select { padding: 5px 9px; font-size: 12.5px; }

.rel-add, .sighting-add { display: flex; gap: 8px; flex-wrap: wrap;
  align-items: center; margin-bottom: 14px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border-soft); }
.rel-add select, .sighting-add select, .sighting-add input { padding: 6px 9px; font-size: 12.5px; }
.picker { position: relative; flex: 1; min-width: 180px; }
.picker input { width: 100%; }
.picker-results { position: absolute; top: 100%; left: 0; right: 0; z-index: 20;
  background: var(--surface-3); border: 1px solid var(--border); border-radius: 7px;
  margin-top: 3px; overflow: hidden; max-height: 240px; overflow-y: auto; }
.picker-item { padding: 7px 11px; cursor: pointer; font-size: 13px; }
.picker-item:hover { background: var(--primary); color: #fff; }

.pivot h3:first-of-type { margin-top: 0; }
.pivot-shared li { gap: 8px; }
.inline-edge { margin-left: 6px; }
.inline-edge button { background: var(--surface-3); border: 1px solid var(--border);
  color: var(--accent-soft); font-size: 11px; padding: 2px 7px; border-radius: 5px;
  cursor: pointer; }
.inline-edge button:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

/* --- Path --- */
.path-form { display: flex; gap: 10px; align-items: flex-start; flex-wrap: wrap; }
.path-form .arrow { padding-top: 9px; color: var(--muted); }
.path { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 16px;
        padding: 14px; background: var(--surface-2); border-radius: 8px; }
.path-node { background: var(--surface-3); border: 1px solid var(--border);
  padding: 6px 12px; border-radius: 7px; font-size: 13px; }
.path-node:hover { border-color: var(--accent); }
.path-edge { color: var(--accent-soft); font-size: 11.5px; font-family: var(--mono); }

/* --- Recon-Graph --- */
.graph-wrap { display: flex; flex-direction: column; gap: 10px; }
.graph-bar { display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap; }
.graph-filters { display: flex; gap: 4px; flex-wrap: wrap; }
.gf { display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px;
  color: var(--text-2); background: var(--surface-2); border: 1px solid var(--border);
  padding: 4px 10px; border-radius: 20px; cursor: pointer; user-select: none; }
.gf input { width: auto; margin: 0; accent-color: var(--accent); }
.gf:hover { background: var(--surface-3); }
.graph-controls { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.graph-controls select, .graph-controls input { padding: 6px 9px; font-size: 12.5px; }
#graphSearch { min-width: 180px; }

.graph-stage { position: relative; height: calc(100vh - 230px); min-height: 420px;
  background: radial-gradient(circle at 50% 40%, #131318 0%, #0c0c0e 100%);
  border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.graph-stage canvas { display: block; cursor: grab; touch-action: none; }
.graph-stage canvas:active { cursor: grabbing; }

.graph-tooltip { position: absolute; z-index: 8; pointer-events: none;
  background: rgba(20,20,24,0.96); border: 1px solid var(--border); border-radius: 8px;
  padding: 8px 11px; font-size: 12.5px; max-width: 260px; box-shadow: 0 6px 22px rgba(0,0,0,0.5); }
.graph-tooltip .gt-val { font-family: var(--mono); font-size: 11.5px; color: var(--accent-soft);
  margin-top: 3px; word-break: break-all; }
.graph-tooltip .gt-deg { color: var(--muted); font-size: 11.5px; margin-top: 3px; }
/* On touch the tooltip is a tappable info card (with an Open link), so it needs pointer events. */
.graph-tooltip.touch { pointer-events: auto; }
.graph-tooltip .gt-open { display: inline-block; margin-top: 8px; font-size: 12px;
  font-weight: 600; color: #fff; background: var(--primary); border-radius: 6px; padding: 5px 11px; }
.graph-tooltip .gt-open:hover { background: var(--primary-hover); }

.graph-meta { position: absolute; left: 12px; bottom: 10px; font-size: 11.5px;
  color: var(--muted); background: rgba(13,13,15,0.6); padding: 3px 9px; border-radius: 6px; }
.graph-empty { position: absolute; inset: 0; display: flex; align-items: center;
  justify-content: center; text-align: center; padding: 0 40px; color: var(--muted);
  pointer-events: none; }
.graph-empty[hidden], .graph-tooltip[hidden] { display: none; }

.graph-results { position: absolute; z-index: 9; top: 100%; left: 0; right: 0;
  background: var(--surface-3); border: 1px solid var(--border); border-radius: 7px;
  margin-top: 3px; overflow: hidden; max-height: 240px; overflow-y: auto; }
.graph-results .picker-item { display: flex; align-items: center; gap: 7px; }
.graph-search-box { position: relative; }
.graph-help { margin: 0; }

/* Selection / pivot panel */
.graph-panel { position: absolute; z-index: 9; min-width: 176px; max-width: 240px;
  background: rgba(20,20,24,0.97); border: 1px solid var(--border); border-radius: 9px;
  padding: 10px 12px; box-shadow: 0 8px 26px rgba(0,0,0,0.55); }
.graph-panel[hidden] { display: none; }
.graph-panel .gp-head { display: flex; align-items: center; gap: 7px; font-size: 13px; }
.graph-panel .gp-sub { font-family: var(--mono); font-size: 11.5px; color: var(--accent-soft);
  margin-top: 3px; word-break: break-all; }
.graph-panel .gp-deg { color: var(--muted); font-size: 11.5px; margin-top: 3px; }
.graph-panel .gp-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.graph-panel .gp-actions button { font: inherit; font-size: 12px; padding: 4px 9px;
  border: 1px solid var(--border); background: var(--surface-2); color: var(--text-2);
  border-radius: 6px; cursor: pointer; }
.graph-panel .gp-actions button:hover:not([disabled]) { background: var(--surface-3); color: var(--text); }
.graph-panel .gp-actions button[disabled] { opacity: 0.55; cursor: default; }

.graph-truncate { position: absolute; left: 12px; top: 12px; z-index: 7; max-width: 60%;
  font-size: 11.5px; color: var(--accent-soft); background: rgba(30,18,8,0.82);
  border: 1px solid rgba(232,93,4,0.35); padding: 5px 10px; border-radius: 6px; }
.graph-truncate[hidden] { display: none; }
.graph-loading { position: absolute; right: 12px; top: 12px; z-index: 7; font-size: 11.5px;
  color: var(--text-2); background: rgba(13,13,15,0.75); padding: 4px 10px; border-radius: 6px; }
.graph-loading[hidden] { display: none; }

/* Search filter bar */
.search-filters { display: flex; flex-direction: column; gap: 11px; }
.search-filters .sf-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.search-filters .sf-filters { gap: 7px; }
.search-filters input, .search-filters select {
  padding: 7px 9px; font-size: 13px; background: var(--surface-2);
  border: 1px solid var(--border); border-radius: 7px; color: var(--text); }
.search-filters input:focus, .search-filters select:focus {
  outline: none; border-color: var(--accent); }
.search-filters .sf-q { flex: 1 1 300px; }
.search-filters .sf-filters select { flex: 1 1 130px; min-width: 120px; }

.import-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.known { color: var(--blue-soft); font-size: 12px; }
.new { color: var(--accent-soft); font-size: 12px; }

/* --- Import: tabs + bulk preview --- */
.tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.warn { color: var(--accent-soft); font-size: 12px; }
.err-count { color: var(--primary-hover); font-size: 12px; font-weight: 600; }
tr.row-bad td { background: color-mix(in srgb, var(--primary) 9%, transparent); }
tr.row-note td { border-bottom: 1px solid var(--border-soft);
  padding-top: 0; padding-bottom: 8px; }

/* --- Person dossier: linked records + identity documents --- */
.link-add { display: flex; gap: 7px; flex-wrap: wrap; align-items: center; margin-bottom: 14px; }
.link-add input:not([type=checkbox]), .link-add select { padding: 6px 8px; }
.link-add input[name=value] { flex: 1 1 160px; }
.link-list { margin: 4px 0 14px; }
.link-list li { display: flex; align-items: center; gap: 7px; }
.link-list li.former { opacity: 0.6; }
.link-list li.former a { text-decoration: line-through; }
.link-list .mini { color: var(--muted); font-size: 13px; margin-left: 2px; }
.link-list .mini:hover { color: var(--accent); }

.iddoc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.iddoc-add { margin-bottom: 14px; }
.iddoc-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; }
.iddoc { display: flex; gap: 12px; margin: 0; padding: 10px; border: 1px solid var(--border-soft);
  border-radius: var(--radius); background: var(--surface-2); }
.iddoc img { width: 96px; height: 66px; object-fit: cover; border-radius: 6px;
  border: 1px solid var(--border); background: #000; flex: 0 0 auto; }
.iddoc-noimg { width: 96px; height: 66px; display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--muted); border: 1px dashed var(--border); border-radius: 6px; flex: 0 0 auto; }
.iddoc figcaption { display: flex; flex-direction: column; gap: 3px; min-width: 0; position: relative; }
.iddoc .mrz code { word-break: break-all; font-size: 11px; }
.iddoc .inline-x { position: absolute; top: 0; right: 0; }
.iddoc.former { opacity: 0.62; }
.iddoc-foot { display: flex; gap: 8px; align-items: center; margin-top: 8px; flex-wrap: wrap; }
.iddoc-foot input[name=notes] { flex: 1 1 200px; padding: 6px 8px; }
.iddoc-links { display: flex; gap: 10px; font-size: 12px; margin-top: 2px; }
.iddoc-links a { color: var(--muted); }
.iddoc-links a:hover { color: var(--accent); }
@media (max-width: 640px) { .iddoc-grid { grid-template-columns: 1fr; } }

/* document entity type colours */
.badge-document { background: rgba(124,131,196,0.16); color: #a9adde; }
.dot-document { background: #7c83c4; }
.chip-document { border-left-color: #7c83c4; }
.avatar-ph.badge-document { background: #7c83c4; color: #fff; }

/* --- Dossier: avatar, flags, gallery, documents --- */
.dossier-head { align-items: center; }
.dossier-id { display: flex; gap: 16px; align-items: center; min-width: 0; }
.avatar { width: 74px; height: 74px; border-radius: 12px; object-fit: cover;
  border: 1px solid var(--border); background: var(--surface-2); flex: 0 0 auto; }
.avatar-ph { display: flex; align-items: center; justify-content: center;
  font-size: 31px; font-weight: 600; }
.avatar-ph.badge-indicator { background: var(--ind); color: #1a1205; }
.avatar-ph.badge-person { background: var(--per); color: #fff; }
.avatar-ph.badge-organization { background: var(--org); color: #fff; }
.avatar-ph.badge-infrastructure { background: var(--inf); color: #fff; }
.avatar-ph.badge-place { background: var(--plc); color: #fff; }
.id-line { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; margin-bottom: 4px; }
.id-sub { margin-top: 2px; }

.flag { font-size: 10.5px; font-weight: 600; letter-spacing: 0.4px; text-transform: uppercase;
  padding: 2px 7px; border-radius: 5px; background: var(--surface-3); color: var(--text-2); }
.flag-wanted, .flag-suspect, .flag-seized, .flag-takedown,
.flag-threat-critical { background: rgba(215,38,61,0.2); color: #f0697c; }
.flag-person_of_interest, .flag-monitored, .flag-sinkholed,
.flag-threat-high { background: rgba(232,93,4,0.18); color: #f7a35a; }
.flag-threat-medium { background: rgba(224,168,46,0.18); color: #edbf57; }
.flag-cleared, .flag-active { background: rgba(76,174,76,0.18); color: #6cd06c; }
.flag-defunct, .flag-deceased, .flag-retired, .flag-closed, .flag-deleted,
.flag-inactive, .flag-dormant { background: rgba(120,120,135,0.18); color: #a7a7b0; }

tr.row-defunct td { opacity: 0.5; }
tr.row-defunct .strong { text-decoration: line-through; text-decoration-color: rgba(167,167,176,0.6); }
hr.soft { border: none; border-top: 1px solid var(--border-soft); margin: 12px 0; }

.fields dd { white-space: pre-wrap; }

.upload-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--border-soft); }
.upload-row input[type=file] { font-size: 12.5px; padding: 6px; }
.upload-row input[name=caption] { flex: 1; min-width: 160px; }

.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(146px, 1fr)); gap: 12px; }
.shot { position: relative; margin: 0; border: 1px solid var(--border); border-radius: 9px;
  overflow: hidden; background: var(--surface-2); }
.shot.is-avatar { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.shot img { display: block; width: 100%; height: 132px; object-fit: cover; }
.shot figcaption { font-size: 11.5px; color: var(--text-2); padding: 6px 8px; }
.shot-tag { position: absolute; top: 6px; left: 6px; background: var(--accent); color: #fff;
  font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 6px; border-radius: 4px; }
.shot-actions { position: absolute; top: 6px; right: 6px; display: flex; gap: 4px;
  opacity: 0; transition: opacity 0.12s; }
.shot:hover .shot-actions { opacity: 1; }
.shot-actions form { margin: 0; }
.shot-actions button { background: rgba(13,13,15,0.82); border: 1px solid var(--border);
  color: var(--text); border-radius: 5px; font-size: 13px; line-height: 1; padding: 4px 7px;
  cursor: pointer; }
.shot-actions button:hover { background: var(--primary); border-color: var(--primary); color: #fff; }

.thumb { width: 26px; height: 26px; border-radius: 6px; object-fit: cover; vertical-align: middle;
  margin-right: 9px; border: 1px solid var(--border); background: var(--surface-2); }
.thumb-ph { display: inline-flex; align-items: center; justify-content: center; }
.thumb-ph .dot { margin: 0; }

/* ===========================================================================
   RESPONSIVE — tablet / mobile
   =========================================================================== */

/* Medium screens: tighten the desktop sidebar a touch. */
@media (max-width: 1080px) {
  .layout { grid-template-columns: 200px 1fr; }
  .content { padding: 22px 20px 56px; }
}

/* Mobile / small tablet: sidebar becomes an off-canvas drawer (CSS-only). */
@media (max-width: 860px) {
  .layout { grid-template-columns: 1fr; }

  .rail {
    position: fixed; top: 0; left: 0; bottom: 0; width: 256px; max-width: 84vw;
    height: 100vh; z-index: 60; transform: translateX(-100%);
    transition: transform .22s ease; will-change: transform;
  }
  .nav-toggle:checked ~ .layout .rail {
    transform: translateX(0); box-shadow: 0 0 46px rgba(0,0,0,0.6);
  }

  .nav-backdrop { display: block; position: fixed; inset: 0; z-index: 55;
    background: rgba(0,0,0,0.55); opacity: 0; pointer-events: none;
    transition: opacity .2s; }
  .nav-toggle:checked ~ .layout .nav-backdrop { opacity: 1; pointer-events: auto; }

  /* Topbar: burger + compact brand, then search. */
  .topbar { padding: 11px 16px; gap: 10px; }
  .nav-burger { display: flex; flex-direction: column; justify-content: center;
    gap: 4px; width: 38px; height: 34px; padding: 7px 8px; cursor: pointer;
    border: 1px solid var(--border); border-radius: 8px; background: var(--surface-2);
    flex: 0 0 auto; }
  .nav-burger span { display: block; height: 2px; border-radius: 2px;
    background: var(--text-2); transition: background .15s; }
  .nav-burger:hover span { background: var(--accent); }
  /* Keep the burger + search in the topbar; brand stays in the drawer. */
  .globalsearch input { font-size: 16px; }   /* 16px avoids iOS zoom-on-focus */

  .content { padding: 18px 14px 56px; }
  h1, .hud-title { font-size: 19px; }
  /* 16px inputs prevent iOS Safari from zooming on focus + give bigger tap targets. */
  input, select, textarea { font-size: 16px; padding: 10px 12px; }

  /* HUD stacks. */
  .hud { align-items: flex-start; gap: 12px; }
  .hud-status { width: 100%; }

  /* Stat grids: 2-up instead of squeezing. */
  .grid-stats { grid-template-columns: repeat(2, minmax(0,1fr)); }

  /* Multi-column layouts collapse to one column. */
  .cols, .dash-cols { grid-template-columns: 1fr; }
  .fields { grid-template-columns: 1fr; gap: 2px 0; }
  .fields dt { margin-top: 8px; }

  /* Forms / rows wrap fully. */
  .inline-form, .rel-add, .sighting-add, .upload-row, .path-form,
  .head-row, .head-actions, .filters { flex-direction: column; align-items: stretch; }
  .head-actions form, .head-actions .btn { width: 100%; }
  .picker { min-width: 0; }

  /* Graph: shorter stage, controls that don't crush the select/search. */
  .graph-bar { flex-direction: column; align-items: stretch; }
  .graph-controls { width: 100%; flex-wrap: wrap; gap: 8px; }
  .graph-controls select { flex: 1 1 130px; min-width: 120px; }
  .graph-search-box { flex: 1 1 170px; min-width: 0; }
  #graphSearch { width: 100%; min-width: 0; }
  .graph-controls .btn { flex: 0 0 auto; }
  .graph-stage { height: 64vh; min-height: 340px; }

  /* API reference: scope tag drops under the signature instead of pushing out. */
  .api-scope { margin-left: 0; }

  /* Login card breathes on small screens. */
  .login-card { width: 100%; }
}

@media (max-width: 460px) {
  .grid-stats { grid-template-columns: 1fr 1fr; }
  .login-card { padding: 22px 18px; }
}

/* ===========================================================================
   RECON THEME — tactical polish (global) + auth / account / login
   =========================================================================== */

/* Subtle tactical grid + vignette behind the whole app. */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(rgba(232,93,4,0.022) 1px, transparent 1px) 0 0 / 100% 34px,
    linear-gradient(90deg, rgba(232,93,4,0.022) 1px, transparent 1px) 0 0 / 34px 100%,
    radial-gradient(ellipse at 50% -8%, rgba(178,30,43,0.10), transparent 60%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 28%, #000 55%, transparent 100%);
          mask-image: radial-gradient(ellipse at 50% 28%, #000 55%, transparent 100%);
}
.layout { position: relative; z-index: 1; }

/* Cards: positioned (for accents) + a faint top scan-line; hairline lifts on hover. */
.card { position: relative; }
.card::after { content: ""; position: absolute; top: 0; left: 14px; right: 14px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(232,93,4,0.55), transparent); }
.card:hover { border-color: var(--border); }

/* Section headers → recon tick + hairline + tracked uppercase. */
.card > h2 { display: flex; align-items: center; gap: 9px; padding-bottom: 11px;
  margin-bottom: 15px; border-bottom: 1px solid var(--border-soft);
  text-transform: uppercase; letter-spacing: 1.4px; font-size: 12.5px; }
.card > h2::before { content: ""; width: 8px; height: 8px; border-radius: 2px;
  background: var(--accent); box-shadow: 0 0 9px rgba(232,93,4,0.75); flex: 0 0 auto; }

/* Terminal-style code blocks (curl example, key reveal, etc.). */
pre { background: #08080a; border: 1px solid var(--border); border-radius: 8px;
  padding: 27px 14px 13px; margin: 4px 0 10px; overflow-x: auto; position: relative;
  font-family: var(--mono); font-size: 12.5px; line-height: 1.55; color: var(--text-2); }
pre::before { content: "● ● ●"; position: absolute; top: 8px; left: 13px;
  font-size: 7px; letter-spacing: 4px; color: #3a3a42; }
pre code { background: none; padding: 0; color: var(--accent-soft); }

/* Flashes → left status bar, tinted. */
.flash { position: relative; padding: 11px 14px 11px 17px; border-radius: 8px;
  margin-bottom: 16px; border: 1px solid var(--border); background: var(--surface-2);
  font-size: 13px; }
.flash::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  border-radius: 3px 0 0 3px; }
.flash-error { border-color: rgba(215,38,61,0.4); }
.flash-error::before { background: #f0697c; }
.flash-ok { border-color: rgba(76,174,76,0.4); }
.flash-ok::before { background: #6cd06c; }

/* Login screen. */
.login-body { display: flex; min-height: 100vh; align-items: center; justify-content: center;
  padding: 24px; background: radial-gradient(circle at 50% 36%, #15151a 0%, #09090b 72%); }
.login-card { width: 364px; max-width: 92vw; padding: 27px 27px 24px;
  box-shadow: 0 26px 70px rgba(0,0,0,0.6), 0 0 0 1px rgba(232,93,4,0.05); }
.login-brand { display: flex; align-items: center; gap: 11px; font-weight: 700;
  letter-spacing: 0.3em; font-size: 17px; }
.login-tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--muted); margin: 6px 0 20px; }
.login-tag b { color: var(--accent-soft); font-weight: 600; }

/* Rail user block. */
.rail-user { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 9px; }
.rail-user .who { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.rail-user .who .dot { width: 7px; height: 7px; margin: 0; background: #6cd06c;
  box-shadow: 0 0 7px rgba(108,208,108,0.85); }
.rail-user .who code { background: none; padding: 0; color: var(--text); }

/* API keys: reveal + scope toggles. */
.apikey-reveal { user-select: all; }
.apikey-reveal code { color: #6cd06c; font-size: 13px; word-break: break-all; }
.scopes-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 2px 0; }
.scope-toggle { display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 20px;
  padding: 5px 13px; font-size: 12px; font-family: var(--mono); color: var(--text-2);
  text-transform: uppercase; letter-spacing: 0.6px; user-select: none; }
.scope-toggle input { width: auto; margin: 0; accent-color: var(--accent); }
.scope-toggle:hover { background: var(--surface-3); border-color: var(--accent); }
.scope-tag { font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--accent-soft); }

/* ===========================================================================
   DASHBOARD HUD + API REFERENCE
   =========================================================================== */

/* HUD header */
.hud { display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap; margin-bottom: 22px; }
.hud-title { margin: 0; }
.hud-sub { font-family: var(--mono); font-size: 12px; color: var(--muted);
  letter-spacing: 0.4px; margin-top: 5px; }
.hud-sub b { color: var(--accent-soft); }
.hud-status { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.hud-chip { display: inline-flex; align-items: center; gap: 7px; font-size: 12px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 20px;
  padding: 5px 12px; color: var(--text-2); }
.hud-chip.mono { font-family: var(--mono); letter-spacing: 0.4px; }
.hud-chip .hud-k { color: var(--muted); font-size: 10.5px; letter-spacing: 1px; }
.hud-chip .dot { margin: 0; }
.dot-live { width: 7px; height: 7px; background: #6cd06c;
  box-shadow: 0 0 7px rgba(108,208,108,0.85); animation: pulse 2.4s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Stat cards: label on top, dot accent, big tabular number */
.stat-top { display: flex; align-items: center; gap: 7px; }
.stat-top .dot { margin: 0; }
.stat-go { font-size: 13px; color: var(--accent-soft); font-family: var(--mono);
  margin-top: 6px; }
a.card.stat { transition: border-color .12s, transform .12s; }
a.card.stat:hover { border-color: var(--accent); transform: translateY(-1px); }

/* Three-column dashboard layout */
.dash-cols { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 880px)  { .dash-cols { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1240px) { .dash-cols { grid-template-columns: repeat(3, minmax(0,1fr)); } }

/* --- Command Center dashboard --- */
.kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
  gap: 10px; margin-bottom: 18px; }
.kpi-row.inline { margin: 4px 0 12px; grid-template-columns: repeat(3, 1fr); }
.kpi { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--radius);
  padding: 12px 13px; display: flex; flex-direction: column; gap: 4px; }
.kpi-n { font-size: 24px; font-weight: 600; font-variant-numeric: tabular-nums; }
.kpi-l { font-size: 11.5px; color: var(--muted); display: flex; align-items: center; gap: 6px; }

.cmd-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 900px)  { .cmd-grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (min-width: 1340px) { .cmd-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }

.barlist { display: flex; flex-direction: column; gap: 8px; }
.bar-row { display: grid; grid-template-columns: 40% 1fr auto; align-items: center; gap: 10px;
  color: var(--text); font-size: 12.5px; }
.bar-row:hover .bar-label { color: var(--accent-soft); }
.bar-label { display: flex; align-items: center; gap: 6px; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bar-track { height: 8px; background: var(--surface-2); border-radius: 5px; overflow: hidden; }
.bar-fill { display: block; height: 100%; border-radius: 5px; min-width: 2px; background: var(--accent); }
.bar-val { font-variant-numeric: tabular-nums; color: var(--text-2); font-size: 12px; }
.fill-edge { background: var(--accent); }
.fill-indicator { background: #e85d04; } .fill-person { background: #4a82bf; }
.fill-organization { background: #cf3a44; } .fill-infrastructure { background: #7b8794; }
.fill-place { background: #2a9d8f; } .fill-area { background: #b06cd0; }
.fill-asset { background: #d9a441; } .fill-account { background: #d96c9e; }
.fill-financial_account { background: #46a06b; } .fill-webcam { background: #3fb6c0; }
.fill-document { background: #7c83c4; }

.spark { display: flex; align-items: flex-end; gap: 2px; height: 90px; margin-top: 4px; }
.spark-col { flex: 1; height: 100%; display: flex; align-items: flex-end; }
.spark-bar { width: 100%; min-height: 2px; background: linear-gradient(var(--accent), var(--primary));
  border-radius: 2px 2px 0 0; transition: opacity .1s; }
.spark-col:hover .spark-bar { opacity: 0.7; }
.spark-axis { display: flex; justify-content: space-between; font-size: 10.5px;
  color: var(--muted); margin-top: 5px; font-family: var(--mono); }
.spark-col.is-today .spark-bar { background: linear-gradient(#f7a35a, var(--accent)); box-shadow: 0 0 8px rgba(232,93,4,0.5); }

/* Full-bleed page (dashboards/consoles use the whole width) */
.content-full { max-width: none; }

/* Hero KPI band */
.kpi-hero { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px; margin-bottom: 14px; }
.hcard { position: relative; display: block; color: var(--text);
  background: linear-gradient(155deg, var(--surface) 0%, var(--surface-2) 120%);
  border: 1px solid var(--border-soft); border-radius: 13px; padding: 16px 18px 15px;
  overflow: hidden; transition: border-color .12s, transform .12s; }
.hcard:hover { border-color: var(--border); transform: translateY(-2px); }
.hcard::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent); }
.hcard::after { content: ""; position: absolute; right: -40px; top: -40px; width: 120px;
  height: 120px; border-radius: 50%; background: radial-gradient(circle, rgba(232,93,4,0.10), transparent 70%); }
.hcard.tone-blue::before { background: var(--blue-soft); }
.hcard.tone-blue::after { background: radial-gradient(circle, rgba(74,130,191,0.12), transparent 70%); }
.hcard.tone-ind::before { background: var(--accent-soft); }
.hcard.tone-org::before { background: var(--org); }
.hcard.tone-org::after { background: radial-gradient(circle, rgba(207,58,68,0.12), transparent 70%); }
.hcard-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.hcard-l { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.7px; }
.hcard-n { font-size: 42px; font-weight: 700; font-variant-numeric: tabular-nums;
  line-height: 1.05; margin-top: 8px; letter-spacing: -0.5px; }
.hcard-sub { font-size: 11.5px; color: var(--text-2); margin-top: 5px; }
.delta { font-size: 10.5px; font-weight: 600; padding: 2px 8px; border-radius: 20px; white-space: nowrap; }
.delta.up { background: rgba(76,174,76,0.16); color: #6cd06c; }

/* Threat posture bars */
.tl-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.tl-low { background: #6cd06c; } .tl-medium { background: #edbf57; }
.tl-high { background: #f7a35a; } .tl-critical { background: #f0697c; }
.tlbar-low { background: #4cae4c; } .tlbar-medium { background: #e0a82e; }
.tlbar-high { background: #e85d04; } .tlbar-critical { background: #d7263d; }

/* Latest-links feed */
.feed-links li { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ln-node { display: inline-flex; align-items: center; gap: 6px; }
.ln-node .dot { margin: 0; }
.ln-node:hover { color: var(--accent-soft); }
.ln-edge { font-family: var(--mono); font-size: 10.5px; text-transform: uppercase;
  letter-spacing: 0.6px; color: var(--accent-soft); background: var(--surface-2);
  border: 1px solid var(--border-soft); padding: 1px 7px; border-radius: 5px; }

/* --- API reference --------------------------------------------------------- */
.api-list { display: flex; flex-direction: column; }
.api-ep { padding: 16px 0; border-top: 1px solid var(--border-soft); }
.api-ep:first-child { padding-top: 2px; border-top: 0; }
.api-sig { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.api-path { font-size: 13.5px; color: var(--text); background: var(--surface-2);
  padding: 3px 9px; }
.api-scope { margin-left: auto; }
.api-desc { margin: 9px 0 0; color: var(--text-2); }
.api-block { margin-top: 12px; }
.api-h { display: block; font-size: 10.5px; text-transform: uppercase;
  letter-spacing: 1px; color: var(--muted); margin-bottom: 6px; }
.api-block pre { margin: 0; }
.api-params { width: auto; }
.api-params td { padding: 4px 14px 4px 0; border: 0; }

/* Method verbs */
.verb { font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.5px; padding: 3px 9px; border-radius: 6px; border: 1px solid transparent; }
.verb-get    { background: rgba(74,130,191,0.16);  color: #8fc0f5; border-color: rgba(74,130,191,0.35); }
.verb-post   { background: rgba(76,174,76,0.16);   color: #6cd06c; border-color: rgba(76,174,76,0.35); }
.verb-delete { background: rgba(215,38,61,0.18);   color: #f0697c; border-color: rgba(215,38,61,0.35); }
.verb-patch  { background: rgba(232,93,4,0.16);    color: #f7a35a; border-color: rgba(232,93,4,0.35); }
.verb-status { background: var(--surface-3); color: var(--text-2); }
.api-notes { display: grid; grid-template-columns: max-content 1fr; gap: 4px 14px;
  margin: 12px 0 0; font-size: 12.5px; }
.api-notes dt { font-weight: 600; color: var(--text-2); }
.api-notes dd { margin: 0; }
.api-nav { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }

/* ===========================================================================
   EVENTS / TIMELINE (Recon-Expansion P0)
   =========================================================================== */
.ev-type { font-family: var(--mono); font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.6px; color: var(--accent-soft);
  background: var(--surface-2); border: 1px solid var(--border-soft);
  border-left: 3px solid var(--accent); padding: 2px 8px; border-radius: 5px; }
.ev-flight        { border-left-color: var(--blue-soft); color: #8fc0f5; }
.ev-voyage        { border-left-color: var(--plc); color: #6fd3c4; }
.ev-trip          { border-left-color: var(--plc); }
.ev-meeting       { border-left-color: var(--per); color: #8fc0f5; }
.ev-transaction   { border-left-color: #6cd06c; color: #6cd06c; }
.ev-communication { border-left-color: var(--org); color: #f08891; }
.ev-capture       { border-left-color: var(--ind); }

/* Timeline list */
.tl { list-style: none; margin: 0; padding: 0; }
.tl-foot { display: flex; align-items: center; gap: 12px; justify-content: center;
  padding-top: 14px; margin-top: 4px; border-top: 1px solid var(--border-soft); }
.tl-foot #tlShown { font-family: var(--mono); }
.tl-item { display: flex; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--border-soft); }
.tl-item:last-child { border-bottom: 0; }
.tl-time { flex: 0 0 152px; }
.tl-date { font-family: var(--mono); font-size: 12px; color: var(--text-2); }
.tl-body { min-width: 0; flex: 1; }
.tl-head { display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.tl-title { font-weight: 500; }
.tl-title:hover { color: var(--accent-soft); }
.tl-meta { color: var(--muted); font-size: 12.5px; margin-top: 4px; }
.tl-parts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 7px; }
.tl-part { display: inline-flex; align-items: center; gap: 6px; font-size: 12px;
  background: var(--surface-2); border: 1px solid var(--border-soft);
  padding: 2px 8px; border-radius: 14px; color: var(--text-2); }
.tl-part:hover { border-color: var(--accent); color: var(--text); }
.tl-part .dot { margin: 0; }
.tl-role { font-family: var(--mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--muted); }

/* Event record form grid */
.ev-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; }
.ev-grid label { display: flex; flex-direction: column; gap: 5px; font-size: 12.5px; color: var(--text-2); }
.ev-wide { grid-column: 1 / -1; }
.ev-latlng { display: flex; gap: 6px; }
.ev-latlng input { width: 50%; }
@media (max-width: 860px) {
  .ev-grid { grid-template-columns: 1fr; }
  .tl-item { flex-direction: column; gap: 4px; }
  .tl-time { flex-basis: auto; }
}

/* --- Area entity (GEOINT P1) + Map view ------------------------------------ */
.badge-area { background: rgba(176,108,208,0.16); color: #d6a6ec; }
.dot-area { background: #b06cd0; }
.chip-area { border-left-color: #b06cd0; }
.stat-area { border-left-color: #b06cd0; }
.avatar-ph.badge-area { background: #b06cd0; color: #fff; }

.map-wrap { display: flex; flex-direction: column; gap: 10px; }
.map-stage { background: #0c0c0e; }
.map-stage canvas { display: block; cursor: grab; touch-action: none; }
.map-stage canvas:active { cursor: grabbing; }
.map-attrib { position: absolute; right: 8px; bottom: 7px; font-size: 10.5px;
  color: var(--muted); background: rgba(13,13,15,0.6); padding: 2px 7px; border-radius: 5px; }

/* --- Asset entity (Movement P3) -------------------------------------------- */
.badge-asset { background: rgba(217,164,65,0.16); color: #e6c074; }
.dot-asset { background: #d9a441; }
.chip-asset { border-left-color: #d9a441; }
.stat-asset { border-left-color: #d9a441; }
.avatar-ph.badge-asset { background: #d9a441; color: #2a1f06; }

/* --- Account / Persona entity (SOCMINT P4) --------------------------------- */
.badge-account { background: rgba(217,108,158,0.16); color: #e79cc0; }
.dot-account { background: #d96c9e; }
.chip-account { border-left-color: #d96c9e; }
.stat-account { border-left-color: #d96c9e; }
.avatar-ph.badge-account { background: #d96c9e; color: #fff; }

/* --- Financial account entity (FININT P5) ---------------------------------- */
.badge-financial_account { background: rgba(70,160,107,0.16); color: #7fd3a3; }
.dot-financial_account { background: #46a06b; }
.chip-financial_account { border-left-color: #46a06b; }
.stat-financial_account { border-left-color: #46a06b; }
.avatar-ph.badge-financial_account { background: #46a06b; color: #06210f; }

/* --- Map controls: layer filter + timeline (GEOINT) ------------------------ */
.map-controls { display: flex; justify-content: space-between; align-items: center;
  gap: 14px; flex-wrap: wrap; }
.map-layers { display: flex; gap: 6px; flex-wrap: wrap; }
.map-time { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 220px;
  justify-content: flex-end; }
.map-time #mapSlider { flex: 1; max-width: 360px; min-width: 120px; accent-color: var(--accent); }
#mapTimeLabel { font-family: var(--mono); min-width: 92px; text-align: right; }
@media (max-width: 860px) {
  .map-time { justify-content: flex-start; }
  .map-time #mapSlider { max-width: none; }
}

/* Map timeline: date endpoints + cursor + disabled state */
.map-date { font-size: 11px; color: var(--muted); white-space: nowrap; }
.map-date-in { font-family: var(--mono); font-size: 11.5px; color: var(--text);
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px;
  padding: 4px 6px; color-scheme: dark; width: 122px; }
.map-date-in:focus { outline: none; border-color: var(--accent); }
.map-cursor { font-family: var(--mono); font-size: 12px; color: var(--accent-soft);
  min-width: 84px; text-align: right; }
.map-time .btn:disabled, .map-time input:disabled { opacity: 0.4; cursor: not-allowed; }

/* Map cluster popup (list of co-located items) */
.graph-tooltip .gt-item { display: flex; align-items: center; gap: 7px; padding: 4px 2px;
  color: var(--text); border-top: 1px solid var(--border-soft); font-size: 12.5px; }
.graph-tooltip .gt-item:first-of-type { border-top: 0; }
.graph-tooltip .gt-item:hover { color: var(--accent-soft); }
.graph-tooltip .gt-item .dot { margin: 0; }

/* Compact, searchable popup when many entities share a location */
.graph-tooltip.map-popup { width: 264px; max-width: 78vw; padding: 0; }
.map-popup .mp-head { display: flex; justify-content: space-between; align-items: center;
  padding: 8px 11px 6px; font-size: 12.5px; }
.map-popup .mp-close { background: none; border: none; color: var(--muted); cursor: pointer;
  font-size: 14px; line-height: 1; padding: 0 2px; }
.map-popup .mp-close:hover { color: var(--text); }
.map-popup .mp-search { display: block; width: calc(100% - 22px); margin: 0 11px 7px;
  padding: 5px 8px; font-size: 12.5px; background: var(--surface-2);
  border: 1px solid var(--border); border-radius: 6px; color: var(--text); }
.map-popup .mp-search:focus { outline: none; border-color: var(--accent); }
.map-popup .mp-list { max-height: 240px; overflow-y: auto; padding: 0 11px 9px; }
.map-popup .mp-list .gt-item { padding: 5px 2px; }
.map-popup .mp-more, .map-popup .mp-empty { padding: 7px 2px 2px; color: var(--muted);
  font-size: 11.5px; }

/* --- Webcam entity (GEOINT/OSINT) ------------------------------------------ */
.badge-webcam { background: rgba(63,182,192,0.16); color: #7fd6dd; }
.dot-webcam { background: #3fb6c0; }
.chip-webcam { border-left-color: #3fb6c0; }
.stat-webcam { border-left-color: #3fb6c0; }
.avatar-ph.badge-webcam { background: #3fb6c0; color: #06211f; }
.webcam-embed { position: relative; width: 100%; padding-top: 56.25%; border-radius: 8px;
  overflow: hidden; border: 1px solid var(--border); background: #000; margin-bottom: 10px; }
.webcam-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.webcam-embed img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.webcam-embed video { position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; display: block; background: #000; }

/* Webcam live badge + error state (inline HLS player) */
.webcam-embed .live-badge { position: absolute; top: 10px; left: 10px; z-index: 2;
  font-family: var(--mono); font-size: 10px; letter-spacing: 1px; color: #fff;
  background: rgba(178,30,43,.85); padding: 2px 8px; border-radius: 5px; }
.webcam-embed.webcam-error::after { content: "Stream unavailable — open the source."; position: absolute;
  inset: 0; display: grid; place-items: center; color: var(--muted); padding: 16px; text-align: center; font-size: 13px; }
