/* ==========================================================================
   Megan Foca — Identidade visual (site de autor da Focus Fit)
   A Motivadora: leve, acolhedora, energética e positiva.
   Mobile-first, CSS próprio (sem frameworks).
   ========================================================================== */

/* --------------------------------------------------------------------------
   Variáveis (paleta, tipografia, raios, sombras)
   -------------------------------------------------------------------------- */
:root {
    /* Base clara e arejada (família Focus Fit) */
    --branco: #ffffff;
    --canvas: #f5f5f5;          /* cinza claro de fundo */
    --canvas-quente: #fffaf0;   /* creme quente para seções alternadas */

    /* Texto */
    --texto: #2b2b2b;
    --texto-suave: #5f5f5f;
    --texto-claro: #8a8a8a;

    /* Cor de destaque da Megan: amarelo (energia/alegria) */
    --amarelo: #f4b400;
    --amarelo-claro: #ffd24d;
    --amarelo-suave: #fff4d1;

    /* Referência da marca Focus Fit */
    --laranja: #da8201;
    --laranja-escuro: #b86d01;

    /* Apoio */
    --borda: #ececec;
    --preto: #000000;

    /* Tipografia */
    --fonte-titulo: "Quicksand", "Poppins", system-ui, sans-serif;
    --fonte-corpo: "Nunito Sans", "Inter", system-ui, sans-serif;

    /* Raios e sombras (cantos arredondados, sombras suaves) */
    --raio-sm: 10px;
    --raio: 18px;
    --raio-lg: 28px;
    --raio-pill: 999px;
    --sombra-suave: 0 8px 24px rgba(0, 0, 0, 0.06);
    --sombra-media: 0 14px 40px rgba(0, 0, 0, 0.10);
    --sombra-amarela: 0 12px 30px rgba(244, 180, 0, 0.28);

    /* Layout */
    --largura-max: 1140px;
    --espaco-secao: 72px;
}

/* --------------------------------------------------------------------------
   Reset leve
   -------------------------------------------------------------------------- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

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

body {
    margin: 0;
    font-family: var(--fonte-corpo);
    font-size: 1.05rem;
    line-height: 1.7;
    color: var(--texto);
    background-color: var(--canvas);
}

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

a {
    color: var(--laranja);
    text-decoration: none;
    transition: color 0.2s ease;
}

a:hover {
    color: var(--laranja-escuro);
}

h1,
h2,
h3,
h4 {
    font-family: var(--fonte-titulo);
    font-weight: 700;
    line-height: 1.2;
    color: var(--texto);
    margin: 0 0 0.6em;
}

p {
    margin: 0 0 1rem;
}

:focus-visible {
    outline: 3px solid var(--amarelo);
    outline-offset: 2px;
    border-radius: 4px;
}

/* --------------------------------------------------------------------------
   Utilitários de layout
   -------------------------------------------------------------------------- */
.container {
    width: 100%;
    max-width: var(--largura-max);
    margin: 0 auto;
    padding: 0 20px;
}

.secao {
    padding: var(--espaco-secao) 0;
}

.secao--canvas {
    background-color: var(--canvas);
}

.secao--branca {
    background-color: var(--branco);
}

.secao--quente {
    background-color: var(--canvas-quente);
}

.cabecalho-secao {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px;
}

.cabecalho-secao .selo-texto {
    display: inline-block;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--laranja);
    background: var(--amarelo-suave);
    padding: 6px 16px;
    border-radius: var(--raio-pill);
    margin-bottom: 16px;
}

.cabecalho-secao h2 {
    font-size: clamp(1.8rem, 4vw, 2.6rem);
    margin-bottom: 12px;
}

.cabecalho-secao p {
    color: var(--texto-suave);
    font-size: 1.1rem;
    margin: 0;
}

