/*
Theme Name: Treine Xadrez
Theme URI: https://treinexadrez.com.br
Description: Child theme do Twenty Twenty-Four para o hub de conteúdo Treine Xadrez. Site de autoridade em xadrez, otimizado para SEO, com funil para YouTube e cursos (Hotmart/Kiwify).
Author: Treine Xadrez
Template: twentytwentyfour
Version: 1.0.0
Text Domain: treinexadrez
*/

/* =========================================================
   VARIÁVEIS DE COR — PALETA TREINE XADREZ
   ========================================================= */
:root{
  --tx-azul-base: #0A3D7A;
  --tx-azul-acao: #1E5FB8;
  --tx-dourado: #C98A2E;
  --tx-dourado-hover: #A8721F;
  --tx-texto: #0D1B2A;
  --tx-texto-claro: #51606F;
  --tx-fundo: #F7F9FC;
  --tx-fundo-card: #FFFFFF;
  --tx-borda: #E1E8F0;
  --tx-verde: #3FA66A;
  --tx-fonte-titulo: "Merriweather", Georgia, serif;
  --tx-fonte-corpo: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* =========================================================
   BASE
   ========================================================= */
body{
  background-color: var(--tx-fundo);
  color: var(--tx-texto);
  font-family: var(--tx-fonte-corpo);
  font-size: 17px;
  line-height: 1.7;
}

h1,h2,h3,h4,h5,h6{
  font-family: var(--tx-fonte-titulo);
  color: var(--tx-texto);
  font-weight: 700;
  line-height: 1.25;
}

a{
  color: var(--tx-azul-acao);
  text-decoration: none;
  transition: color .15s ease;
}
a:hover{ color: var(--tx-azul-base); }

::selection{ background: var(--tx-dourado); color: var(--tx-texto); }

/* =========================================================
   HEADER / NAVEGAÇÃO
   ========================================================= */
.tx-header{
  background: var(--tx-azul-base);
  padding: 14px 0;
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 2px 10px rgba(10,61,122,.15);
}
.tx-header .wp-block-navigation a{
  color: #FFFFFF !important;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: .2px;
}
.tx-header .wp-block-navigation a:hover{
  color: var(--tx-dourado) !important;
}
.tx-header .wp-block-site-logo img{
  border-radius: 50%;
}
.tx-header .wp-block-site-title a{
  color: #FFFFFF !important;
  font-family: var(--tx-fonte-titulo);
  font-weight: 700;
}

/* Botão CTA dentro do menu (classe usada no menu: "tx-btn-cta") */
.tx-header .wp-block-navigation-item.tx-btn-cta > a{
  background: var(--tx-dourado);
  color: var(--tx-texto) !important;
  padding: 8px 18px !important;
  border-radius: 6px;
  font-weight: 700;
}
.tx-header .wp-block-navigation-item.tx-btn-cta > a:hover{
  background: var(--tx-dourado-hover);
  color: var(--tx-texto) !important;
}

/* =========================================================
   BOTÕES GERAIS
   ========================================================= */
.wp-block-button.is-style-tx-dourado .wp-block-button__link{
  background-color: var(--tx-dourado);
  color: #FFFFFF;
  font-weight: 600;
  border-radius: 6px;
  padding: 13px 28px;
  font-size: 15px;
}
.wp-block-button.is-style-tx-dourado .wp-block-button__link:hover{
  background-color: var(--tx-dourado-hover);
}
.wp-block-button.is-style-tx-outline .wp-block-button__link{
  background: transparent;
  border: 1.5px solid #FFFFFF;
  color: #FFFFFF;
  font-weight: 600;
  border-radius: 6px;
  padding: 12px 26px;
}
.wp-block-button.is-style-tx-outline .wp-block-button__link:hover{
  background: rgba(255,255,255,.12);
}
.wp-block-button.is-style-tx-link .wp-block-button__link{
  background: transparent;
  color: #D9E4F3;
  font-weight: 600;
  padding: 12px 6px;
  text-decoration: underline;
  text-decoration-color: rgba(217,228,243,.4);
}
.wp-block-button.is-style-tx-link .wp-block-button__link:hover{
  color: #FFFFFF;
  text-decoration-color: #FFFFFF;
}
/* Variante do tx-link fora do hero (fundo claro) */
.tx-sobre-faixa .wp-block-button.is-style-tx-link .wp-block-button__link{
  color: var(--tx-azul-acao);
  text-decoration-color: rgba(30,95,184,.35);
}
.tx-sobre-faixa .wp-block-button.is-style-tx-link .wp-block-button__link:hover{
  color: var(--tx-azul-base);
  text-decoration-color: var(--tx-azul-base);
}

/* =========================================================
   HERO (página inicial)
   ========================================================= */
.tx-hero{
  background: linear-gradient(135deg, var(--tx-azul-base) 0%, #07294F 100%);
  color: #FFFFFF;
  padding: 76px 0 64px;
}
.tx-hero-kicker{
  text-transform: uppercase;
  letter-spacing: 1.6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--tx-dourado);
  margin-bottom: 14px;
}
.tx-hero h1{
  color: #FFFFFF;
  font-size: clamp(28px, 4.2vw, 44px);
  margin-bottom: 18px;
  max-width: 760px;
}
.tx-hero p{
  color: #D9E4F3;
  font-size: 18px;
  max-width: 640px;
}
.tx-hero .wp-block-buttons{ margin-top: 26px; align-items: center; }

/* =========================================================
   TÍTULOS DE SEÇÃO
   ========================================================= */
.tx-section-titulo{
  font-size: 26px;
  margin-bottom: 6px;
}
.tx-section-sub{
  color: var(--tx-texto-claro);
  font-size: 15px;
  margin-top: 0;
  margin-bottom: 28px;
}

/* =========================================================
   DESTAQUE EDITORIAL (home)
   ========================================================= */
.tx-destaque-grid{ gap: 28px; margin-top: 22px; }
.tx-card-destaque h2{ font-size: 26px; margin: 0 0 10px; }
.tx-card-destaque h2 a{ color: var(--tx-texto); }
.tx-card-destaque h2 a:hover{ color: var(--tx-azul-acao); }
.tx-card-destaque p{ color: var(--tx-texto-claro); font-size: 16px; }

.tx-card-lista{
  border-top: 1px solid var(--tx-borda);
  padding: 16px 0;
}
.tx-card-lista:first-child{ border-top: none; padding-top: 0; }
.tx-card-lista h3{ font-size: 16px; margin: 4px 0 0; }
.tx-card-lista h3 a{ color: var(--tx-texto); }
.tx-card-lista h3 a:hover{ color: var(--tx-azul-acao); }

/* =========================================================
   EDITORIAS (categorias em destaque)
   ========================================================= */
.tx-editorias{ border-top: 1px solid var(--tx-borda); border-bottom: 1px solid var(--tx-borda); }
.tx-editoria-card{
  background: var(--tx-fundo-card);
  border: 1px solid var(--tx-borda);
  border-radius: 10px;
  padding: 22px 20px;
  height: 100%;
}
.tx-editoria-card h3{ font-size: 17px; margin: 0 0 8px; }
.tx-editoria-card h3 a{ color: var(--tx-texto); }
.tx-editoria-card h3 a:hover{ color: var(--tx-azul-acao); }
.tx-editoria-card p{ color: var(--tx-texto-claro); font-size: 14.5px; margin: 0; }

/* =========================================================
   FAIXA "SOBRE" NA HOME
   ========================================================= */
.tx-sobre-faixa{
  background: var(--tx-fundo-card);
  border-top: 1px solid var(--tx-borda);
  padding: 56px 0;
}
.tx-sobre-faixa p{ color: var(--tx-texto-claro); font-size: 17px; max-width: 680px; }

/* =========================================================
   CARDS DE ARTIGO / POST
   ========================================================= */
.tx-card{
  background: var(--tx-fundo-card);
  border: 1px solid var(--tx-borda);
  border-radius: 12px;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease;
  height: 100%;
}
.tx-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(10,61,122,.12);
}
.tx-card img{ aspect-ratio: 16/10; object-fit: cover; width: 100%; }
.tx-card .tx-card-body{ padding: 18px 20px 22px; }
.tx-card .tx-card-categoria{
  display: inline-block;
  background: rgba(30,95,184,.1);
  color: var(--tx-azul-acao);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 4px 10px;
  border-radius: 20px;
  margin-bottom: 10px;
}
.tx-card h3{ font-size: 19px; margin: 0 0 8px; }
.tx-card h3 a{ color: var(--tx-texto); }
.tx-card h3 a:hover{ color: var(--tx-azul-acao); }
.tx-card p{ color: var(--tx-texto-claro); font-size: 15px; }

