/* Throughline — components
   Cards, chips, trajectory, refusal, drawer, chat surface.
*/

/* ===== App chrome ===== */
.app-rail {
  position: sticky;
  top: 0;
  z-index: 30;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.app-rail-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-5);
  height: 56px;
  padding: 0 var(--s-5);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.05em;
  color: var(--fg);
}
/* Throughline logo mark — the line-with-violet-dot. Strokes inherit
   currentColor so the line follows --fg in any theme; the dot uses
   --accent directly via SVG fill. Drop-shadow gives the dot a faint
   halo to echo the print logo. */
.throughline-mark {
  flex: 0 0 auto;
  color: var(--fg);
  overflow: visible;
  filter: drop-shadow(0 0 6px color-mix(in oklab, var(--accent) 35%, transparent));
}
.throughline-mark circle {
  filter: drop-shadow(0 0 3px color-mix(in oklab, var(--accent) 60%, transparent));
}
/* Legacy .brand-mark kept as a no-op for any callers that still render it.
   It used to be a 14px square — now invisible so it doesn't double up. */
.brand-mark { display: none; }
.brand b { font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.brand .sep { color: var(--fg-faint); }

.nav {
  display: flex;
  gap: var(--s-5);
  font-family: var(--f-mono);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}
.nav a { padding: 4px 0; }
.nav a.active { color: var(--fg); border-bottom: 1px solid var(--signal-emerged); }
.nav a:hover { color: var(--fg); text-decoration: none; }

.app-rail-meta {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  font-family: var(--f-mono);
  font-size: var(--fs-xs);
  color: var(--fg-dim);
}
.dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--signal-emerged);
  display: inline-block;
  margin-right: 6px;
  vertical-align: 1px;
}

/* ===== Page-level layout ===== */
.page {
  min-height: 100dvh;
}

.editorial {
  max-width: 760px;
  margin-inline: auto;
  padding: var(--s-7) var(--gutter) var(--s-9);
}
.wide {
  max-width: 1180px;
  margin-inline: auto;
  padding: var(--s-6) var(--gutter) var(--s-8);
}

/* ===== Sectioning ===== */
.section-head {
  display: grid;
  grid-template-columns: var(--rail) 1fr;
  gap: var(--s-4);
  padding-top: var(--s-7);
  margin-bottom: var(--s-5);
  border-top: 1px solid var(--line);
  padding-block-start: var(--s-6);
}
.section-head .num {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  color: var(--fg-faint);
  padding-top: 6px;
}

/* ===== Stock card (editorial entry) ===== */
.stock-entry {
  display: grid;
  grid-template-columns: var(--rail) 1fr;
  gap: var(--s-4);
  padding-block: var(--s-7);
  border-top: 1px solid var(--line);
}
.stock-entry .meta {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  text-transform: uppercase;
  padding-top: 6px;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.stock-entry .meta .ticker {
  color: var(--fg);
  font-weight: 600;
  font-size: var(--fs-xs);
}
.stock-entry .body { display: contents; }
.stock-entry .summary {
  font-family: var(--f-serif);
  font-weight: 400;
  font-size: var(--fs-xl);
  line-height: 1.34;
  letter-spacing: -0.012em;
  color: var(--fg);
  text-wrap: pretty;
}
.stock-entry .summary em {
  font-style: italic;
  color: var(--fg-muted);
}
.stock-entry .row {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
  flex-wrap: wrap;
}
.stock-entry .row h2 {
  font-family: var(--f-sans);
  font-weight: 600;
  font-size: var(--fs-md);
  letter-spacing: -0.005em;
  margin: 0;
  color: var(--fg);
}
.stock-entry .row .sector {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.04em;
  color: var(--fg-faint);
  text-transform: uppercase;
}
.stock-entry .trail {
  margin-top: var(--s-5);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  border-top: 1px solid var(--line);
  padding-top: var(--s-5);
}
.stock-entry .trail-item .label {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: var(--s-2);
}
.stock-entry .trail-item .topic {
  font-family: var(--f-sans);
  font-size: var(--fs-sm);
  color: var(--fg);
  line-height: 1.32;
}
.stock-entry .ctas {
  margin-top: var(--s-5);
  display: flex;
  gap: var(--s-4);
  align-items: center;
  flex-wrap: wrap;
}

/* ===== Chips ===== */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
  padding: 3px 8px;
  line-height: 1.2;
  border: 1px solid var(--line);
  border-radius: 2px;
  background: var(--bg-raised);
  font-weight: 500;
}
.chip .swatch { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.chip.signal-emerged { color: var(--signal-emerged); border-color: color-mix(in oklab, var(--signal-emerged) 38%, var(--line)); }
.chip.signal-disappeared { color: var(--signal-disappeared); border-color: color-mix(in oklab, var(--signal-disappeared) 38%, var(--line)); }
.chip.signal-dodged { color: var(--signal-dodged); border-color: color-mix(in oklab, var(--signal-dodged) 38%, var(--line)); }
.chip.signal-walked { color: var(--signal-walked); border-color: color-mix(in oklab, var(--signal-walked) 38%, var(--line)); }

/* Citation chip */
.cite {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.02em;
  color: var(--fg-muted);
  padding: 1px 6px 2px;
  border: 1px solid var(--line);
  background: color-mix(in oklab, var(--bg-raised) 70%, transparent);
  border-radius: var(--radius);
  cursor: pointer;
  vertical-align: 1px;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap;
}
.cite:hover {
  color: var(--fg);
  border-color: var(--fg-muted);
  background: var(--bg-raised);
  text-decoration: none;
}
.cite .arrow { color: var(--fg-faint); }
.cite .q {
  color: var(--fg);
  font-weight: 500;
}
.cite.is-active {
  color: var(--bg);
  background: var(--signal-emerged);
  border-color: var(--signal-emerged);
}
.cite.is-active .q, .cite.is-active .arrow { color: var(--bg); }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg);
  padding: 8px 12px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  background: transparent;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.btn:hover { background: var(--bg-raised); border-color: var(--fg-muted); text-decoration: none; }