/* Botões */
.botao {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 1rem;
    line-height: 1;
    padding: 16px 30px;
    border-radius: var(--raio-pill);
    border: 2px solid transparent;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.botao svg {
    width: 18px;
    height: 18px;
}

.botao--primario {
    background: var(--amarelo);
    color: #3a2c00;
    box-shadow: var(--sombra-amarela);
}

.botao--primario:hover {
    background: var(--amarelo-claro);
    color: #3a2c00;
    transform: translateY(-2px);
}

.botao--contorno {
    background: transparent;
    color: var(--texto);
    border-color: var(--amarelo);
}

.botao--contorno:hover {
    background: var(--amarelo-suave);
    color: var(--texto);
    transform: translateY(-2px);
}

.botao--claro {
    background: var(--branco);
    color: var(--texto);
    box-shadow: var(--sombra-suave);
}

.botao--claro:hover {
    color: var(--laranja);
    transform: translateY(-2px);
}

/* --------------------------------------------------------------------------
   Cabeçalho / navegação
   -------------------------------------------------------------------------- */
.cabecalho {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--borda);
}

.cabecalho__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 72px;
}

.marca {
    display: flex;
    align-items: center;
    gap: 12px;
}

.marca__avatar {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: var(--amarelo-suave);
    padding: 4px;
    box-shadow: var(--sombra-suave);
    object-fit: cover;
    object-position: top center;
}

.marca__texto {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.marca__nome {
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 1.2rem;
    color: var(--texto);
}

.marca__selo {
    font-size: 0.72rem;
    color: var(--texto-claro);
    font-weight: 600;
}

.nav {
    display: flex;
    align-items: center;
    gap: 28px;
}

.nav__links {
    display: flex;
    align-items: center;
    gap: 28px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav__links a {
    font-family: var(--fonte-titulo);
    font-weight: 600;
    color: var(--texto);
    position: relative;
    padding: 4px 0;
}

.nav__links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 3px;
    border-radius: 3px;
    background: var(--amarelo);
    transition: width 0.25s ease;
}

.nav__links a:hover,
.nav__links a.ativo {
    color: var(--laranja);
}

.nav__links a:hover::after,
.nav__links a.ativo::after {
    width: 100%;
}

/* Menção Focus Fit no header */
.selo-focusfit {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--canvas);
    border: 1px solid var(--borda);
    border-radius: var(--raio-pill);
    padding: 6px 14px 6px 8px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--texto-suave);
}

.selo-focusfit img {
    height: 20px;
    width: auto;
}

/* Botão hambúrguer (mobile) */
.menu-toggle {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 46px;
    height: 46px;
    padding: 0;
    background: var(--amarelo-suave);
    border: none;
    border-radius: var(--raio-sm);
    cursor: pointer;
}

.menu-toggle span {
    display: block;
    width: 22px;
    height: 3px;
    margin: 0 auto;
    border-radius: 3px;
    background: var(--texto);
    transition: transform 0.25s ease, opacity 0.25s ease;
}

/* --------------------------------------------------------------------------
   Hero (home)
   -------------------------------------------------------------------------- */
.hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 85% 15%, var(--amarelo-suave) 0%, rgba(255, 244, 209, 0) 55%),
        linear-gradient(180deg, var(--branco) 0%, var(--canvas) 100%);
    padding: 56px 0 64px;
}

.hero__grid {
    display: grid;
    gap: 36px;
    align-items: center;
}

.hero__saudacao {
    display: inline-block;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--laranja);
    background: var(--amarelo-suave);
    padding: 8px 20px;
    border-radius: var(--raio-pill);
    margin-bottom: 18px;
    font-size: 1rem;
}

.hero h1 {
    font-size: clamp(2.1rem, 6vw, 3.4rem);
    margin-bottom: 18px;
}

.hero h1 .destaque {
    color: var(--laranja);
    position: relative;
}

.hero__lead {
    font-size: 1.2rem;
    color: var(--texto-suave);
    margin-bottom: 28px;
    max-width: 540px;
}

.hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.hero__figura {
    position: relative;
    text-align: center;
}

.hero__figura::before {
    content: "";
    position: absolute;
    inset: 8% 12%;
    background: radial-gradient(circle, var(--amarelo-claro) 0%, var(--amarelo-suave) 60%, rgba(255, 244, 209, 0) 75%);
    border-radius: 50%;
    z-index: 0;
}