/* =========================================================
   SEÇÃO YOUTUBE / FUNIL
   ========================================================= */
.tx-youtube-cta{
  background: var(--tx-texto);
  color: #FFFFFF;
  padding: 60px 0;
  text-align: center;
}
.tx-youtube-cta h2{ color: #FFFFFF; font-size: clamp(24px,4vw,34px); }
.tx-youtube-cta p{ color: #C7D2DE; max-width: 600px; margin: 14px auto 26px; }

/* =========================================================
   NEWSLETTER
   ========================================================= */
.tx-newsletter{
  background: var(--tx-fundo-card);
  border: 1px solid var(--tx-borda);
  border-radius: 14px;
  padding: 36px;
  text-align: center;
}
.tx-newsletter h3{ font-size: 22px; margin-bottom: 8px; }
.tx-newsletter p{ color: var(--tx-texto-claro); margin-bottom: 18px; }

/* =========================================================
   FOOTER
   ========================================================= */
.tx-footer{
  background: #07172B;
  color: #9FB3C8;
  padding: 50px 0 24px;
  font-size: 14px;
}
.tx-footer h4{ color: #FFFFFF; font-size: 15px; margin-bottom: 14px; }
.tx-footer a{ color: #9FB3C8; }
.tx-footer a:hover{ color: var(--tx-dourado); }
.tx-footer .wp-block-navigation a{ color: #9FB3C8 !important; font-size: 14px; }
.tx-footer .wp-block-navigation a:hover{ color: var(--tx-dourado) !important; }

/* =========================================================
   ARTIGO / SINGLE POST
   ========================================================= */
.single-post .entry-content{
  font-size: 18px;
  line-height: 1.8;
  max-width: 720px;
}
.single-post .entry-content h2{ margin-top: 1.6em; font-size: 28px; }
.single-post .entry-content h3{ margin-top: 1.3em; font-size: 22px; }
.single-post .entry-content blockquote{
  border-left: 4px solid var(--tx-dourado);
  padding-left: 20px;
  font-style: italic;
  color: var(--tx-texto-claro);
}
.tx-leitura-meta{
  display: flex;
  gap: 16px;
  color: var(--tx-texto-claro);
  font-size: 14px;
  margin-bottom: 24px;
}

/* Caixa de CTA dentro do artigo (shortcode/bloco reusável) */
.tx-cta-artigo{
  background: var(--tx-fundo-card);
  border: 1px solid var(--tx-borda);
  border-left: 4px solid var(--tx-azul-acao);
  border-radius: 8px;
  padding: 26px 28px;
  margin: 36px 0;
}
.tx-cta-artigo h4{ color: var(--tx-texto); margin-bottom: 8px; font-size: 18px; }
.tx-cta-artigo p{ color: var(--tx-texto-claro); margin-bottom: 14px; }
.tx-cta-artigo a.tx-cta-btn{
  display: inline-block;
  background: transparent;
  color: var(--tx-azul-acao);
  font-weight: 600;
  padding: 0;
  border-radius: 0;
  text-decoration: underline;
  text-decoration-color: rgba(30,95,184,.35);
}
.tx-cta-artigo a.tx-cta-btn:hover{ color: var(--tx-azul-base); text-decoration-color: var(--tx-azul-base); }

/* =========================================================
   CARD DE CURSO (página Cursos)
   ========================================================= */
.tx-curso-card{
  background: var(--tx-fundo-card);
  border: 1px solid var(--tx-borda);
  border-radius: 12px;
  overflow: hidden;
  height: 100%;
}
.tx-curso-img{ margin: 0; }
.tx-curso-img img{ aspect-ratio: 16/9; object-fit: cover; width: 100%; display: block; }
.tx-curso-body{ padding: 20px 22px 24px; }
.tx-curso-categoria{
  text-transform: uppercase;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .5px;
  color: var(--tx-azul-acao);
  margin: 0 0 8px;
}
.tx-curso-body h3{ font-size: 19px; margin: 0 0 8px; }
.tx-curso-body p{ color: var(--tx-texto-claro); font-size: 15px; }
.tx-curso-rodape{ align-items: center; margin-top: 16px; }
.tx-curso-preco{
  font-size: 20px;
  font-weight: 700;
  color: var(--tx-texto);
  margin: 0;
}
.tx-curso-rodape .wp-block-button.is-style-tx-dourado .wp-block-button__link{
  padding: 10px 20px;
  font-size: 14px;
}

/* =========================================================
   RESPONSIVO
   ========================================================= */
@media (max-width: 768px){
  .tx-hero{ padding: 52px 0 40px; }
  .tx-newsletter{ padding: 26px 18px; }
  .tx-destaque-grid{ flex-direction: column; }
  .tx-destaque-grid .wp-block-column{ flex-basis: 100% !important; }
  .tx-sobre-faixa{ padding: 40px 0; }
}
