.site-footer {
    background-color: var(--footer-background-color); /* Cor de fundo dinâmica */
    color: var(--footer-text-color); /* Cor do texto dinâmica */
    padding: 40px 20px;
}

.footer-columns {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* Força 4 colunas iguais */
    gap: 150px; /* Espaço entre as colunas */
    max-width: 1200px;
    margin: 0 auto;
}

.footer-col {
    margin-bottom: 20px;
    padding: 0; /* Removendo o padding interno para evitar sobreposição */
}

.footer-title {
    font-weight: bold;
    margin-bottom: 30px;
    color: var(--footer-text-color); /* Cor dos títulos dinâmica */
}

.footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-col li {
    margin-bottom: 20px; /* Adiciona 20px de espaçamento entre os links */
}

.footer-col li:last-child {
    margin-bottom: 0; /* Remove o espaço extra no último item da lista */
}

.footer-col a {
    color: var(--footer-link-color); /* Cor dos links dinâmica */
    text-decoration: none;
    margin-left: 10px; /* Adiciona 10px de margem à esquerda dos links */
}

.footer-col a:hover {
    color: var(--footer-link-hover-color); /* Cor dos links ao hover dinâmica */
    text-decoration: underline;
}

.footer-social-links li {
    display: flex;
    align-items: center;
    gap: 5px; /* Espaço entre o ícone e o texto */
}

.footer-social-links img {
    width: 20px; /* Tamanho dos ícones */
    height: 20px;
}

.footer-bottom {
    text-align: center;
    margin-top: 40px; /* Aumentando o espaço acima */
    font-size: 0.875rem;
    border-top: 1px solid #e0e0e0;
    padding-top: 20px;
    color: var(--footer-link-color); /* Cor dinâmica dos links para o texto do rodapé */
}

.footer-description {
    color: var(--footer-link-color); /* Cor dinâmica dos links para a descrição */
}

.footer-logo {
    margin-bottom: 20px; /* Margem inferior de 20px */
    width: 180px; /* Largura fixa da logo */
    height: 40px; /* Altura fixa da logo */
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: transparent; /* Cor de fundo transparente */
    overflow: hidden; /* Oculta qualquer excesso, se necessário */
}

.footer-logo img {
    width: 100%; /* Ajusta a largura da imagem ao contêiner */
    height: 100%; /* Ajusta a altura da imagem ao contêiner */
    object-fit: contain; /* Garante que a imagem fique inteira no contêiner */
    object-position: center; /* Centraliza a imagem */
}

/* Aviso de cookies e LGPD */
#cookie-banner {
    display: none; /* Esconde até que o JS verifique o localStorage */
    position: fixed;
    bottom: 10px; /* Mantém a distância do rodapé */
    left: 50%;
    transform: translateX(-50%);
    width: 90%; /* Usa até 90% da largura */
    max-width: 900px; /* Define um limite máximo */
    background-color: var(--cookie-banner-bg);
    color: var(--cookie-banner-text-color);
    padding: 16px 30px; /* Ajuste interno para manter espaçamento uniforme */
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    z-index: 9999;
    border-radius: 8px; /* Borda arredondada */
}

#cookie-banner p {
    flex: 1; /* O texto ocupa o máximo de espaço disponível */
    margin: 0;
    text-align: left; /* Mantém o texto alinhado à esquerda */
    padding-right: 30px; /* Adiciona espaçamento entre o texto e o botão */
}

#cookie-banner a {
    color: var(--cookie-link-color);
    text-decoration: underline;
}

#cookie-banner a:hover {
    color: var(--cookie-link-hover);
}

#accept-cookies {
    background-color: var(--cookie-button-color);
    color: #fff;
    border: none;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: bold;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: 4px;
    transition: background 0.3s ease-in-out;
}

/* Efeito hover para melhorar interação */
#accept-cookies:hover {
    background-color: var(--cookie-button-hover);
}
