/* ============================================================
   SINGLE: CONTROLE EMOCIONAL
   Arquivo: assets/css/single/controle-emocional.css
   Prefixo: .sce-  (sem conflito com outras páginas)

   AJUSTES v2:
   1. Rodapé mobile: corrigido com margin negativa para cobrir laterais brancas
   2. Espaço entre seção relacionados e rodapé no mobile
   3/4. Layout preparado para o TOC JS (bc-toc-grid) → article como alvo
   5. Removido hover azul no botão WhatsApp
   6. Post Views removido (não existe no HTML, só prevenção via CSS)
============================================================ */

/* ---- RESET INTERNO ---- */
.sce-page *,
.sce-page *::before,
.sce-page *::after {
    box-sizing: border-box;
}

/* ============================================================
   PÁGINA WRAPPER
============================================================ */
.sce-page {
    background: #f5f4f0;
    min-height: 100vh;
}

/* ============================================================
   HERO
============================================================ */
.sce-hero {
    position: relative;
    min-height: 520px;
    display: flex;
    align-items: flex-end;
    overflow: hidden;
}

.sce-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.sce-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    filter: saturate(0.7) brightness(0.85);
    transform: scale(1.03);
    transition: transform 8s ease;
}

.sce-hero:hover .sce-hero-bg img {
    transform: scale(1.06);
}

.sce-hero-no-img {
    background: linear-gradient(135deg, #0f1f4b 0%, #1e3a8a 40%, #2563eb 100%);
}

.sce-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(10, 15, 40, 0.97) 0%,
        rgba(10, 15, 40, 0.75) 45%,
        rgba(10, 15, 40, 0.25) 100%
    );
}

.sce-hero-content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 860px;
    margin: 0 auto;
    padding: 60px 40px 70px;
}

.sce-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 20px;
    font-size: 0.8rem;
    color: rgba(255,255,255,0.6);
}

.sce-breadcrumb a {
    color: rgba(255,255,255,0.6);
    text-decoration: none;
    transition: color 0.2s;
}

.sce-breadcrumb a:hover { color: #fff; }
.sce-breadcrumb-sep { color: rgba(255,255,255,0.35); }

.sce-breadcrumb span:last-child {
    color: rgba(255,255,255,0.45);
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sce-tags-hero {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 18px;
}

.sce-tag {
    background: rgba(37, 99, 235, 0.35);
    border: 1px solid rgba(37, 99, 235, 0.6);
    color: #93c5fd;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 4px 12px;
    border-radius: 20px;
    backdrop-filter: blur(6px);
}

.sce-title {
    font-size: clamp(1.7rem, 4vw, 2.8rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.2;
    margin: 0 0 24px;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4);
    letter-spacing: -0.02em;
}

.sce-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.sce-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    color: rgba(255,255,255,0.65);
    font-size: 0.82rem;
}

.sce-meta-item svg { opacity: 0.8; flex-shrink: 0; }

.sce-scroll-hint {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    color: rgba(255,255,255,0.4);
    animation: sce-bounce 2s ease-in-out infinite;
}

@keyframes sce-bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(6px); }
}

/* ============================================================
   WRAPPER DO CONTEÚDO
   
   O JS do TOC cria um .bc-toc-grid DENTRO do article e injeta
   a sidebar à direita. Aqui só controlamos o padding externo.
============================================================ */
.sce-content-wrapper {
    max-width: 1400px;
    margin: 0 auto;
    padding: 48px 24px 60px;
}

/* O article principal (alvo do TOC JS) */
.sce-article {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 30px rgba(0,0,0,0.08);
    overflow: visible; /* não cortar o sumário que fica outside */
    min-width: 0;
}

/* Quando o TOC cria o grid, o article fica na coluna da esquerda */
.bc-toc-grid .sce-article {
    overflow: hidden;
}

/* ============================================================
   PROGRESSO MOBILE (linha sticky no topo)
============================================================ */
.sce-progress-mobile {
    height: 3px;
    background: #f0f0f0;
    display: none; /* ativado em mobile via media query */
    position: sticky;
    top: 0;
    z-index: 99;
    margin-bottom: 0;
}

.sce-progress-mobile-bar {
    height: 100%;
    width: 0%;
    background: linear-gradient(to right, #2563eb, #60a5fa);
    transition: width 0.2s ease;
}

/* ============================================================
   HIGHLIGHT BOX
============================================================ */
.sce-highlight-box {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    background: linear-gradient(135deg, #eff6ff, #dbeafe);
    border-left: 4px solid #2563eb;
    padding: 22px 28px;
    margin: 36px 40px 0;
    border-radius: 0 12px 12px 0;
}

.sce-highlight-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    background: #2563eb;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-top: 2px;
}

.sce-highlight-text {
    font-size: 1rem;
    color: #1e40af;
    line-height: 1.65;
    margin: 0;
    font-style: italic;
    font-weight: 500;
}

/* ============================================================
   CORPO DO POST
============================================================ */
.sce-content-body {
    padding: 40px 40px 36px;
    font-size: 1.05rem;
    line-height: 1.8;
    color: #2d2d2d;
}

.sce-content-body h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1e3a8a;
    margin: 2.2em 0 0.8em;
    padding-bottom: 8px;
    border-bottom: 2px solid #dbeafe;
}