.btn.primary {
  background: var(--fg);
  color: var(--bg);
  border-color: var(--fg);
}
.btn.primary:hover { background: var(--signal-emerged); border-color: var(--signal-emerged); color: var(--bg); }
.btn.ghost {
  border-color: var(--line);
  color: var(--fg-muted);
}
.btn .arr { font-family: var(--f-mono); }

/* ===== Trajectory components ===== */
.trj {
  display: inline-grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
}

/* (a) Sparkline + delta */
.trj-spark {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.03em;
  color: var(--fg-muted);
}
.trj-spark .nums {
  display: inline-flex;
  gap: 2px;
  color: var(--fg);
}
.trj-spark .nums span {
  display: inline-block;
  min-width: 16px;
  text-align: right;
}
.trj-spark .nums .arrow {
  color: var(--fg-faint);
  padding-inline: 1px;
}
.trj-spark .delta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 6px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.trj-spark.dir-up .delta { color: var(--signal-emerged); border-color: color-mix(in oklab, var(--signal-emerged) 35%, var(--line)); }
.trj-spark.dir-down .delta { color: var(--signal-disappeared); border-color: color-mix(in oklab, var(--signal-disappeared) 35%, var(--line)); }
.trj-spark.dir-mixed .delta { color: var(--signal-walked); border-color: color-mix(in oklab, var(--signal-walked) 35%, var(--line)); }
.trj-spark.dir-dodged .delta { color: var(--signal-dodged); border-color: color-mix(in oklab, var(--signal-dodged) 35%, var(--line)); }

/* (b) Quarter strip with hover quotes */
.trj-strip-head {
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-faint);
  margin-bottom: var(--s-2);
}
.trj-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--line);
}
.trj-strip .qt {
  background: var(--bg-raised);
  padding: var(--s-3) var(--s-3) var(--s-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  position: relative;
  min-height: 70px;
  transition: background .15s;
}
.trj-strip .qt:hover { background: color-mix(in oklab, var(--bg-raised) 70%, var(--bg)); }
.trj-strip .qt .label {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.04em;
  color: var(--fg-faint);
  text-transform: uppercase;
}
.trj-strip .qt .count {
  font-family: var(--f-mono);
  font-size: var(--fs-2xl);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--fg-muted);
  line-height: 1;
}
.trj-strip .qt .bar {
  height: 3px;
  background: var(--line-strong);
  margin-top: 4px;
  position: relative;
}
.trj-strip .qt .bar::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w, 0%);
  background: var(--signal, var(--fg-muted));
}
.trj-strip .qt[data-peak="true"] .count { color: var(--fg); }
.trj-strip .qt[data-peak="true"] {
  background: color-mix(in oklab, var(--signal, var(--fg)) 8%, var(--bg-raised));
}
.trj-strip .qt[data-zero="true"] .count { color: var(--fg-faint); }

