/* ==========================================================================
   Taganroufe — "Caderno dos Enigmas"
   Identidade visual: caderno editorial cerebral / motivo de mosaico
   Paleta: tinta índigo, papel cru, marigold, teal, coral
   ========================================================================== */

:root {
  --tinta: #181a2e;
  --tinta-2: #23264a;
  --papel: #f6f2e9;
  --papel-2: #efe9da;
  --linha: #ddd3bf;
  --marigold: #e3922b;
  --marigold-esc: #c2761a;
  --teal: #1f8f80;
  --coral: #d7556a;
  --violeta: #6a5acd;
  --texto: #25283f;
  --texto-sub: #5c5f74;
  --branco: #ffffff;
  --sombra: 0 18px 50px -28px rgba(24, 26, 46, 0.55);
  --raio: 16px;
  --max: 1140px;
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, serif;
  --sans: "Segoe UI", system-ui, -apple-system, Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: "SFMono-Regular", "Cascadia Mono", "Consolas", "Liberation Mono", monospace;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  color: var(--texto);
  background-color: var(--papel);
  background-image:
    radial-gradient(circle at 1px 1px, rgba(24, 26, 46, 0.06) 1px, transparent 0);
  background-size: 22px 22px;
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: var(--serif); color: var(--tinta); line-height: 1.15; font-weight: 700; }
h1 { font-size: clamp(2.1rem, 6vw, 3.6rem); letter-spacing: -0.01em; }
h2 { font-size: clamp(1.6rem, 4vw, 2.4rem); }
h3 { font-size: 1.2rem; }

a { color: var(--marigold-esc); text-decoration: none; }
a:hover { text-decoration: underline; }

p { margin: 0 0 1rem; }

img, svg { max-width: 100%; }

.wrap { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 22px; }

.etiqueta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono);
  font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--teal); font-weight: 600;
  margin-bottom: 14px;
}
.etiqueta::before {
  content: ""; width: 26px; height: 2px; background: var(--marigold); display: inline-block;
}

.salto { display: block; height: 0; visibility: hidden; }

/* ---------- Barra de navegação ---------- */
.topo {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246, 242, 233, 0.88);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--linha);
}
.topo .wrap { display: flex; align-items: center; justify-content: space-between; min-height: 68px; gap: 16px; }
.marca { display: inline-flex; align-items: center; gap: 11px; font-family: var(--serif); font-weight: 700; font-size: 1.22rem; color: var(--tinta); }
.marca:hover { text-decoration: none; }
.marca .glifo { width: 34px; height: 34px; flex: 0 0 auto; }
.marca small { display: block; font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.2em; color: var(--texto-sub); text-transform: uppercase; }
.nav-links { display: flex; gap: 26px; align-items: center; }
.nav-links a { color: var(--texto); font-size: 0.95rem; font-weight: 500; }
.nav-links a:hover { color: var(--marigold-esc); text-decoration: none; }
.nav-cta {
  background: var(--tinta); color: var(--papel) !important; padding: 9px 18px; border-radius: 999px;
  font-size: 0.9rem !important; font-weight: 600;
}
.nav-cta:hover { background: var(--tinta-2); }
@media (max-width: 860px) { .nav-links { display: none; } }

/* ---------- Botões ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px; justify-content: center;
  font-weight: 600; font-size: 1rem; padding: 14px 26px; border-radius: 999px;
  border: 2px solid transparent; cursor: pointer; transition: transform .12s ease, box-shadow .2s ease;
  font-family: var(--sans);
}
.btn:hover { text-decoration: none; transform: translateY(-2px); }
.btn-primario { background: var(--marigold); color: var(--tinta); box-shadow: var(--sombra); }
.btn-primario:hover { background: var(--marigold-esc); color: var(--papel); }
.btn-fantasma { background: transparent; color: var(--tinta); border-color: var(--tinta); }
.btn-fantasma:hover { background: var(--tinta); color: var(--papel); }

/* ==========================================================================
   PÁGINA JORNAL (main.html) — masthead editorial + revista multi-coluna
   ========================================================================== */

