/* ═══════════════════════════════════════════════════════════════
   conteudo-estilo.css — Estilo das páginas ESTÁTICAS da Central de
   Conteúdo (/conteudo). Copiado para public/conteudo/estilo.css pelo
   scripts/gerar-conteudo.mjs.

   As páginas de conteúdo são HTML puro (sem React e sem JS) para que
   crawlers de IA e o Google leiam tudo sem executar nada. Por isso o
   visual do LayoutPublico é reproduzido aqui com classes próprias,
   usando os MESMOS tokens do design system (src/index.css, tema
   público padrão). Se a identidade visual mudar lá, atualize os
   valores das variáveis abaixo.
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* Superfícies */
  --areia: #f4ece0;
  --areia-escura: #ebe1d2;
  --creme: #fbf6ee;
  --borda: #e3d6c3;

  /* Tinta (textos) */
  --tinta: #2c2520;
  --tinta-suave: #6f655b;

  /* Acento (junção/sincronia) */
  --juncao: #b8893b;
  --juncao-claro: #f0e2c4;

  /* Gradiente da marca (roxo → rosa, o padrão público) */
  --gradiente-marca: linear-gradient(135deg, #7c5cff 0%, #fb7185 100%);

  /* Raios e sombras */
  --radius-suave: 0.75rem;
  --radius-cartao: 1.25rem;
  --shadow-cartao: 0 2px 4px rgba(74, 55, 40, 0.04), 0 12px 32px -8px rgba(74, 55, 40, 0.12);

  /* Tipografia */
  --font-display: 'Fraunces', 'Georgia', serif;
  --font-corpo: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--areia);
  color: var(--tinta);
  font-family: var(--font-corpo);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a {
  color: inherit;
}

img {
  max-width: 100%;
}

.fonte-display {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  letter-spacing: -0.01em;
}

/* ── Cabeçalho ─────────────────────────────────────────────────── */
.cabecalho {
  border-bottom: 1px solid var(--borda);
  background: rgba(251, 246, 238, 0.7);
  backdrop-filter: blur(8px);
}

.cabecalho-conteudo {
  max-width: 64rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
}

.marca {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--tinta);
  text-decoration: none;
}

.marca span {
  color: var(--juncao);
}

.navegacao {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.875rem;
  font-weight: 700;
}

.navegacao a {
  color: var(--tinta-suave);
  text-decoration: none;
}

.navegacao a:hover {
  color: var(--tinta);
}

.botao-marca {
  background-image: var(--gradiente-marca);
  color: #fff !important;
  border-radius: 9999px;
  padding: 0.5rem 1rem;
  box-shadow: var(--shadow-cartao);
}

/* ── Miolo ─────────────────────────────────────────────────────── */
main {
  width: 100%;
  max-width: 48rem;
  margin: 0 auto;
  padding: 2.5rem 1.25rem;
  flex: 1;
}

main.indice {
  max-width: 56rem;
}

/* Trilha (breadcrumb) */
.trilha {
  margin: 0 0 1.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--tinta-suave);
}

.trilha a {
  color: var(--tinta-suave);
  text-decoration: none;
}

.trilha a:hover {
  color: var(--tinta);
}

.trilha span[aria-current] {
  color: var(--tinta);
}

/* Cabeçalho do artigo */
.categoria-selo {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--juncao);
}

h1 {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin: 0.25rem 0 0;
}

.resumo {
  margin: 0.75rem 0 0;
  font-size: 1.125rem;
  color: var(--tinta-suave);
}

.meta-artigo {
  margin: 0.5rem 0 0;
  font-size: 0.875rem;
  color: var(--tinta-suave);
}

.capa {
  background-image: var(--gradiente-marca);
  margin-top: 1.5rem;
  height: 11rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-cartao);
  font-size: 3.75rem;
}

/* ── Corpo do artigo (HTML vindo do Markdown) ──────────────────── */
.artigo-corpo {
  margin-top: 2rem;
}

.artigo-corpo p {
  font-size: 1.05rem;
  line-height: 1.7;
  margin: 0.9rem 0;
}

.artigo-corpo h2 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  margin: 2.25rem 0 0.5rem;
}

.artigo-corpo h3 {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  margin: 1.5rem 0 0.25rem;
}

.artigo-corpo a {
  color: var(--juncao);
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.artigo-corpo ul,
.artigo-corpo ol {
  padding-left: 1.5rem;
  margin: 0.75rem 0;
}

.artigo-corpo li {
  margin: 0.4rem 0;
  line-height: 1.6;
}

.artigo-corpo blockquote {
  margin: 1rem 0;
  padding: 0.5rem 1.25rem;
  border-left: 4px solid var(--juncao);
  background: var(--creme);
  border-radius: 0 var(--radius-suave) var(--radius-suave) 0;
  color: var(--tinta-suave);
}

.artigo-corpo table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.25rem 0;
  font-size: 0.95rem;
  background: var(--creme);
  border-radius: var(--radius-suave);
  overflow: hidden;
}

