/* ============================================================================
   Hitch AI — Budget Request Explorer  ·  HitchAI visual language
   (tokens mirror the marketing site: styles.css)
   ========================================================================== */
:root {
  --bg: #0a0b0d;
  --bg-soft: #101216;
  --bg-panel: #0d0f12;
  --ink: #f4f1ea;
  --ink-dim: #9a988f;
  --ink-faint: #5b5a55;
  --accent: #e8a13c;
  --accent-soft: #f0c98a;
  --line: rgba(244, 241, 234, 0.1);
  --line-soft: rgba(244, 241, 234, 0.06);
  --good: #7bbf7b;
  --warn: #d98c5f;
  --serif: "Instrument Serif", Georgia, serif;
  --sans: "Inter", system-ui, sans-serif;
  --mono: "JetBrains Mono", monospace;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 300;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}
.grain {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
a { color: inherit; }
::selection { background: var(--accent); color: #1a1206; }

/* scrollbars */
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-thumb { background: rgba(244,241,234,0.12); border-radius: 100px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(244,241,234,0.22); }
*::-webkit-scrollbar-track { background: transparent; }

/* ---------- App shell ---------- */
.app { position: relative; z-index: 1; height: 100vh; display: grid; grid-template-rows: auto 1fr; }

.topbar {
  display: flex; align-items: center; gap: 1.4rem;
  padding: 0.9rem clamp(1rem, 3vw, 2rem);
  border-bottom: 1px solid var(--line-soft);
  background: rgba(10, 11, 13, 0.75); backdrop-filter: blur(14px);
}
.brand { font-family: var(--serif); font-size: 1.35rem; letter-spacing: 0.01em; text-decoration: none; white-space: nowrap; }
.brand b { color: var(--accent); font-style: italic; font-weight: 400; }
.topbar__title {
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-dim); padding-left: 1.4rem; border-left: 1px solid var(--line); white-space: nowrap;
}
.topbar__spacer { flex: 1; }
.provenance {
  font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.04em; color: var(--ink-faint);
  text-align: right; line-height: 1.5;
}
.provenance b { color: var(--ink-dim); font-weight: 400; }

/* ---------- Body layout ---------- */
.workspace { display: grid; grid-template-columns: 320px 1fr; min-height: 0; }
.rail {
  border-right: 1px solid var(--line-soft); overflow-y: auto; padding: 1.4rem 1.2rem 3rem;
  background: var(--bg-panel);
}
.main { overflow-y: auto; padding: 1.8rem clamp(1.2rem, 3.5vw, 3rem) 5rem; }

/* ---------- Rail blocks ---------- */
.rail__block { margin-bottom: 1.9rem; }
.rail__label {
  font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 0.8rem; display: flex; justify-content: space-between; align-items: center;
}
.rail__label span { color: var(--ink-faint); }

.search {
  width: 100%; background: var(--bg-soft); border: 1px solid var(--line);
  color: var(--ink); font-family: var(--sans); font-size: 0.9rem; padding: 0.7rem 0.85rem;
  border-radius: 8px; transition: border-color 0.25s;
}
.search:focus { outline: none; border-color: var(--accent); }
.search::placeholder { color: var(--ink-faint); }
.search__hint { font-size: 0.68rem; color: var(--ink-faint); margin-top: 0.5rem; font-family: var(--mono); letter-spacing: 0.03em; }

/* segmented + chips */
.seg { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.chip {
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.04em;
  color: var(--ink-dim); background: var(--bg-soft); border: 1px solid var(--line);
  padding: 0.35rem 0.6rem; border-radius: 100px; cursor: pointer; transition: all 0.2s var(--ease);
  user-select: none;
}
.chip:hover { color: var(--ink); border-color: var(--ink-faint); }
.chip.on { background: var(--accent); color: #1a1206; border-color: var(--accent); }
.chip--est.on { background: var(--accent); }

.facet { display: flex; flex-direction: column; gap: 0.1rem; }
.facet__row {
  display: flex; justify-content: space-between; align-items: center; gap: 0.6rem;
  padding: 0.4rem 0.2rem; cursor: pointer; border-radius: 6px; transition: background 0.18s;
  font-size: 0.85rem; color: var(--ink-dim);
}
.facet__row:hover { background: var(--line-soft); color: var(--ink); }
.facet__row.on { color: var(--ink); }
.facet__check {
  width: 14px; height: 14px; border: 1px solid var(--line); border-radius: 3px; flex-shrink: 0;
  display: grid; place-items: center; font-size: 0.6rem; color: #1a1206;
}
.facet__row.on .facet__check { background: var(--accent); border-color: var(--accent); }
.facet__name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.facet__count { font-family: var(--mono); font-size: 0.7rem; color: var(--ink-faint); }
.facet__caret { font-family: var(--mono); font-size: 0.72rem; color: var(--ink-faint); padding: 0 0.15rem 0 0.35rem; border-radius: 4px; }
.facet__caret:hover { color: var(--accent); background: var(--line-soft); }
.subfacet { margin: 0.1rem 0 0.4rem 0.55rem; padding-left: 0.6rem; border-left: 1px solid var(--line-soft); }
.facet__row--sub { padding: 0.32rem 0.2rem; }
.facet__row--sub .facet__name { font-size: 0.78rem; color: var(--ink-dim); }
.subfacet .facet-more { font-size: 0.62rem; padding: 0.3rem 0.2rem 0.1rem; }

.linkbtn {
  background: none; border: none; color: var(--accent); font-family: var(--mono);
  font-size: 0.66rem; letter-spacing: 0.04em; cursor: pointer; padding: 0;
}
.linkbtn:hover { color: var(--accent-soft); }
.facet-more {
  background: none; border: none; color: var(--accent); font-family: var(--mono);
  font-size: 0.66rem; letter-spacing: 0.03em; cursor: pointer; padding: 0.45rem 0.2rem 0.1rem;
  display: block;
}
.facet-more:hover { color: var(--accent-soft); }
.results--scroll { max-height: 48vh; overflow-y: auto; }

/* ---------- Results list ---------- */
.results { display: flex; flex-direction: column; }
.result {
  text-align: left; width: 100%; background: none; border: none; cursor: pointer;
  padding: 0.7rem 0.4rem; border-top: 1px solid var(--line-soft);
  display: grid; grid-template-columns: 1fr auto; gap: 0.2rem 0.6rem; align-items: baseline;
  transition: background 0.18s;
}
.result:hover { background: var(--line-soft); }
.result.on { background: rgba(232,161,60,0.08); }
.result__title { color: var(--ink); font-size: 0.88rem; line-height: 1.3; }
.result__amt { font-family: var(--mono); font-size: 0.82rem; color: var(--accent); white-space: nowrap; }
.result__meta { grid-column: 1 / -1; font-family: var(--mono); font-size: 0.66rem; color: var(--ink-faint); letter-spacing: 0.03em; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.result__stub { color: var(--warn); }

/* ---------- Main: shared ---------- */
.section-tag {
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent); display: block; margin-bottom: 0.9rem;
}
.h-serif { font-family: var(--serif); font-weight: 400; letter-spacing: -0.01em; }

.empty { display: grid; place-items: center; height: 100%; text-align: center; color: var(--ink-faint); }
.empty__inner { max-width: 30ch; }
.empty h2 { font-family: var(--serif); font-weight: 400; font-size: 2rem; color: var(--ink-dim); margin-bottom: 0.6rem; }

/* overview tiles */
.tiles { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); margin-bottom: 2rem; }
.tile { background: var(--bg); padding: 1.2rem 1.3rem; }
.tile__num { font-family: var(--serif); font-size: clamp(1.8rem, 3.4vw, 2.6rem); line-height: 1; }
.tile__num small { font-size: 0.5em; color: var(--ink-dim); font-family: var(--mono); margin-left: 0.2em; }
.tile__label { font-size: 0.78rem; color: var(--ink-dim); margin-top: 0.5rem; }

.panel { border: 1px solid var(--line-soft); border-radius: 10px; padding: 1.3rem 1.4rem; margin-bottom: 1.5rem; background: var(--bg-panel); }
.panel__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.panel__head h3 { font-family: var(--serif); font-weight: 400; font-size: 1.35rem; }
.panel__note { font-family: var(--mono); font-size: 0.64rem; color: var(--ink-faint); letter-spacing: 0.03em; }

/* ranked bars */
.rank { display: flex; flex-direction: column; gap: 0.55rem; }
.rank__row { display: grid; grid-template-columns: 1fr auto; gap: 0.3rem 0.8rem; align-items: center; }
.rank__name { font-size: 0.85rem; color: var(--ink); }
.rank__name small { color: var(--ink-faint); font-family: var(--mono); font-size: 0.66rem; margin-left: 0.4rem; }
.rank__val { font-family: var(--mono); font-size: 0.8rem; color: var(--accent); }
.rank__bar { grid-column: 1 / -1; height: 3px; background: var(--line); border-radius: 2px; overflow: hidden; }
.rank__bar i { display: block; height: 100%; background: var(--accent); }

/* ---------- Detail view ---------- */
.detail__crumb { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.06em; color: var(--ink-faint); margin-bottom: 0.8rem; }
.detail__crumb b { color: var(--ink-dim); font-weight: 400; }
.detail__title { font-family: var(--serif); font-weight: 400; font-size: clamp(1.8rem, 4vw, 2.8rem); line-height: 1.05; margin-bottom: 0.5rem; }
.detail__title em { font-style: italic; color: var(--accent); }
.detail__sub { color: var(--ink-dim); font-size: 0.9rem; margin-bottom: 0.4rem; }
.badges { display: flex; flex-wrap: wrap; gap: 0.4rem; margin: 0.9rem 0 1.6rem; }
.badge {
  font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.05em; text-transform: uppercase;
  border: 1px solid var(--line); border-radius: 100px; padding: 0.28rem 0.65rem; color: var(--ink-dim);
}
.badge--accent { border-color: var(--accent); color: var(--accent); }
.badge--warn { border-color: var(--warn); color: var(--warn); }

.toolbar { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 1.6rem; }
.btn {
  font-family: var(--sans); font-size: 0.82rem; cursor: pointer;
  border: 1px solid var(--line); background: var(--bg-soft); color: var(--ink);
  padding: 0.5rem 0.9rem; border-radius: 100px; transition: all 0.25s var(--ease);
  display: inline-flex; align-items: center; gap: 0.4rem;
}
.btn:hover { border-color: var(--ink-faint); transform: translateY(-1px); }
.btn--accent { background: var(--accent); color: #1a1206; border-color: var(--accent); font-weight: 500; }
.btn--accent:hover { background: var(--accent-soft); }

/* funding table */
.ftable { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.ftable th, .ftable td { text-align: right; padding: 0.55rem 0.7rem; border-bottom: 1px solid var(--line-soft); }
.ftable th:first-child, .ftable td:first-child { text-align: left; }
.ftable thead th { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-faint); }
.ftable td { font-family: var(--mono); color: var(--ink-dim); }
.ftable td.amt { color: var(--ink); }
.ftable tr.is-request td { color: var(--ink); }
.ftable tr.is-request td.amt { color: var(--accent); }
.est-tag { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.05em; padding: 0.1rem 0.35rem; border-radius: 4px; border: 1px solid var(--line); color: var(--ink-faint); text-transform: uppercase; }
.est-tag.request { color: var(--accent); border-color: var(--accent); }
.est-tag.enacted { color: var(--good); border-color: rgba(123,191,123,0.4); }

/* trajectory sparkline */
.spark { display: flex; align-items: flex-end; gap: 6px; height: 90px; margin-top: 0.4rem; }
.spark__col { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 0.35rem; min-width: 0; }
.spark__bar { width: 100%; max-width: 42px; background: var(--line); border-radius: 3px 3px 0 0; position: relative; transition: height 0.5s var(--ease); }
.spark__bar.request { background: var(--accent); }
.spark__bar.enacted { background: var(--good); opacity: 0.8; }
.spark__bar.actual { background: var(--ink-faint); }
.spark__bar.outyear { background: rgba(232,161,60,0.35); }
.spark__yr { font-family: var(--mono); font-size: 0.6rem; color: var(--ink-faint); }
.spark__v { font-family: var(--mono); font-size: 0.6rem; color: var(--ink-dim); }

/* congressional add card */
.add-card { border: 1px solid var(--accent); border-radius: 10px; padding: 1.1rem 1.3rem; margin-bottom: 1rem; background: rgba(232,161,60,0.05); }
.add-card__head { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; margin-bottom: 0.7rem; }
.add-card__name { font-family: var(--serif); font-size: 1.25rem; }
.add-card__amt { font-family: var(--mono); color: var(--accent); font-size: 1.05rem; }
.recon { font-family: var(--mono); font-size: 0.74rem; color: var(--ink-dim); background: var(--bg); border: 1px dashed var(--line); border-radius: 8px; padding: 0.7rem 0.9rem; margin: 0.6rem 0; }
.recon b { color: var(--good); }
.add-components { list-style: none; display: grid; gap: 0; margin-top: 0.5rem; }
.add-components li { display: flex; justify-content: space-between; padding: 0.4rem 0; border-top: 1px solid var(--line-soft); font-size: 0.83rem; color: var(--ink-dim); }
.add-components li span:last-child { font-family: var(--mono); color: var(--ink); }

/* narrative + projects */
.prose { color: var(--ink-dim); font-size: 0.92rem; line-height: 1.65; max-width: 75ch; }
.prose.search-scope mark { background: var(--accent); color: #1a1206; padding: 0 2px; border-radius: 2px; }
.kicker { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); margin: 1.1rem 0 0.4rem; }

.proj { border-top: 1px solid var(--line); padding: 1.2rem 0; }
.proj__head { display: flex; align-items: baseline; gap: 0.6rem; margin-bottom: 0.5rem; }
.proj__no { font-family: var(--serif); font-style: italic; color: var(--accent); font-size: 1.4rem; }
.proj__title { font-family: var(--serif); font-size: 1.3rem; }

/* contracts table */
.ctable { width: 100%; border-collapse: collapse; font-size: 0.8rem; margin-top: 0.6rem; }
.ctable th, .ctable td { text-align: left; padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
.ctable thead th { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.05em; text-transform: uppercase; color: var(--ink-faint); }
.ctable td.num { text-align: right; font-family: var(--mono); color: var(--ink); white-space: nowrap; }
.ctable .perf { color: var(--ink); }
.ctable .loc { color: var(--ink-faint); font-size: 0.72rem; }

.cite { font-family: var(--mono); font-size: 0.7rem; color: var(--ink-faint); margin-top: 1rem; letter-spacing: 0.02em; }
.cite a { color: var(--accent); text-decoration: none; border-bottom: 1px solid transparent; }
.cite a:hover { border-color: var(--accent); }

.callout { border-left: 2px solid var(--warn); padding: 0.5rem 0 0.5rem 0.9rem; color: var(--ink-dim); font-size: 0.85rem; margin: 0.8rem 0; }
.callout b { color: var(--warn); }

/* market badge bin */
.marketbar { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-bottom: 1.4rem; padding: 0.8rem 1rem; border: 1px dashed var(--line); border-radius: 10px; }
.marketbar__label { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-faint); }

.rules { font-family: var(--mono); font-size: 0.66rem; color: var(--ink-faint); letter-spacing: 0.02em; line-height: 1.7; margin-top: 2rem; padding-top: 1.2rem; border-top: 1px solid var(--line-soft); }
.rules b { color: var(--ink-dim); font-weight: 400; }

/* ---------- full-extract additions ---------- */
.facet--scroll { max-height: 230px; overflow-y: auto; padding-right: 4px; }
.tiles--3 { grid-template-columns: repeat(3, 1fr); }
.tile__num.request { color: var(--accent); }
.tile__num.neg { color: var(--warn); }
.result__neg { color: var(--warn) !important; }
.result__more { font-family: var(--mono); font-size: 0.64rem; color: var(--ink-faint); padding: 0.7rem 0.4rem; letter-spacing: 0.03em; border-top: 1px solid var(--line-soft); }
.dot-detail { color: var(--accent); font-size: 0.6rem; vertical-align: middle; }
.cols2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.cols2 .panel { margin-bottom: 0; }
.rank__row--click { cursor: pointer; border-radius: 6px; padding: 0.15rem 0.3rem; margin: 0 -0.3rem; transition: background 0.16s; }
.rank__row--click:hover { background: var(--line-soft); }
.mover { display: flex; justify-content: space-between; align-items: baseline; gap: 0.8rem; padding: 0.45rem 0.3rem; border-top: 1px solid var(--line-soft); cursor: pointer; border-radius: 6px; transition: background 0.16s; }
.mover:hover { background: var(--line-soft); }
.mover__name { font-size: 0.84rem; color: var(--ink); }
.mover__d { font-family: var(--mono); font-size: 0.78rem; white-space: nowrap; }
.mover__d.up { color: var(--good); }
.mover__d.dn { color: var(--warn); }
.tag-new { font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.05em; text-transform: uppercase; color: var(--accent); border: 1px solid var(--accent); border-radius: 4px; padding: 0 0.3rem; margin-left: 0.3rem; }
.rank__val--green { color: var(--good); }
.rank__bar i.bar-green { background: var(--good); }
.tag-narr { font-family: var(--mono); font-size: 0.54rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-faint); border: 1px solid var(--line); border-radius: 3px; padding: 0 0.25rem; margin-left: 0.25rem; vertical-align: middle; }

/* ---------- v2: view nav ---------- */
.viewnav { display: flex; gap: 0.3rem; padding-left: 1.2rem; border-left: 1px solid var(--line); }
.viewnav__btn { font-family: var(--sans); font-size: 0.82rem; color: var(--ink-dim); background: none; border: 1px solid transparent; border-radius: 100px; padding: 0.4rem 0.85rem; cursor: pointer; transition: all 0.2s var(--ease); white-space: nowrap; }
.viewnav__btn:hover { color: var(--ink); }
.viewnav__btn.on { color: #1a1206; background: var(--accent); border-color: var(--accent); font-weight: 500; }

/* ---------- v2: why-match ---------- */
.panel--why { border-color: var(--accent); background: rgba(232,161,60,0.05); }

/* ---------- v2: legend ---------- */
.legend { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 0.8rem; font-family: var(--mono); font-size: 0.66rem; color: var(--ink-faint); }
.legend .lg { display: inline-flex; align-items: center; gap: 0.35rem; }
.legend .lg::before { content: ""; width: 10px; height: 10px; border-radius: 2px; background: var(--line); }
.legend .lg.actual::before { background: var(--ink-faint); }
.legend .lg.enacted::before { background: var(--good); opacity: 0.8; }
.legend .lg.request::before { background: var(--accent); }
.legend .lg.outyear::before { background: rgba(232,161,60,0.35); }

.spark--tall { height: 175px; }
.spark--tall .spark__bar { max-width: 70px; }

/* ---------- v2: narrative ---------- */
.narr-node { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.03em; color: var(--accent); margin: 1rem 0 0.2rem; }
.prose mark { background: var(--accent); color: #1a1206; padding: 0 2px; border-radius: 2px; }

/* ---------- v2: key-value ---------- */
.kv { display: grid; gap: 0; }
.kv__row { display: flex; justify-content: space-between; gap: 1rem; padding: 0.5rem 0; border-top: 1px solid var(--line-soft); font-size: 0.88rem; }
.kv__row span { color: var(--ink-dim); }
.kv__row b { color: var(--ink); font-weight: 400; text-align: right; }

/* ---------- v2: O&M change ---------- */
.omchg { padding: 0.7rem 0; border-top: 1px solid var(--line-soft); }
.omchg__dir { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.04em; text-transform: uppercase; }
.omchg__dir.up { color: var(--good); }
.omchg__dir.dn { color: var(--warn); }

/* ---------- v2: bills ---------- */
.bills { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); }
.billcard { background: var(--bg); padding: 1rem 1.1rem; display: flex; flex-direction: column; gap: 0.35rem; }
.billcard__chamber { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-faint); }
.billcard__num { font-family: var(--serif); font-size: 1.3rem; }
.billcard__title { font-size: 0.82rem; color: var(--ink-dim); line-height: 1.4; flex: 1; }
.billcard__link { font-family: var(--mono); font-size: 0.68rem; color: var(--accent); text-decoration: none; }
.billcard__link:hover { text-decoration: underline; }

/* ---------- v2: bill status & timeline ---------- */
.billstatus { padding: 0.9rem 0; border-top: 1px solid var(--line-soft); }
.billstatus:first-of-type { border-top: none; }
.billstatus__head { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; }
.billstatus__name { font-family: var(--serif); font-size: 1.15rem; }
.billstatus__date { font-family: var(--mono); font-size: 0.72rem; color: var(--ink-faint); margin-left: auto; }
.billstatus__latest { color: var(--ink-dim); font-size: 0.88rem; line-height: 1.5; margin-top: 0.5rem; }
.badge.st-floor { border-color: var(--accent); color: var(--accent); }
.badge.st-reported { border-color: var(--good); color: var(--good); }
.badge.st-markup { border-color: var(--accent-soft); color: var(--accent-soft); }
.badge.st-none { border-color: var(--warn); color: var(--warn); }
.badge.st-active { border-color: var(--ink-faint); color: var(--ink-dim); }
.src { color: var(--accent); text-decoration: none; font-family: var(--mono); }
.src:hover { color: var(--accent-soft); }
.outlook { margin-top: 0.6rem; padding: 0.6rem 0.8rem; border: 1px dashed var(--line); border-radius: 8px; background: rgba(232,161,60,0.03); }
.outlook__note { font-size: 0.85rem; color: var(--ink); line-height: 1.5; }
.outlook__chips { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.5rem; }
.outlook__chip { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.02em; color: var(--ink-dim); border: 1px solid var(--line); border-radius: 100px; padding: 0.22rem 0.6rem; }
.outlook__chip--key { border-color: var(--accent); color: var(--accent); }
.outlook__tag { font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-faint); margin-top: 0.5rem; }
.prov { display: grid; grid-template-columns: 90px 1fr; gap: 0.7rem; padding: 0.5rem 0; border-top: 1px solid var(--line-soft); align-items: baseline; }
.prov__type { font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.04em; text-transform: uppercase; padding: 0.18rem 0.35rem; border-radius: 4px; border: 1px solid var(--line); color: var(--ink-faint); text-align: center; white-space: nowrap; }
.prov__type.pt-restrict { color: var(--warn); border-color: rgba(217,140,95,0.45); }
.prov__type.pt-auth { color: var(--good); border-color: rgba(123,191,123,0.45); }
.prov__type.pt-report { color: var(--accent); border-color: var(--accent); }
.prov__text { font-size: 0.86rem; color: var(--ink-dim); line-height: 1.45; }
.timeline { margin-top: 0.6rem; border-left: 1px solid var(--line); padding-left: 0.9rem; }
.tl { display: grid; grid-template-columns: 44px 1fr; gap: 0.6rem; padding: 0.4rem 0; border-top: 1px solid var(--line-soft); }
.tl:first-child { border-top: none; }
.tl__date { font-family: var(--mono); font-size: 0.68rem; color: var(--accent); }
.tl__text { font-size: 0.8rem; color: var(--ink-dim); line-height: 1.45; }

/* ---------- v2: tables ---------- */
.ftable--fydp td, .ftable--marks td { font-size: 0.8rem; }
.ftable td.amt-up { color: var(--good); font-family: var(--mono); text-align: right; }
.ftable td.amt-dn { color: var(--warn); font-family: var(--mono); text-align: right; }
.row--click { cursor: pointer; }
.row--click:hover { background: var(--line-soft); }
.mover--node { cursor: pointer; }

/* ---------- responsive ---------- */
@media (max-width: 820px) {
  body { overflow: auto; }
  .app { height: auto; }
  .workspace { grid-template-columns: 1fr; }
  .rail { border-right: none; border-bottom: 1px solid var(--line-soft); max-height: none; }
  .provenance { display: none; }
  .cols2 { grid-template-columns: 1fr; }
  .tiles--3 { grid-template-columns: 1fr; }
  .topbar { flex-wrap: wrap; }
  .viewnav { padding-left: 0; border-left: none; width: 100%; order: 3; overflow-x: auto; }
  .ftable--fydp, .ftable--marks { display: block; overflow-x: auto; white-space: nowrap; }
}
