/* ==========================================================================
   EviTrace — design system  (by Titanium Computing · evitrace.io)
   A forensic / e-discovery console. Dark steel-navy, brushed-metal surfaces,
   a single sharp amber accent (evidence seal / legal exhibit), editorial serif
   display + IBM Plex sans/mono for data. 100% local; fonts vendored offline.
   ========================================================================== */

/* ---- vendored fonts (no network at runtime) ---------------------------- */
@font-face{font-family:"Newsreader";font-style:normal;font-weight:500;font-display:swap;
  src:url("/static/fonts/newsreader-500.woff2") format("woff2");}
@font-face{font-family:"Newsreader";font-style:normal;font-weight:600;font-display:swap;
  src:url("/static/fonts/newsreader-600.woff2") format("woff2");}
@font-face{font-family:"Plex Sans";font-style:normal;font-weight:400;font-display:swap;
  src:url("/static/fonts/plexsans-400.woff2") format("woff2");}
@font-face{font-family:"Plex Sans";font-style:normal;font-weight:500;font-display:swap;
  src:url("/static/fonts/plexsans-500.woff2") format("woff2");}
@font-face{font-family:"Plex Sans";font-style:normal;font-weight:600;font-display:swap;
  src:url("/static/fonts/plexsans-600.woff2") format("woff2");}
@font-face{font-family:"Plex Mono";font-style:normal;font-weight:400;font-display:swap;
  src:url("/static/fonts/plexmono-400.woff2") format("woff2");}
@font-face{font-family:"Plex Mono";font-style:normal;font-weight:500;font-display:swap;
  src:url("/static/fonts/plexmono-500.woff2") format("woff2");}

:root{
  /* steel-navy surfaces, lowest → highest */
  --bg:#0a0e14;
  --bg-2:#0d1218;
  --surface:#121822;
  --surface-2:#18202c;
  --surface-3:#1f2937;
  --line:#222d3d;
  --line-2:#2c3a4e;

  /* ink */
  --ink:#e7edf5;
  --ink-2:#aeb9c9;
  --muted:#7b8798;
  --faint:#56616f;

  /* the one accent: forensic amber (legal seal / exhibit tab) */
  --accent:#e0a951;
  --accent-bright:#f2bd66;
  --accent-deep:#b07d2e;
  --accent-wash:rgba(224,169,81,.10);
  --accent-line:rgba(224,169,81,.32);

  /* semantic */
  --in:#5fb3c9;          /* inbound / received — cool */
  --in-wash:rgba(95,179,201,.12);
  --out:#6fbf8e;         /* outbound / sent — green */
  --out-wash:rgba(111,191,142,.12);
  --danger:#e0746a;      /* harassment / flag */
  --danger-wash:rgba(224,116,106,.12);
  --mca:#e0a951;
  --political:#9a86d6;
  --robocall:#c98bb0;

  --radius:10px;
  --radius-sm:7px;
  --radius-lg:16px;
  --shadow:0 1px 0 rgba(255,255,255,.025) inset, 0 8px 24px -12px rgba(0,0,0,.7);
  --shadow-lg:0 1px 0 rgba(255,255,255,.03) inset, 0 24px 60px -24px rgba(0,0,0,.85);

  --maxw:1320px;
  --sans:"Plex Sans",ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --serif:"Newsreader",Georgia,"Times New Roman",serif;
  --mono:"Plex Mono",ui-monospace,"SF Mono",Menlo,monospace;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:var(--sans);font-size:14px;line-height:1.55;
  letter-spacing:.005em;
  /* faint grain + diagonal steel sheen for depth, not flatness */
  background-image:
    radial-gradient(1200px 600px at 88% -10%, rgba(224,169,81,.045), transparent 60%),
    radial-gradient(900px 500px at -5% 0%, rgba(95,179,201,.05), transparent 55%),
    linear-gradient(180deg,#0b0f16 0%, var(--bg) 40%);
  background-attachment:fixed;
  min-height:100vh;
}
::selection{background:var(--accent-line);color:#fff}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent-bright)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.01em;line-height:1.15;margin:0}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* scrollbars */
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;border:3px solid var(--bg)}
*::-webkit-scrollbar-thumb:hover{background:#3a4a60}

/* ==========================================================================
   App chrome — masthead + rail
   ========================================================================== */
.masthead{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg, rgba(13,18,24,.96), rgba(10,14,20,.92));
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line);
}
.masthead::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent-line) 18%,transparent 60%);}
.masthead-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;height:60px;
  display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand-mark{width:30px;height:30px;flex-shrink:0}
.brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand-name b{font-family:var(--serif);font-weight:600;font-size:16.5px;color:var(--ink);letter-spacing:-.01em}
.brand-name small{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-family:var(--sans);font-weight:600}

.nav{display:flex;gap:2px;margin-left:8px}
.nav a{
  position:relative;color:var(--ink-2);font-weight:500;font-size:13.5px;
  padding:7px 13px;border-radius:8px;letter-spacing:.01em;
  transition:color .15s, background .15s;
}
.nav a:hover{color:var(--ink);background:var(--surface)}
.nav a.active{color:var(--accent-bright)}
.nav a.active::after{content:"";position:absolute;left:13px;right:13px;bottom:-1px;height:2px;
  background:var(--accent);border-radius:2px}

.masthead-meta{margin-left:auto;display:flex;align-items:center;gap:16px}
.masthead-search{position:relative}
.masthead-search input{
  width:240px;background:var(--bg-2);border:1px solid var(--line);color:var(--ink);
  border-radius:8px;padding:8px 12px 8px 34px;font-size:13px;font-family:var(--sans);
  transition:border-color .15s, width .2s, box-shadow .15s;
}
.masthead-search input::placeholder{color:var(--faint)}
.masthead-search input:focus{outline:none;border-color:var(--accent-line);width:280px;
  box-shadow:0 0 0 3px var(--accent-wash)}
.masthead-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);
  width:15px;height:15px;color:var(--faint);pointer-events:none}
.case-pill{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--muted);
  padding:5px 11px;border:1px solid var(--line);border-radius:20px;background:var(--bg-2);white-space:nowrap}
.case-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--out);
  box-shadow:0 0 0 3px var(--out-wash)}

/* page container */
.page{max-width:var(--maxw);margin:0 auto;padding:28px 24px 64px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  margin-bottom:22px;flex-wrap:wrap}
.page-head .eyebrow{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);font-weight:600;margin-bottom:7px}
.page-head h1{font-size:30px;font-weight:600}
.page-head .lede{color:var(--ink-2);font-size:14px;margin-top:6px;max-width:62ch}
.page-head .head-actions{display:flex;gap:10px;align-items:center}

.crumbs{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);margin-bottom:16px}
.crumbs a{color:var(--ink-2)} .crumbs a:hover{color:var(--accent)}
.crumbs span.sep{color:var(--faint)}

/* ==========================================================================
   Primitives — panel, card, buttons, badges, chips
   ========================================================================== */
