/*
Theme Name:  Crescendo no Caminho
Theme URI:   https://crescendonocaminho.com
Description: Child theme do Astra para o blog e loja do Crescendo no Caminho — recursos cristãos para pais.
Author:      Crescendo no Caminho
Author URI:  https://crescendonocaminho.com
Template:    astra
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: crescendo-no-caminho
*/

/* =========================================================
   VARIÁVEIS CSS — identidade visual completa
   ========================================================= */
:root {
    --cor-primaria:       #8B6F47;
    --cor-secundaria:     #F5F0E8;
    --cor-acento:         #6B7F5E;
    --cor-texto:          #3D2E1F;
    --cor-branco-quente:  #FFFDF8;
    --cor-hover:          #7A5F3A;
    --cor-rodape:         #3D2E1F;

    --fonte-titulo: 'Playfair Display', Georgia, 'Times New Roman', serif;
    --fonte-corpo:  'Inter', system-ui, -apple-system, sans-serif;

    --tamanho-h1:   2.5rem;
    --tamanho-h2:   2rem;
    --tamanho-h3:   1.5rem;
    --tamanho-h4:   1.25rem;
    --tamanho-body: 1.05rem;
    --line-height:  1.75;

    --sombra-card:       0 2px 8px rgba(61, 46, 31, 0.08);
    --sombra-card-hover: 0 6px 20px rgba(61, 46, 31, 0.15);
    --raio:              8px;
    --raio-lg:           12px;

    --max-width: 1200px;
    --max-post:  720px;

    --transicao: 0.25s ease;
}

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

body {
    font-family: var(--fonte-corpo);
    font-size:   var(--tamanho-body);
    line-height: var(--line-height);
    color:       var(--cor-texto);
    background:  var(--cor-branco-quente);
    margin: 0;
    padding: 0;
}

/* =========================================================
   TIPOGRAFIA
   ========================================================= */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--fonte-titulo);
    color:       var(--cor-texto);
    line-height: 1.25;
    margin-top: 0;
}

h1 { font-size: var(--tamanho-h1); }
h2 { font-size: var(--tamanho-h2); }
h3 { font-size: var(--tamanho-h3); }
h4 { font-size: var(--tamanho-h4); }

p {
    margin-top: 0;
    margin-bottom: 1.25rem;
}

a {
    color: var(--cor-primaria);
    text-decoration: none;
    transition: color var(--transicao);
}

a:hover, a:focus {
    color: var(--cor-hover);
    text-decoration: underline;
}

/* =========================================================
   CONTAINER
   ========================================================= */
.cnc-container {
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: 1rem;
}

@media (min-width: 768px) {
    .cnc-container { padding-inline: 2rem; }
}

@media (min-width: 1024px) {
    .cnc-container { padding-inline: 3rem; }
}

/* =========================================================
   BOTÕES
   ========================================================= */
.cnc-btn {
    display:         inline-flex;
    align-items:     center;
    gap:             0.4rem;
    padding:         0.75rem 1.5rem;
    border-radius:   var(--raio);
    font-family:     var(--fonte-corpo);
    font-size:       1rem;
    font-weight:     600;
    cursor:          pointer;
    text-decoration: none;
    border:          2px solid transparent;
    transition:      background var(--transicao), color var(--transicao), border-color var(--transicao), box-shadow var(--transicao);
    line-height:     1;
}

.cnc-btn:focus-visible {
    outline: 3px solid var(--cor-acento);
    outline-offset: 3px;
}

.cnc-btn-primario {
    background:   var(--cor-primaria);
    color:        #fff;
    border-color: var(--cor-primaria);
}

.cnc-btn-primario:hover {
    background:   var(--cor-hover);
    border-color: var(--cor-hover);
    color:        #fff;
    text-decoration: none;
    box-shadow:   0 4px 12px rgba(139, 111, 71, 0.4);
}

.cnc-btn-secundario {
    background:   transparent;
    color:        var(--cor-acento);
    border-color: var(--cor-acento);
}

