
/* ==========================================================================
   1. VARIABLES GLOBALES (Colores y Fuentes)
   Cambia los colores aquí y se actualizarán en TODA la página.
   ========================================================================== */
:root {
    --rojo-principal: #17b0f7; /* Color rojo de tu marca */
    --rojo-oscuro: #1c9feb;    /* Para cuando pasas el mouse por un botón rojo */
    --gris-fondo: #f9fafb;     /* Color de fondo de la página */
    --gris-texto: #4b5563;     /* Color para párrafos normales */
    --oscuro: #333333;         /* Color casi negro para títulos y pie de página */
    --blanco: #ffffff;
    --sombra-suave: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    --sombra-fuerte: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

/* ==========================================================================
   2. ESTILOS BASE (Generales)
   ========================================================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box; /* Evita que los bordes rompan el tamaño de las cajas */
}

body.cuerpo-pagina {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: var(--gris-fondo);
    color: var(--oscuro);
    line-height: 1.6;
}

body.cuerpo-pagina {
    font-family: 'Montserrat', sans-serif;
    font-weight: 500; /* Usamos Regular para mejor lectura */
    color: var(--gris-texto);
    background-color: var(--gris-fondo);
    line-height: 1.6;
}




/* ==========================================================================
   ESTRUCTURA BASE Y CONTENEDORES
   ========================================================================== */
.contenedor {
    width: 100%;
    max-width: 1550px; /* Ancho máximo en computadoras */
    margin: 0 auto;    /* Centra el contenedor en la pantalla */
    padding-left: 25px;  /* Espacio obligatorio a la izquierda */
    padding-right: 25px; /* Espacio obligatorio a la derecha */
    box-sizing: border-box; /* Evita que el padding deforme el ancho total */
}

.cuadricula-3-columnas {
    padding: 30px;
}
.cuadricula-4-columnas{
    padding: 30px;
}



/* Espaciado general de las secciones */
.seccion-padding {
    padding-top: 80px;
    padding-bottom: 80px;
}

/* Contenedor central: Mantiene el contenido alineado y evita que toque los bordes 
.contenedor {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
} */

/* ==========================================================================
   3. NAVEGACIÓN Y CABECERA (Header)
   ========================================================================== */
.cabecera-principal {
    background-color: var(--blanco);
    box-shadow: var(--sombra-suave);
    position: sticky; /* Se queda pegado arriba al bajar */
    top: 0;
    z-index: 100; /* Asegura que el menú esté siempre por encima de todo */
}

.nav-contenedor {
    display: flex;
    justify-content: space-between; /* Separa el logo del menú a los extremos */
    align-items: center;
    padding-top: 15px;
    padding-bottom: 15px;
}

.logo-img {
    height: 70px;
    cursor: pointer;
}

/* Lista de enlaces del menú */
.nav-enlaces ul {
    display: flex;
    list-style: none;
    gap: 30px; /* Separación entre enlaces */
}

.enlace-menu {
    text-decoration: none;
    color: var(--oscuro);
    font-weight: bold;
    text-transform: uppercase;
    font-size: 14px;
    position: relative;
    transition: color 0.3s;
}

/* Línea roja que aparece al pasar el mouse por el menú */
.enlace-menu::after {
    content: ''; position: absolute; width: 0; height: 2px;
    bottom: -5px; left: 0; background-color: var(--rojo-principal);
    transition: width 0.3s;
}
.enlace-menu:hover::after { width: 100%; }
.enlace-menu:hover { color: var(--rojo-principal); }

/* Botón Hamburguesa (Oculto en PC, visible en celular) */
.btn-menu-movil {
    display: none;
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
}

/* ==========================================================================
   4. SECCIONES Y ESTRUCTURA (Grillas y Espaciados)
   ========================================================================== */
.seccion-oculta { display: none; }
.seccion-activa { display: block; animation: aparecer 0.5s ease-in; }

