/* FOOTER.CSS */
/*
 * PÁGINA: Hoja de Estilos del Pie de Página y Privacidad (Footer & Privacy CSS) - As Tech Computer
 * PROPÓSITO: Definir de manera centralizada la presentación visual del pie de página global, el botón flotante de atención al cliente y el sistema modular de gestión de cookies.
 * FUNCIONALIDADES:
 * - Configuración base del contenedor utilizando la paleta oscura corporativa, blindando colores críticos mediante la directiva !important para evitar herencias no deseadas.
 * - Estructuración del contenido principal en columnas mediante CSS Grid, facilitando la alineación responsiva de enlaces, logotipo y redes sociales.
 * - Estilización del botón flotante de WhatsApp, integrando sombras (box-shadow), posicionamiento anclado (fixed) y animaciones de escala fluida al interactuar (hover).
 * - Formateo visual arquitectónico del motor de privacidad: incluye la capa de desenfoque (backdrop-filter), el banner emergente y el modal de ajustes detallados.
 * - Diseño interactivo de componentes de usuario (interruptores tipo toggle, botones sólidos/outline y acordeones con <details>) para la personalización de cookies.
 * - Implementación de Media Queries para reestructurar fluidamente las cuadrículas y redimensionar elementos táctiles en dispositivos móviles.
 */

/* =========================================
   1. RESET Y CONFIGURACIÓN BASE DEL FOOTER
   ========================================= */
/**
 * El sistema neutraliza márgenes y paddings a nivel de raíz para 
 * asegurar que el contenedor oscuro del pie de página ocupe el 100% 
 * del ancho sin desbordamientos. Los colores se blindan con !important.
 */
html, body {
    margin: 0;
    padding: 0;
    width: 100%;
}

.pie-pagina {
    background-color: #1d1d1f !important;
    color: #f5f5f7 !important;           
    padding: 80px 20px 30px;
    width: 100%;
}

/* =========================================
   2. ESTRUCTURA DE COLUMNAS (GRID)
   ========================================= */
/**
 * Se implementa una cuadrícula dinámica (CSS Grid) asimétrica 
 * (1fr 2fr 1fr) para distribuir el espacio entre el logo, los 
 * bloques de enlaces y las redes sociales.
 */
.contenedor-pie {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 2fr 1fr; 
    gap: 40px;
                align-items: start; 
}

/* =========================================
   3. ESTILOS DE ENLACES Y TEXTOS
   ========================================= */
/**
 * El sistema estiliza las listas de navegación secundaria, eliminando 
 * viñetas por defecto y aplicando transiciones suaves de color (al 
 * tono naranja corporativo) cuando el usuario interactúa.
 */
.fila-links h4 {
    color: #fff !important;
    margin-bottom: 25px;
    font-size: 1rem;
    font-weight: 700;
}

.fila-links ul {
    list-style: none;
    padding: 0;
                }

.fila-links li {
    margin-bottom: 15px;
}

.fila-links a {
    color: #a1a1a6 !important;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 0.95rem;
}

