/* ==========================================================================
   Footer Component — matches production red-es.es
   ========================================================================== */

.pf-redes-footer {
    margin-top: 0;
}

/* Sponsors section */
.pf-redes-footer__sponsors {
    background-color: var(--pf-redes-bg-dark);
    color: var(--pf-redes-text-inverse);
    padding: 40px 0;
}

.pf-redes-footer__sponsor-row {
    margin-bottom: 30px;
    text-align: center;
}

.pf-redes-footer__sponsor-row:last-child {
    margin-bottom: 0;
}

.pf-redes-footer__sponsor-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 12px;
    opacity: 0.8;
    font-weight: 600;
}

.pf-redes-footer__sponsor-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 24px;
}

.pf-redes-footer__sponsor-logos img {
    max-height: 60px;
    width: auto;
    object-fit: contain;
}

/* Bottom bar: legal + copyright */
.pf-redes-footer__bottom {
    background-color: #111111;
    color: var(--pf-redes-text-inverse);
    padding: 20px 0;
}

.pf-redes-footer__inner {
    text-align: center;
}

/* Legal links */
.pf-redes-footer__legal {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.pf-redes-footer__legal a {
    color: var(--pf-redes-text-inverse);
    text-decoration: none;
    font-size: 13px;
    transition: opacity var(--pf-redes-transition);
}

.pf-redes-footer__legal a:hover,
.pf-redes-footer__legal a:focus {
    color: var(--pf-redes-text-inverse);
    opacity: 0.8;
}

.pf-redes-footer__separator {
    color: var(--pf-redes-text-inverse);
    opacity: 0.5;
}

/* Copyright */
.pf-redes-footer__copyright {
    font-size: 12px;
    opacity: 0.7;
    margin: 0;
}

/* Responsive */
@media (max-width: 600px) {
    .pf-redes-footer__sponsor-logos img {
        max-height: 45px;
    }

    .pf-redes-footer__sponsor-logos {
        gap: 16px;
    }
}