@keyframes aparecer {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.seccion-padding { padding: 80px 0; }

.encabezado-centro {
    text-align: center;
    margin-bottom: 50px;
}

.titulo-seccion {
    font-size: 32px;
    text-transform: uppercase;
    margin-bottom: 10px;
}

.texto-rojo { color: var(--rojo-principal); }
.subtitulo-gris { color: var(--gris-texto); }

.linea-roja {
    width: 80px;
    height: 4px;
    background-color: var(--rojo-principal);
    margin: 0 auto;
}

/* Sistemas de Cuadrículas (Grids) para alinear cajas de lado a lado */
.cuadricula-2-columnas { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.cuadricula-3-columnas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.cuadricula-4-columnas { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.alineacion-centro { align-items: center; }

/* ==========================================================================
   5. BOTONES PERSONALIZADOS
   ========================================================================== */
.btn-rojo {
    background-color: var(--rojo-principal);
    color: var(--blanco);
    padding: 15px 40px;
    border: none;
    border-radius: 50px;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s;
}
.btn-rojo:hover { background-color: var(--rojo-oscuro); transform: scale(1.05); }

.btn-transparente {
    background-color: transparent;
    color: var(--blanco);
    padding: 13px 40px;
    border: 2px solid var(--blanco);
    border-radius: 50px;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s;
}
.btn-transparente:hover { background-color: var(--blanco); color: var(--oscuro); }

.btn-oscuro {
    background-color: var(--oscuro);
    color: var(--blanco);
    padding: 15px 30px;
    border: none;
    border-radius: 8px;
    font-weight: bold;
    cursor: pointer;
}
.btn-oscuro:hover { background-color: #333; }

/* ==========================================================================
   6. CARRUSEL (SLIDER) DE INICIO - CORREGIDO
   ========================================================================== */
.carrusel-contenedor {
    position: relative;
    height: 550px;
    overflow: hidden;
    background-color: var(--oscuro); /* Por si demora en cargar la imagen */
}
.carrusel-slide {
    position: absolute; /* Pone las 3 imágenes una encima de otra */
    top: 0; left: 0; width: 100%; height: 100%;
    background-size: cover; background-position: center;
    opacity: 0; /* Las oculta todas usando transparencia */
    transition: opacity 1.5s ease-in-out; /* EFECTO SUAVE (Fade) de 1.5 segundos */
    z-index: 1;
}
.carrusel-slide.activo {
    opacity: 1; /* Hace visible solo la imagen activa */
    z-index: 2; /* La manda al frente */
}
.carrusel-filtro-oscuro {
    background: rgba(0, 0, 0, 0.5);
    height: 100%; width: 100%;
    display: flex; align-items: center; justify-content: center; text-align: center;
}
.carrusel-contenido { color: var(--blanco); max-width: 800px; padding: 20px; }
.titulo-gigante { font-size: 55px; font-weight: 800; text-transform: uppercase; margin-bottom: 20px; }
.subtitulo-carrusel { font-size: 24px; margin-bottom: 40px; }
.carrusel-botones { display: flex; gap: 20px; justify-content: center; }

/* ==========================================================================
   7. TARJETAS (Cajas de Características y Valores)
   ========================================================================== */
.tarjeta-caracteristica, .tarjeta-valor {
    background-color: var(--blanco);
    padding: 40px;
    text-align: center;
    border-radius: 15px;
    box-shadow: var(--sombra-suave);
    border-top: 8px solid var(--rojo-principal);
    transition: transform 0.3s, box-shadow 0.3s, background-color 0.3s;
}
.tarjeta-caracteristica:hover {
    transform: translateY(-10px); /* Efecto de flotar hacia arriba */
    box-shadow: var(--sombra-fuerte);
}
.icono-grande { font-size: 50px; color: var(--rojo-principal); margin-bottom: 20px; }
.titulo-tarjeta { font-size: 20px; margin-bottom: 15px; }

/* Efecto hover especial para las tarjetas de Valores (Se pintan de rojo) */
.tarjeta-valor { border-top: none; }
.circulo-icono {
    width: 80px; height: 80px; background-color: var(--gris-fondo);
    color: var(--rojo-principal); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px; font-size: 30px; transition: background 0.3s;
}
.tarjeta-valor:hover { background-color: var(--rojo-principal); color: var(--blanco); }
.tarjeta-valor:hover .circulo-icono { background-color: var(--blanco); }
.tarjeta-valor:hover p { color: var(--blanco); } /* Cambia texto a blanco */

/* ==========================================================================
   8. FORMULARIOS DE CONTACTO
   ========================================================================== */
.caja-formulario, .caja-contacto-info {
    background-color: var(--blanco); padding: 40px;
    border-radius: 20px; box-shadow: var(--sombra-fuerte);
}
.input-formulario {
    width: 100%; padding: 15px; margin-bottom: 20px; margin-top: 5px;
    background-color: var(--gris-fondo); border: 1px solid #ddd;
    border-radius: 8px; font-family: inherit; outline: none;
}
.input-formulario:focus { border-color: var(--rojo-principal); }
.text-area { height: 120px; resize: vertical; }
.btn-enviar-form {
    width: 100%; padding: 15px; background-color: var(--rojo-principal);
    color: white; font-weight: bold; border: none; border-radius: 8px; cursor: pointer;
}

/* ==========================================================================
   9. WHATSAPP FLOTANTE
   ========================================================================== 
.whatsapp-flotante {
    position: fixed; bottom: 30px; right: 30px;
    background-color: #25d366; color: white;
    width: 60px; height: 60px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 30px; box-shadow: 2px 5px 15px rgba(0,0,0,0.3);
    z-index: 1000; transition: transform 0.3s; text-decoration: none;
}
.whatsapp-flotante:hover { transform: scale(1.1); } */

/* ==========================================================================
   9. WHATSAPP FLOTANTE (VERSIÓN CORREGIDA Y OPTIMIZADA)
   ========================================================================== */
.whatsapp-flotante {
    position: fixed; 
    bottom: 30px; 
    right: 30px;
    background-color: #25d366; 
    color: white;
    width: 60px; 
    height: 60px; 
    border-radius: 50%;
    display: flex; 
    align-items: center; 
    justify-content: center;
    font-size: 30px; 
    z-index: 1000; 
    text-decoration: none;
    
    /* Aceleración por hardware para eliminar el temblor del icono */
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    
    /* Animación más rápida: 1.5 segundos en lugar de 2s */
    animation: latido-whatsapp 3.5s infinite;
}

/* Al pasar el cursor: apagamos la animación para que el transform funcione limpio */
.whatsapp-flotante:hover { 
    animation: none; 
    transform: scale(1.1) translateZ(0); 
    box-shadow: 2px 5px 15px rgba(0,0,0,0.4); 
}

/* La magia de la animación (Solo Ondas Expansivas, sin temblor) */
@keyframes latido-whatsapp {
    0% {
        /* Doble sombra: sombra base oscura + sombra verde inicial */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 0 rgba(37, 211, 102, 0.7);
    }
    50% {
        /* Solo se expande y desvanece la sombra verde, el botón NO crece */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 15px rgba(37, 211, 102, 0);
    }
    100% {
        /* Vuelve a la normalidad */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 0 rgba(37, 211, 102, 0);
    }
}

/* Cuando pasamos el mouse, pausamos el latido y lo dejamos un poco más grande */
.whatsapp-flotante:hover { 
    animation-play-state: paused;
    transform: scale(1.1); 
    box-shadow: 2px 5px 15px rgba(0,0,0,0.3); /* Mantiene la sombra base al hacer hover */
}

/* La magia de la animación (Respiración + Ondas) */
@keyframes latido-whatsapp {
    0% {
        transform: scale(1);
        /* Doble sombra: una para la profundidad estática y otra verde que se expande */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 0 rgba(37, 211, 102, 0.7);
    }
    50% {
        transform: scale(1.05); /* Crece un 5% */
        /* La sombra verde se expande 15px y se vuelve completamente transparente (0) */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 15px rgba(37, 211, 102, 0);
    }
    100% {
        transform: scale(1);
        /* Vuelve a su estado original para reiniciar el ciclo suavemente */
        box-shadow: 2px 5px 15px rgba(0,0,0,0.3), 0 0 0 0 rgba(37, 211, 102, 0);
    }
}

/* ==========================================================================
   14. SECCIÓN NOSOTROS
   ========================================================================== */
.cabecera-oscura {
    background-color: var(--oscuro);
    color: var(--blanco);
    padding: 80px 20px;
}

.cabecera-oscura .titulo-seccion {
    color: var(--rojo-principal);
}

.cabecera-oscura .subtitulo-gris {
    color: #9ca3af; /* Un gris más claro para que resalte sobre el fondo oscuro */
    margin-top: 15px;
}

/* Contenedor de la cuadrícula de Nosotros */
#nosotros .cuadricula-2-columnas {
    align-items: center; /* Centra la imagen y el texto verticalmente */
    gap: 60px; /* Espacio amplio entre la imagen y los textos */
    padding: 40px;
}

/* Estilos de la Imagen */
.imagen-nosotros {
    width: 100%;          /* Obliga a la imagen a no salirse de su mitad de la página */
    height: auto;         /* Mantiene las proporciones correctas */
    border-radius: 15px;  /* Bordes curvos (rounded-2xl) */
    box-shadow: var(--sombra-fuerte); /* Sombra amplia (shadow-2xl) */
    border-left: 8px solid var(--rojo-principal); /* Franja roja a la izquierda */
    object-fit: cover;
}

/* Estilos de los Textos (Misión y Visión) */
.textos-nosotros {
    display: flex;
    flex-direction: column;
    gap: 40px; /* Espacio entre el bloque de Misión y el de Visión */

}

.titulo-rojo-cursiva {
    color: var(--rojo-principal);
    font-size: 28px;
    font-weight: bold;
    font-style: italic;
    margin-bottom: 20px;
}

.texto-cursiva, .texto-normal {
    color: var(--gris-texto);
    font-size: 18px;     /* Texto un poco más grande para facilitar la lectura */
    line-height: 1.8;    /* Interlineado relajado (leading-relaxed) */
}

.texto-cursiva {
    font-style: italic;
}

/* ==========================================================================
   11. SECCIÓN PRODUCTOS
   ========================================================================== */
.banner-rojo-simple {
    background-color: var(--rojo-principal);
    color: var(--blanco);
    text-align: center;
    padding: 50px 20px;
}
.titulo-espaciado {
    font-size: 28px;
    text-transform: uppercase;
    letter-spacing: 2px; /* Separa las letras para darle estilo */
}

.tarjeta-producto {
    background-color: var(--blanco);
    border-radius: 15px;
    overflow: hidden; /* Evita que la imagen se salga de los bordes curvos */
    box-shadow: var(--sombra-suave);
    transition: transform 0.3s, box-shadow 0.3s;
    margin-top: 0px;
}
.tarjeta-producto:hover {
    transform: translateY(-10px);
    box-shadow: var(--sombra-fuerte);
}
.imagen-producto {
    width: 100%;
    height: 220px;
    object-fit: cover; /* Recorta la imagen para que encaje perfecto */
}
.contenido-producto {
    padding: 25px;
}
.etiqueta-roja {
    color: var(--rojo-principal);
    font-weight: bold;
    font-size: 12px;
    text-transform: uppercase;
}
.titulo-producto {
    font-size: 22px;
    margin: 5px 0 15px 0;
}
.lista-check {
    list-style: none;
    margin-bottom: 25px;
}
.lista-check li {
    margin-bottom: 10px;
    color: var(--gris-texto);
    font-size: 14px;
}
.icono-check {
    color: #22c55e; /* Color verde para el check */
    margin-right: 10px;
}
.texto-producto-simple {
    color: var(--gris-texto);
    font-size: 14px;
    margin-bottom: 25px;
}

/* Botones específicos de productos */
.btn-contorno-rojo {
    width: 100%;
    padding: 12px;
    background-color: transparent;
    color: var(--rojo-principal);
    border: 2px solid var(--rojo-principal);
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s;
}
.btn-contorno-rojo:hover {
    background-color: var(--rojo-principal);
    color: var(--blanco);
}
.btn-oscuro-ancho {
    width: 100%;
    padding: 14px;
    background-color: var(--oscuro);
    color: var(--blanco);
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: background 0.3s;
}
.btn-oscuro-ancho:hover {
    background-color: #333;
}

/* ==========================================================================
   12. SECCIÓN TESTIMONIOS
   ========================================================================== */
.fondo-gris-claro {
    background-color: #f3f4f6;
}
.tarjeta-testimonio {
    background-color: var(--blanco);
    padding: 30px;
    border-radius: 15px;
    box-shadow: var(--sombra-suave);
}
.estrellas {
    color: #facc15; /* Color amarillo oro */
    margin-bottom: 15px;
}
.texto-cita {
    color: var(--gris-texto);
    font-style: italic;
    margin-bottom: 25px;
}
.autor-info {
    display: flex;
    align-items: center;
    gap: 15px;
}
.avatar-autor {
    width: 50px;
    height: 50px;
    background-color: var(--rojo-principal);
    color: var(--blanco);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 20px;
}
.nombre-autor {
    font-weight: bold;
    font-size: 14px;
}
.fecha-autor {
    color: #9ca3af;
    font-size: 12px;
}

/* ==========================================================================
   13. PIE DE PÁGINA (FOOTER)
   ========================================================================== */
.pie-pagina {
    background-color: var(--oscuro); /* Fondo negro/gris muy oscuro */
    color: #d1d5db; /* Texto en gris claro para contraste */
    padding-top: 70px;
}

.pie-cuadricula {
    display: grid;
    /* Cambiamos de repeat(4, 1fr) a repeat(5, 1fr) para acomodar la nueva lista */
    grid-template-columns: repeat(5, 1fr); 
    gap: 30px; /* Reducimos ligeramente el gap de 40px a 30px para que todo respire bien */
    padding-bottom: 50px;
}

.pie-columna {
    display: flex;
    flex-direction: column;
}

.pie-logo {
    color: var(--blanco);
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 15px;
    letter-spacing: 1px;
}

.pie-texto {
    font-size: 14px;
    margin-bottom: 25px;
    line-height: 1.7;
}

/* Íconos de Redes Sociales */
.pie-redes {
    display: flex;
    gap: 15px;
}
.icono-red {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: #374151; /* Gris oscuro */
    color: var(--blanco);
    border-radius: 50%;
    text-decoration: none;
    transition: background-color 0.3s, transform 0.3s;
}
.icono-red:hover {
    background-color: var(--rojo-principal);
    transform: translateY(-5px); /* Pequeño salto al pasar el mouse */
}

/* Títulos de las columnas del footer */
.pie-titulo {
    color: var(--blanco);
    font-size: 18px;
    margin-bottom: 25px;
    text-transform: uppercase;
    position: relative;
    padding-bottom: 10px;
}
/* Línea roja decorativa debajo de los títulos */
.pie-titulo::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 40px;
    height: 3px;
    background-color: var(--rojo-principal);
}

/* Listas de enlaces y datos de contacto */
.pie-lista-enlaces, .pie-lista-info {
    list-style: none;
    padding: 0;
    margin: 0;
}
.pie-lista-enlaces li, .pie-lista-info li {
    margin-bottom: 15px;
    font-size: 15px;
}

.pie-lista-enlaces a {
    color: #d1d5db;
    text-decoration: none;
    transition: color 0.3s, padding-left 0.3s; /* Animación suave */
    display: inline-block;
}
.pie-lista-enlaces a i {
    font-size: 11px;
    margin-right: 8px;
    color: var(--rojo-principal);
}
.pie-lista-enlaces a:hover {
    color: var(--rojo-principal);
    padding-left: 8px; /* El enlace se mueve un poquito a la derecha */
}

.pie-lista-info li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.pie-lista-info i {
    color: var(--rojo-principal);
    margin-top: 4px;
}

/* Barra negra inferior (Copyright) */
.pie-barra-inferior {
    background-color: #111111; /* Negro puro */
    padding: 25px 0;
    font-size: 14px;
}
.pie-inferior-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
}


/* ==========================================================================
   18. AJUSTE FINAL FOOTER (Libro de Reclamaciones con Imagen)
   ========================================================================== */

/* Estilo para que el enlace completo sea un bloque flex apilado (texto arriba, imagen abajo) */
.pie-lista-enlaces a.pie-link-reclamaciones-completo {
    display: flex; 
    flex-direction: column; /* Apila los elementos hijos verticalmente */
    gap: 12px; /* Espacio obligatorio entre el texto y la imagen */
    align-items: flex-start; /* Alinea todo a la izquierda por defecto */
    text-decoration: none;
    transition: color 0.3s ease, padding-left 0.3s ease; /* Mantenemos consistencia con la lista */
}

/* Replicamos el hover general de la lista, pero solo para que afecte al bloque completo */
.pie-link-reclamaciones-completo:hover {
    color: var(--rojo-principal); /* El texto cambia a rojo */
    padding-left: 8px; /* Pequeño movimiento a la derecha, igual que los otros enlaces */
}

/* Estilos específicos para la imagen pequeña debajo del texto */
.pie-img-reclamaciones-footer {
    width: 150px; /* Tamaño corporativo pequeño */
    height: auto;
    display: block; /*Stacked layout */
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Efecto suave de zoom y sombra */
    background-color: transparent; /* Asegura transparencia si el PNG lo define */
    border-radius: 4px; /* Unos bordes muy suaves opcionales */
}

/* Efecto al pasar el cursor sobre TODO el bloque del enlace: la imagen se destaca */
.pie-link-reclamaciones-completo:hover .pie-img-reclamaciones-footer {
    transform: scale(1.05); /* Pequeño zoom de 5% */
    /*box-shadow: 0 4px 8px rgba(0,0,0,0.3); /* Pequeña sombra de profundidad en fondo oscuro */
    filter: brightness(1.1); /* Se ilumina ligeramente */
}


/* Ajustes para tablets y celulares solo del footer */
@media (max-width: 992px) {
    .pie-cuadricula { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
    .pie-cuadricula { grid-template-columns: 1fr; }
    .pie-inferior-flex {
        flex-direction: column;
        text-align: center;
    }
}

/* ==========================================================================
   15. SECCIÓN CONTACTO Y FORMULARIO
   ========================================================================== */
/*.gap-grande { gap: 50px; }*/

/* Configuración de la Cuadrícula Dinámica para Contacto */
.contacto-grid {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Dos mitades iguales en computadora */
    gap: 40px;
    padding: 30px;
    margin-top: -70px;
}

/* En computadora: Asignamos posiciones específicas */
.info-item {
    grid-column: 1; /* Columna Izquierda */
    grid-row: 1;    /* Fila 1 (Arriba) */
}
.map-item {
    grid-column: 1; /* Columna Izquierda */
    grid-row: 2;    /* Fila 2 (Debajo de la información) */
}
.form-item {
    grid-column: 2;         /* Columna Derecha */
    grid-row: 1 / span 2;   /* Abarca el alto de la Fila 1 y 2 juntas */
}

/* Estilo para listas desplegables (Select) */
.select-formulario {
    cursor: pointer;
    background-color: var(--blanco);
    color: var(--oscuro);
    /* Se añade una flechita personalizada por si el navegador la oculta */
    appearance: auto; 
}

/* Lista de Información de Contacto */
.lista-contacto-detallada {
    list-style: none;
    margin-top: 25px;
    margin-bottom: 30px;
}
.lista-contacto-detallada li {
    display: flex;
    align-items: flex-start;
    margin-bottom: 25px;
}
.icono-contacto {
    width: 45px;
    height: 45px;
    background-color: var(--gris-fondo);
    color: var(--rojo-principal);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    margin-right: 20px;
    flex-shrink: 0;
}
.detalle-contacto h4 {
    font-size: 16px;
    margin-bottom: 3px;
    color: var(--oscuro);
}
.detalle-contacto p {
    font-size: 15px;
    color: var(--gris-texto);
}

/* Botones de Llamada y WhatsApp */
.botones-contacto-directo {
    display: flex;
    gap: 15px;
    margin-top: 20px;
}
.btn-contacto-llamar, .btn-contacto-whatsapp {
    flex: 1;
    text-align: center;
    padding: 12px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    color: var(--blanco);
    transition: background-color 0.3s, transform 0.2s;
}
.btn-contacto-llamar {
    background-color: var(--oscuro);
}
.btn-contacto-llamar:hover {
    background-color: #333;
    transform: translateY(-2px);
}
.btn-contacto-whatsapp {
    background-color: #25d366; /* Verde original de WhatsApp */
}
.btn-contacto-whatsapp:hover {
    background-color: #1ebc59;
    transform: translateY(-2px);
}

/* Contenedor del Mapa /
.contenedor-mapa {
    margin-top: 40px;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    border: 1px solid #e5e7eb;
}
*/

/* Contenedor del Mapa ajustado para la grilla */
.contenedor-mapa {
    border-radius: 15px;
    overflow: hidden;
    box-shadow: var(--sombra-suave);
    border: 1px solid #e5e7eb;
    height: 100%; /* Para que llene el espacio restante */
}

/* Detalles del Formulario */
.titulo-caja.central {
    text-align: center;
    margin-bottom: 10px;
    font-size: 24px;
}
.texto-formulario-desc {
    text-align: center;
    color: var(--gris-texto);
    margin-bottom: 30px;
    font-size: 15px;
}
.form-grupo {
    margin-bottom: 20px;
}
.form-grupo label {
    display: block;
    font-weight: bold;
    font-size: 14px;
    margin-bottom: 8px;
    color: var(--oscuro);
}
.form-grupo-dos-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.btn-enviar-form-grande {
    width: 100%;
    padding: 16px;
    background-color: var(--rojo-principal);
    color: var(--blanco);
    font-size: 16px;
    font-weight: bold;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: background-color 0.3s, transform 0.2s;
    margin-top: 10px;
}
.btn-enviar-form-grande:hover {
    background-color: var(--rojo-oscuro);
    transform: translateY(-2px);
}

/* ==========================================================================
   16. AJUSTES DE INICIO (Banner y Botón Asesoría)
   ========================================================================== */
/* Banner "Necesita una cotización" */
.banner-rojo {
    background-color: var(--rojo-principal);
    color: var(--blanco);
    padding: 50px 0;
    margin-top: 50px;
}
.banner-flex {
    display: flex;
    justify-content: space-between; /* Empuja el texto a la izq y el botón a la der */
    align-items: center;
    flex-wrap: wrap; /* Evita que se rompa en pantallas chicas */
    gap: 20px;
}
.banner-texto h2 {
    font-size: 28px;
    margin-bottom: 5px;
}
.banner-texto p {
    font-size: 16px;
    opacity: 0.9;
}

/* Botón "Solicitar asesoría" de las cajas de características */
.enlace-rojo {
    background: none;
    border: none;
    color: var(--rojo-principal);
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 0;
    margin-top: 15px;
    transition: color 0.3s;
}
.enlace-rojo i {
    transition: transform 0.3s; /* Prepara la flecha para animarse */
}
.enlace-rojo:hover {
    color: var(--rojo-oscuro);
}
.enlace-rojo:hover i {
    transform: translateX(8px); /* La flecha se mueve a la derecha al hacer hover */
}

/* ==========================================================================
   ADAPTACIÓN PARA PANTALLAS MEDIANAS (Tablets o ventanas reducidas)
   Actúa cuando la ventana mide menos de 1024px pero más de 768px
   ========================================================================== */
@media (max-width: 1024px) {
    /* Convertimos las grillas grandes a 2 columnas para que no se aprieten */
    .cuadricula-3-columnas, 
    .cuadricula-4-columnas {
        grid-template-columns: repeat(2, 1fr);
    }
    
    /* Reducimos un poco los títulos gigantes para que encajen mejor */
    .titulo-gigante {
        font-size: 45px;
    }

    /* La sección nosotros pasa a 1 columna (imagen arriba, texto abajo) 
       porque a este tamaño la imagen y el texto juntos se ven muy apretados */
    #nosotros .cuadricula-2-columnas {
        grid-template-columns: 1fr;
        text-align: center;
    }
    
    .imagen-nosotros {
        max-height: 400px; /* Evita que la imagen sea excesivamente alta */
    }

    .pie-cuadricula { 
        grid-template-columns: repeat(3, 1fr); /* 3 columnas en tablets */
    }
}

/* ==========================================================================
   19. CABECERAS ROJAS UNIFICADAS
   ========================================================================== */
.cabecera-roja {
    background-color: var(--rojo-principal);
    padding: 30px 20px;
    width: 100%;
}

.cabecera-roja .encabezado-centro {
    margin-bottom: 0; /* Anula el margen inferior para que quede centrado perfecto */
}

.texto-blanco {
    color: var(--blanco) !important;
}

.linea-blanca {
    width: 60px;
    height: 4px;
    background-color: var(--blanco);
    margin: 15px auto;
    border-radius: 2px;
}

.subtitulo-blanco {
    color: rgba(255, 255, 255, 0.9); /* Blanco semitransparente para fácil lectura */
    font-size: 18px;
    max-width: 700px;
    margin: 0 auto;
}

/* ==========================================================================
   20. ESTILO DEL ENLACE DE DESARROLLO (FOOTER)
   ========================================================================== */
.pie-inferior-flex a {
    color: var(--rojo-principal); /* Color rojo de tu marca */
    text-decoration: none;        /* Quita el subrayado */
    font-weight: 700;             /* Lo hace más negrita para que resalte */
    transition: all 0.3s ease;    /* Suaviza el cambio al pasar el mouse */
    padding: 2px 5px;
    border-radius: 4px;
}

.pie-inferior-flex a:hover {
    color: var(--blanco);         /* Al pasar el mouse cambia a blanco */
    background-color: var(--rojo-principal); /* Se crea un fondo rojo tipo botón */
    text-decoration: none;
}

/* ==========================================================================
   10. ADAPTACIÓN PARA CELULARES (Responsive Design)
   Todo lo que esté aquí adentro solo se aplica en pantallas pequeñas
   ========================================================================== */
@media (max-width: 900px) {

    /* El orden dinámico para celulares en Contacto */
    .contacto-grid {
        grid-template-columns: 1fr; /* Todo a una sola columna */
    }
    .info-item {
        grid-column: 1;
        grid-row: 1; /* Primero la información */
    }
    .form-item {
        grid-column: 1;
        grid-row: 2; /* Segundo el formulario */
    }
    .map-item {
        grid-column: 1;
        grid-row: 3; /* Tercero, hasta el final, el mapa */
    }
    .form-grupo-dos-cols {
        grid-template-columns: 1fr; /* Los campos del form también se apilan */
    }

    /* El menú pasa a ser vertical y se oculta */
    .nav-enlaces {
        display: none;
        position: absolute; top: 100%; left: 0; width: 100%;
        background-color: var(--blanco); box-shadow: var(--sombra-fuerte); padding: 20px;
    }
    .nav-enlaces.mostrar-menu { display: block; }
    .nav-enlaces ul { flex-direction: column; text-align: center; }
    .btn-menu-movil { display: block; } /* Mostramos el botón hamburguesa */
    
    /* Todas las cuadrículas pasan a ser de 1 sola columna hacia abajo */
    .cuadricula-2-columnas, .cuadricula-3-columnas, .cuadricula-4-columnas {
        grid-template-columns: 1fr;
    }
    
    .titulo-gigante { font-size: 35px; }
    .carrusel-botones { 
        flex-direction: column; 
        align-items: center; /* Esta línea mágica evita que se estiren a los lados */
        gap: 15px; /* Un pequeño espacio extra entre ellos para que se vean mejor apilados */
    }

    /* El banner rojo se centra y se pone en columna en celulares */
    .banner-flex {
        flex-direction: column;
        text-align: center;}

        /* Ajustes generales para que nada choque en móviles */
    .contenedor {
        padding-left: 40px;
        padding-right: 40px;
    }

    .seccion-padding {
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .pie-cuadricula { 
        grid-template-columns: repeat(2, 1fr); /* 2 columnas en celulares grandes */
    }

    /* Evita que los textos largos o imágenes rompan la pantalla hacia los lados */
    body {
        overflow-x: hidden;
    }

}

/* Ajustes para la navegación móvil */
@media (max-width: 768px) {
    
    .nav-contenedor {
        display: flex;
        justify-content: center; /* Esto centrará el logo */
        align-items: center;
        position: relative;      /* Permite que el botón se posicione respecto a esta caja */
        min-height: 80px;        /* Ajusta la altura si es necesario */
        padding: 10px 0;
    }

    .nav-logo {
        margin: 0 auto;         /* Refuerza el centrado del logo */
        z-index: 1;
    }

    .btn-menu-movil {
        display: block;         /* Asegura que sea visible */
        position: absolute;     /* Lo sacamos del flujo para que no empuje al logo */
        right: 20px;            /* Lo pegamos a la derecha */
        top: 50%;               /* Lo bajamos al 50% de la altura */
        transform: translateY(-50%); /* Lo centramos verticalmente exacto */
        background: transparent;
        border: none;
        font-size: 24px;        /* Tamaño de la hamburguesa */
        color: var(--oscuro);
        cursor: pointer;
        z-index: 10;            /* Para que siempre esté por encima */
    }

    /* Ajuste para que el menú desplegable no se descuadre */
    .nav-enlaces {
        position: absolute;
        top: 100%;             /* Aparece justo debajo de la cabecera */
        left: 0;
        width: 100%;
        background-color: var(--blanco);
        box-shadow: var(--sombra-fuerte);
        text-align: center;
    }
}

@media (max-width: 576px) {
    .pie-cuadricula { 
        grid-template-columns: 1fr; /* 1 sola columna en celulares pequeños */
    }
    .pie-inferior-flex {
        flex-direction: column;
        text-align: center;
    }

    /* Centramos el bloque completo del libro de reclamaciones en móviles si el footer se centra */
    .pie-link-reclamaciones-completo {
        align-items: center;
    }

}



/* Ajuste para celulares muy angostos (menos de 480px) */
@media (max-width: 480px) {
    /* Reducimos los márgenes laterales para ganar espacio */
    .contenedor {
        padding-left: 15px;
        padding-right: 15px;
    }

    /* Aseguramos que la cuadrícula de contacto no tenga márgenes raros */
    .contacto-grid {
        gap: 25px; /* Reducimos el espacio entre elementos */
    }

    /* Forzamos a que el formulario y la info ocupen el 100% real */
    .contacto-info, .contacto-formulario {
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }
    
    /* Si tienes iconos grandes en la info de contacto, los ajustamos un poco */
    .info-item {
        padding: 15px;
    }
}

