/* --- ESTILOS GERAIS E VARIÁVEIS --- */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');

:root {
    --cor-principal: #67c15e; /* Verde do novo design */
    --cor-fundo: #212529;      /* Fundo do novo design */
    --cor-superficie: #292e33; /* Superfície do novo design */
    --cor-texto: #ffffff;      /* Texto principal do novo design */
    --cor-texto-secundario: #adb5bd;
    --cor-borda: #3e444a;
    --cor-principal-hover: #76d46d; /* Efeito hover para o verde */
}

html { height: 100%; }
body { font-family: 'Poppins', sans-serif; background-color: var(--cor-fundo); color: var(--cor-texto); margin: 0; padding: 0; line-height: 1.6; min-height: 100%; display: flex; flex-direction: column; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; width: 100%; box-sizing: border-box; flex-grow: 1; }

.main-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 992px) { .has-sidebar .main-layout { grid-template-columns: 3fr 1fr; } }
.no-sidebar .sidebar { display: none; }
.no-sidebar .main-content { grid-column: 1 / -1; }
.sidebar-widget { background-color: var(--cor-superficie); padding: 1.5rem; border-radius: 8px; margin-bottom: 1.5rem; }
.sidebar-widget h4 { margin-top: 0; border-bottom: 2px solid var(--cor-principal); padding-bottom: 0.5rem; }
.sidebar-list { list-style: none; padding: 0; margin: 0; }
.sidebar-list li { margin-bottom: 0.8rem; }
.sidebar-list a { text-decoration: none; color: var(--cor-texto-secundario); transition: color 0.2s ease; }
.sidebar-list a:hover { color: var(--cor-principal); }
.ad-placeholder { width: 100%; height: 250px; background-color: #333; display: flex; align-items: center; justify-content: center; border-radius: 8px; }
.ad-placeholder::before { content: 'Anúncio'; color: var(--cor-texto-secundario); }
.main-nav { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; margin-bottom: 2rem; }
.nav-left, .nav-center { display: flex; align-items: center; }
.site-title { text-decoration: none; color: var(--cor-texto); font-size: 1.5rem; font-weight: 700; }
.main-nav i { font-size: 1.5rem; color: var(--cor-texto-secundario); cursor: pointer; transition: color 0.2s ease; }
.main-nav i:hover { color: var(--cor-principal); }
.side-nav { height: 100%; width: 280px; position: fixed; z-index: 1000; top: 0; left: -300px; background-color: var(--cor-superficie); padding-top: 60px; transition: left 0.3s ease; border-right: 1px solid var(--cor-borda); }
.side-nav.open { left: 0; }
.side-nav a { padding: 10px 15px; text-decoration: none; font-size: 1.2rem; color: var(--cor-texto-secundario); display: block; transition: color 0.2s ease; }
.side-nav a:hover { color: var(--cor-principal); }
.side-nav .btn-close { position: absolute; top: 0; right: 25px; font-size: 36px; margin-left: 50px; }
.nav-right { position: relative; display: flex; align-items: center; }
#search-form { order: 2; }
#search-icon { order: 3; }
#search-bar { position: absolute; top: 50%; transform: translateY(-50%); right: 40px; width: 0; opacity: 0; visibility: hidden; padding: 0.5rem 1rem; border: 1px solid var(--cor-borda); background: var(--cor-superficie); color: var(--cor-texto); border-radius: 20px; transition: all 0.3s ease-in-out; outline: none; }
#search-bar.search-bar-visible { visibility: visible; opacity: 1; width: 200px; }
.post-list-header { margin-bottom: 1.5rem; border-bottom: 2px solid var(--cor-principal); padding-bottom: 0.5rem; }
.post-list-header h1 { margin: 0; }
.post-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; }

/* --- NOVO ESTILO DE LISTA (1 COLUNA) --- */
.post-list-redesigned {
    display: flex; /* Usamos flexbox para uma lista vertical */
    flex-direction: column; /* Organiza os cards um embaixo do outro */
    gap: 1.5rem; /* Espaçamento entre os cards */
}

/* O card agora será uma coluna de itens: imagem e conteúdo */
.mod-card-redesigned {
    background-color: var(--cor-superficie);
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none;
    color: var(--cor-texto);
    border: 1px solid var(--cor-borda);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    display: flex;
    flex-direction: column;
}

.mod-card-redesigned:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

/* Ajustamos a imagem do banner */
.mod-card-image {
    height: 180px; /* Um pouco mais alta para o formato largo */
    background-size: cover;
    background-position: center;
    position: relative;
}

.mod-card-overlay {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(to top, rgba(41, 46, 51, 0.5) 0%, rgba(41, 46, 51, 0) 60%);
}

/* A MUDANÇA PRINCIPAL: O conteúdo agora fica ABAIXO da imagem */
.mod-card-content {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    /* Removemos o posicionamento que fazia o conteúdo sobrepor a imagem */
    position: static;
}

/* O ícone não precisa mais da borda para "saltar" */
.mod-card-content-icon {
    width: 60px;
    height: 60px;
    border-radius: 15px;
    object-fit: cover;
    flex-shrink: 0;
    border: none; /* Removemos a borda */
}

.mod-card-text h3 {
    margin: 0 0 0.25rem 0;
    font-size: 1.1rem;
    font-weight: 600;
    border: none;
}

.mod-card-text p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--cor-texto-secundario);
}


/* --- ESTILO DA NOVA PAGINAÇÃO --- */
.pagination {
    display: flex;
    justify-content: center; /* Centraliza os botões */
    align-items: center;
    list-style: none; /* Remove as bolinhas da lista */
    padding: 0;
    margin-top: 2.5rem;
    flex-wrap: wrap; /* Permite que os botões quebrem a linha em telas pequenas */
}
.page-item {
    margin: 0 4px; /* Espaço entre os botões */
}
.page-link {
    display: block;
    padding: 0.7rem 1.1rem;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--cor-texto-secundario);
    background-color: var(--cor-superficie);
    border: 1px solid var(--cor-borda);
    border-radius: 8px; /* Cantos mais arredondados */
    text-decoration: none;
    transition: all 0.2s ease;
}
.page-item:not(.disabled) .page-link:hover {
    background-color: #31363b;
    color: var(--cor-principal);
    border-color: var(--cor-principal);
    transform: translateY(-2px);
}
.page-item.active .page-link {
    z-index: 1;
    color: #fff;
    background-color: var(--cor-principal);
    border-color: var(--cor-principal);
}
.page-item.disabled .page-link {
    color: #6c757d;
    pointer-events: none; /* Impede o clique em botões desativados */
    background-color: transparent;
    border-color: transparent;
    opacity: 0.7;
}

/* --- RODAPÉ E RESPONSIVO --- */
.site-footer { background-color: var(--cor-superficie); border-top: 1px solid var(--cor-borda); padding: 2rem 0; margin-top: auto; }
.container-footer { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; text-align: center; }
.footer-social-icons i { font-size: 1.8rem; color: var(--cor-texto-secundario); margin: 0 15px; transition: color 0.2s ease, transform 0.2s ease; }
.footer-social-icons i:hover { color: var(--cor-principal); transform: scale(1.1); }
.footer-links { margin-top: 1rem; }
.footer-links a { color: var(--cor-texto-secundario); text-decoration: none; margin: 0 5px; }
.footer-links a:hover { text-decoration: underline; }
@media (max-width: 768px) {
    body { padding-top: 1rem; }
    .container { padding: 0 1rem; }
    h2 { font-size: 1.5rem; }
    .post-list { grid-template-columns: 1fr; gap: 1rem; }
}