/* ---------- Masthead (newspaper style) ---------- */
.masthead { background: var(--papel); border-bottom: 3px double var(--tinta); }
.masthead-fita { border-bottom: 1px solid var(--linha); background: var(--tinta); color: var(--papel); }
.masthead-fita-grade {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  min-height: 34px; font-family: var(--mono); font-size: 0.68rem;
  letter-spacing: 0.16em; text-transform: uppercase; color: rgba(246,242,233,0.82);
}
.masthead-fita-grade .mf-data { color: var(--marigold); font-weight: 600; }
.masthead-fita-grade .mf-lema { text-align: right; }

.masthead-titulo { padding: 22px 0 18px; text-align: center; border-bottom: 1px solid var(--linha); }
.masthead-titulo-grade { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.masthead-marca { display: inline-flex; align-items: center; gap: 14px; }
.masthead-marca:hover { text-decoration: none; }
.masthead-marca .glifo { width: 44px; height: 44px; flex: 0 0 auto; }
.masthead-marca .mm-nome {
  font-family: var(--serif); font-weight: 700; color: var(--tinta);
  font-size: clamp(2.2rem, 7vw, 3.7rem); letter-spacing: 0.04em; line-height: 1;
}
.masthead-tagline {
  margin: 0; font-family: var(--serif); font-style: italic; color: var(--texto-sub);
  font-size: clamp(0.92rem, 2.4vw, 1.08rem); max-width: 56ch;
}

/* ---------- Navegação masthead (dropdown / acordeão) ---------- */
.masthead-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246, 242, 233, 0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--linha);
}
.masthead-nav-grade { display: flex; align-items: center; justify-content: space-between; gap: 16px; min-height: 56px; }
.indice-toggle {
  display: inline-flex; align-items: center; gap: 9px; cursor: pointer;
  background: transparent; border: 1px solid var(--linha); border-radius: 999px;
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--tinta); font-weight: 600; padding: 9px 16px;
  transition: background .15s ease, color .15s ease;
}
.indice-toggle:hover { background: var(--tinta); color: var(--papel); }
.indice-toggle .it-icone { width: 18px; height: 18px; flex: 0 0 auto; }
.indice-toggle[aria-expanded="true"] { background: var(--tinta); color: var(--papel); }

.masthead-nav-links { display: flex; gap: 26px; align-items: center; }
.masthead-nav-links a { color: var(--texto); font-size: 0.95rem; font-weight: 500; }
.masthead-nav-links a:hover { color: var(--marigold-esc); text-decoration: none; }
.masthead-nav-links .mn-cta {
  background: var(--tinta); color: var(--papel) !important; padding: 9px 18px; border-radius: 999px;
  font-size: 0.9rem; font-weight: 600;
}
.masthead-nav-links .mn-cta:hover { background: var(--tinta-2); }

.indice-painel {
  border-top: 1px solid var(--linha);
  background: var(--papel);
  box-shadow: var(--sombra);
}
.indice-painel[hidden] { display: none; }
.indice-grade {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px 30px; padding-top: 22px; padding-bottom: 22px;
}
.indice-item {
  display: flex; gap: 14px; align-items: baseline; padding: 12px 8px;
  border-bottom: 1px solid var(--linha); color: var(--texto);
}
.indice-item:hover { text-decoration: none; background: var(--papel-2); }
.ii-num { font-family: var(--serif); font-weight: 700; color: var(--marigold-esc); font-size: 1.1rem; flex: 0 0 auto; }
.ii-corpo strong { display: block; font-family: var(--serif); color: var(--tinta); font-size: 1.05rem; }
.ii-corpo small { color: var(--texto-sub); font-size: 0.86rem; }

