/* ========================================
   CSS ORGANIZADO - TEMA MCE
   ======================================== */

/* ========================================
   VARIÁVEIS CSS GLOBAIS
   ======================================== */

:root {
    --primary-color: #FF6B35;
    --secondary-color: #FF8C42;
    --accent-color: #f7931e;
    --bg-white: #ffffff;
    --bg-light: #f8f9fa;
    --text-dark: #2c1810;
    --text-muted: #6c757d;
    --border-color: #dee2e6;
    --shadow-light: rgba(0, 0, 0, 0.05);
    --shadow-medium: rgba(0, 0, 0, 0.1);
    --shadow-orange: rgba(255, 107, 53, 0.3);
    --gradient-primary: linear-gradient(135deg, #FF8C42 0%, #FF6B35 100%);
    --gradient-light: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    --gradient-orange-light: linear-gradient(135deg, #fff5f0 0%, #ffe8d6 100%);
    --transition-fast: all 0.2s ease;
    --transition-normal: all 0.3s ease;
    --border-radius: 8px;
    --border-radius-small: 6px;
    --border-radius-large: 12px;
}

/* ========================================
   LAYOUT E ESTRUTURA BASE
   ======================================== */

/* Layout Full-Width (100% da tela) */
.container,
.container-fluid,
.row,
.col-md-8,
.col-md-6,
.col-md-4,
.pagina-left,
.pagina-right {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.container {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}

.container-fluid {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
}

.row {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.col-md-8,
.col-md-6,
.col-md-4,
.pagina-left,
.pagina-right {
    width: 100% !important;
    max-width: 100% !important;
    flex: none !important;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
}

/* ========================================
   HEADER E NAVEGAÇÃO
   ======================================== */

/* Header minimalista */
.header-minimal {
    position: relative !important;
    background: var(--gradient-light) !important;
    padding: 40px 20px !important;
    text-align: center !important;
    border-bottom: 1px solid var(--border-color) !important;
    margin-bottom: 30px !important;
}

/* Botão expandir do header */
.header-minimal .expand-button-container {
    display: block !important;
    text-align: right !important;
    margin: 0 !important;
    position: absolute !important;
    top: 15px !important;
    right: 15px !important;
    z-index: 100 !important;
    pointer-events: auto !important;
}

.header-minimal .expand-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--gradient-primary) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    cursor: pointer !important;
    transition: var(--transition-normal) !important;
    box-shadow: 0 4px 15px var(--shadow-orange) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    outline: none !important;
    position: relative !important;
    z-index: 100 !important;
    pointer-events: auto !important;
    user-select: none !important;
}

.header-minimal .expand-btn:hover {
    background: var(--gradient-primary) !important;
    transform: scale(1.1) !important;
    box-shadow: 0 6px 20px var(--shadow-orange) !important;
}

.header-minimal .expand-btn:active {
    transform: scale(0.95) !important;
    box-shadow: 0 2px 8px var(--shadow-orange) !important;
}

.header-minimal .expand-btn i {
    font-size: 1.2em !important;
    transition: var(--transition-normal) !important;
}

.header-minimal .expand-btn.active i {
    transform: rotate(45deg) !important;
}

/* Descrição completa do header */
.header-descricao-completa {
    max-height: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    transition: max-height 0.3s ease, opacity 0.3s ease !important;
    background: var(--gradient-orange-light) !important;
    border: 1px solid var(--primary-color) !important;
    border-radius: var(--border-radius) !important;
    padding: 0 20px !important;
    margin: 20px 0 !important;
    box-shadow: 0 2px 8px var(--shadow-orange) !important;
}

.header-descricao-completa[style*="display: block"] {
    max-height: none !important;
    opacity: 1 !important;
    padding: 20px !important;
}

.header-descricao-completa p {
    color: var(--text-dark) !important;
    line-height: 1.6 !important;
    margin-bottom: 15px !important;
    font-size: 16px !important;
}

.header-descricao-completa p:last-child {
    margin-bottom: 0 !important;
}

/* ========================================
   MENU MOBILE
   ======================================== */

/* Botões mobile */
.mobile-buttons {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    position: relative !important;
    z-index: 100 !important;
    flex-shrink: 0 !important;
}

.botao-menu,
.botao-busca {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--gradient-primary) !important;
    color: #fff !important;
    border: 1px solid rgba(255, 107, 53, 0.3) !important;
    transition: var(--transition-normal) !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: var(--border-radius-small) !important;
    cursor: pointer !important;
    font-size: 16px !important;
    position: relative !important;
    z-index: 101 !important;
}

.botao-menu:hover,
.botao-busca:hover {
    background: linear-gradient(135deg, #FF6B35 0%, #FF8C42 100%) !important;
    transform: scale(1.05) !important;
    box-shadow: 0 4px 12px var(--shadow-orange) !important;
}

/* Menu mobile ativo */
.topo-menu.active {
    display: block !important;
    width: 100% !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background: var(--gradient-primary) !important;
    border-radius: var(--border-radius) !important;
    box-shadow: 0 4px 12px var(--shadow-medium) !important;
    z-index: 1000 !important;
    margin-top: 10px !important;
}

.topo-menu.active li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    width: 100% !important;
}

.topo-menu.active li:last-child {
    border-bottom: none !important;
    box-shadow: none !important;
}

.topo-menu.active li a {
    padding: 15px 20px !important;
    color: #fff !important;
    font-size: 16px !important;
    line-height: 1.3 !important;
}

.topo-menu.active li a:hover {
    background: rgba(255, 255, 255, 0.1) !important;
}




/* ========================================
   CARDS E GRIDS
   ======================================== */

/* Grid de contos */
.contos-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
    gap: 30px !important;
    padding: 20px !important;
}