.trj-strip[data-signal="emerged"] { --signal: var(--signal-emerged); }
.trj-strip[data-signal="disappeared"] { --signal: var(--signal-disappeared); }
.trj-strip[data-signal="dodged"] { --signal: var(--signal-dodged); }

/* (c) Stacked-bar mention ledger */
.trj-ledger {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
}
.trj-ledger .col {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 0;
  margin: 0;
  max-width: none;
}
.trj-ledger .stack {
  display: flex;
  flex-direction: column-reverse;
  height: 80px;
  border-bottom: 1px solid var(--line-strong);
  gap: 1px;
}
.trj-ledger .seg {
  background: var(--signal, var(--fg-muted));
  min-height: 2px;
}
.trj-ledger .seg.s2 { opacity: 0.7; }
.trj-ledger .seg.s3 { opacity: 0.45; }
.trj-ledger .lbl {
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.04em;
  color: var(--fg-dim);
  text-transform: uppercase;
}
.trj-ledger .total {
  color: var(--fg);
  font-size: var(--fs-sm);
}

/* ===== Refusal banner ===== */
.refusal {
  border: 1px solid var(--line);
  border-left: 2px solid var(--signal-dodged);
  background: color-mix(in oklab, var(--signal-dodged) 6%, var(--bg-raised));
  padding: var(--s-4) var(--s-5);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-4);
  border-radius: var(--radius);
  margin-block: var(--s-4);
}
.refusal .icon {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--signal-dodged);
  padding-top: 2px;
}
.refusal .body {
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--fg);
}
.refusal .body .lede {
  font-weight: 500;
  color: var(--fg);
}
.refusal .body p { margin: 0 0 6px; }
.refusal .body .alt {
  margin-top: var(--s-3);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}

/* Empty state */
.empty {
  border: 1px dashed var(--line);
  padding: var(--s-6);
  text-align: center;
  border-radius: var(--radius);
  color: var(--fg-muted);
}
.empty .glyph {
  font-family: var(--f-mono);
  color: var(--fg-faint);
  margin-bottom: var(--s-3);
}

/* ===== Stock detail layout ===== */
.stock-header {
  border-bottom: 1px solid var(--line);
  padding-block: var(--s-7) var(--s-6);
}
.stock-header .crumbs {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  text-transform: uppercase;
  margin-bottom: var(--s-5);
}
.stock-header .ticker-row {
  display: flex;
  align-items: baseline;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.stock-header .ticker {
  font-family: var(--f-mono);
  font-weight: 600;
  font-size: var(--fs-xl);
  letter-spacing: 0.02em;
  color: var(--fg);
}
.stock-header .company {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  color: var(--fg-muted);
}
.stock-header .sector {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-faint);
  text-transform: uppercase;
}
.stock-header .summary-display {
  font-family: var(--f-serif);
  font-weight: 400;
  font-size: var(--fs-2xl);
  line-height: 1.22;
  letter-spacing: -0.018em;
  color: var(--fg);
  text-wrap: pretty;
  max-width: 880px;
  margin-block: var(--s-5);
}
.stock-header .meta-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin-top: var(--s-4);
}
.stock-header .meta-grid .cell {
  background: var(--bg);
  padding: var(--s-3) var(--s-4);
}
.stock-header .meta-grid .label {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.stock-header .meta-grid .val {
  font-family: var(--f-mono);
  font-size: var(--fs-md);
  color: var(--fg);
}

/* Tabs */
.tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
  margin-block: var(--s-6) 0;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  overflow-x: auto;
}
.tabs button {
  padding: var(--s-3) var(--s-4);
  color: var(--fg-dim);
  border-bottom: 1px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
}
.tabs button.active { color: var(--fg); border-bottom-color: var(--signal-emerged); }
.tabs button:hover { color: var(--fg); }

/* Narrative card */
.narrative {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s-6);
  padding-block: var(--s-6);
  border-top: 1px solid var(--line);
}
.narrative:first-of-type { border-top: 0; padding-top: var(--s-5); }
.narrative .left {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.narrative .topic {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--fg);
  line-height: 1.28;
}
.narrative .quote {
  font-family: var(--f-mono);
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--fg);
  border-left: 2px solid var(--line-strong);
  padding: var(--s-2) 0 var(--s-2) var(--s-4);
  margin-block: var(--s-2) var(--s-3);
}
.narrative .quote.peak { border-left-color: var(--signal-emerged); }
.narrative .quote.disap { border-left-color: var(--signal-disappeared); }
.narrative .significance {
  font-family: var(--f-sans);
  font-size: var(--fs-sm);
  line-height: 1.6;
  color: var(--fg-muted);
}
.narrative .actions {
  display: flex;
  gap: var(--s-3);
  margin-top: var(--s-3);
  flex-wrap: wrap;
}