@media (max-width: 860px) {
  .masthead-nav-links { display: none; }
  .indice-grade { grid-template-columns: 1fr; gap: 0; }
}

/* ---------- Herói editorial ---------- */
.editorial-hero { padding: 56px 0 52px; border-bottom: 1px solid var(--linha); }
.eh-grade { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 52px; align-items: center; }
.eh-kicker {
  font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal); font-weight: 600; margin: 0 0 14px;
}
.eh-titulo { font-size: clamp(2.3rem, 5.6vw, 3.8rem); margin: 0; }
.eh-titulo em { color: var(--marigold-esc); font-style: italic; }
.eh-standfirst {
  font-family: var(--serif); font-size: 1.2rem; line-height: 1.55; color: var(--texto);
  max-width: 48ch; margin: 22px 0 26px;
  border-left: 3px solid var(--marigold); padding-left: 18px;
}
.eh-acoes { display: flex; flex-wrap: wrap; gap: 14px; }
.eh-byline { font-family: var(--mono); font-size: 0.78rem; letter-spacing: 0.06em; color: var(--texto-sub); margin: 24px 0 0; text-transform: uppercase; }
.eh-byline strong { color: var(--tinta); }
.eh-meta {
  margin: 26px 0 0; padding-top: 22px; border-top: 1px solid var(--linha);
  display: flex; gap: 36px; flex-wrap: wrap;
}
.eh-meta div { display: flex; flex-direction: column-reverse; }
.eh-meta dt { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--texto-sub); }
.eh-meta dd { margin: 0; font-family: var(--serif); font-weight: 700; font-size: 2rem; color: var(--tinta); line-height: 1; }

.eh-figura { margin: 0; }
.eh-ilustra {
  background: var(--branco); border: 1px solid var(--linha); border-radius: var(--raio);
  padding: 14px; box-shadow: var(--sombra);
}
.eh-ilustra svg { display: block; width: 100%; height: auto; border-radius: 8px; }
.eh-figura figcaption {
  margin-top: 12px; font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.04em;
  color: var(--texto-sub); text-align: center;
}

@media (max-width: 860px) {
  .eh-grade { grid-template-columns: 1fr; gap: 36px; }
  .editorial-hero { padding: 40px 0 38px; }
  .eh-figura { order: -1; max-width: 460px; margin: 0 auto; }
}

/* ---------- Secções genéricas ---------- */
section { padding: 64px 0; }
.cabeca-seccao { max-width: 60ch; margin-bottom: 40px; }
.cabeca-seccao p { color: var(--texto-sub); font-size: 1.05rem; }

.faixa-tinta { background: var(--tinta); color: var(--papel-2); }
.faixa-tinta h2, .faixa-tinta h3 { color: var(--papel); }
.faixa-tinta .cabeca-seccao p { color: rgba(246,242,233,0.78); }
.faixa-tinta .etiqueta { color: var(--marigold); }