.hero__figura img {
    position: relative;
    z-index: 1;
    margin: 0 auto;
    max-height: 460px;
    width: auto;
    filter: drop-shadow(0 18px 30px rgba(0, 0, 0, 0.18));
}

.hero__frases {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 26px;
}

.hero__frases span {
    background: var(--branco);
    border: 1px solid var(--borda);
    border-radius: var(--raio-pill);
    padding: 8px 16px;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--texto-suave);
    box-shadow: var(--sombra-suave);
}

/* --------------------------------------------------------------------------
   Seção "Quem é a Megan"
   -------------------------------------------------------------------------- */
.quem {
    display: grid;
    gap: 40px;
    align-items: center;
}

.quem__figura {
    position: relative;
    background: linear-gradient(160deg, var(--amarelo-suave), var(--branco));
    border-radius: var(--raio-lg);
    padding: 24px;
    box-shadow: var(--sombra-suave);
    text-align: center;
}

.quem__figura img {
    margin: 0 auto;
    max-height: 380px;
    width: auto;
}

.quem__texto h2 {
    font-size: clamp(1.7rem, 4vw, 2.4rem);
}

.quem__texto .assinatura {
    margin-top: 18px;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--laranja);
}

/* --------------------------------------------------------------------------
   Pilares / filosofia (cards)
   -------------------------------------------------------------------------- */
.cards {
    display: grid;
    gap: 22px;
    grid-template-columns: 1fr;
}

.card {
    background: var(--branco);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    padding: 28px 26px;
    box-shadow: var(--sombra-suave);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

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

.card__icone {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--raio-sm);
    background: var(--amarelo-suave);
    color: var(--laranja);
    margin-bottom: 18px;
}

.card__icone svg {
    width: 28px;
    height: 28px;
}

.card h3 {
    font-size: 1.25rem;
    margin-bottom: 8px;
}

.card p {
    color: var(--texto-suave);
    margin: 0;
    font-size: 1rem;
}

/* Temas que ela aborda (lista de pílulas com ícone) */
.temas {
    display: grid;
    gap: 18px;
    grid-template-columns: 1fr;
}

.tema {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--branco);
    border-radius: var(--raio);
    padding: 22px;
    border: 1px solid var(--borda);
    box-shadow: var(--sombra-suave);
}

.tema__icone {
    flex: 0 0 auto;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--amarelo);
    color: #3a2c00;
}

.tema__icone svg {
    width: 24px;
    height: 24px;
}

.tema h3 {
    font-size: 1.1rem;
    margin-bottom: 4px;
}

.tema p {
    margin: 0;
    color: var(--texto-suave);
    font-size: 0.98rem;
}

/* --------------------------------------------------------------------------
   Chamada final (CTA)
   -------------------------------------------------------------------------- */
.cta-final {
    position: relative;
    overflow: hidden;
    text-align: center;
    background: linear-gradient(135deg, var(--amarelo) 0%, var(--amarelo-claro) 100%);
    border-radius: var(--raio-lg);
    padding: 56px 28px;
    box-shadow: var(--sombra-media);
}

.cta-final h2 {
    color: #3a2c00;
    font-size: clamp(1.8rem, 4vw, 2.6rem);
    margin-bottom: 14px;
}

.cta-final p {
    color: #5a4500;
    font-size: 1.15rem;
    max-width: 580px;
    margin: 0 auto 28px;
}

/* --------------------------------------------------------------------------
   Blog — listagem
   -------------------------------------------------------------------------- */
.pagina-topo {
    background:
        radial-gradient(circle at 80% 20%, var(--amarelo-suave) 0%, rgba(255, 244, 209, 0) 60%),
        var(--branco);
    border-bottom: 1px solid var(--borda);
    padding: 48px 0;
    text-align: center;
}

.pagina-topo .selo-texto {
    display: inline-block;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--laranja);
    background: var(--amarelo-suave);
    padding: 6px 16px;
    border-radius: var(--raio-pill);
    margin-bottom: 14px;
}

.pagina-topo h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    margin: 0 0 10px;
}

.pagina-topo p {
    color: var(--texto-suave);
    margin: 0;
    font-size: 1.1rem;
}