.panel{background:linear-gradient(180deg,var(--surface),var(--surface) 40%, #10161f);
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.panel-pad{padding:20px 22px}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:15px 22px;border-bottom:1px solid var(--line)}
.panel-head h2,.panel-head h3{font-size:16px}
.panel-head .sub{font-size:11.5px;color:var(--muted);font-family:var(--sans);letter-spacing:.02em}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-weight:600;
  font-size:13px;line-height:1;padding:9px 15px;border-radius:8px;cursor:pointer;border:1px solid transparent;
  transition:background .15s,border-color .15s,color .15s,transform .05s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn svg{width:15px;height:15px}
.btn-primary{background:linear-gradient(180deg,var(--accent-bright),var(--accent));color:#22180a;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 6px 16px -8px var(--accent-deep)}
.btn-primary:hover{background:linear-gradient(180deg,#f6c878,var(--accent-bright));color:#1c1306}
.btn-ghost{background:var(--surface-2);color:var(--ink-2);border-color:var(--line-2)}
.btn-ghost:hover{color:var(--ink);border-color:#3a4a60;background:var(--surface-3)}
.btn-sm{padding:6px 11px;font-size:12px}
.btn[disabled],.btn.disabled{opacity:.5;cursor:not-allowed;position:relative}
.btn[disabled]:active{transform:none}
/* tooltip for stubbed actions */
.btn[data-tip]{position:relative}
.btn[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%);background:#05080d;color:var(--ink-2);border:1px solid var(--line-2);
  padding:6px 10px;border-radius:7px;font-size:11.5px;font-weight:500;white-space:nowrap;z-index:20;
  box-shadow:var(--shadow);font-family:var(--sans)}
.btn[data-tip]:hover::before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;
  transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--line-2)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:6px;
  font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:var(--sans);
  border:1px solid transparent}
.badge .tdot{width:6px;height:6px;border-radius:50%;background:currentColor}
.b-image{background:rgba(95,179,201,.13);color:#8fd0e0;border-color:rgba(95,179,201,.2)}
.b-video{background:rgba(95,179,201,.1);color:#79c3d6;border-color:rgba(95,179,201,.18)}
.b-pdf{background:rgba(224,116,106,.13);color:#ec9c93;border-color:rgba(224,116,106,.22)}
.b-vcard{background:rgba(111,191,142,.13);color:#90d4ab;border-color:rgba(111,191,142,.22)}
.b-other{background:var(--surface-3);color:var(--ink-2);border-color:var(--line-2)}
.b-PART{background:rgba(154,134,214,.13);color:#b6a6e4;border-color:rgba(154,134,214,.22)}
.b-RCS{background:var(--accent-wash);color:var(--accent-bright);border-color:var(--accent-line)}
.b-sms{background:rgba(95,179,201,.12);color:#8fd0e0;border-color:rgba(95,179,201,.2)}
.b-mms{background:rgba(154,134,214,.12);color:#b6a6e4;border-color:rgba(154,134,214,.2)}
.b-in{background:var(--in-wash);color:#8fd0e0;border-color:rgba(95,179,201,.2)}
.b-out{background:var(--out-wash);color:#90d4ab;border-color:rgba(111,191,142,.2)}
.cat{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:11px;
  font-weight:600;letter-spacing:.03em;border:1px solid transparent;font-family:var(--sans)}
.cat .tdot{width:7px;height:7px;border-radius:50%;background:currentColor}
.cat-mca{background:var(--accent-wash);color:var(--accent-bright);border-color:var(--accent-line)}
.cat-political{background:rgba(154,134,214,.12);color:#b6a6e4;border-color:rgba(154,134,214,.28)}
.cat-robocall{background:rgba(201,139,176,.12);color:#d6a4c4;border-color:rgba(201,139,176,.28)}
.cat-other{background:var(--surface-3);color:var(--ink-2);border-color:var(--line-2)}

.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:8px;font-size:12.5px;
  background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);font-family:var(--sans)}
.chip.active{background:var(--accent-wash);border-color:var(--accent-line);color:var(--accent-bright)}
.chip:hover{border-color:var(--line-2);color:var(--ink)}
.chip .n{color:var(--faint);font-size:11px;font-variant-numeric:tabular-nums}
.chip-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

.tag-num{font-family:var(--mono);font-size:12px;background:var(--bg-2);border:1px solid var(--line);
  color:var(--ink-2);padding:3px 8px;border-radius:6px;display:inline-block}
code{font-family:var(--mono);font-size:.9em;background:var(--bg-2);border:1px solid var(--line);
  padding:1px 6px;border-radius:5px;color:var(--ink-2)}
.muted{color:var(--muted)}.faint{color:var(--faint)}
mark{background:var(--accent-wash);color:var(--accent-bright);padding:0 2px;border-radius:3px}

/* ==========================================================================
   Stat tiles (dashboard)
   ========================================================================== */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.stat{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--surface),#10161f);
  border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.stat::before{content:"";position:absolute;inset:0 auto 0 0;width:3px;
  background:linear-gradient(180deg,var(--accent),transparent)}
.stat.is-flag::before{background:linear-gradient(180deg,var(--danger),transparent)}
.stat.is-cool::before{background:linear-gradient(180deg,var(--in),transparent)}
.stat .label{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600}
.stat .value{font-family:var(--serif);font-weight:600;font-size:34px;line-height:1.1;margin-top:6px;
  color:var(--ink);font-variant-numeric:tabular-nums}
.stat .value small{font-size:15px;color:var(--muted);font-family:var(--sans);font-weight:500}
.stat .foot{margin-top:7px;font-size:11.5px;color:var(--ink-2)}
.stat .foot b{color:var(--accent-bright);font-weight:600}

/* ==========================================================================
   Tables — data-dense but elegant
   ========================================================================== */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius)}
table.data{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}
table.data thead th{position:sticky;top:0;background:var(--surface-2);text-align:left;
  font-family:var(--sans);font-weight:600;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);padding:11px 16px;border-bottom:1px solid var(--line-2);white-space:nowrap}
table.data tbody td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tbody tr{transition:background .12s}
table.data tbody tr:hover{background:var(--surface-2)}
table.data tbody tr:last-child td{border-bottom:0}
table.data a.row-link{color:var(--ink);font-weight:500}
table.data a.row-link:hover{color:var(--accent-bright)}
.num{font-variant-numeric:tabular-nums;font-family:var(--mono)}
.tr-flag td:first-child{box-shadow:inset 3px 0 0 var(--accent)}
td .sub{display:block;color:var(--muted);font-size:11.5px;margin-top:3px}
.minibar{height:6px;border-radius:4px;background:var(--surface-3);overflow:hidden;min-width:60px}
.minibar > span{display:block;height:100%;background:linear-gradient(90deg,var(--accent-deep),var(--accent));border-radius:4px}
.minibar.cool > span{background:linear-gradient(90deg,#2f6b7a,var(--in))}

/* ==========================================================================
   SVG volume chart
   ========================================================================== */
.chart{width:100%;display:block}
.chart .axis{stroke:var(--line);stroke-width:1}
.chart .grid{stroke:var(--line);stroke-width:1;stroke-dasharray:2 4;opacity:.6}
.chart .bar-all{fill:var(--surface-3)}
.chart .bar-mca{fill:var(--accent)}
.chart text{fill:var(--muted);font-family:var(--mono);font-size:10px}
.chart .lbl-axis{fill:var(--faint);font-family:var(--sans);font-size:10px;letter-spacing:.05em}
.chart-legend{display:flex;gap:18px;font-size:12px;color:var(--ink-2);margin-top:4px}
.chart-legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:7px;vertical-align:-1px}

/* ==========================================================================
   Entities
   ========================================================================== */
.ent-rank{font-family:var(--serif);font-size:15px;color:var(--faint);width:30px;text-align:right;font-variant-numeric:tabular-nums}
.ent-name{font-family:var(--sans);font-weight:600;color:var(--ink);font-size:13.5px}
.ent-name .unnamed{color:var(--muted);font-style:italic;font-weight:500;font-family:var(--serif)}
.ent-evidence{color:var(--muted);font-size:11.5px;margin-top:3px;max-width:46ch;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dom-chip{font-family:var(--mono);font-size:11px;color:var(--accent-bright);background:var(--accent-wash);
  border:1px solid var(--accent-line);padding:1px 7px;border-radius:5px}

/* entity detail */
.ent-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-bottom:20px}
@media(max-width:880px){.ent-hero{grid-template-columns:1fr}}
.evidence-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.evidence-list li{display:flex;gap:11px;padding:11px 14px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:9px;border-left:3px solid var(--accent);font-size:12.5px;color:var(--ink-2);line-height:1.45}
.evidence-list li .ico{color:var(--accent);flex-shrink:0;margin-top:1px}
.numgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.numgrid a{font-family:var(--mono);font-size:12.5px;background:var(--bg-2);border:1px solid var(--line);
  color:var(--ink-2);padding:8px 11px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;
  transition:border-color .12s,color .12s}
.numgrid a:hover{border-color:var(--accent-line);color:var(--accent-bright)}
.numgrid a .cnt{color:var(--faint);font-size:11px}

/* ==========================================================================
   Conversations
   ========================================================================== */
.thread-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.thread-row{display:flex;gap:14px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);
  transition:background .12s;background:var(--surface)}
.thread-row:last-child{border-bottom:0}
.thread-row:hover{background:var(--surface-2)}
.thread-avatar{width:38px;height:38px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--surface-3);border:1px solid var(--line-2);font-family:var(--serif);font-weight:600;font-size:15px;color:var(--ink-2)}
.thread-avatar.flag{background:var(--accent-wash);border-color:var(--accent-line);color:var(--accent-bright)}
.thread-main{min-width:0;flex:1}
.thread-who{font-weight:600;color:var(--ink);font-size:13.5px;display:flex;align-items:center;gap:8px}
.thread-snip{color:var(--muted);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.thread-side{margin-left:auto;text-align:right;white-space:nowrap;color:var(--muted);font-size:11.5px}
.thread-side .cnt{color:var(--ink-2);font-weight:600;font-variant-numeric:tabular-nums}

/* chat */
.conv-head{display:flex;align-items:center;gap:14px;padding:16px 20px;margin-bottom:18px}
.conv{display:flex;flex-direction:column;gap:9px;max-width:820px;margin:0 auto}
.daysep{display:flex;align-items:center;gap:14px;color:var(--faint);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;margin:16px 0 4px;font-weight:600}
.daysep::before,.daysep::after{content:"";flex:1;height:1px;background:var(--line)}
.bub{max-width:74%;padding:11px 15px;border-radius:14px;font-size:13.5px;white-space:pre-wrap;
  word-break:break-word;line-height:1.5;box-shadow:var(--shadow);position:relative}
.bub.in{align-self:flex-start;background:var(--surface-2);border:1px solid var(--line);
  border-bottom-left-radius:5px}
.bub.out{align-self:flex-end;background:linear-gradient(180deg,#163026,#12281f);
  border:1px solid rgba(111,191,142,.28);border-bottom-right-radius:5px}
.bub .ts{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:10.5px;color:var(--muted);
  margin-top:8px;font-family:var(--sans)}
.bub img{max-width:280px;border-radius:9px;display:block;margin-top:8px;border:1px solid var(--line)}
.bub .att{margin-top:8px;font-size:12.5px}

/* ==========================================================================
   Filter bar + gallery
   ========================================================================== */
.filterbar{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;padding:16px 18px;margin-bottom:20px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
select,input[type=text],input[type=search]{background:var(--bg-2);color:var(--ink);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:9px 11px;font-size:13px;font-family:var(--sans);transition:border-color .15s,box-shadow .15s}
select:focus,input:focus{outline:none;border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-wash)}
input[type=text],input[type=search]{min-width:240px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237b8798' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}

.grid-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:14px}
.card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;transition:border-color .15s,transform .12s,box-shadow .15s}
.card:hover{border-color:var(--line-2);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.card .thumb{aspect-ratio:1/1;background:var(--bg-2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover}
.card .card-meta{padding:9px 11px;display:flex;justify-content:space-between;align-items:center;gap:6px}
.card .card-meta:first-of-type{padding-bottom:0}
.card .card-meta .sz{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums}
.card .card-date{padding:0 11px 10px;font-size:10.5px;color:var(--faint)}

/* ==========================================================================
   Search results
   ========================================================================== */
.result-group{margin-bottom:26px}
.result-group .grp-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.result-group .grp-head h3{font-size:15px}
.result-group .grp-head .count{font-size:11px;color:var(--muted);background:var(--surface-2);
  border:1px solid var(--line);padding:2px 9px;border-radius:20px;font-family:var(--mono)}
.result{display:flex;gap:14px;padding:13px 16px;border:1px solid var(--line);border-radius:9px;
  background:var(--surface);margin-bottom:8px;transition:border-color .12s}
.result:hover{border-color:var(--line-2)}
.result .r-type{flex-shrink:0;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  background:var(--surface-3);border:1px solid var(--line-2)}
.result .r-body{min-width:0;flex:1}
.result .r-title{font-weight:600;color:var(--ink);font-size:13.5px}
.result .r-snip{color:var(--ink-2);font-size:12.5px;margin-top:3px;line-height:1.5}
.result .r-side{margin-left:auto;text-align:right;color:var(--muted);font-size:11.5px;white-space:nowrap}

/* ==========================================================================
   Misc — empty states, pager, callout, kv
   ========================================================================== */
.empty{text-align:center;padding:64px 24px;color:var(--muted)}
.empty .ico{width:48px;height:48px;margin:0 auto 16px;color:var(--faint);opacity:.7}
.empty h3{font-size:18px;color:var(--ink-2);margin-bottom:7px}
.empty p{max-width:42ch;margin:0 auto;font-size:13px}

.callout{display:flex;gap:12px;padding:13px 16px;border-radius:10px;font-size:12.5px;line-height:1.5;
  background:var(--accent-wash);border:1px solid var(--accent-line);color:#e8d4ac;margin-bottom:18px}
.callout .ico{color:var(--accent);flex-shrink:0;margin-top:1px}
.callout.cool{background:var(--in-wash);border-color:rgba(95,179,201,.28);color:#bfe2ec}
.callout.cool .ico{color:var(--in)}
.callout code{background:rgba(0,0,0,.25);border-color:transparent}

.pager{display:flex;gap:8px;align-items:center;justify-content:center;margin:28px 0 0}
.pager a,.pager span{padding:8px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);
  font-size:13px;color:var(--ink-2);font-weight:500}
.pager a:hover{border-color:var(--accent-line);color:var(--accent-bright)}
.pager span.muted{color:var(--faint)}
.pager .pos{background:transparent;border-color:transparent;color:var(--muted);font-variant-numeric:tabular-nums}

.kv{display:grid;grid-template-columns:160px 1fr;gap:9px 18px;font-size:13px}
.kv dt{color:var(--muted);font-size:12px}
.kv dd{margin:0;word-break:break-word;color:var(--ink-2)}

.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cols-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:920px){.cols-2,.cols-3{grid-template-columns:1fr}}
.span-2{grid-column:span 2}
@media(max-width:920px){.span-2{grid-column:auto}}

.section-title{display:flex;align-items:baseline;gap:12px;margin:30px 0 14px}
.section-title h2{font-size:20px}
.section-title .hint{font-size:12px;color:var(--muted)}
.section-title a{margin-left:auto;font-size:12.5px;font-weight:600}

/* staggered page-load reveal — resting state is ALWAYS visible; the animation
   only adds an entrance. Guarded so content is never permanently hidden if
   animations are disabled (print/PDF, reduced-motion, older engines). */
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:no-preference){
  .rise{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
  .rise-1{animation-delay:.04s}.rise-2{animation-delay:.10s}.rise-3{animation-delay:.16s}
  .rise-4{animation-delay:.22s}.rise-5{animation-delay:.28s}
}

@media(max-width:760px){
  .masthead-search{display:none}
  .page-head h1{font-size:24px}
  .nav a{padding:7px 9px;font-size:13px}
  .ent-hero{grid-template-columns:1fr}
}

/* ==========================================================================
   EviTrace — brand wordmark + extended categories + TCPA + Ask console
   ========================================================================== */
.brand-word{font-family:var(--serif);font-weight:600;font-size:16.5px;color:var(--ink);
  letter-spacing:-.005em}
.brand-word span{color:var(--accent-bright)}
.nav a.nav-ai{color:var(--accent-bright)}
.nav a.nav-ai::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--accent);margin-right:6px;vertical-align:1px;box-shadow:0 0 0 3px var(--accent-wash)}
.nav a.nav-ai:hover{background:var(--accent-wash)}

/* extended AI-category chips (mca/political/robocall/other already exist) */
.cat-debt{background:rgba(201,139,176,.12);color:#d6a4c4;border-color:rgba(201,139,176,.28)}
.cat-phishing{background:var(--danger-wash);color:#ec9c93;border-color:rgba(224,116,106,.3)}
.cat-legit{background:var(--out-wash);color:#90d4ab;border-color:rgba(111,191,142,.28)}
.cat-personal{background:var(--in-wash);color:#8fd0e0;border-color:rgba(95,179,201,.28)}

/* TCPA violation badge — texted after STOP */
.tcpa-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:6px;
  font-size:10.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;font-family:var(--sans);
  background:var(--danger-wash);color:#ef9a8f;border:1px solid rgba(224,116,106,.4)}
.tr-tcpa td:first-child{box-shadow:inset 3px 0 0 var(--danger)}

/* clickable sortable headers (server-side, entities/saved tables) */
table.data thead th a.sort-link{color:var(--muted);display:inline-flex;align-items:center;gap:5px;
  font:inherit;letter-spacing:inherit;text-transform:inherit}
table.data thead th a.sort-link:hover{color:var(--ink-2)}
table.data thead th a.sort-link.is-sorted{color:var(--accent-bright)}
.sort-caret{font-size:8px;line-height:1}
/* client-side sortable (Ask result tables) */
table.sortable thead th.sort-th{cursor:pointer;user-select:none}
table.sortable thead th.sort-th:hover{color:var(--ink-2)}
table.sortable thead th[data-dir]::after{content:"▲";font-size:8px;margin-left:5px;color:var(--accent-bright)}
table.sortable thead th[data-dir="desc"]::after{content:"▼"}

/* ---- Ask Evi console -------------------------------------------------- */
.ask-thread{display:flex;flex-direction:column;gap:0;margin-bottom:18px}
.ask-turn{padding:20px 0;border-bottom:1px solid var(--line)}
.ask-turn:first-child{padding-top:6px}
.ask-turn.is-latest{scroll-margin-top:80px}
.ask-q{display:flex;gap:13px;align-items:flex-start;margin-bottom:16px}
.ask-a{display:flex;gap:13px;align-items:flex-start}
.ask-av{flex-shrink:0;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-size:10.5px;font-weight:700;letter-spacing:.04em}
.ask-av.you{background:var(--surface-3);border:1px solid var(--line-2);color:var(--ink-2);
  font-family:var(--sans);text-transform:uppercase}
.ask-av.ai{background:var(--accent-wash);border:1px solid var(--accent-line);color:var(--accent-bright)}
.ask-q-body{flex:1;font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);line-height:1.4;padding-top:2px}
.ask-a-body{flex:1;min-width:0}
.ask-summary{font-size:15px;line-height:1.6;color:var(--ink);background:linear-gradient(180deg,var(--surface),#10161f);
  border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px;padding:14px 18px;margin-bottom:14px}
.ask-err{font-size:13.5px;line-height:1.55;color:#f0c4bd;background:var(--danger-wash);
  border:1px solid rgba(224,116,106,.32);border-radius:10px;padding:13px 16px}
.ask-result{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface);margin-bottom:12px}
.ask-result-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  padding:11px 14px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.ask-result-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ask-result .tbl-wrap{max-height:440px;overflow:auto;border-radius:0}
.ask-result table.data tbody td{font-family:var(--mono);font-size:12px}
.ask-sql{margin-top:4px}
.ask-sql summary{cursor:pointer;font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.03em;
  display:inline-flex;align-items:center;gap:6px;padding:5px 0;user-select:none}
.ask-sql summary:hover{color:var(--accent-bright)}
.ask-sql summary::-webkit-details-marker{display:none}
.ask-sql summary::before{content:"▸";font-size:10px;transition:transform .12s}
.ask-sql[open] summary::before{transform:rotate(90deg)}
.sql-block{font-family:var(--mono);font-size:12.5px;line-height:1.55;color:var(--accent-bright);
  background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:13px 16px;margin:8px 0 0;
  white-space:pre-wrap;word-break:break-word;overflow-x:auto}

.ask-composer{position:sticky;bottom:16px;display:flex;gap:10px;align-items:flex-end;
  background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line-2);
  border-radius:14px;padding:12px;box-shadow:var(--shadow-lg)}
.ask-composer textarea{flex:1;resize:none;min-height:24px;max-height:180px;background:transparent;border:0;
  color:var(--ink);font-family:var(--sans);font-size:14.5px;line-height:1.5;padding:6px 8px}
.ask-composer textarea:focus{outline:none}
.ask-composer textarea::placeholder{color:var(--faint)}
.ask-starter{cursor:pointer;font-family:var(--sans);text-align:left}

/* ---- regex / whitespace matches ------------------------------------------- */
.regex-toggle{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-2);
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:8px 11px;cursor:pointer;user-select:none}
.regex-toggle input{accent-color:var(--accent)}
.match-row{display:flex;gap:14px;padding:12px 16px;border:1px solid var(--line);border-radius:9px;
  background:var(--surface);margin-bottom:8px}
.match-row .m-meta{flex-shrink:0;width:150px;font-size:11px;color:var(--muted)}
.match-row .m-meta .mono{display:block;color:var(--ink-2);font-size:12px}
.match-row .m-text{flex:1;min-width:0;font-size:13px;line-height:1.55;color:var(--ink-2);
  font-family:var(--mono);white-space:pre-wrap;word-break:break-word}
.match-row .m-text mark{white-space:pre-wrap}