/* ---------- Revista multi-coluna (análises como artigos) ---------- */
.revista-cabeca { max-width: 70ch; }
.revista-cabeca h2 { font-size: clamp(1.8rem, 4.4vw, 2.6rem); }
.revista-colunas {
  column-count: 3; column-gap: 36px;
  border-top: 2px solid var(--tinta); padding-top: 8px;
}
.artigo-jogo {
  break-inside: avoid; -webkit-column-break-inside: avoid;
  display: inline-block; width: 100%;
  padding: 26px 0 28px; border-bottom: 1px solid var(--linha);
  margin-bottom: 8px;
}
.artigo-jogo .folio {
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--texto-sub); margin: 0 0 6px;
}
.artigo-jogo .folio-num { color: var(--marigold-esc); font-weight: 700; }
.artigo-jogo h3 { font-size: 1.5rem; margin: 0 0 14px; }
.capa-artigo {
  width: 100%; aspect-ratio: 16 / 10; border-radius: 12px; overflow: hidden;
  background: var(--papel-2); border: 1px solid var(--linha);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 22px -14px rgba(24, 26, 46, 0.5); margin-bottom: 16px;
}
.capa-artigo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.artigo-jogo .lead { font-size: 0.97rem; color: var(--texto); margin: 0 0 14px; }
.artigo-jogo .lead::first-letter {
  font-family: var(--serif); font-weight: 700; font-size: 3.1rem; line-height: 0.78;
  float: left; padding: 4px 10px 0 0; color: var(--tinta);
}
.pull {
  margin: 0 0 16px; padding: 4px 0 4px 16px; border-left: 3px solid var(--teal);
  font-family: var(--serif); font-style: italic; font-size: 1.08rem; line-height: 1.4; color: var(--tinta);
}
.nota-artigo {
  display: inline-flex; align-items: baseline; gap: 4px; margin: 0 0 14px;
  font-family: var(--mono); font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--texto-sub);
}
.nota-artigo b { font-family: var(--serif); font-size: 1.7rem; color: var(--marigold-esc); letter-spacing: 0; }
.nota-artigo span { color: var(--texto-sub); }
.etiquetas-jogo { display: flex; gap: 7px; flex-wrap: wrap; margin: 0; padding: 0; list-style: none; }
.etiquetas-jogo li { font-size: 0.74rem; background: var(--papel-2); border: 1px solid var(--linha); padding: 3px 9px; border-radius: 999px; color: var(--texto-sub); }
.artigo-jogo.destaque h3 { color: var(--marigold-esc); }

@media (max-width: 960px) { .revista-colunas { column-count: 2; column-gap: 30px; } }
@media (max-width: 640px) { .revista-colunas { column-count: 1; } .capa-artigo { aspect-ratio: 16 / 9; } }

/* ---------- Desafio do Dia (secção única e interativa) ---------- */
.desafio { background: var(--tinta); color: var(--papel-2); }
.desafio h2 { color: var(--papel); font-size: clamp(1.9rem, 5vw, 3rem); }
.desafio .etiqueta { color: var(--marigold); }
.desafio-grade { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.desafio-intro p { color: rgba(246,242,233,0.84); max-width: 46ch; }

.pista {
  margin-top: 26px; background: rgba(255,255,255,0.05); border: 1px solid rgba(246,242,233,0.16);
  border-radius: 14px; padding: 20px 22px;
}
.pista-rotulo { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--marigold); margin: 0 0 8px; }
.pista-clue { font-family: var(--serif); font-size: 1.06rem; color: var(--papel); margin: 0 0 14px; }
.pista-letras { color: rgba(246,242,233,0.6); font-style: italic; }
.pista-btn {
  cursor: pointer; background: transparent; color: var(--papel);
  border: 1.5px solid var(--marigold); border-radius: 999px; padding: 9px 18px;
  font-family: var(--sans); font-weight: 600; font-size: 0.9rem; transition: background .15s ease, color .15s ease;
}
.pista-btn:hover { background: var(--marigold); color: var(--tinta); }
.pista-resposta {
  margin: 14px 0 0; font-family: var(--serif); font-weight: 700; font-size: 1.5rem;
  letter-spacing: 0.12em; color: var(--marigold);
}
.pista-resposta[hidden] { display: none; }