.cnc-btn-secundario:hover {
    background:   var(--cor-acento);
    color:        #fff;
    text-decoration: none;
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header,
#masthead {
    background:    var(--cor-branco-quente);
    border-bottom: 1px solid rgba(139, 111, 71, 0.12);
    position:      sticky;
    top:           0;
    z-index:       1000;
    transition:    box-shadow var(--transicao);
}

.site-header.scrolled,
#masthead.scrolled {
    box-shadow: 0 2px 12px rgba(61, 46, 31, 0.1);
}

/* Logo */
.site-logo img,
.custom-logo {
    max-height: 56px;
    width: auto;
}

/* Navegação principal */
.main-navigation a,
.ast-main-navigation a {
    font-family: var(--fonte-corpo);
    font-weight: 500;
    color:       var(--cor-texto);
    padding:     0.4rem 0.75rem;
    transition:  color var(--transicao);
}

.main-navigation a:hover,
.ast-main-navigation a:hover {
    color:           var(--cor-primaria);
    text-decoration: none;
}

/* Hamburger (mobile) */
.cnc-hamburger {
    display:         flex;
    flex-direction:  column;
    justify-content: space-between;
    width:           28px;
    height:          20px;
    background:      transparent;
    border:          none;
    cursor:          pointer;
    padding:         0;
}

.cnc-hamburger span {
    display:       block;
    height:        2px;
    background:    var(--cor-texto);
    border-radius: 2px;
    transition:    transform var(--transicao), opacity var(--transicao);
}

.cnc-hamburger.ativo span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.cnc-hamburger.ativo span:nth-child(2) { opacity: 0; }
.cnc-hamburger.ativo span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* =========================================================
   TÍTULOS DE SEÇÃO
   ========================================================= */
.cnc-secao-titulo {
    font-family: var(--fonte-titulo);
    font-size:   var(--tamanho-h2);
    color:       var(--cor-texto);
    text-align:  center;
    margin-bottom: 0.5rem;
}

.cnc-secao-subtitulo {
    text-align:   center;
    color:        #6b5a45;
    margin-bottom: 2.5rem;
    font-size:    1.05rem;
}

.cnc-secao-titulo::after {
    content:     '';
    display:     block;
    width:       48px;
    height:      3px;
    background:  var(--cor-acento);
    margin:      0.6rem auto 0;
    border-radius: 2px;
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer,
#colophon {
    background: var(--cor-rodape);
    color:      #e8dfd0;
    padding:    3rem 0 1.5rem;
}

.site-footer a {
    color:           #e8dfd0;
    text-decoration: none;
    transition:      color var(--transicao);
}

.site-footer a:hover {
    color:           var(--cor-secundaria);
    text-decoration: none;
}

.cnc-footer-grid {
    display: grid;
    gap:     2.5rem;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .cnc-footer-grid { grid-template-columns: 2fr 1fr 1fr; }
}

.cnc-footer-col h4 {
    color:         var(--cor-secundaria);
    font-family:   var(--fonte-titulo);
    font-size:     1.1rem;
    margin-bottom: 1rem;
}

.cnc-footer-col ul {
    list-style: none;
    padding:    0;
    margin:     0;
}

.cnc-footer-col ul li {
    margin-bottom: 0.5rem;
}

.cnc-footer-social {
    display: flex;
    gap:     0.75rem;
    margin-top: 1rem;
}

.cnc-footer-social a {
    display:       flex;
    align-items:   center;
    justify-content: center;
    width:         36px;
    height:        36px;
    border-radius: 50%;
    background:    rgba(245, 240, 232, 0.12);
    transition:    background var(--transicao);
}

.cnc-footer-social a:hover {
    background: var(--cor-primaria);
}

.cnc-footer-social svg {
    width:  18px;
    height: 18px;
    fill:   #e8dfd0;
}

.cnc-footer-copy {
    border-top:  1px solid rgba(245, 240, 232, 0.15);
    margin-top:  2.5rem;
    padding-top: 1.25rem;
    text-align:  center;
    font-size:   0.875rem;
    color:       #a89880;
}

/* =========================================================
   BREADCRUMBS
   ========================================================= */