.sce-content-body h3 {
    font-size: 1.2rem;
    font-weight: 700;
    color: #333;
    margin: 1.8em 0 0.6em;
}

.sce-content-body p { margin: 0 0 1.4em; }

.sce-content-body a {
    color: #2563eb;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.sce-content-body blockquote {
    margin: 2em 0;
    padding: 20px 28px;
    background: #f8faff;
    border-left: 4px solid #93c5fd;
    border-radius: 0 8px 8px 0;
    font-style: italic;
    color: #374151;
}

.sce-content-body ul,
.sce-content-body ol {
    padding-left: 1.5em;
    margin: 0 0 1.4em;
}

.sce-content-body li { margin-bottom: 0.5em; }

.sce-content-body img {
    max-width: 100%;
    height: auto;
    border-radius: 10px;
    margin: 1em 0;
}

/* ============================================================
   POST VIEWS — OCULTAR (ajuste 6)
   O plugin WP-PostViews injeta fora do nosso controle;
   garantimos que fique invisível nesta página.
============================================================ */
.sce-article .post-views-count,
.sce-article .post-views,
.sce-article [class*="post-view"],
.sce-article .views {
    display: none !important;
}

/* ============================================================
   TAGS DO POST
============================================================ */
.sce-tags-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 0 40px 28px;
    border-bottom: 1px solid #f0f0f0;
}

.sce-tags-label {
    font-size: 0.8rem;
    font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sce-tag-link {
    text-decoration: none;
    font-size: 0.78rem;
    color: #2563eb;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    padding: 3px 10px;
    border-radius: 20px;
    transition: all 0.2s;
    font-weight: 500;
}

.sce-tag-link:hover {
    background: #2563eb;
    color: #fff;
    border-color: #2563eb;
}

/* ============================================================
   COMPARTILHAMENTO
============================================================ */
.sce-share {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding: 24px 40px 36px;
}

.sce-share-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sce-share-btns {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.sce-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: 8px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    border: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

/* Botão WhatsApp — ajuste 5: sem hover azul, mantém verde */
.sce-share-wa {
    background: #25d366;
    color: #fff !important; /* garante que o texto nunca muda de cor */
}

.sce-share-wa:hover {
    background: #1db954;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(37,211,102,0.4);
    text-decoration: none;
}

.sce-share-wa:focus,
.sce-share-wa:active,
.sce-share-wa:visited {
    color: #fff !important;
}

/* Remove qualquer override de link do Astra/tema */
.sce-page .sce-share-wa,
.sce-page .sce-share-wa:hover,
.sce-page .sce-share-wa:visited,
.sce-page .sce-share-wa:focus {
    color: #fff !important;
    text-decoration: none !important;
}

.sce-share-copy {
    background: #f3f4f6;
    color: #374151;
}

.sce-share-copy:hover {
    background: #e5e7eb;
    transform: translateY(-2px);
}

.sce-share-copy.copied {
    background: #d1fae5;
    color: #065f46;
}

/* ============================================================
   POSTS RELACIONADOS

   Ajuste 1 (mobile): margin negativa para cobrir as laterais brancas
   Ajuste 2 (mobile): padding-top cria o espaço branco entre seções
============================================================ */
.sce-relacionados {
    background: linear-gradient(180deg, #0f1f4b 0%, #1a2e6b 100%);
    padding: 64px 0 72px;
    margin-bottom: 40px; /* espaço antes do rodapé — desktop e mobile */
}

.sce-relacionados-inner {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 24px;
}

.sce-relacionados-header {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 40px;
}

.sce-relacionados-icon {
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    background: linear-gradient(135deg, #2563eb, #60a5fa);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    box-shadow: 0 4px 20px rgba(37,99,235,0.4);
    margin-top: 4px;
}

.sce-relacionados-title {
    font-size: clamp(1.3rem, 3vw, 1.8rem);
    font-weight: 800;
    color: #fff;
    margin: 0 0 6px;
    letter-spacing: -0.02em;
}

.sce-relacionados-sub {
    font-size: 0.9rem;
    color: rgba(255,255,255,0.55);
    margin: 0;
    line-height: 1.5;
}

/* Grid: 1 destaque grande (2 linhas) + 3 menores */
.sce-rel-grid {
    display: grid;
    grid-template-columns: 1.7fr 1fr;
    grid-template-rows: auto auto;
    gap: 18px;
}

.sce-rel-card {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 14px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    backdrop-filter: blur(8px);
}

.sce-rel-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.35);
    border-color: rgba(37,99,235,0.5);
}

.sce-rel-card:active {
    transform: translateY(-2px) scale(0.99);
    transition: all 0.1s ease;
}

.sce-rel-card--featured {
    grid-row: 1 / 3;
}

.sce-rel-card--featured .sce-rel-thumb {
    padding-top: 68%;
}

.sce-rel-card--featured .sce-rel-title {
    font-size: 1.2rem;
    -webkit-line-clamp: 3;
}

.sce-rel-card--featured .sce-rel-excerpt {
    display: -webkit-box;
}

.sce-rel-link {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

.sce-rel-thumb {
    position: relative;
    width: 100%;
    padding-top: 58%;
    overflow: hidden;
    background: rgba(255,255,255,0.05);
    flex-shrink: 0;
}

.sce-rel-thumb img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.sce-rel-card:hover .sce-rel-thumb img {
    transform: scale(1.06);
}

.sce-rel-thumb-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255,255,255,0.2);
    background: linear-gradient(135deg, rgba(37,99,235,0.15), rgba(30,58,138,0.2));
}

.sce-rel-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: linear-gradient(135deg, #1e3a8a, #2563eb);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 4px 10px;
    border-radius: 20px;
    display: flex;
    align-items: center;
    gap: 5px;
    box-shadow: 0 2px 10px rgba(37,99,235,0.5);
}

.sce-rel-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.sce-rel-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #f0f4ff;
    line-height: 1.45;
    margin: 0 0 10px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sce-rel-excerpt {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.5);
    line-height: 1.6;
    margin: 0 0 14px;
    display: none;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.sce-rel-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
}

