/*
Theme Name: Pomares Gazeta V2
Theme URI: https://pomaresdamantiqueira.com.br
Author: Oswaldo Jacob
Description: Tema editorial em estilo de gazeta para o site do Pr. Oswaldo Jacob — textos bíblicos, reflexões, vida no campo no sítio Pomares da Mantiqueira (Carlos Euler) e loja virtual de produtos do sítio (ovos, mel e terra adubada). Compatível com WooCommerce.
Version: 2.0.2
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pomares-gazeta
Tags: blog, news, e-commerce, two-columns, custom-menu, custom-logo, featured-images
*/

/* ==========================================================================
   1. TOKENS
   ========================================================================== */
:root {
  /* Paleta — terra, mata e mel da Mantiqueira */
  --papel: #FBF7EE;          /* papel envelhecido de gazeta */
  --papel-2: #F3ECDD;        /* papel sombreado */
  --tinta: #221E18;          /* tinta de impressão */
  --tinta-suave: #5C544A;
  --fio: #D9CFBC;            /* fios/hairlines */
  --mata: #1F4D2C;           /* verde da serra — Textos Bíblicos */
  --ceu: #2E4A66;            /* azul de entardecer — Reflexões */
  --terra: #8A4A22;          /* terra adubada — Vida no Campo */
  --mel: #C2820A;            /* mel — Loja */
  --mel-claro: #F5E3BC;
  --branco: #FFFFFF;

  /* Tipografia */
  --f-display: "Fraunces", Georgia, serif;          /* títulos com personalidade */
  --f-texto: "Source Serif 4", Georgia, serif;      /* leitura longa */
  --f-ui: "Public Sans", -apple-system, sans-serif; /* rótulos, navegação, loja */

  --medida: 68ch;
  --raio: 2px;
  --sombra: 0 1px 0 var(--fio), 0 12px 28px -18px rgba(34, 30, 24, .35);
}

/* ==========================================================================
   2. BASE
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}

body {
  margin: 0;
  background: var(--papel);
  color: var(--tinta);
  font-family: var(--f-texto);
  font-size: 1.0625rem;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--mata); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--mel); }

a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 2px solid var(--mel);
  outline-offset: 3px;
}

h1, h2, h3, h4 {
  font-family: var(--f-display);
  font-weight: 600;
  line-height: 1.12;
  letter-spacing: -.01em;
  margin: 0 0 .5em;
  text-wrap: balance;
}

.wrap {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 32px);
}

.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden; clip: rect(1px,1px,1px,1px);
}

/* ==========================================================================
   3. CABEÇALHO — masthead de gazeta
   ========================================================================== */
.topo-fio {
  font-family: var(--f-ui);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--tinta-suave);
  border-bottom: 1px solid var(--fio);
  padding: .5rem 0;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.masthead {
  text-align: center;
  padding: clamp(1.4rem, 4vw, 2.4rem) 0 1.2rem;
  border-bottom: 3px double var(--tinta);
}

.masthead .titulo-site {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(2.1rem, 6vw, 3.6rem);
  letter-spacing: -.015em;
  margin: 0;
}
.masthead .titulo-site a { color: var(--tinta); text-decoration: none; }
.masthead .titulo-site a:hover { color: var(--mata); }

.masthead .descricao-site {
  font-family: var(--f-ui);
  font-size: .8rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--tinta-suave);
  margin: .5rem 0 0;
}

.custom-logo { margin: 0 auto .6rem; max-height: 84px; width: auto; }