/* ===== Chat surface ===== */
.chat-shell {
  display: grid;
  grid-template-columns: 1fr;
  max-width: 920px;
  margin-inline: auto;
  padding: var(--s-5) var(--gutter) 200px;
}
.chat-stock-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  padding-block: var(--s-3);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--s-5);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.chat-stock-bar .stock-pick {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  color: var(--fg);
}
.chat-stock-bar .stock-pick b { font-weight: 600; }

.turn { padding-block: var(--s-5); }
.turn + .turn { border-top: 1px solid var(--line); }
.turn.user .who {
  color: var(--fg-muted);
}
.turn.assistant .who {
  color: var(--signal-emerged);
}
.turn .who {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: var(--s-3);
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.turn.user .text {
  font-family: var(--f-serif);
  font-size: var(--fs-lg);
  line-height: 1.42;
  color: var(--fg);
}
.turn.assistant .text {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  line-height: 1.56;
  color: var(--fg);
  text-wrap: pretty;
}
.turn.assistant .text p { margin: 0 0 var(--s-3); }
.turn.assistant .text p:last-child { margin-bottom: 0; }

/* tool-call inline chips */
.tools-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-block: var(--s-3);
}
.tool-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.02em;
  color: var(--fg-dim);
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-sunk);
  cursor: pointer;
  transition: color .15s, border-color .15s;
}
.tool-chip > span { white-space: nowrap; }
.tools-strip { flex-direction: column; align-items: flex-start; }
.tool-chip:hover { color: var(--fg); border-color: var(--fg-muted); }
.tool-chip .arr { color: var(--fg-faint); }
.tool-chip .name { color: var(--fg-muted); }
.tool-chip .ok { color: var(--signal-emerged); }
.tool-chip .running { color: var(--signal-walked); }
.tool-chip .caret { font-size: 9px; color: var(--fg-faint); margin-left: 2px; }

.tool-detail {
  margin-block: var(--s-3);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-sunk);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  overflow: hidden;
}
.tool-detail .head {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  border-bottom: 1px solid var(--line);
  color: var(--fg-muted);
}
.tool-detail .head b { color: var(--fg); font-weight: 500; }
.tool-detail .body {
  padding: var(--s-3);
  color: var(--fg-muted);
  line-height: 1.5;
  white-space: pre-wrap;
}
.tool-detail .body .k { color: var(--fg-dim); }
.tool-detail .body .v { color: var(--fg); }

/* Chat composer */
.composer {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid var(--line);
  padding: var(--s-4) var(--gutter);
  z-index: 25;
}
.composer-inner {
  max-width: 920px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-3);
  align-items: end;
}
.composer textarea {
  width: 100%;
  resize: none;
  min-height: 44px;
  max-height: 160px;
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  background: var(--bg-raised);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: var(--s-3) var(--s-4);
  color: var(--fg);
  line-height: 1.4;
  outline: none;
}
.composer textarea:focus { border-color: var(--fg-muted); }
.composer .hint {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.05em;
  color: var(--fg-faint);
  text-align: center;
  margin-top: var(--s-2);
  text-transform: uppercase;
}

/* Chat suggestions */
.suggest {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-bottom: var(--s-5);
}
.suggest button {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.02em;
  color: var(--fg-muted);
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: transparent;
  text-align: left;
}
.suggest button:hover { color: var(--fg); border-color: var(--fg-muted); }