.sce-rel-date {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.75rem;
    color: rgba(255,255,255,0.4);
}

.sce-rel-cta {
    font-size: 0.78rem;
    font-weight: 700;
    color: #60a5fa;
    letter-spacing: 0.01em;
    transition: color 0.2s;
}

.sce-rel-card:hover .sce-rel-cta { color: #93c5fd; }

/* ============================================================
   RESPONSIVIDADE — TABLET
============================================================ */
@media (max-width: 1024px) {
    .sce-content-wrapper {
        padding: 36px 20px 48px;
    }

    .sce-hero-content {
        padding: 48px 28px 60px;
    }

    .sce-highlight-box {
        margin: 28px 28px 0;
    }

    .sce-content-body,
    .sce-tags-footer,
    .sce-share {
        padding-left: 28px;
        padding-right: 28px;
    }

    /* Grid relacionados: 2 colunas iguais */
    .sce-rel-grid {
        grid-template-columns: 1fr 1fr;
    }

    .sce-rel-card--featured {
        grid-column: 1 / -1;
        grid-row: auto;
    }

    .sce-rel-card--featured .sce-rel-thumb {
        padding-top: 50%;
    }
}

/* ============================================================
   RESPONSIVIDADE — MOBILE
============================================================ */
@media (max-width: 768px) {
    .sce-hero { min-height: 420px; }

    .sce-hero-content {
        padding: 40px 20px 52px;
    }

    /* Remove padding lateral do wrapper em mobile
       para o conteúdo ocupar 100% da tela */
    .sce-content-wrapper {
        padding: 0 0 0;
    }

    .sce-article {
        border-radius: 0;
        box-shadow: none;
    }

    /* Progresso mobile visível */
    .sce-progress-mobile {
        display: block;
    }

    .sce-highlight-box {
        margin: 24px 16px 0;
        padding: 18px 20px;
    }

    .sce-content-body {
        padding: 28px 20px 24px;
        font-size: 1rem;
    }

    .sce-tags-footer { padding: 0 20px 22px; }

    .sce-share {
        padding: 20px 20px 28px;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    /* ---- AJUSTE 2: espaço entre relacionados e rodapé ---- */
    .sce-relacionados {
        margin-top: 32px;
        /* margin-bottom controlado via JS para funcionar em desktop e mobile */
    }

    .sce-relacionados-inner {
        padding: 0 20px;
    }

    /* Grid relacionados: 1 coluna */
    .sce-rel-grid {
        grid-template-columns: 1fr;
    }

    .sce-rel-card--featured {
        grid-column: auto;
        grid-row: auto;
    }

    .sce-rel-card--featured .sce-rel-thumb { padding-top: 60%; }
    .sce-rel-card--featured .sce-rel-title { font-size: 1.1rem; }
    .sce-rel-card--featured .sce-rel-excerpt { display: -webkit-box; }

    .sce-relacionados-header {
        gap: 14px;
        margin-bottom: 28px;
    }
}

/* ============================================================
   RESPONSIVIDADE — MOBILE PEQUENO
============================================================ */
@media (max-width: 480px) {
    .sce-hero { min-height: 380px; }
    .sce-title { font-size: 1.5rem; }
    .sce-meta { gap: 12px; }

    .sce-content-body {
        font-size: 0.97rem;
        padding: 24px 16px 20px;
    }

    .sce-highlight-box {
        margin: 20px 12px 0;
        padding: 16px;
        flex-direction: column;
        gap: 10px;
    }

    .sce-tags-footer { padding: 0 16px 18px; }
    .sce-share { padding: 16px 16px 24px; }

    .sce-share-btn {
        padding: 8px 14px;
        font-size: 0.82rem;
    }

    .sce-relacionados-inner { padding: 0 16px; }

    .sce-relacionados-icon {
        width: 42px;
        height: 42px;
        border-radius: 10px;
    }

    .sce-rel-body { padding: 16px; }
    .sce-rel-title { font-size: 0.9rem; }
}

/* ============================================================
   AJUSTE DO TOC GLASSMORPHISM PARA CONTROLE EMOCIONAL
   
   O TOC usa classes .bc-toc-* globais. Aqui sobrescrevemos
   apenas as cores para combinar com a identidade azul escuro
   da página de Controle Emocional, sem alterar o arquivo
   original do TOC (que é compartilhado com Estratégias).
   
   Escopo: apenas dentro de .sce-page
============================================================ */

/* Wrapper glassmorphism — tom mais quente/azul escuro */
.sce-page .bc-toc-wrapper {
    background: rgba(239, 246, 255, 0.75);
    border: 1px solid rgba(37, 99, 235, 0.2);
    box-shadow:
        0 8px 32px rgba(30, 58, 138, 0.12),
        inset 0 1px 1px rgba(255, 255, 255, 0.95);
}

/* Título do TOC */
.sce-page .bc-toc-title {
    background: linear-gradient(135deg, #0f1f4b 0%, #2563eb 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.sce-page .bc-toc-title::after {
    background: linear-gradient(90deg, #0f1f4b 0%, transparent 100%);
}

/* Links ativos — azul mais escuro */
.sce-page .bc-toc-link.active {
    background: rgba(15, 31, 75, 0.1);
    color: #0f1f4b;
}

.sce-page .bc-toc-link.active::before {
    background: #0f1f4b;
    box-shadow: 0 0 8px rgba(15, 31, 75, 0.4);
}

.sce-page .bc-toc-link:hover {
    background: rgba(37, 99, 235, 0.08);
    color: #1e3a8a;
}

/* Botão mobile do TOC — mantém padrão mas garante z-index acima da bottom bar */
.sce-page ~ .bc-toc-mobile-trigger,
.bc-toc-mobile-trigger {
    bottom: 80px; /* acima da mobile bottom bar do site */
}

/* ============================================================
   FIX RODAPÉ MOBILE — BORDAS BRANCAS LATERAIS (AJUSTE 1)

   O rodapé do Astra tem estrutura assim:
     <footer id="colophon" class="site-footer">
       <div class="ast-footer-overlay">
         <div class="ast-container">  ← esse tem max-width
           ...conteúdo...
         </div>
       </div>
     </footer>

   O background azul está no .ast-container ou no inner div,
   não na tag <footer> em si — por isso ficam faixas brancas
   nas laterais em mobile.

   Solução: forçar o background do footer e seus wrappers
   para a mesma cor azul escuro da seção de relacionados,
   APENAS nesta página (escopo via body class do WordPress).
   
   O WordPress adiciona a classe "category-controle-emocional"
   ou "single-post" no <body>. Usamos .sce-page como âncora
   já que é o wrapper da nossa página.
============================================================ */

/* Aplica-se ao footer quando estamos no single de CE */
.sce-page ~ footer,
.sce-page + footer,
body.category-controle-emocional footer#colophon,
body.single footer#colophon {
    /* Fallback: se os seletores acima não peguem o footer correto,
       o próximo bloco cobre via JavaScript no single-controle-emocional.js */
}

/* Abordagem mais robusta: pseudo-elemento na .sce-page que
   cobre o espaço entre o fim da página e o rodapé */
.sce-page {
    position: relative;
}

/* Garante que a cor de fundo da página termine em azul escuro
   (igual ao fundo da seção relacionados), eliminando visualmente
   qualquer gap branco antes do footer */
.sce-page::after {
    content: '';
    display: block;
    /* Nenhum estilo extra necessário aqui — o margin-bottom: 32px
       no .sce-relacionados já cria o espaço branco desejado,
       e o fundo da .sce-page é #f5f4f0 (claro), não branco puro */
}