/* Navegação por seções, com a cor de cada caderno */
.nav-secoes {
  border-bottom: 1px solid var(--tinta);
  background: var(--papel);
  position: sticky;
  top: 0;
  z-index: 50;
}
.nav-secoes ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}
.nav-secoes a {
  display: block;
  font-family: var(--f-ui);
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--tinta);
  text-decoration: none;
  padding: .85rem 1.1rem;
  border-bottom: 3px solid transparent;
}
.nav-secoes a:hover { border-bottom-color: var(--mel); color: var(--tinta); }
.nav-secoes li.cor-mata  a:hover, .nav-secoes li.cor-mata  a[aria-current] { border-bottom-color: var(--mata); }
.nav-secoes li.cor-ceu   a:hover, .nav-secoes li.cor-ceu   a[aria-current] { border-bottom-color: var(--ceu); }
.nav-secoes li.cor-terra a:hover, .nav-secoes li.cor-terra a[aria-current] { border-bottom-color: var(--terra); }
.nav-secoes li.cor-mel   a:hover, .nav-secoes li.cor-mel   a[aria-current] { border-bottom-color: var(--mel); }

/* ==========================================================================
   4. ASSINATURA — faixa do Versículo do Dia
   ========================================================================== */
.versiculo-faixa {
  background: var(--mata);
  color: var(--papel);
  text-align: center;
  padding: .9rem clamp(16px, 4vw, 32px);
}
.versiculo-faixa .vf-texto {
  font-family: var(--f-display);
  font-style: italic;
  font-size: clamp(1rem, 2.4vw, 1.2rem);
  margin: 0;
}
.versiculo-faixa .vf-ref {
  font-family: var(--f-ui);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mel-claro);
  display: block;
  margin-top: .3rem;
}

/* ==========================================================================
   5. CARTÕES E SEÇÕES DA CAPA
   ========================================================================== */
.secao { padding: clamp(2rem, 5vw, 3.2rem) 0 1rem; }

.secao-cabeca {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  border-bottom: 2px solid var(--tinta);
  padding-bottom: .4rem;
  margin-bottom: 1.4rem;
}
.secao-cabeca h2 {
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  margin: 0;
}
.secao-cabeca .ver-tudo {
  margin-left: auto;
  font-family: var(--f-ui);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--tinta-suave);
}
.secao-cabeca .ver-tudo:hover { color: var(--mel); }

.selo {
  font-family: var(--f-ui);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--branco);
  background: var(--tinta);
  padding: .25rem .55rem;
  border-radius: var(--raio);
  display: inline-block;
}
.selo-mata  { background: var(--mata); }
.selo-ceu   { background: var(--ceu); }
.selo-terra { background: var(--terra); }
.selo-mel   { background: var(--mel); }

.grade {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
}
.grade-3 { grid-template-columns: repeat(3, 1fr); }
.grade-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grade-3, .grade-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .grade-3, .grade-4 { grid-template-columns: 1fr; } }

.cartao { display: flex; flex-direction: column; }
.cartao .miniatura {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--papel-2);
  border: 1px solid var(--fio);
  margin-bottom: .8rem;
}
.cartao .miniatura img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.cartao:hover .miniatura img { transform: scale(1.03); }

.cartao h3 { font-size: 1.18rem; margin: .45rem 0 .35rem; }
.cartao h3 a { color: var(--tinta); text-decoration: none; }
.cartao h3 a:hover { color: var(--mata); }
.cartao .resumo { color: var(--tinta-suave); font-size: .95rem; margin: 0 0 .5rem; }
.cartao .meta {
  font-family: var(--f-ui);
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--tinta-suave);
}

/* Destaque da capa */
.destaque {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: clamp(1.4rem, 4vw, 2.6rem);
  padding: clamp(1.6rem, 4vw, 2.6rem) 0;
  border-bottom: 1px solid var(--fio);
}
@media (max-width: 820px) { .destaque { grid-template-columns: 1fr; } }
.destaque .miniatura {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid var(--fio);
  background: var(--papel-2);
}
.destaque .miniatura img { width: 100%; height: 100%; object-fit: cover; }
.destaque h2 { font-size: clamp(1.7rem, 4.5vw, 2.6rem); margin: .6rem 0; }
.destaque h2 a { color: var(--tinta); text-decoration: none; }
.destaque h2 a:hover { color: var(--mata); }
.destaque .resumo { font-size: 1.08rem; color: var(--tinta-suave); }