.cnc-breadcrumbs {
    font-size:   0.875rem;
    color:       #6b5a45;
    padding:     0.75rem 0;
    margin-bottom: 1.5rem;
}

.cnc-breadcrumbs a { color: var(--cor-primaria); }
.cnc-breadcrumbs span { margin-inline: 0.4rem; }

/* =========================================================
   CARDS DE POST
   ========================================================= */
.cnc-card {
    background:    var(--cor-branco-quente);
    border-radius: var(--raio-lg);
    box-shadow:    var(--sombra-card);
    overflow:      hidden;
    display:       flex;
    flex-direction: column;
    transition:    box-shadow var(--transicao), transform var(--transicao);
}

.cnc-card:hover {
    box-shadow: var(--sombra-card-hover);
    transform:  translateY(-3px);
}

.cnc-card-img {
    aspect-ratio: 16/9;
    overflow:     hidden;
}

.cnc-card-img img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    display:    block;
    transition: transform 0.4s ease;
}

.cnc-card:hover .cnc-card-img img {
    transform: scale(1.04);
}

.cnc-card-corpo {
    padding:        1.25rem;
    flex:           1;
    display:        flex;
    flex-direction: column;
}

.cnc-card-categoria {
    display:       inline-block;
    font-size:     0.75rem;
    font-weight:   600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color:         var(--cor-acento);
    margin-bottom: 0.5rem;
}

.cnc-card-titulo {
    font-family:   var(--fonte-titulo);
    font-size:     1.2rem;
    margin-bottom: 0.5rem;
    color:         var(--cor-texto);
}

.cnc-card-titulo a {
    color:           var(--cor-texto);
    text-decoration: none;
}

.cnc-card-titulo a:hover { color: var(--cor-primaria); }

.cnc-card-excerpt {
    font-size:      0.95rem;
    color:          #5a4a38;
    display:        -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow:       hidden;
    flex: 1;
    margin-bottom: 1rem;
}

.cnc-card-link {
    font-weight:   600;
    font-size:     0.9rem;
    color:         var(--cor-primaria);
    align-self:    flex-start;
}

.cnc-card-link:hover { color: var(--cor-hover); }

/* =========================================================
   GRID DE POSTS (ARCHIVE)
   ========================================================= */
