/* β.15-FinBR-B.2 — design tokens vIA-Finanças painel RAV vivo */

:root {
  /* Tipografia stack system (sem Google Fonts; sem dependência rede) */
  --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --font-mono: ui-monospace, "SFMono-Regular", Menlo, Consolas,
               "Liberation Mono", monospace;

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-8: 3rem;

  /* Tipografia size */
  --fs-xs: 0.75rem;
  --fs-sm: 0.875rem;
  --fs-base: 1rem;
  --fs-md: 1.125rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.5rem;
  --fs-2xl: 2rem;
  --fs-3xl: 2.5rem;

  /* Borda */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;

  /* Largura conteúdo */
  --content-max: 1100px;
}

/* Tema claro (default) — luminâncias verificadas WCAG AA */
:root, [data-theme="light"] {
  --bg: #ffffff;            /* L=1.000 */
  --bg-muted: #f5f7fa;      /* L=0.929 */
  --bg-card: #ffffff;
  --fg: #0d1b2a;            /* L=0.045; vs #ffffff = 17.4:1  AAA */
  --fg-muted: #4a5568;      /* L=0.107; vs #ffffff = 8.6:1   AAA */
  --fg-accent: #1f4ec7;     /* L=0.119; vs #ffffff = 7.7:1   AAA */
  --border: #e2e8f0;
  --selo-bg: #f5f3ff;
  --selo-fg: #4c1d95;       /* vs #f5f3ff ≈ 9.5:1            AAA */

  /* Cores por categoria fator */
  --cat-regime-fg: #1d4ed8;       /* azul */
  --cat-regime-bg: #dbeafe;
  --cat-choque-fg: #b45309;       /* laranja */
  --cat-choque-bg: #fef3c7;
  --cat-macro-fg: #047857;        /* verde */
  --cat-macro-bg: #d1fae5;
  --cat-empirica-fg: #4b5563;     /* cinza */
  --cat-empirica-bg: #f3f4f6;
}

/* Tema escuro — luminâncias verificadas WCAG AA */
[data-theme="dark"] {
  --bg: #0d1b2a;            /* L=0.045 */
  --bg-muted: #161f30;
  --bg-card: #14202f;
  --fg: #e5e7eb;            /* L=0.866; vs #0d1b2a = 13.4:1 AAA */
  --fg-muted: #9ca3af;      /* L=0.395; vs #0d1b2a = 6.4:1  AA  */
  --fg-accent: #66c2ff;     /* L=0.521; vs #0d1b2a = 8.4:1  AAA */
  --border: #2d3748;
  --selo-bg: #1f1b3a;
  --selo-fg: #c4b5fd;       /* vs #1f1b3a ≈ 8.0:1           AAA */

  --cat-regime-fg: #93c5fd;
  --cat-regime-bg: #1e3a8a;
  --cat-choque-fg: #fdba74;
  --cat-choque-bg: #78350f;
  --cat-macro-fg: #6ee7b7;
  --cat-macro-bg: #064e3b;
  --cat-empirica-fg: #d1d5db;
  --cat-empirica-bg: #374151;
}

