/* footer.css (Versión con Responsive Mejorado) */

/* Variables de color */
:root {
    --footer-dark-bg: #212529;
    --footer-dark-text-primary: #adb5bd;
    --footer-dark-text-secondary: #868e96;
    --footer-dark-highlight: #343a40;
    --footer-dark-shadow: #121314;
    --footer-icon-color: #dee2e6;
}

.main-footer-dark-neumorphic {
    background-color: var(--footer-dark-bg);
    color: var(--footer-dark-text-primary);
    padding: 60px 0 30px 0;
    font-family: 'Poppins', sans-serif;
    font-weight: 300;
    font-size: 0.875rem;
}

.footer-content-wrapper-dark-neumorphic {
    width: 600px; /* Usamos porcentaje para mayor flexibilidad */
    max-width: 900px; /* Un ancho máximo más estándar para footers anchos */
    margin: 0 auto;
}

.footer-top-dark-neumorphic {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap; /* Permite que los elementos se envuelvan en pantallas pequeñas */
    gap: 40px; /* Espacio entre el bloque de logo y las columnas de nav */
    margin-bottom: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--footer-dark-highlight); /* Línea divisoria sutil */
    
}

.footer-logo-address-dark-neumorphic {
    flex: 1; /* Permite que el bloque del logo crezca */
    gap: 40px;
    min-width: 250px; /* Ancho mínimo antes de envolver */
}

.logo-container-dark-neumorphic {
    margin: 0px 0 50px 0;
}

.logo-container-dark-neumorphic img {
    max-width: 220px; /* Un tamaño máximo para el logo */
    height: auto;
}

.address-dark-neumorphic {
    color: var(--footer-dark-text-secondary);
    font-size: 0.9rem;
    line-height: 1.6;
}

/* Contenedor para ambas columnas de navegación */
.footer-nav-columns-container {
    display: flex;
    gap: 60px; /* Espacio entre las dos columnas de navegación */
    flex-wrap: wrap; /* Permite que las columnas también se envuelvan */
}

.footer-nav-dark-neumorphic ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-nav-dark-neumorphic ul li {
    margin-bottom: 12px;
}

.footer-nav-dark-neumorphic ul li a {
    color: var(--footer-dark-text-primary);
    text-decoration: none;
    transition: color 0.2s ease;
}

.footer-nav-dark-neumorphic ul li a:hover {
    color: #fff;
}

.footer-social-section-dark-neumorphic {
    text-align: center;
    margin-bottom: 40px;
}

.social-icons-dark-neumorphic {
    display: inline-flex;
    gap: 25px;
}

.social-icon-item-dark-neumorphic {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50px;
    height: 50px;
    background-color: var(--footer-dark-bg);
    color: var(--footer-icon-color);
    font-size: 1.2rem;
    text-decoration: none;
    border-radius: 50%;
    transition: all 0.25s ease-out;
    box-shadow: 
        4px 4px 8px var(--footer-dark-shadow),
        -4px -4px 10px var(--footer-dark-highlight);
}

.social-icon-item-dark-neumorphic:hover {
    color: #fff;
    box-shadow: 
        inset 3px 3px 5px var(--footer-dark-shadow), 
        inset -3px -3px 5px var(--footer-dark-highlight);
    transform: scale(0.95);
}

.social-icon-item-dark-neumorphic:active {
    box-shadow: 
        inset 4px 4px 7px var(--footer-dark-shadow), 
        inset -4px -4px 7px var(--footer-dark-highlight);
    transform: scale(0.90);
}

.footer-copyright-dark-neumorphic {
    text-align: center;
    font-size: 0.8rem;
}

.footer-copyright-dark-neumorphic p {
    margin: 0;
    color: var(--footer-dark-text-secondary);
}


/*
==========================================================================
    MEDIA QUERIES PARA RESPONSIVE - FOOTER (VERSIÓN ANTÍDOTO)
==========================================================================
*/

/* --- Para Tablets (hasta 992px) --- */
@media (max-width: 992px) {
    .footer-top-dark-neumorphic {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 40px;
    }

    .footer-logo-address-dark-neumorphic {
        width: 100%;
    }

    /* ¡ANTÍDOTO! Hacemos que las columnas se apilen mucho antes */
    .footer-nav-columns-container {
        flex-direction: column; /* Apilamos las columnas de nav verticalmente */
        align-items: center;    /* Las centramos */
        gap: 30px;              /* Reducimos drásticamente el gap vertical */
        width: 100%;
    }
}


/* --- Para Móviles (hasta 768px) --- */
@media (max-width: 768px) {
    .main-footer-dark-neumorphic {
        padding: 40px 0 20px 0;
        text-align: center;
    }
    
    .footer-top-dark-neumorphic {
        border-bottom: none;
        margin-bottom: 20px;
        padding-bottom: 20px;
    }

    /* Como ya son una columna, aquí solo ajustamos el espacio */
    .footer-nav-columns-container {
        gap: 0;
    }

    .footer-nav-dark-neumorphic ul {
        margin-bottom: 20px;
    }
    
    .footer-nav-dark-neumorphic ul li {
        margin-bottom: 15px;
    }

    .social-icons-dark-neumorphic {
        gap: 20px;
    }

    .social-icon-item-dark-neumorphic {
        width: 45px;
        height: 45px;
        font-size: 1.1rem;
    }
}


/* --- Para Móviles Pequeños (hasta 480px) --- */
@media (max-width: 480px) {
    .footer-content-wrapper-dark-neumorphic {
        width: 95%;
    }

    .footer-nav-dark-neumorphic.footer-nav-col2 {
        margin-top: -10px;
    }
    
    .footer-nav-dark-neumorphic ul li {
        margin-bottom: 12px;
    }

    .social-icon-item-dark-neumorphic {
        width: 40px;
        height: 40px;
    }
}