.puzzle {
  background: var(--papel); color: var(--texto); border-radius: 18px; padding: 22px;
  box-shadow: var(--sombra); max-width: 380px; margin: 0 auto; width: 100%;
}
.puzzle-topo { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.puzzle-mov { font-family: var(--mono); font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--texto-sub); }
.puzzle-mov b { font-family: var(--serif); font-size: 1.25rem; color: var(--tinta); }
.puzzle-baralhar {
  cursor: pointer; background: var(--marigold); color: var(--tinta); border: none; border-radius: 999px;
  padding: 9px 18px; font-family: var(--sans); font-weight: 600; font-size: 0.9rem; transition: background .15s ease, color .15s ease;
}
.puzzle-baralhar:hover { background: var(--marigold-esc); color: var(--papel); }
.puzzle-tabuleiro {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  aspect-ratio: 1; background: var(--papel-2); border: 1px solid var(--linha);
  border-radius: 12px; padding: 8px;
}
.peca-puzzle {
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  border: 1px solid var(--linha); border-radius: 9px;
  background: var(--branco); color: var(--tinta);
  font-family: var(--serif); font-weight: 700; font-size: clamp(1.4rem, 7vw, 2.1rem);
  transition: transform .08s ease, background .12s ease; aspect-ratio: 1;
}
.peca-puzzle:hover { background: var(--marigold); transform: translateY(-1px); }
.peca-puzzle:active { transform: translateY(0); }
.peca-puzzle.vazia { background: transparent; border: 1px dashed var(--linha); cursor: default; box-shadow: none; }
.peca-puzzle.vazia:hover { transform: none; background: transparent; }
.puzzle-status {
  margin: 16px 0 0; font-size: 0.9rem; color: var(--texto-sub); text-align: center; min-height: 1.4em;
}
.puzzle-status.ganhou { color: var(--teal); font-weight: 600; }

@media (max-width: 860px) {
  .desafio-grade { grid-template-columns: 1fr; gap: 32px; }
  .desafio-intro { text-align: left; }
}

/* ---------- Metodologia ---------- */
.metodo-grade {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 2px solid var(--tinta);
}
.metodo-item {
  padding: 28px 26px 28px 0; border-right: 1px solid var(--linha);
}
.metodo-item:last-child { border-right: none; }
.metodo-item:not(:first-child) { padding-left: 26px; }
.mi-num { font-family: var(--serif); font-style: italic; font-size: 1.4rem; color: var(--marigold-esc); }
.metodo-item h3 { margin: 8px 0 8px; font-size: 1.25rem; }
.metodo-item p { margin: 0; color: var(--texto-sub); font-size: 0.97rem; }
.metodo-rodape { margin-top: 32px; }
@media (max-width: 820px) {
  .metodo-grade { grid-template-columns: 1fr; }
  .metodo-item { border-right: none; border-bottom: 1px solid var(--linha); padding: 22px 0; }
  .metodo-item:not(:first-child) { padding-left: 0; }
  .metodo-item:last-child { border-bottom: none; }
}

/* ---------- Ranking ---------- */
.tabela-ranking { width: 100%; border-collapse: collapse; background: var(--branco); border-radius: var(--raio); overflow: hidden; box-shadow: var(--sombra); }
.tabela-ranking th, .tabela-ranking td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--linha); font-size: 0.95rem; }
.tabela-ranking thead th { background: var(--tinta); color: var(--papel); font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; }
.tabela-ranking tbody tr:last-child td { border-bottom: none; }
.tabela-ranking tbody tr:nth-child(odd) { background: var(--papel); }
.tabela-ranking .pos { font-family: var(--serif); font-weight: 700; color: var(--marigold-esc); font-size: 1.1rem; }
.tabela-ranking tbody td { color: var(--tinta); }
.tabela-envolve { overflow-x: auto; }

/* ---------- Sobre / dois blocos ---------- */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.lista-checada { list-style: none; padding: 0; margin: 18px 0 0; }
.lista-checada li { position: relative; padding-left: 30px; margin-bottom: 12px; color: var(--texto-sub); }
.lista-checada li::before {
  content: ""; position: absolute; left: 0; top: 4px; width: 16px; height: 16px;
  border-radius: 5px; background: var(--teal);
}
@media (max-width: 820px) { .duo { grid-template-columns: 1fr; gap: 28px; } }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; }
.faq details {
  background: var(--branco); border: 1px solid var(--linha); border-radius: 12px;
  padding: 4px 20px; margin-bottom: 12px;
}
.faq summary {
  cursor: pointer; font-family: var(--serif); font-weight: 700; font-size: 1.08rem; color: var(--tinta);
  padding: 14px 0; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 14px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--mono); font-size: 1.5rem; color: var(--marigold-esc); }