/* Detecta preferência sistema (default antes de JS hydratar) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) {
    color-scheme: dark;
    --bg: #0d1b2a;
    --bg-muted: #161f30;
    --bg-card: #14202f;
    --fg: #e5e7eb;
    --fg-muted: #9ca3af;
    --fg-accent: #66c2ff;
    --border: #2d3748;
    --selo-bg: #1f1b3a;
    --selo-fg: #c4b5fd;
    --cat-regime-fg: #93c5fd; --cat-regime-bg: #1e3a8a;
    --cat-choque-fg: #fdba74; --cat-choque-bg: #78350f;
    --cat-macro-fg: #6ee7b7; --cat-macro-bg: #064e3b;
    --cat-empirica-fg: #d1d5db; --cat-empirica-bg: #374151;
  }
}

* { box-sizing: border-box; }
html { color-scheme: light dark; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: 1.6;
  background: var(--bg);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
}

a {
  color: var(--fg-accent);
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}
a:hover, a:focus { text-decoration-thickness: 2px; }

main { max-width: var(--content-max); margin: 0 auto; padding: var(--space-5) var(--space-4); }
header.site, footer.site {
  padding: var(--space-4);
  background: var(--bg-muted);
  border-bottom: 1px solid var(--border);
}
footer.site { border-top: 1px solid var(--border); border-bottom: 0; margin-top: var(--space-8); }

header.site .row, footer.site .row {
  max-width: var(--content-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.brand { display: flex; align-items: center; gap: var(--space-2); }
.brand svg { height: 32px; width: auto; color: var(--fg); }
.brand strong { font-size: var(--fs-md); }

.theme-toggle {
  margin-left: auto;
  background: var(--bg-card);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  font: inherit;
  cursor: pointer;
}
.theme-toggle:focus { outline: 2px solid var(--fg-accent); outline-offset: 2px; }

.hero { margin-bottom: var(--space-6); }
.hero h1 { font-size: var(--fs-3xl); margin: 0 0 var(--space-3); }
.hero p { font-size: var(--fs-md); color: var(--fg-muted); margin: 0; }

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-5);
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  text-decoration: none;
  color: var(--fg);
  transition: border-color 120ms ease, transform 120ms ease;
}
.card:hover { border-color: var(--fg-accent); transform: translateY(-1px); }
.card .indicador { font-weight: 700; font-size: var(--fs-md); }
.card .janela { color: var(--fg-muted); font-size: var(--fs-sm); }
.card .ic { font-family: var(--font-mono); font-size: var(--fs-sm); }
.card .status {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-muted);
}
.card .ts { font-size: var(--fs-xs); color: var(--fg-muted); }

h1, h2, h3 { line-height: 1.25; }
h2 { font-size: var(--fs-xl); margin-top: var(--space-6); }
h3 { font-size: var(--fs-lg); margin-top: var(--space-4); }

.section { margin-top: var(--space-5); }
.tag { display: inline-block; padding: 2px var(--space-2); border-radius: var(--radius-sm); font-size: var(--fs-xs); font-weight: 600; }
.tag-regime { background: var(--cat-regime-bg); color: var(--cat-regime-fg); }
.tag-choque { background: var(--cat-choque-bg); color: var(--cat-choque-fg); }
.tag-macro { background: var(--cat-macro-bg); color: var(--cat-macro-fg); }
.tag-empirica { background: var(--cat-empirica-bg); color: var(--cat-empirica-fg); }

table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  margin: var(--space-3) 0;
}
th, td {
  padding: var(--space-2) var(--space-3);
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
th { background: var(--bg-muted); font-weight: 600; }
td.num { font-family: var(--font-mono); text-align: right; white-space: nowrap; }

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-3);
  margin: var(--space-3) 0;
}
.kpi {
  background: var(--bg-muted);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
}
.kpi .label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--fg-muted); }
.kpi .value { font-family: var(--font-mono); font-size: var(--fs-lg); margin-top: var(--space-1); }
.kpi.highlight { border-color: var(--fg-accent); }

.selo {
  background: var(--selo-bg);
  color: var(--selo-fg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  word-break: break-all;
  margin: var(--space-2) 0;
}
.selo strong { font-family: var(--font-sans); display: block; font-size: var(--fs-sm); margin-bottom: var(--space-1); color: var(--fg); }

.disclaimer {
  background: var(--bg-muted);
  border-left: 3px solid var(--fg-accent);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  margin-top: var(--space-4);
  font-style: italic;
}
.r6flag {
  background: #fef3c7;
  color: #78350f;
  border-left: 3px solid #b45309;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  margin: var(--space-3) 0;
  font-size: var(--fs-sm);
}
[data-theme="dark"] .r6flag { background: #78350f; color: #fef3c7; }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .r6flag { background: #78350f; color: #fef3c7; }
}

footer.site small { color: var(--fg-muted); font-size: var(--fs-xs); }
footer.site .row { gap: var(--space-3); }
footer.site .contato { font-size: var(--fs-sm); }

.back-link {
  display: inline-block;
  margin-bottom: var(--space-3);
  font-size: var(--fs-sm);
}

@media (max-width: 600px) {
  .hero h1 { font-size: var(--fs-2xl); }
  header.site .row, footer.site .row { gap: var(--space-2); }
  th, td { padding: var(--space-2); font-size: var(--fs-xs); }
}