.busca {
    display: flex;
    gap: 10px;
    max-width: 520px;
    margin: 26px auto 0;
}

.busca input {
    flex: 1;
    border: 1px solid var(--borda);
    border-radius: var(--raio-pill);
    padding: 14px 22px;
    font-family: var(--fonte-corpo);
    font-size: 1rem;
    background: var(--branco);
    color: var(--texto);
}

.busca input:focus {
    outline: none;
    border-color: var(--amarelo);
    box-shadow: 0 0 0 3px var(--amarelo-suave);
}

.posts-grid {
    display: grid;
    gap: 26px;
    grid-template-columns: 1fr;
}

.post-card {
    display: flex;
    flex-direction: column;
    background: var(--branco);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    height: 100%;
}

.post-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sombra-media);
}

.post-card__thumb {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--amarelo-suave);
}

.post-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.35s ease;
}

.post-card:hover .post-card__thumb img {
    transform: scale(1.05);
}

.post-card__tag {
    position: absolute;
    top: 14px;
    left: 14px;
    background: var(--amarelo);
    color: #3a2c00;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 0.78rem;
    padding: 6px 14px;
    border-radius: var(--raio-pill);
}

.post-card__corpo {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 24px;
}

.post-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    color: var(--texto-claro);
    margin-bottom: 10px;
}

.post-card__meta svg {
    width: 16px;
    height: 16px;
}

.post-card h2,
.post-card h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
}

.post-card h2 a,
.post-card h3 a {
    color: var(--texto);
}

.post-card h2 a:hover,
.post-card h3 a:hover {
    color: var(--laranja);
}

.post-card__resumo {
    color: var(--texto-suave);
    font-size: 0.98rem;
    margin-bottom: 18px;
    flex: 1;
}

.post-card__link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--laranja);
}

.post-card__link svg {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.post-card__link:hover svg {
    transform: translateX(4px);
}

/* Estado vazio */
.vazio {
    text-align: center;
    background: var(--branco);
    border: 1px dashed var(--borda);
    border-radius: var(--raio);
    padding: 56px 28px;
}

.vazio__icone {
    width: 72px;
    height: 72px;
    margin: 0 auto 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--amarelo-suave);
    color: var(--laranja);
}

.vazio__icone svg {
    width: 34px;
    height: 34px;
}

.vazio h2 {
    font-size: 1.5rem;
}

.vazio p {
    color: var(--texto-suave);
    max-width: 440px;
    margin: 0 auto 22px;
}

/* Layout blog com sidebar */
.blog-layout {
    display: grid;
    gap: 36px;
    grid-template-columns: 1fr;
}

.sidebar {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.widget {
    background: var(--branco);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    padding: 24px;
    box-shadow: var(--sombra-suave);
}

.widget__titulo {
    font-size: 1.15rem;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--amarelo-suave);
}

.recentes {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.recente {
    display: flex;
    gap: 14px;
    align-items: center;
}

.recente__thumb {
    flex: 0 0 auto;
    width: 64px;
    height: 64px;
    border-radius: var(--raio-sm);
    overflow: hidden;
    background: var(--amarelo-suave);
}

.recente__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.recente__titulo {
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 0.95rem;
    line-height: 1.3;
    color: var(--texto);
}

.recente__titulo:hover {
    color: var(--laranja);
}

.recente__data {
    display: block;
    font-size: 0.8rem;
    color: var(--texto-claro);
    margin-top: 2px;
}

.lista-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.pill {
    background: var(--amarelo-suave);
    color: var(--laranja-escuro);
    border-radius: var(--raio-pill);
    padding: 6px 14px;
    font-size: 0.85rem;
    font-weight: 600;
}

/* --------------------------------------------------------------------------
   Paginação
   -------------------------------------------------------------------------- */
.paginacao {
    margin-top: 36px;
}

.paginacao nav {
    display: flex;
    justify-content: center;
}

.paginacao svg {
    width: 18px;
    height: 18px;
}

/* Estiliza o componente padrão de paginação do Laravel */
.paginacao ul,
.paginacao .pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
    align-items: center;
}