.faq details[open] summary::after { content: "\2013"; }
.faq details p { color: var(--texto-sub); margin: 0 0 16px; }

/* ---------- Formulário de subscrição ---------- */
#newsletter .wrap { max-width: 1000px; }
.bloco-form {
  position: relative; overflow: hidden;
  background: linear-gradient(150deg, var(--tinta) 0%, var(--tinta-2) 100%);
  border: 1px solid rgba(246,242,233,0.12);
  border-radius: 26px; padding: 48px; color: var(--papel); box-shadow: var(--sombra);
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 44px; align-items: stretch;
}
.bloco-form::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(circle at 1px 1px, rgba(246,242,233,0.05) 1px, transparent 0);
  background-size: 22px 22px;
}
.bloco-form > * { position: relative; z-index: 1; }
.bloco-form h2 { color: var(--papel); }
.bloco-form p { color: rgba(246,242,233,0.82); }
.bloco-form .etiqueta { color: var(--marigold); }
.form-intro { display: flex; flex-direction: column; }
.form-beneficios { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 11px; }
.form-beneficios li {
  position: relative; padding-left: 30px; font-size: 0.95rem; color: rgba(246,242,233,0.88);
}
.form-beneficios li::before {
  content: ""; position: absolute; left: 0; top: 6px; width: 16px; height: 16px;
  border-radius: 5px; background: var(--marigold);
}

.form-cartao {
  background: rgba(246,242,233,0.05);
  border: 1px solid rgba(246,242,233,0.16);
  border-radius: 18px; padding: 26px;
}
.form-cartao-titulo {
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--marigold); margin: 0 0 18px;
}
form#subscribeForm { display: grid; gap: 16px; }
.campo-linha { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.campo { display: grid; gap: 6px; }
.campo label { font-size: 0.82rem; font-family: var(--mono); letter-spacing: 0.06em; color: rgba(246,242,233,0.85); }
.campo label .opcional { color: rgba(246,242,233,0.55); text-transform: none; letter-spacing: 0; }
.campo label .obrigatorio { color: var(--marigold); }
.campo input[type="text"], .campo input[type="tel"], .campo input[type="email"] {
  width: 100%; padding: 13px 15px; border-radius: 10px; border: 1px solid rgba(246,242,233,0.25);
  background: rgba(255,255,255,0.06); color: var(--papel); font-size: 1rem; font-family: var(--sans);
  transition: border-color .15s ease, background .15s ease;
}
.campo input::placeholder { color: rgba(246,242,233,0.45); }
.campo input:focus { outline: 2px solid var(--marigold); border-color: var(--marigold); background: rgba(255,255,255,0.1); }
.consentimento {
  display: flex; gap: 11px; align-items: flex-start; font-size: 0.86rem; color: rgba(246,242,233,0.85);
  background: rgba(255,255,255,0.04); border: 1px solid rgba(246,242,233,0.12);
  border-radius: 10px; padding: 13px 14px;
}
.consentimento input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--marigold); flex: 0 0 auto; }
.consentimento a { color: var(--marigold); }
.form-nota { font-size: 0.78rem; color: rgba(246,242,233,0.6); margin: 0; text-align: center; }
#successMsg {
  display: none; margin-top: 6px; padding: 14px 16px; border-radius: 10px;
  background: rgba(31,143,128,0.22); border: 1px solid var(--teal); color: #d8f5ef; font-size: 0.92rem;
}
#successMsg.show { display: block; }
.bloco-form .btn-primario { width: 100%; }
@media (max-width: 820px) {
  .bloco-form { grid-template-columns: 1fr; padding: 30px; gap: 30px; }
}
@media (max-width: 460px) {
  .campo-linha { grid-template-columns: 1fr; }
  .form-cartao { padding: 20px; }
}