/* ===== Citation drawer ===== */
.drawer-scrim {
  position: fixed; inset: 0;
  background: color-mix(in oklab, #000 40%, transparent);
  z-index: 40;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
.drawer-scrim.open { opacity: 1; pointer-events: auto; }
.drawer {
  position: fixed;
  top: 0; right: 0;
  width: min(560px, 100vw);
  height: 100dvh;
  background: var(--bg);
  border-left: 1px solid var(--line);
  z-index: 41;
  transform: translateX(100%);
  transition: transform .25s ease-out;
  display: flex;
  flex-direction: column;
}
.drawer.open { transform: translateX(0); }
.drawer-head {
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.drawer-head .ticker { color: var(--fg); font-weight: 600; }
.drawer-head .close { color: var(--fg-dim); cursor: pointer; padding: 4px; }
.drawer-head .close:hover { color: var(--fg); }
.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--s-5);
}
.drawer-body .cite-meta {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: var(--s-3);
}
.drawer-body .transcript {
  font-family: var(--f-mono);
  font-size: var(--fs-sm);
  line-height: 1.7;
  color: var(--fg-muted);
  white-space: pre-wrap;
}
.drawer-body .transcript mark {
  background: color-mix(in oklab, var(--signal-emerged) 28%, transparent);
  color: var(--fg);
  padding: 1px 2px;
  border-radius: var(--radius);
}
.drawer-body .speaker {
  color: var(--fg);
  font-weight: 500;
  margin-top: var(--s-4);
}
.drawer-foot {
  border-top: 1px solid var(--line);
  padding: var(--s-3) var(--s-5);
  display: flex;
  gap: var(--s-3);
  align-items: center;
  justify-content: space-between;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-dim);
}

@media (max-width: 700px) {
  .drawer {
    top: auto; bottom: 0; right: 0; left: 0;
    width: 100%;
    height: 88dvh;
    border-left: 0;
    border-top: 1px solid var(--line);
    transform: translateY(100%);
  }
  .drawer.open { transform: translateY(0); }
  .stock-entry { grid-template-columns: 1fr; gap: var(--s-3); }
  .stock-entry .meta { flex-direction: row; gap: var(--s-3); }
  .stock-entry .trail { grid-template-columns: 1fr; }
  .stock-header .meta-grid { grid-template-columns: 1fr 1fr; }
  .narrative { grid-template-columns: 1fr; gap: var(--s-3); }
  .editorial { padding: var(--s-5) var(--s-4) var(--s-8); }
  .nav { display: none; }
  .stock-header .summary-display { font-size: var(--fs-xl); }
  .turn.user .text { font-size: var(--fs-md); }
  .section-head { grid-template-columns: 1fr; }
  .section-head .num { padding-top: 0; }
}

/* ===== Tweaks helper styles override ===== */
[data-tools="hidden"] .tools-strip,
[data-tools="hidden"] .tool-detail { display: none; }
[data-tools="expanded"] .tool-detail { display: block; }

/* ===== Hero (homepage opener) ===== */
.hero {
  padding-block: var(--s-8) var(--s-5);
}
.hero .kicker {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-dim);
  margin-bottom: var(--s-4);
}
.hero .lede {
  font-family: var(--f-serif);
  font-weight: 400;
  font-size: var(--fs-3xl);
  line-height: 1.12;
  letter-spacing: -0.022em;
  color: var(--fg);
  text-wrap: balance;
  max-width: 18ch;
}
.hero .deck {
  margin-top: var(--s-5);
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--fg-muted);
  max-width: 60ch;
}
.hero .meta-bar {
  display: flex;
  gap: var(--s-5);
  flex-wrap: wrap;
  margin-top: var(--s-6);
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  text-transform: uppercase;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding-block: var(--s-3);
}
.hero .meta-bar b { color: var(--fg); font-weight: 500; }

/* Cross-stock pattern callouts */
.pattern {
  border-top: 1px solid var(--line);
  padding-block: var(--s-6);
  display: grid;
  grid-template-columns: var(--rail) 1fr;
  gap: var(--s-4);
}
.pattern .num {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-faint);
  padding-top: 4px;
}
.pattern h3 {
  margin: 0 0 var(--s-3);
  font-family: var(--f-sans);
  font-weight: 600;
  font-size: var(--fs-lg);
  line-height: 1.24;
  letter-spacing: -0.012em;
  color: var(--fg);
}
.pattern .body {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  line-height: 1.56;
  color: var(--fg-muted);
}
.pattern .tags {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
  margin-top: var(--s-3);
}

@media (max-width: 700px) {
  .pattern { grid-template-columns: 1fr; gap: var(--s-2); }
  .hero .lede { font-size: var(--fs-2xl); }
}

/* ============================================================
   Inline "Ask the agent" link (used inside narrative cards)
   ============================================================ */
