/* ===============================================================================
[Painel] | 04 LAYOUT FOOTER - v1.3 - /src/static/css/04-layout/footer.css
Padrão: contraste garantido, espaçamento seguro e responsividade mobile
=============================================================================== */
.footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: var(--footer-height);
    background-color: #0f172a;
    color: #f8fafc;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-sm);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 100;
    padding: 0 var(--spacing-4);
}

.footer-content {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    flex-wrap: wrap;
    justify-content: center;
}

.footer-content p {
    margin: 0;
    opacity: 0.9;
}

.footer-link {
    color: #60a5fa;
    text-decoration: none;
    font-weight: 500;
    transition: opacity var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
}

.footer-link:hover {
    opacity: 0.8;
    text-decoration: underline;
}

.footer-separator {
    color: rgba(255, 255, 255, 0.3);
    margin: 0 var(--spacing-1);
}

.main-content {
    margin-bottom: calc(var(--footer-height) + var(--spacing-6));
    min-height: calc(100vh - var(--navbar-height) - var(--footer-height) - var(--spacing-6));
}

@media (max-width: 480px) {
    .footer-content {
        flex-direction: column;
        gap: var(--spacing-2);
    }

    .footer-separator {
        display: none;
    }
}
/* ===============================================================================
[Painel] | 04 LAYOUT FOOTER - v1.3 - /src/static/css/04-layout/footer.css
=============================================================================== */
