.elementor-kit-6{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-color-kadence1:#2B6CB0;--e-global-color-kadence2:#215387;--e-global-color-kadence3:#1A202C;--e-global-color-kadence4:#2D3748;--e-global-color-kadence5:#4A5568;--e-global-color-kadence6:#718096;--e-global-color-kadence7:#EDF2F7;--e-global-color-kadence8:#F7FAFC;--e-global-color-kadence9:#ffffff;--e-global-typography-primary-font-family:"Roboto";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Roboto Slab";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-6.el-is-editing{--global-palette1:#2B6CB0;--global-palette2:#215387;--global-palette3:#1A202C;--global-palette4:#2D3748;--global-palette5:#4A5568;--global-palette6:#718096;--global-palette7:#EDF2F7;--global-palette8:#F7FAFC;--global-palette9:#ffffff;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.elementor-kit-6 e-page-transition{background-color:#FFBC7D;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ==========================================================================
   1. VARIÁVEIS GERAIS (DESIGN SYSTEM)
   ========================================================================== */
:root {
    /* Paleta de Cores Institucionais */
    --primary-blue: #0A2342;    /* Azul Marinho (Cabeçalhos, Rodapés, Títulos) */
    --secondary-blue: #1D70B8;  /* Azul Celeste (Botões, Links, Destaques) */
    --accent-color: #F39C12;    /* Cor de Alerta/Apoio (Opcional, para etiquetas) */
    
    /* Cores de Fundo e Texto */
    --bg-body: #F4F6F9;         /* Cinza muito claro para o fundo do site */
    --bg-white: #FFFFFF;        /* Fundo de cards e seções brancas */
    --text-main: #333333;       /* Cor principal do texto (leitura) */
    --text-muted: #666666;      /* Texto secundário (datas, locais) */
    --border-color: #E0E4E8;    /* Bordas sutis */

    /* Tipografia */
    --font-heading: 'Montserrat', sans-serif;
    --font-body: 'Inter', sans-serif;

    /* Espaçamentos e Sombras */
    --radius: 8px;
    --shadow-sm: 0 2px 5px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 15px rgba(0, 0, 0, 0.08);
    --transition: all 0.3s ease-in-out;
}

/* ==========================================================================
   2. RESET E ESTILOS GERAIS
   ========================================================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-body);
    background-color: var(--bg-body);
    color: var(--text-main);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--primary-blue);
    font-weight: 700;
    margin-bottom: 1rem;
}

a {
    text-decoration: none;
    color: var(--secondary-blue);
    transition: var(--transition);
}

a:hover {
    color: var(--primary-blue);
}

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

/* Container Global (Limita a largura do site) */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ==========================================================================
   3. BOTÕES (UI COMPONENT)
   ========================================================================== */
.btn {
    display: inline-block;
    padding: 12px 28px;
    border-radius: var(--radius);
    font-family: var(--font-heading);
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    transition: var(--transition);
    border: none;
}

.btn-primary {
    background-color: var(--secondary-blue);
    color: var(--bg-white);
}

.btn-primary:hover {
    background-color: var(--primary-blue);
    transform: translateY(-2px);
}

.btn-outline {
    background-color: transparent;
    border: 2px solid var(--secondary-blue);
    color: var(--secondary-blue);
}

.btn-outline:hover {
    background-color: var(--secondary-blue);
    color: var(--bg-white);
}

/* ==========================================================================
   4. CABEÇALHO (HEADER) E NAVEGAÇÃO
   ========================================================================== */
.site-header {
    background-color: var(--primary-blue);
    padding: 15px 0;
    position: sticky;
    top: 0;
    z-index: 999;
    box-shadow: var(--shadow-md);
}

.header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    color: var(--bg-white);
    font-family: var(--font-heading);
    font-size: 1.2rem;
    line-height: 1.2;
}

.logo:hover { color: var(--bg-white); opacity: 0.9; }

.main-nav ul {
    list-style: none;
    display: flex;
    gap: 30px;
}