.ask-agent-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  color: var(--fg-muted);
  border: 1px dashed var(--line);
  background: transparent;
  padding: 6px 10px;
  border-radius: 2px;
  letter-spacing: 0.01em;
  transition: border-color 120ms ease, color 120ms ease, background 120ms ease;
}
.ask-agent-link:hover {
  color: var(--fg);
  border-color: var(--line-strong);
  background: color-mix(in oklab, var(--fg) 4%, transparent);
}
.ask-agent-link .arr {
  font-family: var(--f-mono);
  font-size: 0.95em;
  color: var(--fg-dim);
}
.ask-agent-link:hover .arr { color: var(--fg-muted); }

/* ============================================================
   Floating chat — collapsed launcher pill + expanded panel
   Anchored bottom-right. Pill always visible; panel slides up.
   ESC + × close to launcher; click-outside is a no-op.
   ============================================================ */

.chat-launcher {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 40;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px 10px 12px;
  background: var(--bg-raised);
  color: var(--fg);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  font-size: var(--fs-sm);
  letter-spacing: 0.01em;
  box-shadow:
    0 1px 0 color-mix(in oklab, var(--fg) 4%, transparent) inset,
    0 8px 24px -12px rgba(0,0,0,0.45),
    0 2px 6px -2px rgba(0,0,0,0.25);
  transition: transform 140ms ease, box-shadow 140ms ease,
              opacity 160ms ease, border-color 140ms ease;
}
.chat-launcher:hover {
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--fg) 35%, var(--line-strong));
  box-shadow:
    0 1px 0 color-mix(in oklab, var(--fg) 6%, transparent) inset,
    0 12px 28px -12px rgba(0,0,0,0.55),
    0 2px 6px -2px rgba(0,0,0,0.3);
}
.chat-launcher.is-open {
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}
.chat-launcher .lc-icon {
  display: inline-flex;
  width: 22px;
  height: 22px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--bg-sunk);
  color: var(--fg-muted);
  border: 1px solid var(--line);
}
.chat-launcher:hover .lc-icon { color: var(--fg); }
.chat-launcher .lc-label { font-weight: 500; }

.chat-float {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 41;
  width: min(420px, calc(100vw - 48px));
  height: min(600px, calc(100vh - 48px));
  display: flex;
  flex-direction: column;
  background: var(--bg-raised);
  border: 1px solid var(--line-strong);
  border-radius: 4px;
  box-shadow:
    0 1px 0 color-mix(in oklab, var(--fg) 5%, transparent) inset,
    0 24px 60px -20px rgba(0,0,0,0.6),
    0 8px 24px -12px rgba(0,0,0,0.4);
  opacity: 0;
  transform: translateY(8px) scale(0.98);
  pointer-events: none;
  transform-origin: bottom right;
  transition: opacity 180ms ease, transform 180ms ease;
}
.chat-float.is-open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.cf-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s-3);
  padding: 12px 12px 10px 14px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--fg) 3%, var(--bg-raised)),
    var(--bg-raised));
}
.cf-head-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.cf-head-left .dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--signal-emerged);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--signal-emerged) 22%, transparent);
  flex: 0 0 auto;
}
.cf-head .eyebrow {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.cf-sub {
  font-size: var(--fs-mono-xs);
  color: var(--fg-dim);
  margin-top: 2px;
}
.cf-head-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
}
.cf-btn {
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--fg-dim);
  border-radius: 3px;
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.cf-btn:hover {
  background: color-mix(in oklab, var(--fg) 7%, transparent);
  color: var(--fg);
}

.cf-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cf-scroll::-webkit-scrollbar { width: 8px; }
.cf-scroll::-webkit-scrollbar-track { background: transparent; }
.cf-scroll::-webkit-scrollbar-thumb {
  background: color-mix(in oklab, var(--fg) 12%, transparent);
  border-radius: 4px;
}

.cf-empty { padding: 4px 2px; }
.cf-suggest {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cf-suggest > button {
  text-align: left;
  font-size: var(--fs-sm);
  color: var(--fg-muted);
  background: var(--bg-sunk);
  border: 1px solid var(--line);
  border-radius: 3px;
  padding: 10px 12px;
  line-height: 1.45;
  cursor: pointer;
  transition: border-color 120ms ease, color 120ms ease, background 120ms ease;
}
.cf-suggest > button:hover {
  border-color: var(--line-strong);
  color: var(--fg);
  background: color-mix(in oklab, var(--fg) 3%, var(--bg-sunk));
}

.chat-float .turn { display: flex; flex-direction: column; gap: 6px; }
.chat-float .turn .who {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-dim);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.chat-float .turn.user .text {
  align-self: flex-end;
  max-width: 88%;
  background: color-mix(in oklab, var(--fg) 7%, var(--bg-raised));
  border: 1px solid var(--line);
  border-radius: 3px;
  padding: 8px 10px;
  font-size: var(--fs-sm);
  line-height: 1.5;
  color: var(--fg);
}
.chat-float .turn.assistant .text {
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--fg);
}
.chat-float .turn.assistant .text p { margin: 0 0 8px 0; text-wrap: pretty; }
.chat-float .turn.assistant .text p:last-child { margin-bottom: 0; }
.chat-float .tools-strip {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--line);
}