.fila-links a:hover {
    color: var(--color-naranja, #e17203) !important; 
}

/* =========================================
   4. REDES SOCIALES E ÍCONOS
   ========================================= */
/**
 * Configuración en formato flexible (Flexbox) para la botonera 
 * de iconos sociales, garantizando espaciado uniforme y cursores 
 * interactivos.
 */
.redes-sociales ul {
    margin-top: 25px;
    display: flex;
    gap: 15px;
    list-style: none;
    padding: 0;
}

.redes-sociales i {
    font-size: 24px;
    color: #a1a1a6 !important;
    transition: color 0.3s ease;
    cursor: pointer;
}

.redes-sociales i:hover {
    color: var(--color-naranja, #e17203) !important;
}
.seccion-logo {
    transition: transform 0.4s ease;
}

.seccion-logo:hover {
    transform: translateY(-10px);
}

.seccion-logo img {
    width: 160px;
    filter: brightness(0) invert(1);
    transition: all 0.4s ease;
}

.seccion-logo:hover img {
    filter: brightness(1.5) invert(0);
    transform: scale(1.1);

}



/* =========================================
   5. BARRA DE DERECHOS Y COPYRIGHT
   ========================================= */
/**
 * Diseño de la franja final de la página, separada por un borde 
 * superior sutil, destinada a los derechos de propiedad intelectual.
 */
.barra-derechos {
    text-align: center;
    margin-top: 60px;
    padding-top: 30px;
    border-top: 1px solid #424245;
    color: #a1a1a6 !important;
    font-size: 0.85rem;
}

/* =========================================
   6. DISEÑO RESPONSIVO (MÓVILES)
   ========================================= */
/**
 * El sistema colapsa las columnas del grid en una sola (1fr) y centra 
 * los elementos (textos y logotipos) cuando la pantalla se reduce a 
 * dimensiones de tableta o móvil (max-width: 900px).
 */
@media (max-width: 900px) {
    .contenedor-pie {
        grid-template-columns: 1fr; 
        text-align: center; 
        gap: 50px;
    }

    .seccion-logo img {
        margin: 0 auto;
        display: block;
    }
   
    .redes-sociales ul {
        justify-content: center;
    }
}

/* =========================================
   7. BOTÓN FLOTANTE DE CONTACTO (WHATSAPP)
   ========================================= */
/**
 * Configuración del botón de contacto rápido, anclado de forma absoluta 
 * (fixed) en la esquina inferior derecha. Incluye sombras de profundidad 
 * y un efecto de escala. Se reduce su tamaño en pantallas pequeñas.
 */
.btn-whatsapp-flotante {
    position: fixed;
    bottom: 30px;    
    right: 30px;     
    background-color: #25D366; 
    color: #FFF;
    width: 60px;
    height: 60px;
    border-radius: 50%; 
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 35px;
    box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.3);
    z-index: 9999;
    text-decoration: none;
    transition: transform 0.3s ease, background-color 0.3s ease;
}

.btn-whatsapp-flotante:hover {
    background-color: #1EBE57; 
    transform: scale(1.1); 
}

@media (max-width: 768px) {
    .btn-whatsapp-flotante {
        width: 50px;
        height: 50px;
        font-size: 30px;
        bottom: 20px;
        right: 20px;
    }
}

/* =========================================
   8. SISTEMA DE PRIVACIDAD Y GESTIÓN DE COOKIES
   ========================================= */
/**
 * Diseño arquitectónico del motor de privacidad. El sistema define una 
 * clase utilitaria para bloquear el scroll, una capa oscura de fondo 
 * (overlay) y el contenedor principal del banner flotante.
 */
.bloquear-scroll {
    overflow: hidden;
}

.overlay-cookies {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: 999998;
    display: none;
}

.contenedor-cookies {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 700px;
    background-color: #ffffff;
    box-shadow: 0px 20px 50px rgba(0, 0, 0, 0.2);
    border-radius: 24px;
    display: none;
    flex-direction: column;
    padding: 30px;
    z-index: 999999;
    text-align: center;
}

.texto-cookies {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    margin-bottom: 25px;
}

.texto-cookies i {
    font-size: 45px;
    color: #e06c00;
}

.texto-cookies p {
    margin: 0;
    font-size: 0.95rem;
    color: #86868b;
    line-height: 1.5;
}

/**
 * Sistema de botones de decisión (Aceptar, Rechazar y Más Información) 
 * con efectos de elevación interactivos.
 */
.botones-cookies {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    width: 100%;
}

.btn-aceptar,
.btn-rechazar {
    padding: 12px 25px;
    border-radius: 30px;
    cursor: pointer;
    font-weight: 700;
    transition: all 0.3s;
    flex: 1;
    border: none;
    font-size: 0.95rem;
}

.btn-aceptar {
    background-color: #e06c00;
    color: white;
}

.btn-aceptar:hover {
    background-color: #cc6200;
    transform: scale(1.02);
}

.btn-rechazar {
    background-color: #f5f5f7;
    color: #1d1d1f;
}

.btn-rechazar:hover {
    background-color: #e8e8ed;
}

.btn-enlace {
    background: none;
    border: none;
    color: #86868b;
    text-decoration: underline;
    font-weight: 700;
    cursor: pointer;
    font-size: 0.9rem;
    transition: color 0.3s;
}

.btn-enlace:hover {
    color: #1d1d1f;
}

/**
 * Ventana modal de ajustes granulares. Posicionada en el centro de la 
 * pantalla (translate -50%, -50%) con scroll interno para desglosar 
 * las políticas de la LFPDPPP.
 */
.modal-ajustes {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 95%;
    max-width: 650px;
    height: 85vh;
    background-color: #f7f7f7;
    border-radius: 12px;
    z-index: 999999;
    display: flex;
    flex-direction: column;
    box-shadow: 0px 20px 60px rgba(0, 0, 0, 0.3);
    overflow: hidden;
    font-family: 'Lato', sans-serif;
}

.modal-header-ajustes {
    padding: 20px 30px;
    background: #fff;
    border-bottom: 1px solid #e0e0e0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
}

.modal-header-ajustes h2 {
    font-size: 1.3rem;
    font-weight: 900;
    color: #000;
    margin: 0;
}

.btn-cerrar {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: #000;
    cursor: pointer;
    font-weight: bold;
}

.modal-body-ajustes {
    padding: 25px 30px;
    overflow-y: auto;
    text-align: left;
    flex: 1;
    max-height: 55vh;
}

.intro-ajustes {
    font-size: 0.9rem;
    color: #444;
    margin-bottom: 25px;
    line-height: 1.6;
}

.intro-ajustes a {
    color: #e06c00;
    font-weight: bold;
    text-decoration: none;
}

/**
 * Tarjetas de información legal separadas visualmente (Cards).
 */
.cookie-card {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    margin-bottom: 15px;
    padding: 20px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.02);
}