.artigo-corpo th,
.artigo-corpo td {
  border: 1px solid var(--borda);
  padding: 0.6rem 0.75rem;
  text-align: left;
  vertical-align: top;
}

.artigo-corpo th {
  background: var(--areia-escura);
  font-weight: 700;
}

/* CTA contextual (no meio do artigo) */
.cta-contextual {
  margin: 2rem 0;
  padding: 1.25rem 1.5rem;
  background: var(--juncao-claro);
  border: 2px solid var(--juncao);
  border-radius: var(--radius-cartao);
}

.cta-contextual p {
  margin: 0;
  font-weight: 700;
}

.cta-contextual a {
  display: inline-block;
  margin-top: 0.5rem;
  color: var(--juncao);
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ── FAQ ───────────────────────────────────────────────────────── */
.faq {
  margin-top: 2.5rem;
}

.faq h2 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  margin: 0 0 1rem;
}

.faq-item {
  background: var(--creme);
  border: 2px solid var(--borda);
  border-radius: var(--radius-cartao);
  padding: 1rem 1.25rem;
  margin: 0.75rem 0;
}

.faq-item h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  font-family: var(--font-corpo);
}

.faq-item p {
  margin: 0.35rem 0 0;
  color: var(--tinta-suave);
}

/* ── Leia também ───────────────────────────────────────────────── */
.leia-tambem {
  margin-top: 2.5rem;
}

.leia-tambem h2 {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  margin: 0 0 1rem;
}

.leia-tambem-grade {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
}

.cartao-artigo {
  display: flex;
  flex-direction: column;
  background: var(--creme);
  border: 2px solid var(--borda);
  border-radius: var(--radius-cartao);
  padding: 1.25rem;
  text-decoration: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cartao-artigo:hover {
  border-color: var(--juncao);
  box-shadow: var(--shadow-cartao);
}

.cartao-artigo .emoji {
  font-size: 1.75rem;
}

.cartao-artigo h3 {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 800;
  margin: 0.5rem 0 0;
  color: var(--tinta);
}

.cartao-artigo p {
  margin: 0.5rem 0 0;
  font-size: 0.875rem;
  color: var(--tinta-suave);
}

.cartao-artigo .leitura {
  margin-top: auto;
  padding-top: 0.75rem;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--tinta-suave);
}

/* ── Índice (/conteudo) ────────────────────────────────────────── */
.indice-cabecalho p {
  margin: 0.75rem 0 0;
  font-size: 1.125rem;
  color: var(--tinta-suave);
}

.grupo-categoria {
  margin-top: 2.5rem;
}

.grupo-categoria > h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 1rem;
}

.grupo-categoria .leia-tambem-grade {
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
}

.selo-pilar {
  display: inline-block;
  margin-left: 0.5rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--juncao);
  border: 1px solid var(--juncao);
  border-radius: 9999px;
  padding: 0.05rem 0.5rem;
  vertical-align: middle;
}

/* ── CTA final ─────────────────────────────────────────────────── */
.cta-final {
  margin-top: 3rem;
  background-image: var(--gradiente-marca);
  border-radius: var(--radius-cartao);
  padding: 2rem 1.5rem;
  text-align: center;
  color: #fff;
}

.cta-final p.titulo {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0;
}

.cta-final p.texto {
  margin: 0.5rem auto 0;
  max-width: 34rem;
  color: rgba(255, 255, 255, 0.9);
}

.cta-final a {
  display: inline-block;
  margin-top: 1rem;
  background: #fff;
  color: var(--tinta);
  font-weight: 700;
  text-decoration: none;
  border-radius: 9999px;
  padding: 0.75rem 1.5rem;
  box-shadow: var(--shadow-cartao);
}

/* ── Rodapé ────────────────────────────────────────────────────── */
.rodape {
  margin-top: 3rem;
  border-top: 1px solid var(--borda);
  background: rgba(251, 246, 238, 0.6);
}

.rodape-conteudo {
  max-width: 64rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 2rem 1.25rem;
  text-align: center;
  font-size: 0.875rem;
  color: var(--tinta-suave);
}

.rodape-conteudo .marca {
  font-size: 1.125rem;
}

.rodape-conteudo a {
  color: var(--juncao);
  font-weight: 700;
  text-decoration: none;
}

.rodape-conteudo a:hover {
  text-decoration: underline;
}

/* ── Responsivo ────────────────────────────────────────────────── */
@media (max-width: 640px) {
  h1 {
    font-size: 1.9rem;
  }

  .navegacao {
    gap: 0.6rem;
  }

  .capa {
    height: 8rem;
    font-size: 3rem;
  }

  .artigo-corpo table {
    display: block;
    overflow-x: auto;
  }
}
