:root {
  --bg: #0d0f12;
  --bg-raised: #15181d;
  --bg-panel: #1a1e24;
  --fg: #d4d7da;
  --fg-bright: #e8ebee;
  --ink-soft: #6b7280;
  --rule: #262b33;
  --accent: #58a6ff;
  --accent-dim: #1f3a5f;
  --ok: #22c55e;
  --warn: #eab308;
  --err: #ef4444;
  --font-mono: "SF Mono", "Cascadia Code", "JetBrains Mono", "Fira Code", Consolas, monospace;
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--fg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ─── Topbar ─── */
.topbar {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 0;
  z-index: 100;
}
.logo {
  font-family: var(--font-mono);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--fg-bright);
  text-decoration: none;
  letter-spacing: 0.04em;
}
.logo:hover { color: var(--accent); }
.nav {
  display: flex;
  gap: 0.15rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.nav a {
  color: var(--ink-soft);
  text-decoration: none;
  padding: 0.25rem 0.55rem;
  border-radius: 3px;
  transition: color 0.12s, background 0.12s;
}
.nav a:hover { color: var(--fg-bright); background: var(--bg); }
.nav a.on { color: var(--accent); background: var(--accent-dim); }

/* ─── Breadcrumbs ─── */
.breadcrumbs {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  padding: 0.4rem 1.5rem;
  background: var(--bg-raised);
  border-bottom: 1px solid var(--rule);
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.breadcrumbs a { color: var(--accent); text-decoration: none; }
.breadcrumbs a:hover { text-decoration: underline; }
.breadcrumbs .here { color: var(--fg-bright); }

/* ─── Main content ─── */
main {
  max-width: 920px;
  margin: 0 auto;
  padding: 1.5rem 1.5rem 3rem;
}
main h1 {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 1.15rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-bright);
  margin-bottom: 1.25rem;
}
main h2 {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--fg);
  margin-bottom: 0.75rem;
}
main h3 { font-size: 1rem; font-weight: 500; margin-bottom: 0.25rem; }
p.lede {
  color: var(--ink-soft);
  font-size: 0.88rem;
  margin-bottom: 1.5rem;
  line-height: 1.7;
  max-width: 65ch;
}
code {
  font-family: var(--font-mono);
  font-size: 0.82em;
  background: var(--bg-raised);
  padding: 0.1em 0.3em;
  border-radius: 2px;
}

/* ─── Links ─── */
a { color: var(--accent); }
a:hover { color: var(--fg-bright); }

/* ─── Buttons ─── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.45rem 0.95rem;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background: var(--bg-raised);
  color: var(--fg);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.btn:hover {
  background: var(--bg-panel);
  border-color: var(--ink-soft);
  color: var(--fg-bright);
}
.btn.primary {
  background: var(--accent-dim);
  border-color: var(--accent);
  color: var(--accent);
}
.btn.primary:hover { background: var(--accent); color: #000; }
.btn.small { padding: 0.25rem 0.6rem; font-size: 0.68rem; }

/* ─── Forms ─── */
label { display: block; margin: 0.6rem 0 0.25rem; }
label.check {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: var(--fg);
  cursor: pointer;
  margin: 0.5rem 0;
}
input[type="text"],
input[type="url"],
select {
  width: 100%;
  padding: 0.4rem 0.55rem;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: 3px;
  color: var(--fg);
  transition: border-color 0.12s;
}
input[type="text"]:focus,
input[type="url"]:focus,
select:focus { outline: none; border-color: var(--accent); }
input[type="checkbox"] {
  accent-color: var(--accent);
  width: 1rem; height: 1rem;
}
.hint {
  font-size: 0.75rem;
  color: var(--ink-soft);
  margin-top: 0.15rem;
  line-height: 1.5;
}
.hint code { font-size: 0.85em; }

/* ─── Stacked form ─── */
form.stacked { max-width: 560px; }
form.stacked label { margin-top: 1rem; }
form.stacked label.check { margin-top: 0.5rem; }

/* ─── Alerts ─── */
.alert {
  padding: 0.6rem 1rem;
  border-left: 3px solid var(--err);
  background: var(--bg-raised);
  font-size: 0.85rem;
  margin-bottom: 1rem;
  border-radius: 0 3px 3px 0;
  color: var(--err);
}

/* ─── Panels ─── */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 1rem 1.25rem;
  margin-bottom: 1rem;
}
.panel-header {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}
.panel-header h2 { margin-bottom: 0; font-size: 0.85rem; }