/* Cards de contos */
.conto-card {
    background: var(--bg-white) !important;
    border: 1px solid var(--border-color) !important;
    border-radius: var(--border-radius) !important;
    padding: 20px !important;
    transition: var(--transition-normal) !important;
    box-shadow: 0 2px 8px var(--shadow-light) !important;
    position: relative !important;
    overflow: hidden !important;
}

.conto-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 8px 25px var(--shadow-medium) !important;
    border-color: var(--primary-color) !important;
}

/* Título do conto */
.conto-titulo {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--text-dark) !important;
    margin-bottom: 15px !important;
    line-height: 1.3 !important;
    position: relative !important;
}

.conto-titulo a {
    color: inherit !important;
    text-decoration: none !important;
    transition: var(--transition-normal) !important;
}

.conto-titulo a::after {
    content: '' !important;
    position: absolute !important;
    bottom: -5px !important;
    left: 0 !important;
    width: 0 !important;
    height: 2px !important;
    background: var(--gradient-primary) !important;
    transition: width 0.3s ease !important;
}

.conto-card:hover .conto-titulo a::after {
    width: 100% !important;
}

/* ========================================
   PAGINAÇÃO
   ======================================== */

.paginacao,
.paginacao-minimal {
    width: 100% !important;
    max-width: 100% !important;
    margin: 60px 0 40px 0 !important;
    padding: 0 20px !important;
    box-sizing: border-box !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 8px !important;
}

.paginacao ul,
.paginacao-minimal ul {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    flex-wrap: wrap !important;
}

.paginacao li a,
.paginacao li em,
.paginacao li span,
.paginacao-minimal li a,
.paginacao-minimal li em,
.paginacao-minimal li span {
    display: inline-block !important;
    padding: 15px 20px !important;
    margin: 0 !important;
    background: var(--bg-white) !important;
    color: var(--text-dark) !important;
    text-decoration: none !important;
    border: 2px solid var(--border-color) !important;
    border-radius: var(--border-radius) !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    line-height: 1 !important;
    transition: var(--transition-normal) !important;
    min-width: 48px !important;
    text-align: center !important;
    box-sizing: border-box !important;
}

.paginacao li a:hover,
.paginacao-minimal li a:hover {
    background: var(--gradient-primary) !important;
    color: #fff !important;
    border-color: var(--primary-color) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px var(--shadow-orange) !important;
}

.paginacao li em,
.paginacao li .current,
.paginacao-minimal li em,
.paginacao-minimal li .current {
    background: var(--gradient-primary) !important;
    color: #fff !important;
    border-color: var(--primary-color) !important;
    font-style: normal !important;
    font-weight: 700 !important;
    box-shadow: 0 2px 8px var(--shadow-orange) !important;
}

/* ========================================
   FOOTER
   ======================================== */

.rodape {
    background: var(--gradient-light) !important;
    border-top: 1px solid var(--border-color) !important;
    padding: 40px 0 20px 0 !important;
    margin-top: 60px !important;
}

.rodape-menu {
    margin-bottom: 30px !important;
}

.rodape-menu ul {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.rodape-menu li {
    margin: 0 !important;
}

.rodape-menu a {
    color: var(--text-muted) !important;
    text-decoration: none !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    transition: var(--transition-normal) !important;
    padding: 8px 12px !important;
    border-radius: var(--border-radius-small) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}

.rodape-menu a:hover {
    color: var(--primary-color) !important;
    background: rgba(255, 107, 53, 0.1) !important;
    transform: translateY(-1px) !important;
}

.rodape-menu a i {
    font-size: 12px !important;
    transition: var(--transition-normal) !important;
}

.rodape-menu a:hover i {
    transform: scale(1.1) !important;
}

/* ========================================
   RESPONSIVO
   ======================================== */

/* Mobile - até 768px */
@media (max-width: 768px) {
    .mobile-buttons {
        display: flex !important;
    }
    
    .botao-menu,
    .botao-busca {
        display: flex !important;
    }
    

    
    .topo-menu {
        display: none !important;
    }
    
    .contos-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding: 15px !important;
    }
    
    .paginacao,
    .paginacao-minimal {
        padding: 0 15px !important;
        gap: 6px !important;
    }
    
    .paginacao li a,
    .paginacao li em,
    .paginacao li span,
    .paginacao-minimal li a,
    .paginacao-minimal li em,
    .paginacao-minimal li span {
        padding: 12px 16px !important;
        font-size: 14px !important;
        min-width: 40px !important;
    }
}

/* Desktop - acima de 768px */
@media (min-width: 769px) {
    .mobile-buttons {
        display: none !important;
    }
    
    .botao-menu,
    .botao-busca {
        display: none !important;
    }
    

    
    .topo-menu {
        display: block !important;
    }
}

/* Mobile pequeno - até 480px */
@media (max-width: 480px) {
    .paginacao,
    .paginacao-minimal {
        padding: 0 10px !important;
        gap: 4px !important;
    }
    
    .paginacao li a,
    .paginacao li em,
    .paginacao li span,
    .paginacao-minimal li a,
    .paginacao-minimal li em,
    .paginacao-minimal li span {
        padding: 10px 14px !important;
        font-size: 13px !important;
        min-width: 36px !important;
    }
    
    .rodape-menu ul {
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
    }
    
    .rodape-menu a {
        font-size: 13px !important;
        padding: 6px 10px !important;
    }
}