/* Faixa do sítio na capa */
.faixa-sitio {
  background: var(--papel-2);
  border-top: 1px solid var(--fio);
  border-bottom: 1px solid var(--fio);
  margin-top: 2rem;
}
.faixa-sitio .wrap {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 1.5rem;
  padding-top: 1.4rem;
  padding-bottom: 1.4rem;
}
@media (max-width: 700px) { .faixa-sitio .wrap { grid-template-columns: 1fr; } }
.faixa-sitio h2 { font-size: 1.35rem; margin: 0 0 .2rem; }
.faixa-sitio p { margin: 0; color: var(--tinta-suave); }

/* ==========================================================================
   6. BOTÕES
   ========================================================================== */
.botao,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  font-family: var(--f-ui);
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--branco) !important;
  background: var(--mata) !important;
  border: none;
  border-radius: var(--raio);
  padding: .8rem 1.4rem;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  transition: background .2s ease;
}
.botao:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--mel) !important; color: var(--tinta) !important; }

.botao-mel { background: var(--mel) !important; color: var(--tinta) !important; }
.botao-mel:hover { background: var(--tinta) !important; color: var(--branco) !important; }

.botao-whatsapp { background: #1B7B45 !important; }

/* ==========================================================================
   7. ARTIGO (single) — leitura de sermão
   ========================================================================== */
.artigo { padding: clamp(2rem, 5vw, 3.5rem) 0; }
.artigo-cabeca { max-width: var(--medida); margin: 0 auto 1.6rem; text-align: center; }
.artigo-cabeca h1 { font-size: clamp(1.9rem, 5vw, 3rem); }
.artigo-cabeca .meta {
  font-family: var(--f-ui);
  font-size: .76rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--tinta-suave);
  margin-top: .8rem;
}
.artigo-capa { max-width: 880px; margin: 0 auto 2rem; border: 1px solid var(--fio); }

.artigo-corpo { max-width: var(--medida); margin: 0 auto; font-size: 1.125rem; }
.artigo-corpo > p:first-of-type::first-letter {
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 3.4em;
  float: left;
  line-height: .82;
  padding: .06em .12em 0 0;
  color: var(--mata);
}
.artigo-corpo h2 { font-size: 1.5rem; margin-top: 2rem; }
.artigo-corpo h3 { font-size: 1.25rem; margin-top: 1.6rem; }
.artigo-corpo blockquote {
  margin: 1.8rem 0;
  padding: .2rem 0 .2rem 1.4rem;
  border-left: 3px solid var(--mel);
  font-family: var(--f-display);
  font-style: italic;
  font-size: 1.18em;
  color: var(--mata);
}
.artigo-corpo img { border: 1px solid var(--fio); margin: 1.5rem auto; }

.artigo-rodape {
  max-width: var(--medida);
  margin: 2.5rem auto 0;
  padding-top: 1.2rem;
  border-top: 3px double var(--fio);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  font-family: var(--f-ui);
  font-size: .85rem;
}

/* Navegação entre posts e comentários */
.post-navigation, .comments-area { max-width: var(--medida); margin: 2rem auto 0; }
.comments-area input, .comments-area textarea {
  width: 100%;
  border: 1px solid var(--fio);
  background: var(--branco);
  padding: .7rem;
  font-family: var(--f-texto);
  border-radius: var(--raio);
}

/* ==========================================================================
   8. ARQUIVOS / LISTAS
   ========================================================================== */
.arquivo-cabeca {
  text-align: center;
  padding: clamp(2rem, 5vw, 3rem) 0 1rem;
  border-bottom: 3px double var(--tinta);
  margin-bottom: 2rem;
}
.arquivo-cabeca h1 { font-size: clamp(1.8rem, 4.5vw, 2.6rem); margin: .4rem 0 0; }
.arquivo-cabeca .descricao { color: var(--tinta-suave); max-width: 60ch; margin: .6rem auto 0; }