.paginacao a,
.paginacao span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 12px;
    border-radius: var(--raio-pill);
    background: var(--branco);
    border: 1px solid var(--borda);
    color: var(--texto);
    font-weight: 700;
    font-family: var(--fonte-titulo);
}

.paginacao a:hover {
    background: var(--amarelo-suave);
    color: var(--laranja);
}

.paginacao .active span,
.paginacao [aria-current] span {
    background: var(--amarelo);
    border-color: var(--amarelo);
    color: #3a2c00;
}

.paginacao .disabled span {
    opacity: 0.45;
}

/* --------------------------------------------------------------------------
   Postagem individual
   -------------------------------------------------------------------------- */
.artigo {
    background: var(--branco);
    border: 1px solid var(--borda);
    border-radius: var(--raio-lg);
    overflow: hidden;
    box-shadow: var(--sombra-suave);
}

.artigo__capa {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--amarelo-suave);
}

.artigo__capa img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.artigo__credito {
    font-size: 0.8rem;
    color: var(--texto-claro);
    padding: 8px 28px 0;
    font-style: italic;
}

.artigo__corpo {
    padding: 32px 28px 40px;
}

.artigo__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    color: var(--texto-claro);
    font-size: 0.9rem;
    margin-bottom: 18px;
}

.artigo__meta span {
    display: inline-flex;
    align-items: center;
    gap: 7px;
}

.artigo__meta svg {
    width: 17px;
    height: 17px;
    color: var(--laranja);
}

.artigo__corpo h1 {
    font-size: clamp(1.8rem, 4.5vw, 2.6rem);
    margin-bottom: 18px;
}

/* Conteúdo rico vindo do banco */
.conteudo {
    font-size: 1.08rem;
    line-height: 1.8;
    color: var(--texto);
}

.conteudo h2 {
    font-size: 1.6rem;
    margin: 1.6em 0 0.5em;
}

.conteudo h3 {
    font-size: 1.3rem;
    margin: 1.4em 0 0.5em;
}

.conteudo p {
    margin: 0 0 1.2em;
}

.conteudo a {
    color: var(--laranja);
    text-decoration: underline;
}

.conteudo img {
    border-radius: var(--raio);
    margin: 1.4em 0;
    box-shadow: var(--sombra-suave);
}

.conteudo ul,
.conteudo ol {
    margin: 0 0 1.2em;
    padding-left: 1.4em;
}

.conteudo li {
    margin-bottom: 0.5em;
}

.conteudo blockquote {
    margin: 1.6em 0;
    padding: 18px 24px;
    border-left: 5px solid var(--amarelo);
    background: var(--amarelo-suave);
    border-radius: 0 var(--raio) var(--raio) 0;
    font-style: italic;
    color: var(--texto-suave);
}

/* Caixa do autor */
.autor-box {
    display: flex;
    gap: 18px;
    align-items: center;
    background: var(--canvas-quente);
    border: 1px solid var(--borda);
    border-radius: var(--raio);
    padding: 22px;
    margin: 36px 0 0;
}

.autor-box__foto {
    flex: 0 0 auto;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--amarelo-suave);
    box-shadow: var(--sombra-suave);
}

.autor-box__foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
}

.autor-box__nome {
    font-family: var(--fonte-titulo);
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--texto);
    margin-bottom: 2px;
}

.autor-box__papel {
    font-size: 0.85rem;
    color: var(--laranja);
    font-weight: 600;
    margin-bottom: 6px;
}

.autor-box p {
    margin: 0;
    color: var(--texto-suave);
    font-size: 0.95rem;
}

/* Tags da postagem */
.artigo__tags {
    margin-top: 28px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.artigo__tags .rotulo {
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--texto-suave);
    margin-right: 4px;
}

/* Navegação anterior/próximo */
.nav-posts {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 14px;
    margin-top: 36px;
    padding-top: 28px;
    border-top: 1px solid var(--borda);
}

.nav-posts a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--canvas);
    border: 1px solid var(--borda);
    border-radius: var(--raio-pill);
    padding: 12px 22px;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--texto);
    max-width: 48%;
}