.cnc-posts-grid {
    display: grid;
    gap:     1.75rem;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .cnc-posts-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Grid home (3 colunas) */
.cnc-posts-grid-3 {
    display: grid;
    gap:     1.75rem;
    grid-template-columns: 1fr;
}

@media (min-width: 768px) {
    .cnc-posts-grid-3 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
    .cnc-posts-grid-3 { grid-template-columns: repeat(3, 1fr); }
}

/* =========================================================
   LAYOUT BLOG COM SIDEBAR
   ========================================================= */
.cnc-blog-layout {
    display: grid;
    gap:     3rem;
    grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
    .cnc-blog-layout { grid-template-columns: 1fr 320px; }
}

/* =========================================================
   SIDEBAR
   ========================================================= */
.cnc-sidebar .widget {
    background:    var(--cor-branco-quente);
    border-radius: var(--raio-lg);
    padding:       1.5rem;
    margin-bottom: 1.75rem;
    box-shadow:    var(--sombra-card);
}

.cnc-sidebar .widget-title {
    font-family:   var(--fonte-titulo);
    font-size:     1.15rem;
    color:         var(--cor-texto);
    border-bottom: 2px solid var(--cor-acento);
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
}

/* =========================================================
   SINGLE POST
   ========================================================= */
.cnc-post-container {
    max-width:   var(--max-post);
    margin:      0 auto;
}

.cnc-post-meta {
    display:   flex;
    flex-wrap: wrap;
    gap:       1rem;
    font-size: 0.875rem;
    color:     #6b5a45;
    margin-bottom: 2rem;
    align-items: center;
}

.cnc-post-meta a { color: var(--cor-primaria); }

.cnc-post-content {
    font-size:   var(--tamanho-body);
    line-height: var(--line-height);
}

.cnc-post-content img {
    max-width:     100%;
    height:        auto;
    border-radius: var(--raio);
    margin: 1.5rem 0;
}

/* Citações bíblicas */
.cnc-post-content blockquote {
    background:    var(--cor-secundaria);
    border-left:   4px solid var(--cor-acento);
    padding:       1.25rem 1.5rem;
    margin:        2rem 0;
    border-radius: 0 var(--raio) var(--raio) 0;
    font-style:    italic;
    color:         #4a3728;
}

.cnc-post-content blockquote p:last-child {
    margin-bottom: 0;
}

/* CTA no final do post */
.cnc-post-cta {
    background:    var(--cor-secundaria);
    border:        1px solid rgba(139, 111, 71, 0.2);
    border-radius: var(--raio-lg);
    padding:       2rem;
    margin:        3rem 0;
    text-align:    center;
}

.cnc-post-cta h3 {
    font-size: 1.3rem;
    margin-bottom: 0.75rem;
}

/* Posts relacionados */
.cnc-relacionados {
    margin-top: 3rem;
}

.cnc-relacionados h3 {
    font-size:     var(--tamanho-h3);
    margin-bottom: 1.5rem;
}

/* =========================================================
   PAGINAÇÃO
   ========================================================= */
.cnc-paginacao {
    display:         flex;
    justify-content: center;
    gap:             0.5rem;
    margin-top:      3rem;
    flex-wrap:       wrap;
}

.cnc-paginacao a,
.cnc-paginacao span {
    display:       flex;
    align-items:   center;
    justify-content: center;
    width:         40px;
    height:        40px;
    border-radius: var(--raio);
    font-weight:   600;
    font-size:     0.9rem;
    color:         var(--cor-texto);
    border:        1px solid rgba(61, 46, 31, 0.15);
    transition:    background var(--transicao), color var(--transicao);
}

.cnc-paginacao a:hover {
    background:      var(--cor-primaria);
    color:           #fff;
    text-decoration: none;
    border-color:    var(--cor-primaria);
}

.cnc-paginacao .current {
    background:  var(--cor-primaria);
    color:       #fff;
    border-color: var(--cor-primaria);
}

/* =========================================================
   COMENTÁRIOS
   ========================================================= */
.comments-area {
    max-width:  var(--max-post);
    margin:     3rem auto 0;
}

.comment-form input,
.comment-form textarea {
    border:        1px solid rgba(61, 46, 31, 0.2);
    border-radius: var(--raio);
    padding:       0.65rem 1rem;
    font-family:   var(--fonte-corpo);
    font-size:     1rem;
    width:         100%;
    background:    var(--cor-branco-quente);
    color:         var(--cor-texto);
    transition:    border-color var(--transicao);
}

.comment-form input:focus,
.comment-form textarea:focus {
    outline:      none;
    border-color: var(--cor-primaria);
}

.comment-form .submit {
    background:    var(--cor-primaria);
    color:         #fff;
    border:        none;
    padding:       0.75rem 2rem;
    border-radius: var(--raio);
    font-family:   var(--fonte-corpo);
    font-size:     1rem;
    font-weight:   600;
    cursor:        pointer;
    transition:    background var(--transicao);
}

.comment-form .submit:hover {
    background: var(--cor-hover);
}

/* =========================================================
   ACESSIBILIDADE — FOCUS STATES
   ========================================================= */
:focus-visible {
    outline:        2px solid var(--cor-acento);
    outline-offset: 3px;
}

/* =========================================================
   UTILITÁRIOS
   ========================================================= */
.cnc-text-center { text-align: center; }
.cnc-mt-1 { margin-top: 1rem; }
.cnc-mt-2 { margin-top: 2rem; }
.cnc-mt-3 { margin-top: 3rem; }

/* Seção com padding vertical padrão */
.cnc-secao {
    padding: 4rem 0;
}

.cnc-secao-bege {
    background: var(--cor-secundaria);
}

.cnc-secao-escura {
    background: var(--cor-texto);
    color:      var(--cor-secundaria);
}
