/* ==== 11. ESTILOS FOOTER ==== */
.main-footer {
    background: #050505;
    /* Un negro un poco más profundo que el fondo anterior */
    padding: 60px 5% 20px;
    color: #fff;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/*contenedor del footer*/
.container-footer {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 40px;
}

.footer-col {
    word-wrap: break-word;
    /* Rompe el texto si es muy largo */
    overflow: hidden;
}

/*columnas del footer*/
.footer-col h4 {
    color: var(--color-principal);
    font-size: 1.1rem;
    margin-bottom: 25px;
    text-transform: uppercase;
    letter-spacing: 2px;
}

/*logo del footer*/
.footer-logo {
    width: 250px;
    margin-bottom: 20px;
    filter: brightness(0) invert(1);
    /* Si el logo es oscuro, esto lo pone blanco */
}

/*parrafo*/
.footer-col p {
    color: #888;
    line-height: 1.6;
    font-size: 0.95rem;
}

/*color del parrafo conspan*/
.footer-col span {
    color: var(--color-principal);
}

/*caja contenedora de redes sociales*/
.social-links {
    display: flex;
    gap: 15px;
    margin-top: 20px;
}

/*iconos de las redes sociales*/
.social-links img {
    width: 50px;
    height: 50px;
    transition: 0.3s;
    filter: opacity(0.6);
}

/*transformacion de los iconos al pasar el mouse*/
.social-links img:hover {
    filter: opacity(1) drop-shadow(0 0 5px var(--color-principal));
    transform: translateY(-3px);
}

/*columna de servicios*/
.footer-col ul {
    list-style: none;
    padding: 0;
}

/*lista de servicios*/
.footer-col ul li {
    margin-bottom: 12px;
}

/*enlaces*/
.footer-col ul li a {
    color: #888;
    text-decoration: none;
    transition: 0.3s;
}

/*transformacion de los enlaces al pasar el mouse*/
.footer-col ul li a:hover {
    color: var(--color-principal);
    padding-left: 5px;
}

/* Barra Inferior */
.footer-bottom {
    margin-top: 60px;
    padding-top: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    text-align: center;
    font-size: 0.8rem;
    color: #555;
}

/* Responsive */
@media (max-width: 768px) {
    .container-footer {

        text-align: center;
    }

    .social-links {
        justify-content: center;
    }
}