/* ─── Feed / feed items ─── */
.feed { display: flex; flex-direction: column; gap: 0.35rem; }
.feed-item {
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--rule);
}
.feed-item:last-child { border-bottom: none; }
.feed-item .meta {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--ink-soft);
  letter-spacing: 0.02em;
}
.feed-item .meta .src { color: var(--accent); }
.feed-item .meta .sep { margin: 0 0.3rem; opacity: 0.5; }
.feed-item h3 { font-size: 0.92rem; font-weight: 500; line-height: 1.5; }
.feed-item h3 a { color: var(--fg-bright); text-decoration: none; }
.feed-item h3 a:hover { color: var(--accent); }
.feed-item .summary {
  font-size: 0.82rem;
  color: var(--ink-soft);
  line-height: 1.55;
  margin-top: 0.15rem;
}

/* ─── Badges ─── */
.badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  padding: 0.05rem 0.35rem;
  border-radius: 3px;
  background: var(--bg-raised);
  border: 1px solid var(--rule);
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.badge.on { color: var(--ok); border-color: var(--ok); }
.badge.off { color: var(--ink-soft); border-color: var(--rule); }
.badge.kind { color: var(--accent); border-color: var(--accent-dim); }

/* ─── Grid KPIs ─── */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.75rem;
  margin-top: 0.5rem;
}
.kpi {
  background: var(--bg-raised);
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: 0.75rem 1rem;
  text-align: center;
}
.kpi .num {
  display: block;
  font-family: var(--font-mono);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--fg-bright);
  line-height: 1.2;
}
.kpi .lbl {
  display: block;
  font-size: 0.7rem;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-top: 0.15rem;
}

/* ─── Tables ─── */
table { width: 100%; border-collapse: collapse; }
th, td {
  border: 1px solid var(--rule);
  padding: 0.5rem 0.6rem;
  text-align: left;
  font-size: 0.82rem;
}
th {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  background: var(--bg-raised);
}
td { color: var(--fg); }
table.list { border: 1px solid var(--rule); }
table.list th, table.list td { border: none; border-bottom: 1px solid var(--rule); }
table.list tr:last-child td { border-bottom: none; }
.actions-cell { white-space: nowrap; }

/* ─── Mono ─── */
.mono {
  font-family: var(--font-mono);
  font-size: 0.82em;
}

/* ─── Actions bar ─── */
.actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}
.actions form { margin: 0; }

/* ─── Footer ─── */
.footer {
  text-align: center;
  padding: 1.5rem;
  border-top: 1px solid var(--rule);
  margin-top: 2rem;
}
.footer .mono {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
}

/* ─── Search results ─── */
.result-card { border: 1px solid var(--rule); padding: 1rem; margin: 1rem 0; border-radius: 4px; background: var(--bg-panel); }
.result-meta { color: var(--ink-soft); font-size: 0.85rem; font-family: var(--font-mono); }
.result-topicos { margin-top: 0.5rem; }
.result-topicos span { background: var(--accent-dim); color: var(--accent); padding: 2px 8px; border-radius: 3px; font-size: 0.8rem; margin-right: 4px; }
.result-entidades { color: var(--accent); font-size: 0.85rem; margin-top: 0.25rem; }
.result-resumo { margin-top: 0.5rem; font-style: italic; color: var(--ink-soft); }

/* ─── Topic / Entity tags ─── */
.topic-list { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; }
.topic-tag { background: var(--accent-dim); color: var(--accent); padding: 4px 10px; border-radius: 15px; font-size: 0.85rem; cursor: pointer; text-decoration: none; }
.topic-tag:hover { background: var(--accent); color: #000; }
.topic-count { color: var(--ink-soft); font-size: 0.8rem; margin-left: 4px; }
.entity-list { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-top: 1rem; }
.entity-tag { background: var(--bg-raised); color: var(--fg); padding: 4px 10px; border-radius: 15px; font-size: 0.85rem; text-decoration: none; border: 1px solid var(--rule); }
.entity-tag:hover { border-color: var(--accent); }

/* ─── Section block ─── */
.section { margin: 2rem 0; padding: 1rem; border: 1px solid var(--rule); border-radius: 4px; background: var(--bg-raised); }

/* ─── Misc ─── */
pre { background: var(--bg-raised); padding: 1rem; overflow-x: auto; border: 1px solid var(--rule); border-radius: 3px; font-family: var(--font-mono); font-size: 0.8rem; line-height: 1.5; }
#graph { height: 400px; border: 1px solid var(--rule); border-radius: 4px; background: var(--bg-raised); }

/* ─── Tag cloud (topics/entities) ─── */
.tag-list { display: flex; flex-wrap: wrap; gap: 0.4rem; margin: 0.5rem 0; }
.tag {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 12px;
  font-size: 0.78rem;
  cursor: default;
}
.tag.topic { background: var(--accent-dim); color: var(--accent); }
.tag.entity { background: var(--bg-raised); color: var(--fg); border: 1px solid var(--rule); }
.tag .count { color: var(--ink-soft); font-size: 0.72rem; margin-left: 0.2rem; }

/* ─── Rich result card ─── */
.card {
  border: 1px solid var(--rule);
  padding: 1rem;
  margin: 1rem 0;
  border-radius: 4px;
  background: var(--bg-panel);
}
.card-meta { color: var(--ink-soft); font-size: 0.85rem; font-family: var(--font-mono); }
.card-resumo { margin-top: 0.5rem; font-style: italic; color: var(--ink-soft); font-size: 0.88rem; }

/* ─── Two-column comparison ─── */
.cols-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.compare-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1rem 0; }
.compare-side { border: 1px solid var(--rule); border-radius: 4px; padding: 1rem; background: var(--bg); }
.compare-side h4 {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent);
  margin-bottom: 0.5rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--rule);
}