/* ---------- Rodapé ---------- */
.rodape { background: var(--tinta); color: rgba(246,242,233,0.72); padding: 56px 0 28px; }
.rodape-grade { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 40px; }
.rodape h4 { color: var(--papel); font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; margin: 0 0 16px; }
.rodape a { color: rgba(246,242,233,0.78); display: block; margin-bottom: 9px; font-size: 0.94rem; }
.rodape a:hover { color: var(--marigold); }
.rodape .marca { color: var(--papel); margin-bottom: 14px; }
.rodape .marca small { color: rgba(246,242,233,0.55); }
.nap { font-style: normal; font-size: 0.92rem; line-height: 1.9; }
.nap a { display: inline; margin: 0; }
.rodape-base {
  border-top: 1px solid rgba(246,242,233,0.14); margin-top: 40px; padding-top: 22px;
  display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  font-size: 0.82rem; color: rgba(246,242,233,0.5);
}
@media (max-width: 820px) { .rodape-grade { grid-template-columns: 1fr; gap: 30px; } }

/* ---------- Páginas de conteúdo (legal) ---------- */
.cabecalho-pagina { background: var(--tinta); color: var(--papel); padding: 56px 0 44px; }
.cabecalho-pagina h1 { color: var(--papel); }
.cabecalho-pagina p { color: rgba(246,242,233,0.78); max-width: 60ch; margin-top: 12px; }
.migalhas { font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--marigold); margin-bottom: 18px; }
.migalhas a { color: var(--marigold); }
.conteudo-legal { max-width: 760px; margin: 0 auto; padding: 56px 22px; }
.conteudo-legal h2 { margin-top: 38px; font-size: 1.45rem; }
.conteudo-legal h3 { margin-top: 26px; }
.conteudo-legal ul { padding-left: 22px; }
.conteudo-legal li { margin-bottom: 8px; color: var(--texto-sub); }
.conteudo-legal .atualizado { font-family: var(--mono); font-size: 0.8rem; color: var(--texto-sub); }
.caixa-info { background: var(--papel-2); border-left: 4px solid var(--marigold); padding: 18px 22px; border-radius: 0 12px 12px 0; margin: 24px 0; }
.caixa-info p:last-child { margin-bottom: 0; }
.tabela-dados { width: 100%; border-collapse: collapse; margin: 18px 0; }
.tabela-dados th, .tabela-dados td { border: 1px solid var(--linha); padding: 10px 12px; text-align: left; font-size: 0.92rem; vertical-align: top; }
.tabela-dados th { background: var(--papel-2); font-family: var(--mono); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.06em; }

/* ---------- Contacto ---------- */
.grelha-contacto { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.cartao-contacto { background: var(--branco); border: 1px solid var(--linha); border-radius: var(--raio); padding: 28px; }
.cartao-contacto h3 { margin-top: 0; }
@media (max-width: 820px) { .grelha-contacto { grid-template-columns: 1fr; } }

/* ---------- 404 ---------- */
.erro-404 { text-align: center; padding: 90px 22px; max-width: 620px; margin: 0 auto; }
.erro-404 .codigo { font-family: var(--serif); font-size: clamp(5rem, 20vw, 9rem); color: var(--marigold); line-height: 1; }

/* ---------- Acessibilidade ---------- */
:focus-visible { outline: 3px solid var(--marigold); outline-offset: 2px; border-radius: 4px; }
.skip {
  position: absolute; left: -999px; top: 0; background: var(--marigold); color: var(--tinta);
  padding: 10px 16px; z-index: 100; border-radius: 0 0 8px 0; font-weight: 600;
}
.skip:focus { left: 0; }

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}