.cf-composer {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid var(--line);
  background: var(--bg-raised);
}
.cf-composer textarea {
  flex: 1 1 auto;
  resize: none;
  background: var(--bg-sunk);
  border: 1px solid var(--line);
  border-radius: 3px;
  color: var(--fg);
  font: inherit;
  font-size: var(--fs-sm);
  line-height: 1.45;
  padding: 8px 10px;
  outline: none;
  transition: border-color 120ms ease;
}
.cf-composer textarea:focus { border-color: var(--line-strong); }
.cf-composer textarea::placeholder { color: var(--fg-faint); }
.cf-composer .btn {
  flex: 0 0 auto;
  padding: 8px 12px;
  font-size: var(--fs-sm);
}
.cf-composer .btn .arr {
  font-family: var(--f-mono);
  margin-left: 4px;
  color: var(--fg-dim);
}
.cf-composer .btn.primary {
  background: var(--fg);
  color: var(--bg);
  border: 1px solid var(--fg);
}
.cf-composer .btn.primary:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.cf-composer .btn.primary .arr { color: color-mix(in oklab, var(--bg) 70%, var(--fg)); }
.cf-composer .btn.ghost {
  border: 1px solid var(--line-strong);
  color: var(--fg-muted);
}
.cf-composer .btn.ghost:hover { color: var(--fg); }

.cf-foot {
  padding: 6px 12px 10px;
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.04em;
  border-top: 1px solid color-mix(in oklab, var(--line) 60%, transparent);
  background: var(--bg-raised);
  color: var(--fg-faint);
}

/* Mobile: pill collapses to icon-only; panel goes near full-screen */
@media (max-width: 640px) {
  .chat-launcher {
    right: 16px;
    bottom: 16px;
    padding: 10px 14px 10px 12px;
  }
  .chat-launcher .lc-label { display: none; }
  .chat-float {
    right: 12px;
    left: 12px;
    bottom: 12px;
    width: auto;
    height: min(72vh, calc(100vh - 24px));
  }
}

/* ============================================================
   Methodology page (/methodology)
   ------------------------------------------------------------
   Single-column, 760px reading width via .editorial. No images.
   Five sections: what we do, pipeline, verify-vs-editorial,
   flag form, what we are not. Same tokens as the rest of the site.
   ============================================================ */
.methodology .meth-kicker {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.methodology .meth-updated {
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.06em;
  color: var(--fg-faint);
  text-transform: uppercase;
}
.methodology .h-display {
  font-family: var(--f-serif);
  font-size: clamp(28px, 4vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-7) 0;
  color: var(--fg);
}
.methodology .meth-section {
  border-top: 1px solid var(--line);
  padding-block: var(--s-7) var(--s-2);
  margin-top: var(--s-6);
}
.methodology .meth-section:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.methodology .meth-h {
  font-family: var(--f-sans);
  font-size: var(--fs-xl);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-5) 0;
  color: var(--fg);
}
.methodology .meth-section > p {
  font-size: var(--fs-md);
  line-height: 1.65;
  color: var(--fg);
  text-wrap: pretty;
  margin: 0 0 var(--s-4) 0;
}
.methodology .meth-section > p.dim { color: var(--fg-muted); }

/* Pipeline list — numbered editorial steps */
.meth-pipeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.meth-pipeline > li {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--s-4);
  align-items: start;
}
.meth-pipeline .step {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  color: var(--fg-faint);
  padding-top: 4px;
}
.meth-pipeline h3 {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  font-weight: 600;
  margin: 0 0 4px 0;
  color: var(--fg);
}
.meth-pipeline p {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--fg-muted);
  margin: 0;
  text-wrap: pretty;
}
.meth-pipeline p.strong {
  color: var(--fg);
  border-left: 2px solid var(--accent);
  padding: 2px 0 2px var(--s-4);
}