.cookie-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.cookie-card-header h3 {
    font-size: 1.05rem;
    color: #000;
    margin: 0;
    font-weight: 900;
    letter-spacing: 0.5px;
}

.badge-fijo {
    font-size: 0.8rem;
    color: #888;
    font-weight: 700;
    background: #f0f0f0;
    padding: 4px 10px;
    border-radius: 4px;
}

.cookie-card-body p {
    font-size: 0.85rem;
    color: #555;
    margin: 0 0 15px 0;
    line-height: 1.5;
}

/**
 * Estilización de elementos HTML semánticos (<details> y <summary>) 
 * para crear bloques de texto desplegables nativos.
 */
details {
    border-top: 1px solid #eee;
    padding-top: 12px;
}

details summary {
    cursor: pointer;
    color: #e06c00;
    font-size: 0.85rem;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 8px;
    outline: none;
}

details summary::-webkit-details-marker {
    display: none;
}

details[open] summary i {
    transform: rotate(90deg);
    transition: transform 0.2s;
}

.texto-oculto {
    margin-top: 15px !important;
    padding: 15px;
    background: #f9f9f9;
    border-radius: 6px;
    border-left: 3px solid #e06c00;
}

/**
 * Construcción visual de interruptores (Toggle Switches) estilo iOS 
 * utilizando checkboxes ocultos e inputs pseudo-elemento.
 */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 28px;
    flex-shrink: 0;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #d1d1d6;
    transition: .4s;
    border-radius: 34px;
}

.slider:before {
    position: absolute;
    content: "";
    height: 20px;
    width: 20px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    transition: .4s;
    border-radius: 50%;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

input:checked+.slider {
    background-color: #e06c00;
}

input:checked+.slider:before {
    transform: translateX(22px);
}

/**
 * Panel inferior del modal con botones de acción global masivos 
 * (Aceptar o Rechazar todo) estilizados en variantes outline y solid.
 */
.modal-footer {
    padding: 20px 30px;
    border-top: 1px solid #e0e0e0;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 12px;
    z-index: 10;
}

.btn-x-outline {
    background: white;
    border: 1px solid #e06c00;
    color: #e06c00;
    padding: 14px;
    border-radius: 6px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 0.9rem;
}

.btn-x-outline:hover {
    background: #fff3e0;
}

.btn-x-solid {
    background: #e06c00;
    border: 1px solid #e06c00;
    color: white;
    padding: 14px;
    border-radius: 6px;
    font-weight: 900;
    cursor: pointer;
    transition: all 0.2s;
    font-size: 0.9rem;
}

.btn-x-solid:hover {
    background: #cc6200;
}