.nav-posts a:hover {
    background: var(--amarelo-suave);
    color: var(--laranja);
}

.nav-posts svg {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

.nav-posts .rotulo-nav {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.voltar-blog {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 28px;
    font-family: var(--fonte-titulo);
    font-weight: 700;
    color: var(--laranja);
}

.voltar-blog svg {
    width: 18px;
    height: 18px;
    transition: transform 0.2s ease;
}

.voltar-blog:hover svg {
    transform: translateX(-4px);
}

/* --------------------------------------------------------------------------
   Rodapé
   -------------------------------------------------------------------------- */
.rodape {
    background: #1c1c1c;
    color: #d8d8d8;
    padding: 56px 0 28px;
}

.rodape__grid {
    display: grid;
    gap: 36px;
    grid-template-columns: 1fr;
    margin-bottom: 36px;
}

.rodape__marca {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 16px;
}

.rodape__marca img {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--amarelo-suave);
    padding: 4px;
    object-fit: cover;
    object-position: top center;
}

.rodape__marca strong {
    font-family: var(--fonte-titulo);
    font-size: 1.25rem;
    color: var(--branco);
}

.rodape p {
    color: #aaaaaa;
    font-size: 0.95rem;
}

.rodape h4 {
    color: var(--branco);
    font-size: 1.05rem;
    margin-bottom: 16px;
}

.rodape__links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.rodape__links a {
    color: #cccccc;
    font-weight: 600;
}

.rodape__links a:hover {
    color: var(--amarelo-claro);
}

.rodape__focusfit {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: var(--raio);
    padding: 16px 20px;
}

.rodape__focusfit img {
    height: 30px;
    width: auto;
}

.rodape__focusfit span {
    font-size: 0.85rem;
    color: #cccccc;
    line-height: 1.4;
}

.rodape__focusfit strong {
    display: block;
    color: var(--amarelo-claro);
    font-family: var(--fonte-titulo);
}

.rodape__base {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 22px;
    text-align: center;
    font-size: 0.85rem;
    color: #999999;
}

.rodape__base a {
    color: var(--amarelo-claro);
}

/* --------------------------------------------------------------------------
   Responsivo (tablet e desktop)
   -------------------------------------------------------------------------- */
@media (min-width: 600px) {
    .cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .temas {
        grid-template-columns: repeat(2, 1fr);
    }

    .posts-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .rodape__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 900px) {
    :root {
        --espaco-secao: 96px;
    }

    .hero__grid {
        grid-template-columns: 1.05fr 0.95fr;
    }

    .quem {
        grid-template-columns: 0.9fr 1.1fr;
    }

    .cards {
        grid-template-columns: repeat(4, 1fr);
    }

    .blog-layout {
        grid-template-columns: 1fr 320px;
    }

    .rodape__grid {
        grid-template-columns: 1.6fr 1fr 1.4fr;
    }
}

/* Menu mobile */
@media (max-width: 859px) {
    .menu-toggle {
        display: flex;
    }

    .nav {
        position: fixed;
        inset: 72px 0 auto 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        background: var(--branco);
        border-bottom: 1px solid var(--borda);
        box-shadow: var(--sombra-media);
        padding: 12px 20px 24px;
        transform: translateY(-130%);
        transition: transform 0.3s ease;
        z-index: 90;
    }

    .nav.aberto {
        transform: translateY(0);
    }

    .nav__links {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        width: 100%;
    }

    .nav__links li {
        border-bottom: 1px solid var(--borda);
    }

    .nav__links a {
        display: block;
        padding: 16px 4px;
    }

    .nav__links a::after {
        display: none;
    }

    .selo-focusfit {
        margin-top: 16px;
        align-self: flex-start;
    }

    .menu-toggle[aria-expanded="true"] span:nth-child(1) {
        transform: translateY(8px) rotate(45deg);
    }

    .menu-toggle[aria-expanded="true"] span:nth-child(2) {
        opacity: 0;
    }

    .menu-toggle[aria-expanded="true"] span:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg);
    }
}

/* Acessibilidade: respeita preferência por menos movimento */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