.paginacao {
  display: flex;
  justify-content: center;
  gap: .4rem;
  padding: 2.5rem 0;
  font-family: var(--f-ui);
}
.paginacao .page-numbers {
  padding: .5rem .9rem;
  border: 1px solid var(--fio);
  text-decoration: none;
  color: var(--tinta);
  border-radius: var(--raio);
}
.paginacao .page-numbers.current { background: var(--tinta); color: var(--branco); border-color: var(--tinta); }
.paginacao .page-numbers:hover { border-color: var(--mel); }

/* ==========================================================================
   9. LOJA (WooCommerce)
   ========================================================================== */
.loja-aviso {
  background: var(--mel-claro);
  border: 1px solid var(--mel);
  padding: 1.2rem 1.4rem;
  border-radius: var(--raio);
  font-family: var(--f-ui);
  font-size: .95rem;
}

.woocommerce ul.products li.product {
  text-align: left;
  background: var(--branco);
  border: 1px solid var(--fio);
  border-radius: var(--raio);
  padding: 0 0 1rem;
  overflow: hidden;
}
.woocommerce ul.products li.product img { margin-bottom: .8rem; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--f-display);
  font-size: 1.1rem;
  padding: 0 1rem;
}
.woocommerce ul.products li.product .price {
  font-family: var(--f-ui);
  font-weight: 700;
  color: var(--mata) !important;
  padding: 0 1rem;
}
.woocommerce ul.products li.product .button { margin: .6rem 1rem 0; }
.woocommerce span.onsale { background: var(--mel); border-radius: var(--raio); }

/* Cartões estáticos da loja (fallback sem WooCommerce) */
.produto-cartao {
  background: var(--branco);
  border: 1px solid var(--fio);
  border-top: 4px solid var(--mel);
  border-radius: var(--raio);
  padding: 1.4rem;
  box-shadow: var(--sombra);
}
.produto-cartao .produto-icone { font-size: 2rem; line-height: 1; }
.produto-cartao h3 { font-size: 1.25rem; margin: .6rem 0 .3rem; }
.produto-cartao p { color: var(--tinta-suave); font-size: .95rem; margin: 0 0 1rem; }

/* ==========================================================================
   10. RODAPÉ
   ========================================================================== */
.rodape {
  background: var(--tinta);
  color: var(--papel);
  margin-top: 3rem;
}
.rodape a { color: var(--mel-claro); }
.rodape a:hover { color: var(--branco); }
.rodape-grade {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2rem;
  padding: clamp(2rem, 5vw, 3rem) 0;
}
.rodape h3 {
  font-family: var(--f-ui);
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mel);
}
.rodape ul { list-style: none; margin: 0; padding: 0; }
.rodape li { margin-bottom: .5rem; }
.rodape-fio {
  border-top: 1px solid rgba(251, 247, 238, .18);
  padding: 1.1rem 0;
  font-family: var(--f-ui);
  font-size: .75rem;
  letter-spacing: .06em;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .6rem;
  color: rgba(251, 247, 238, .7);
}

/* ==========================================================================
   11. BUSCA E WIDGETS
   ========================================================================== */
.form-busca { display: flex; gap: .5rem; max-width: 480px; }
.form-busca input[type="search"] {
  flex: 1;
  border: 1px solid var(--fio);
  background: var(--branco);
  padding: .7rem .9rem;
  font-family: var(--f-texto);
  border-radius: var(--raio);
}

.widget { margin-bottom: 2rem; }
.widget-title {
  font-family: var(--f-ui);
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  border-bottom: 2px solid var(--tinta);
  padding-bottom: .35rem;
}

/* Alinhamentos padrão do WordPress */
.alignleft { float: left; margin: 0 1.2rem .8rem 0; }
.alignright { float: right; margin: 0 0 .8rem 1.2rem; }
.aligncenter { margin-left: auto; margin-right: auto; }
.wp-caption { max-width: 100%; }
.wp-caption-text {
  font-family: var(--f-ui);
  font-size: .8rem;
  color: var(--tinta-suave);
  text-align: center;
  padding: .4rem 0;
}