/* ─── Coverage bar ─── */
.coverage-bar { height: 6px; background: var(--rule); border-radius: 3px; overflow: hidden; margin: 0.25rem 0; }
.coverage-bar .fill { height: 100%; background: var(--accent); border-radius: 3px; }

/* ─── Status flow / transitions ─── */
.status-flow { display: flex; align-items: center; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.75rem; flex-wrap: wrap; }
.status-flow .arrow { color: var(--ink-soft); }

/* ─── Toggle tabs ─── */
.tabs { display: flex; gap: 0; border: 1px solid var(--rule); border-radius: 4px; overflow: hidden; }
.tabs .tab {
  padding: 0.4rem 0.9rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: var(--bg-raised);
  color: var(--ink-soft);
  cursor: pointer;
  border-right: 1px solid var(--rule);
  transition: background 0.12s, color 0.12s;
}
.tabs .tab:last-child { border-right: none; }
.tabs .tab:hover { background: var(--bg-panel); color: var(--fg); }
.tabs .tab.active { background: var(--accent-dim); color: var(--accent); }

/* ─── Slider (wireframe-style) ─── */
.slider-wf {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--ink-soft);
}
.slider-track {
  flex: 1;
  height: 6px;
  background: var(--rule);
  border-radius: 3px;
  position: relative;
}
.slider-track .thumb {
  position: absolute;
  left: 30%;
  top: -4px;
  width: 14px;
  height: 14px;
  background: var(--accent);
  border-radius: 50%;
}

/* ─── Side panel (network) ─── */
.side-panel { background: var(--bg-panel); border: 1px solid var(--rule); border-radius: 4px; padding: 1rem; }
.side-panel h3 {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-soft);
  margin-bottom: 0.75rem;
}

/* ─── Network graph wrapper ─── */
#graph { height: 400px; border: 1px solid var(--rule); border-radius: 4px; background: var(--bg-raised); }
#graph svg { display: block; }
#graph .legend { font-family: var(--font-mono); font-size: 10px; }

/* ─── Badge variants ─── */
.badge.candidato { color: var(--warn); border-color: var(--warn); }
.badge.confirmada { color: var(--ok); border-color: var(--ok); }
.badge.rejeitada { color: var(--err); border-color: var(--err); }
.badge.arquivada { color: var(--ink-soft); border-color: var(--rule); }

/* ─── Section with left accent ─── */
.section { margin: 1.5rem 0; padding: 1rem; border: 1px solid var(--rule); border-radius: 4px; background: var(--bg-raised); }
.section.accent { border-left: 3px solid var(--accent); }
.section.ok { border-left: 3px solid var(--ok); }
.section.warn { border-left: 3px solid var(--warn); }
.section.err { border-left: 3px solid var(--err); }

/* ─── Alert variants ─── */
.alert.ok { border-left-color: var(--ok); color: var(--ok); }
.alert.warn { border-left-color: var(--warn); color: var(--warn); }

/* ─── Inline definition list ─── */
.dl-inline { display: grid; grid-template-columns: auto 1fr; gap: 0.3rem 1rem; font-size: 0.85rem; }
.dl-inline dt { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink-soft); white-space: nowrap; }
.dl-inline dd { color: var(--fg); overflow: hidden; text-overflow: ellipsis; }

/* ─── Accordion trigger ─── */
.accordion-trigger {
  cursor: pointer;
  user-select: none;
}
.accordion-trigger:hover { color: var(--accent); }
.accordion-body { display: none; margin-top: 0.5rem; }
.accordion-body.open { display: block; }