/* Two-column verify-vs-editorial */
.meth-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}
@media (max-width: 720px) {
  .meth-cols { grid-template-columns: 1fr; }
}
.meth-col {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: var(--s-5);
  background: color-mix(in oklab, var(--fg) 2%, var(--bg-raised));
}
.meth-col-head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px dashed var(--line);
}
.meth-col-head .dim {
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.04em;
}
.meth-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.meth-col li {
  font-size: var(--fs-sm);
  line-height: 1.55;
  color: var(--fg);
  padding-left: var(--s-4);
  position: relative;
  text-wrap: pretty;
}
.meth-col li::before {
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
}
.meth-col.verify li::before { content: "✓"; color: var(--signal-emerged); }
.meth-col.editorial li::before { content: "⚠"; color: var(--signal-walked); }
.meth-col li strong { color: var(--fg); font-weight: 600; }

/* Verified / editorial badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  border: 1px solid var(--line);
}
.badge.ok { color: var(--signal-emerged); border-color: color-mix(in oklab, var(--signal-emerged) 35%, var(--line)); }
.badge.warn { color: var(--signal-walked); border-color: color-mix(in oklab, var(--signal-walked) 35%, var(--line)); }

/* Flag form */
.meth-flag { scroll-margin-top: 80px; }
.meth-form {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  margin-top: var(--s-4);
}
.meth-form label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.meth-form .lbl {
  font-family: var(--f-mono);
  font-size: var(--fs-mono-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.meth-form .lbl .dim {
  text-transform: none;
  letter-spacing: 0;
  color: var(--fg-faint);
}
.meth-form input,
.meth-form textarea,
.meth-form .meth-select {
  font-family: var(--f-sans);
  font-size: var(--fs-md);
  color: var(--fg);
  background: var(--bg-sunk);
  border: 1px solid var(--line);
  border-radius: 3px;
  padding: 10px 12px;
  outline: none;
  transition: border-color 120ms ease;
  resize: vertical;
}
.meth-form input:focus,
.meth-form textarea:focus,
.meth-form .meth-select:focus { border-color: var(--line-strong); }
.meth-form input::placeholder,
.meth-form textarea::placeholder { color: var(--fg-faint); }
/* Native select sized to match inputs; chevron supplied via background. */
.meth-form .meth-select {
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  padding-right: 32px;
  background-image: linear-gradient(45deg, transparent 50%, var(--fg-muted) 50%),
                    linear-gradient(135deg, var(--fg-muted) 50%, transparent 50%);
  background-position: calc(100% - 16px) 16px, calc(100% - 11px) 16px;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}
.meth-form .meth-select:invalid { color: var(--fg-faint); }
.meth-form-foot {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  flex-wrap: wrap;
  margin-top: var(--s-2);
}
.meth-mailto {
  font-size: var(--fs-sm);
}
.meth-mailto:hover { color: var(--fg); }
.meth-thanks {
  border: 1px solid var(--line);
  border-left: 3px solid var(--signal-emerged);
  padding: var(--s-5);
  border-radius: 0 4px 4px 0;
  background: color-mix(in oklab, var(--signal-emerged) 5%, var(--bg-raised));
  margin-top: var(--s-4);
}
.meth-thanks p { margin: 0 0 var(--s-4) 0; line-height: 1.55; color: var(--fg); }

/* "What we are not" — calm bullet list, not screaming */
.meth-not {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.meth-not li {
  font-size: var(--fs-md);
  line-height: 1.6;
  color: var(--fg-muted);
  padding-left: var(--s-4);
  position: relative;
  text-wrap: pretty;
}
.meth-not li::before {
  content: "—";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--fg-faint);
  font-family: var(--f-mono);
}
.meth-not li strong { color: var(--fg); font-weight: 600; }

/* ============================================================
   Flag-this-finding link (on /[ticker] finding cards)
   Quiet, dashed, sits in the .actions row beside Citation/AskAgent
   ============================================================ */
.flag-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-sm);
  color: var(--fg-faint);
  border: 1px dashed transparent;
  background: transparent;
  padding: 6px 10px;
  border-radius: 2px;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: color 120ms ease, border-color 120ms ease, background 120ms ease;
}
.flag-link:hover {
  color: var(--fg-muted);
  border-color: var(--line);
  background: color-mix(in oklab, var(--fg) 3%, transparent);
}
.flag-link .arr {
  font-family: var(--f-mono);
  font-size: 0.95em;
  color: var(--fg-faint);
}
.flag-link:hover .arr { color: var(--fg-muted); }