.main-nav a {
    color: var(--bg-white);
    font-weight: 500;
    padding: 10px 0;
    display: block;
}

.main-nav a:hover {
    color: #8bb8e8; /* Azul mais claro para hover no fundo escuro */
}

/* ==========================================================================
   5. SEÇÕES E GRIDS (LAYOUT)
   ========================================================================== */
.section {
    padding: 80px 0;
}

.section-bg-white {
    background-color: var(--bg-white);
}

.section-title {
    text-align: center;
    font-size: 2.2rem;
    margin-bottom: 50px;
    position: relative;
}

/* Linha decorativa abaixo do título */
.section-title::after {
    content: '';
    display: block;
    width: 60px;
    height: 4px;
    background-color: var(--secondary-blue);
    margin: 15px auto 0;
    border-radius: 2px;
}

/* Grid genérico de 3 colunas (Usado em Notícias e Convênios) */
.grid-3-cols {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 30px;
}

/* ==========================================================================
   6. CARDS (NOTÍCIAS E CONVÊNIOS)
   ========================================================================== */
.card {
    background: var(--bg-white);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    transition: var(--transition);
    border: 1px solid var(--border-color);
}

.card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: var(--secondary-blue);
}

.card-img {
    height: 200px;
    background-color: #E0E4E8; /* Placeholder */
    width: 100%;
    object-fit: cover;
}

.card-body {
    padding: 25px;
}

.card-title {
    font-size: 1.25rem;
    margin-bottom: 10px;
}

.card-excerpt {
    color: var(--text-muted);
    font-size: 0.95rem;
    margin-bottom: 20px;
}

/* ==========================================================================
   7. LISTA DE EVENTOS
   ========================================================================== */
.event-list {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.event-item {
    display: flex;
    align-items: center;
    background: var(--bg-white);
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    padding: 20px;
    transition: var(--transition);
}

.event-item:hover {
    border-color: var(--secondary-blue);
    box-shadow: var(--shadow-sm);
}

.event-date {
    background-color: var(--bg-body);
    padding: 15px 20px;
    border-radius: var(--radius);
    text-align: center;
    margin-right: 25px;
    min-width: 90px;
}

.event-date .day {
    display: block;
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--primary-blue);
    line-height: 1;
}

.event-date .month {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
}

.event-meta {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-top: 5px;
}

/* ==========================================================================
   8. PÁGINA DE CONVÊNIOS (LAYOUT COM SIDEBAR)
   ========================================================================== */
.convenios-wrapper {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
}

.sidebar-filtros {
    background: var(--bg-white);
    padding: 25px;
    border-radius: var(--radius);
    border: 1px solid var(--border-color);
    position: sticky;
    top: 100px; /* Mantém os filtros fixos ao rolar a página */
}

.filtro-group {
    margin-bottom: 25px;
}

.filtro-title {
    font-size: 1.1rem;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

/* ==========================================================================
   9. RODAPÉ (FOOTER)
   ========================================================================== */
.site-footer {
    background-color: var(--primary-blue);
    color: var(--bg-white);
    text-align: center;
    padding: 40px 0;
    margin-top: auto;
}

.site-footer p {
    color: #A0B2C6;
    font-size: 0.9rem;
}

/* ==========================================================================
   10. RESPONSIVIDADE (MEDIA QUERIES)
   ========================================================================== */
@media (max-width: 992px) {
    /* Tablet */
    .convenios-wrapper {
        grid-template-columns: 1fr; /* Sidebar vai para o topo */
    }
    
    .sidebar-filtros {
        position: static;
    }
}

@media (max-width: 768px) {
    /* Mobile */
    .header-inner {
        flex-direction: column;
        gap: 15px;
    }

    .main-nav ul {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }

    .grid-3-cols {
        grid-template-columns: 1fr; /* 1 coluna no celular */
    }

    .event-item {
        flex-direction: column;
        text-align: center;
    }

    .event-date {
        margin-right: 0;
        margin-bottom: 15px;
    }
}/* End custom CSS */