/* CSS COMPLETO CON CORRECCIONES PARA SAFARI/iOS */
@font-face {
  font-family: 'Geomanist';
  src: url('../fonts/geomanist-light-webfont.woff') format('woff'); 
  font-weight: normal;
  font-style: normal;
}

* {
    font-family: 'Geomanist', sans-serif;
    box-sizing: border-box;
}

body {
    margin: 0;
    background-color: #fff;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

html, body {
 
  -webkit-text-size-adjust: 100%; /* evita zoom automático */
  
}

main {
    flex-grow: 1;
}

/* Header */
header {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff;
    margin-top: 50px;
    margin-bottom: 40px;
}
header img {
    height: auto;
    max-width: 300px;
    object-fit: contain;
}

/* Sección de encabezado */
.bloque-beneficios {
    max-width: 800px;
    margin: auto;
    padding: 0 20px;
    text-align: center;
}

.separador {
    border: none;
    border-top: 1px solid #ccc;
    margin: 30px 0;
}

@keyframes fadeSlideUp {
    0% { opacity: 0; transform: translateY(25px); }
    100% { opacity: 1; transform: translateY(0); }
}

/* TÍTULO PRINCIPAL */
.titulo-beneficios {
    font-size: 46px;
    font-weight: 700;
    color: #111;
    letter-spacing: -0.6px;
    text-transform: lowercase;
    position: relative;
    margin-bottom: 12px;
    animation: fadeSlideUp 0.7s ease-out;
}

/* LÍNEA ELEGANTE BAJO EL TÍTULO CON EFECTO */
.titulo-beneficios::after {
    content: "";
    display: block;
    width: 80px;
    height: 3px;
    background: #000;
    margin: 18px auto 0;
    border-radius: 2px;
    animation: expandLine 0.6s ease-out 0.3s both;
}

@keyframes expandLine {
    from { width: 0; opacity: 0; }
    to { width: 80px; opacity: 1; }
}

/* SUBTÍTULO */
.subtitulo-beneficios {
    font-size: 18px;
    font-weight: 400;
    color: #666;
    line-height: 1.5;
    opacity: 0;
    animation: fadeSlideUp 0.7s ease-out 0.4s forwards;}


@media (max-width: 768px) {
    .titulo-beneficios {
        font-size: 34px;
    }
    .subtitulo-beneficios {
        font-size: 16px;
    }
}

/* Grid de productos */
.products {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
    margin-bottom: 50px;
}

/* Card */
/* Estilo actualizado de las tarjetas */
.container {
    width: 100%;
    aspect-ratio: 1 / 1;
    max-width: 400px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: 90%;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    position: relative;

    /* Nuevo estilo */
    background-color: #ffffff;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.container:hover,
.container:focus,
.container:active {
    transform: translateY(-6px) scale(1.02);   /* hace que el producto resalte */
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);   /* sombra más intensa al hover */
    transform: rotateX(4deg) scale(1.03);
}


/* Overlay */

.overlay {
  position: absolute;
  inset: 0;
   backdrop-filter: blur(8px); 
  background: rgba(230, 229, 229, 0.9);
  opacity: 0;
  transition: opacity 0.4s ease;
  display: flex;
  flex-direction: column;

  padding: 10px;
  pointer-events: none;
}

.overlay.show {
  opacity: 1;
  pointer-events: all; /* ← Reactiva clics dentro del overlay visible */
}



/* Contenido interno */
.items {
    padding: 0 30px;
    
}

.items.head {
    padding-top: 30px; /* Espacio superior */
}

.head {
    font-size: 30px;
    line-height: 12px;
    transform: translateY(40px);
    transition: all 0.7s;
    position: relative;
}

.head hr {
    width: 0;
    border: none;
    border-top: 2px solid #fff;

    transition: all 0.5s;
}

.marca {
    color: #000000;
    font-size: 17px;
    font-weight: bold;
    margin: 5px 0;
    line-height: 29px;
}

.descripcion {
    color: #000000;
    font-size: 15px;
    font-weight: lighter;
    margin: 10px 0;
    line-height: 17px;
}

.price {
    font-size: 22px;
    font-weight: bold;
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.7s;
}

.cart {
    font-size: 12px;
    opacity: 0;
    letter-spacing: 1px;
    transform: translateY(40px);
    transition: all 0.7s;
    display: flex;
    align-items: center;
    gap: 9px;
    color: #fff;
    
}
.new {
    color: #000000;
    margin: 0;
}

/* SOLUCIÓN iOS: Añadir :focus y :active a las animaciones internas */
.container:hover .head,
.container:hover .price,
.container:hover .cart,
.container:focus .head,
.container:focus .price,
.container:focus .cart,
.container:active .head,
.container:active .price,
.container:active .cart {
    transform: translateY(0);
    opacity: 1;
}

.container:hover .head hr,
.container:focus .head hr,
.container:active .head hr {
    width: 100%;
    transition-delay: 0.4s;
}

.container:hover .price,
.container:focus .price,
.container:active .price {
    transition-delay: 0.3s;
}

.container:hover .cart,
.container:focus .cart,
.container:active .cart {
    transition-delay: 0.6s;
}

/* Footer */


/* Responsive: móvil */
@media (max-width: 700px) {
    header{
        margin-top: 30px;
        margin-bottom: 0;
        padding-left: 5%;
        justify-content: flex-start;
    }

    header img {
        max-width: 180px;
    }

    .section-header {
        padding: 0 20px;
        margin: 35px 20px 20px;
    }

    .section-header h2 {
        font-weight: bold;
    }

    .descripcion-seccion {
        line-height: 2;
    }

    .products {
        grid-template-columns: repeat(1, 1fr);
    }

    .container {
        height: 350px;
        background-size: 100%;
    }

    .footer {
        font-size: 13px;
        padding: 15px;
    }
}

/* Responsive: tablet */
@media (min-width: 700px) and (max-width: 1024px) {
    .products {
        grid-template-columns: repeat(2, 1fr);
    }

    .container {
        max-width: 350px;
       
        background-size: 100%;
    }

    header img {
        max-width: 300px;
    }

    header{
        
        margin-bottom: 0;
       
    }
}

/* Responsive: escritorio medio */
@media (max-width: 1530px) {
    .products {
        grid-template-columns: repeat(3, 1fr); /* Cambiado de auto a 1fr */
        max-width: 1100px;
        gap:10px;
    }

    .container {
        width: 100%;
        aspect-ratio: 1 / 1;
        background-position: center;
        background-repeat: no-repeat;
        background-size: 90%;
        border-radius: 10px;
        cursor: pointer;
        overflow: hidden;
        transition: transform 0.3s ease;
        margin: 0 auto;
    }
}

@media (max-width: 1200px) {
    .products {
        grid-template-columns: repeat(2, 1fr);
        max-width: 750px;
    }
}

/* Ajustes adicionales */
@media (max-width: 900px) { /* Corregido a 900px con unidad */
    .head hr {
        margin-top: 20px;
    }

    .products {
        grid-template-columns: repeat(2, 1fr);
    }
}


@media (max-width: 750px) {
    .products {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .container {
        max-width: 350px;
        background-size: 90%;
    }
}

/*nuevo*/

/* contenedor relativo para que el panel se posicione respecto al product-item */
.product-item {
    position: relative;
    display: inline-block; 
    width: 100%;
    max-width: 320px;
}

/* el card conserva su tamaño (tu .container sigue igual) */
.container {
    position: relative;
    z-index: 1;
}

/* panel overlay: cubre el card (ajusta width/height según prefieras) */
.panel-lateral {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    max-height: 80vh;
    overflow-y: auto;
    background: #ffffff;
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.18);
    padding: 25px;
    z-index: 50;
}

/* mostrar panel cuando el checkbox esté marcado (input debe estar antes del panel) */
.toggle-detalle:checked ~ .panel-lateral {
    display: block;
}

/* backdrop opcional oscuro detrás del panel (si quieres énfasis) */
.panel-lateral::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
}

/* botón cerrar en la esquina superior derecha */
.cerrar-panel {
    position: absolute; /* Añadido position: absolute */
    right: 20px;
    font-size: 18px;
    color: #000;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: 60;
    font-weight: 700;
}

/* estilos internos */
.lista-ingredientes { list-style:none; padding-left:0; margin-top:10px; }
.lista-ingredientes li { margin-bottom:8px; line-height:1.5; color:#444; }

/* Responsive: en pantallas pequeñas el panel puede ocupar más altura */
@media (max-width: 768px) {
    .panel-lateral { 
        max-height: 100%;
    }
}

.ver-producto {
    display: inline-block;
    background-color: #333;
    color: #fff;
    border: none;
    padding: 10px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.pedir-ahora {
    background-color: #2f7740;
    color: white;
    padding: 10px 20px;
    border-radius: 8px;
    font-weight: bold;
    cursor: pointer;
    margin-left: auto;
    display: inline-block;
    text-align: center;
    white-space: nowrap;
    font-size: 14px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    text-decoration: none;
}

.items.cart {
    /* CRÍTICO: Añadir margin-top: auto para empujar al fondo */
    margin-top: auto; 
    padding-bottom: 30px; /* Espacio entre los botones y el borde */
    
    display: flex;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

/* SOLUCIÓN iOS: Añadir :focus y :active a los botones */
.ver-producto:hover,
.ver-producto:focus,
.ver-producto:active {
    background-color: #555;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.15);
}

.pedir-ahora:hover,
.pedir-ahora:focus,
.pedir-ahora:active {
    background-color: #45c234;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,0.15);
}
/* ---------------------------------------------------------------------------------- */
/* --- ESTILO PREMIUM / MODERNO PARA MENÚ (Modo Desktop) --- */
/* ---------------------------------------------------------------------------------- */

.menu-principal {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px); /* efecto cristal */
    padding: 12px 0;
    margin-bottom: 25px;
    border-bottom: 1px solid #eaeaea;
    transition: all 0.3s ease;
    position: relative;
    z-index: 9999;
}

.nav-links {
    list-style: none;
    padding: 0;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    gap: 25px;
    max-width: 1300px;
}

.nav-links > li {
    position: relative;
}

.nav-link {
    text-decoration: none;
    color: #444;
    font-size: 17px;
    font-weight: 500;
    letter-spacing: 0.8px;
    padding: 10px 14px;
    border-radius: 12px;
    transition: all 0.3s ease;
    display: inline-flex;
    text-transform: lowercase;
}

/* Colores de Hover/Active: Negro */
.nav-link:hover,
.nav-link.current {
    color: #000;
    background: rgba(0, 0, 0, 0.08); /* Fondo gris muy sutil */
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
}

/* --- DROPDOWN (Desktop) --- */

.submenu {
    list-style: none;
    padding: 10px 0;
    margin-top: 10px;
    position: absolute;
    top: 110%;
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    backdrop-filter: blur(18px); 
    -webkit-backdrop-filter: blur(18px); 
    border-radius: 16px;
    border: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 10px 35px rgba(0,0,0,0.15);
    z-index: 999999; 
    min-width: 260px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s, transform 0.3s;
    transform: translateX(-50%) translateY(10px); /* Sutil desplazamiento inicial */
}

/* 🔴 SOLUCIÓN MÓVIL (DESKTOP): Usar media query para mantener el hover SÓLO en pantallas grandes */
@media (min-width: 969px) {
    .dropdown:hover .submenu,
    .dropdown:focus-within .submenu {
        opacity: 1;
        visibility: visible;
        transform: translateX(-50%) translateY(0); /* Vuelve a la posición normal */
    }
}

/* 🔴 SOLUCIÓN MÓVIL (ACTIVA): Usar .active SIEMPRE (para que el JS lo maneje en móvil) */
.dropdown.active .submenu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0); /* Vuelve a la posición normal */
}


/* --- TITULO CATEGORIA EN SUBMENÚ --- */

.submenu-category-title {
    font-size: 14px;
    font-weight: 700;
    color: #000; /* Títulos de categoría en gris sutil */
    padding: 12px 18px 6px 18px;
    text-transform: lowercase;
    border-top: 1px solid #f0f0f0;
    letter-spacing: 1px;
}

.submenu-category-title:first-child {
    border-top: none;
}

/* --- ITEMS SUBMENÚ --- */

.submenu li a {
    text-decoration: none;
    color: #444;
    font-size: 16px;
    padding: 10px 18px;
    display: block;
    transition: all 0.2s ease;
}

.submenu li a:hover {
    background: #f1f1f1;
    color: #000;
}

/* ---------------------------------------------------------------------------------- */
/* --- RESPONSIVE / MODO MÓVIL (MENU HAMBURGUESA) --- */
/* ---------------------------------------------------------------------------------- */

/* 1. BOTÓN HAMBURGUESA EXTERNO */

#menuHamburger {
    display: none; /* Oculto por defecto en desktop */
    position: absolute; 
    
    right: 5%;
    width: 25px;
    height: 30px;
    background: none;
    border: none;
    cursor: pointer;
    
    padding: 0;
}

.close-btn-inline {
    display: none;
}


#menuHamburger .bar {
    display: block;
    width: 100%;
    height: 2px;
    background: #000; 
    border-radius: 1px;
    transition: all 0.3s ease-in-out;
    margin: 5px 0;
}

/* Animación de la X */
#menuHamburger.active .bar:nth-child(2) {
    opacity: 0;
}
#menuHamburger.active .bar:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
}
#menuHamburger.active .bar:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
}

/* 2. HEADER: Espacio para el botón */
header {
    position: relative;
    
}



@media (max-width: 968px) {

    /* [BUG FIX] Ocultar el logo de escritorio cuando el menú está activo */
    header img, 
    header button:not(.active) {
        /* Muestra el botón de hamburguesa normal, pero... */
        display: block;
    }
    
    /* [BUG FIX] Ocultamos el botón principal cuando el menú está abierto 
        porque usaremos el botón de cierre interno. */
    #menuHamburger.active {
        display: none !important; 
    }

    .no-scroll {
        overflow: hidden;
        position: fixed; 
        width: 100%; 
    }
    
    /* Mostrar el botón en móvil */
    #menuHamburger {
        display: block;
    }

    /* Ocultar menú en estado inicial móvil */
    .menu-principal {
        /* Estilos de la capa deslizante */
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        padding: 0 0 20px 0; /* Eliminamos el padding top de 80px */
        background: #000; 
        border-bottom: none;
        box-shadow: none;
        transform: translateX(100%); /* Inicialmente fuera de la vista (derecha) */
        transition: transform 0.4s cubic-bezier(0.77, 0, 0.175, 1); 
        overflow-y: auto; 
        -webkit-overflow-scrolling: touch;
        z-index: 9998; 
    }
    
    /* Mostrar menú cuando está activo */
    .menu-principal.active {
        transform: translateX(0);
    }
    
    /* 4. [AÑADIDO] CABECERA INTERNA DEL MENÚ MÓVIL (Con logo y cierre) */
    .menu-mobile-header {
        display: flex;
        justify-content: end;
        align-items: center;
        background: #000; 
        padding: 15px 20px;
        position: sticky; /* Permite que el header se desplace hasta el borde superior */
        top: 0;
        z-index: 999999999;
        /* Estilo para la línea de separación visual si lo deseas: */
        border-bottom: 1px solid rgba(255, 255, 255, 0.1); 
        margin-bottom: 50px;
    }

    .menu-mobile-header img {
        height: 30px; /* Ajusta el tamaño del logo móvil dentro del menú */
        width: auto;
        display: block; /* Asegura visibilidad en móvil */
    }

    /* Estilos para el botón de cierre interno (X en la cabecera móvil) */
    .close-btn-inline {
        width: 30px;
        height: 30px;
        background: none;
        border: none;
        cursor: pointer;
        padding: 0;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .close-btn-inline .bar {
        /* Reutiliza el estilo de la barra para la X */
        display: block;
        width: 100%;
        height: 2px;
        background: #fff;
        border-radius: 1px;
        transition: transform 0.3s ease-in-out;
    }
    .close-btn-inline .bar:nth-child(1) {
        transform: translateY(1px) rotate(45deg);
    }
    .close-btn-inline .bar:nth-child(2) {
        transform: translateY(-1px) rotate(-45deg);
    }

    /* 5. LINKS y ESTRUCTURA (Dentro del menú negro) */
    
    .nav-links {
        flex-direction: column;
        align-items: center;
        gap: 0; 
        max-width: 400px;
        margin: 0 auto;
        padding-top: 0; /* Ya tenemos el header fijo en la parte superior */
    }

    .nav-links > li {
        width: 90%; 
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        text-align: center;
    }
    
    .nav-links > li:last-child {
        border-bottom: none;
    }

    .nav-link {
        display: block;
        width: 100%;
        padding: 15px 0; 
        font-size: 20px; 
        font-weight: 500;
        letter-spacing: 1px;
        color: #fff; 
        border-radius: 0;
    }
    
    .nav-link:hover,
    .nav-link.current {
        background: rgba(255, 255, 255, 0.1); 
        color: #fff;
        box-shadow: none;
    }

    /* 6. SUBMENU (Acordeón Vertical) */

    .submenu {
        position: relative;
        
        box-shadow: none;
        border: none;
        background-color: rgba(255, 255, 255, 0.05); 
        min-width: 100%;
        max-height: 0; /* Clave para la transición de altura */
        padding: 0;
        overflow: hidden;
        /* [BUG FIX] Añadir visibility/opacity a la transición para un mejor efecto */
        transition: max-height 0.4s ease-in-out, padding 0.4s ease-in-out, opacity 0.4s, visibility 0.4s;
        border-radius: 0;
        visibility: hidden; /* Oculto por defecto */
        opacity: 0; /* Oculto por defecto */
    }

    /* 🔴 SOLUCIÓN MÓVIL: Abrir submenú SOLO con la clase .active */
    .dropdown.active .submenu {
        max-height: 500px; 
        padding: 10px 0; /* Asegura el padding interno al abrir */
        visibility: visible;
        opacity: 1;
    }

    /* Estilo de los ítems internos */
    .submenu-category-title {
        background: rgba(255, 255, 255, 0.05);
        color: #fff; /* Corregido a blanco para contraste en fondo negro */
        text-transform: lowercase;
        font-size: 16px;
        padding: 10px 16px;
        
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }
    
    .submenu li a {
        color: #eee;
        padding: 15px 30px;
        font-size: 16px;
    }

    .submenu li a:hover {
        background: rgba(255, 255, 255, 0.1);
        color: #fff;
    }
}


/* CONTACTO.CSS: Estilos específicos para la página de contacto */

/* Asegurar que la página ocupe toda la altura */
.contacto-main {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 150px;
    background-color: #ffffff; /* Fondo suave */
}

.contacto-container {
    width: 100%;
    max-width: 450px; /* Ajustado para que se vea bien en el centro */
    text-align: center;
}

.contacto-header {
    margin-bottom: 30px;
}

.contacto-logo {
    max-width: 200px;
    margin-bottom: 20px;
}

.contacto-title {
    font-size: 52px;
    font-weight: 700;
    color: #333;
    margin-bottom: 80px;
}

.contacto-subtitle {
    font-size: 16px;
    color: #666;

}

.contacto-card {
    background: #ffffff;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}

.redes-title {
    font-size: 18px;
    font-weight: 600;
    color: #333;
    margin-top: 15px;
    margin-bottom: 20px;
}

.contacto-divider {
    border: none;
    border-top: 1px solid #eee;
    margin: 30px 0 20px 0;
}

/* --- ESTILOS DE BOTONES --- */

.contacto-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 15px;
    border-radius: 8px;
    font-size: 18px;
    font-weight: 600;
    text-decoration: none;
    color: #ffffff;
    transition: all 0.3s ease;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    margin-bottom: 15px;
}

/* Estilos específicos para WhatsApp */
.contacto-btn.whatsapp {
    background-color: #25D366;
}
.contacto-btn.whatsapp:hover {
    background-color: #128C7E;
    transform: translateY(-2px);
}

/* Contenedor de redes sociales */
.redes-container {
    display: flex;
    gap: 15px;
    justify-content: center;
}

.red-btn {
    flex-grow: 1; /* Permite que ambos botones crezcan por igual */
    padding: 12px 10px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 500;
    text-decoration: none;
    color: #ffffff;
    transition: background-color 0.3s ease, transform 0.3s ease;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

/* Estilos específicos para Instagram */
.red-btn.instagram-btn {
    background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
}
.red-btn.instagram-btn:hover {
    opacity: 0.85;
    transform: translateY(-2px);
}

/* Estilos específicos para TikTok */
.red-btn.tiktok-btn {
    background-color: #000000;
}
.red-btn.tiktok-btn:hover {
    background-color: #69C9D0;
    transform: translateY(-2px);
}

/* Iconos dentro de los botones */
.contacto-btn i, .red-btn i {
    margin-right: 10px;
    font-size: 20px;
}

.contacto-note {
    font-size: 14px;
    color: #999;
    margin-top: 25px;
}


/* --- Responsive Móvil (Ajuste final) --- */
@media (max-width: 768px) {
    .redes-container {
        flex-direction: column; /* Apilamos los botones de redes en pantallas muy pequeñas */
    }
    .contacto-card {
        padding: 20px;
    }
    .contacto-title {
        font-size: 38px;
        margin: 0;
    }

    .contacto-container{
        width: auto;
    max-width: 950px; /* Ajustado para que se vea bien en el centro */
    text-align: center;
    }

    .contacto-main
    {
        padding:20px;
    };

    
    
}

.barra-envio {
  width: 100%;
  background-color: #000; /* color de fondo (puedes cambiarlo) */
  color: #fff; /* color del texto */
  overflow: hidden;
  white-space: nowrap;
  padding: 10px 0;
  font-size: 15px;
  font-weight: 500;
  position: relative; /* para que quede siempre arriba */
  top: 0;
  left: 0;}

.texto-envio {
  display: inline-block;
  padding-left: 100%;
  animation: moverTexto 20s linear infinite;
  font-weight: 600;
}

@keyframes moverTexto {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}



.stock-badge {
    position: absolute; /* Posicionamiento absoluto dentro del .container */
    top: 15px;          /* Distancia desde la parte superior */
    left: 15px;         /* Distancia desde la izquierda */
    background-color: rgba(255, 255, 255, 0.8); /* Fondo blanco semi-transparente */
    color: #333;        /* Color del texto normal */
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 13px;
    font-weight: 700;
    z-index: -1;        /* Asegura que esté por encima de otros elementos si hay solapamiento */
    box-shadow: 0 2px 5px rgba(0,0,0,0.2); /* Sombra sutil */
    text-transform: uppercase;
}

.stock-badge.low-stock {
    background-color: rgba(255, 0, 0, 0.7); /* Fondo rojo para poco stock */
    color: white; /* Texto blanco para resaltar */
    animation: pulse-red 1.5s infinite; /* Efecto de pulsación */
}

.stock-badge.sold-out {
    background-color: rgba(0, 0, 0, 0.7); /* Fondo oscuro para agotado */
    color: white; /* Texto blanco */
    font-size: 14px;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.5); /* Sombra para el texto */
}

/* Efecto de pulsación para poco stock */
@keyframes pulse-red {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.05); opacity: 0.9; }
    100% { transform: scale(1); opacity: 1; }
}

/* Estilos para el estado "agotado" en el container */
.container.agotado {
    opacity: 0.7; /* Oscurece ligeramente la tarjeta completa */
    filter: grayscale(50%); /* Opcional: poner la imagen un poco en escala de grises */
}

.disponible {
    background-color: #28a745 !important; /* Gris el botón */
    pointer-events: none; /* Desactiva el clic en el botón */
    cursor: not-allowed; /* Cambia el cursor a "prohibido" */
    opacity: 0.8;
    color: #fff;
}

/* Opcional: para que la descripción dentro del overlay sea más legible si la tarjeta está "agotada" */
.container.agotado .overlay {
    background-color: rgba(255, 255, 255, 0.7); /* Ajusta el fondo del overlay para mejor lectura */
}

/* Si quieres que el "VER MÁS" también se deshabilite */
.container.agotado .ver-producto {
    pointer-events: none;
    cursor: not-allowed;
    opacity: 0.6;
}

.container.agotado .disponible {
    background-color: #aaa !important; /* Gris el botón */
    pointer-events: none; /* Desactiva el clic en el botón */
    cursor: not-allowed; /* Cambia el cursor a "prohibido" */
    opacity: 0.8;
}


.stock-badge.pre-order {
    /* Color que indica disponibilidad especial */
    background-color: rgba(0, 100, 200, 0.7); 
    color: white;
    font-weight: 700;
    font-size: 12px; /* Ligeramente más pequeño para que quepa el texto largo */
    text-transform: uppercase;
    animation: none;
    /* Ajuste de posición si es necesario */
    padding: 7px 10px; 
}


/* --- NUEVOS ESTILOS PARA EL FOOTER (Estilo Sutil Distribuido) --- */

.footer {
    /* Manteniendo tu base, pero ajustando el padding */
    background-color: #fff;
    text-align: center; 
    padding: 20px 0; /* Padding vertical, pero ancho completo */
    font-size: 14px;
    color: #555;
    border-top: 1px solid #ddd;
    
    /* Usamos Flexbox para centrar todo el contenido verticalmente y manejar el espaciado */
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* 1. Contenedor de enlaces (el <p>) */
.footer-links-group {
    margin: 0 0 15px 0; /* Espacio debajo del grupo de enlaces */
    padding: 0 10px; 
    text-align: center;
    max-width: 1000px; /* Limita el ancho en pantallas grandes */
}

/* 2. Estilo del enlace */
.footer-link {
    color: #555;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.3s ease;
    margin: 0 12px; /* Aumentamos el margen lateral para mejor separación */
    white-space: nowrap; 
    display: inline-block;
}

.footer-link:hover {
    color: #45c234; 
    text-decoration: underline;
}

/* 3. Estilo del Separador "|" */
.link-separator {
    color: #999;
    white-space: nowrap; 
}


/* 4. Contenedor Inferior para Copyright (Estilo Moderno) */
.footer-content-bottom {
    display: flex; /* Hacemos este contenedor un Flex Container */
    justify-content: center; /* Centrar todo el contenido horizontalmente */
    width: 100%;
    margin-top: 15px; /* Espacio de separación arriba */
    padding: 0 20px;
}

.copyright-text-footer {
    margin: 0; /* Eliminamos el margen superior/inferior del párrafo */
    color: #888; /* Hacemos el color más tenue */
    font-size: 13px; /* Hacemos el texto un poco más pequeño */
}


/* --- RESPONSIVE: Mantiene la lista vertical en móvil y centra el copyright --- */

@media (max-width: 700px) {
    /* Mantiene la lista vertical de enlaces como lo teníamos */
    .footer-link, 
    .link-separator {
        display: block; 
        margin: 8px auto; 
    }
    
    .link-separator {
        display: none; 
    }
    
    /* Aseguramos que el copyright también se centre correctamente */
    .footer-content-bottom {
        justify-content: center;
        margin-top: 5px; /* Reducimos el espacio arriba de copyright en móvil */
    }
}



/* SECCIÓN POLÍTICAS */
.politicas-wrapper {
    max-width: 900px;
    margin: 40px auto;
    text-align: left;
    line-height: 1.7;
}

.titulo-politicas {
    font-size: 28px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 10px;
}

.intro-politicas {
    font-size: 16px;
    color: #555;
    text-align: center;
    margin-bottom: 30px;
}

.bloque-politica {
    margin-bottom: 30px;
    padding: 20px;
    border-radius: 12px;
    background: #f9f9f9;
    box-shadow: 0 0 6px rgba(0,0,0,0.08);
}

.bloque-politica h3 {
    margin-bottom: 12px;
    font-size: 20px;
    color: #111;
}

.bloque-politica ul {
    padding-left: 18px;
}

.bloque-politica ul li {
    margin-bottom: 8px;
    color: #444;
}

/* Responsive */
@media (max-width: 650px) {
    .politicas-wrapper {
        padding: 10px;
        margin:0;
    }
    .titulo-politicas {
        font-size: 23px;
    }
}

/* CONTENEDOR GENERAL */
.envio-container {
    max-width: 800px;
   
    padding: 25px 35px;
    line-height: 1.7;
    font-size: 17px;
    animation: fadeUp 0.6s ease-in-out;
}

/* TÍTULO */
.envio-title {
    font-size: 28px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 25px;
    letter-spacing: 0.5px;
}

/* LISTA */
.envio-lista {
    padding-left: 0;
}

.envio-lista li {
    list-style: none;
    margin-bottom: 14px;
    position: relative;
    padding-left: 22px;
}

/* VIÑETA MODERNA */
.envio-lista li::before {
    content: "";
    width: 8px;
    height: 8px;
    background: black;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 7px;
}

/* ANIMACIÓN APARICIÓN SUAVE */
@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .envio-container {
    
        font-size: 16px;
  }
  .envio-title {
        font-size: 24px;
  }
}


.presentaciones {
  display: flex;
  gap: 10px;
  margin: 10px 0;
  flex-wrap: wrap;
}

.opcion-pres {
  padding: 10px 14px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
  background-color: #f8f8f8;
  transition: all 0.25s ease;
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
}

.opcion-pres:hover {
  border-color: #aaa;
  background: #f1f1f1;
}

.opcion-pres.active {
  background: #28a745;
  color: white;
  border-color: #28a745;
}

/* Icono ✔ */
.opcion-pres.active::before {
  content: "✔";
  font-size: 14px;
  font-weight: bold;
}



.stock-text{
    margin-top:5px
}



/* --- ESTILOS MODO COMPARACIÓN --- */

/* El texto de activar */
.comparador-trigger {
    text-align: center;
    margin-bottom: 20px;
   
}
.comparador-trigger p span {
    text-decoration: underline;
    font-weight: 600;
    color: #333;
}

#btn-activar-comparacion {
    display: inline-block; 
    width: fit-content; 
     cursor: pointer;
}

/* --- Estilo del botón/enlace para Salir del modo Comparación (Versión en Negro) --- */

/* Estilo general para el texto del trigger */
.comparador-trigger p {
    font-size: 1rem; /* Puedes ajustar si quieres el texto base más grande */
    color: #333;
    font-weight:200; /* Texto base en negrita moderada */
}

/* Estilo para el SPAN principal (la parte interactiva) */
#btn-activar-comparacion span {
    font-weight: 900; /* Mucho más negrita para resaltar */
    color: #000000; /* Negro puro */
    text-decoration: none; /* Quitamos el subrayado por defecto */
    cursor: pointer; /* Indicar que es interactivo */
    position: relative; /* Para el efecto de subrayado */
    display: inline-block; /* Para que el span se comporte como un bloque para el hover */
    padding-bottom: 2px; /* Espacio para el subrayado */
    text-transform: uppercase;
}

/* Efecto de Subrayado Animado */
#btn-activar-comparacion span::after {
    content: '';
    position: absolute;
    width: 0%; /* Inicia sin subrayado */
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: #000000; /* Color del subrayado */
    transition: width 0.3s ease-out; /* Animación de 0.3 segundos */
}

#btn-activar-comparacion span:hover::after {
    width: 100%; /* El subrayado aparece al 100% al pasar el ratón */
}

/* Mantenemos el estilo para el modo comparación activo */
body.modo-comparacion .comparador-trigger p {
    font-weight: 900; /* Haz todo el párrafo más negrita */
}

body.modo-comparacion #btn-activar-comparacion span {
    font-weight: 900;
    color: #000000;
    text-decoration: none; /* Asegura que no tenga un subrayado por defecto */
}



.check-comparar-container {
    position: absolute;
    top: 15px; /* Posicionamiento: 10px desde la parte inferior */
    right: 15px;  /* Posicionamiento: 10px desde la derecha */
    z-index: 20; /* Encima de otros elementos */
    opacity: 0; 
    transform: translateY(10px); 
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
    display: none; /* Oculto por defecto */
}

/* Cuando el body tiene la clase 'modo-comparacion', mostramos los checks */
body.modo-comparacion .check-comparar-container {
    display: block;
    opacity: 1 !important; 
    transform: translateY(0) !important; 
    transition-delay: 0.2s;
}

/* Diseño del checkbox personalizado */
.custom-checkbox {
    width: 25px;
    height: 25px;
    background-color: white;
    border: 2px solid #333;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s;
}

.custom-checkbox input {
    display: none; /* Ocultar el input real */
}

/* Cuando está seleccionado */
.custom-checkbox.checked {
    background-color: #4CAF50; /* Un verde vibrante y clásico */
    border-color: #4CAF50;
}

.custom-checkbox.checked::after {
    content: '✔';
    color: white;
    font-size: 14px;
}

/* Barra flotante inferior */
.barra-flotante {
    position: fixed;
    bottom: -140px; /* Oculto abajo */
    left: 0;
    width: 100%;
    background: white;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
    padding: 15px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    transition: bottom 0.4s;
    z-index: 1000;
    height: 140px;
}

.barra-flotante.activo {
    bottom: 0;
}

.barra-flotante button {
    padding: 10px 20px;
    background: #333;
    color: white;
    border: none;
    cursor: pointer;
    font-weight: bold;
}
.barra-flotante button:disabled {
    background: #ccc;
    cursor: not-allowed;
}

/* Modal de Comparación */
.modal-comp {
    position: fixed;
    top: 0; 
    left: 0;
    width: 100%; 
    height: 100vh; /* Usa vh para asegurar pantalla completa */
    background: rgba(0,0,0,0.9);
    z-index: 9999 !important; /* Z-index altísimo */
    display: none; 
    justify-content: center;
    align-items: center;
}

/* La clase que agrega JS */
.modal-comp.show {
    display: flex !important; /* Forzar el display flex */
}

.modal-comp-content {
    background: white;
    padding: 30px;
    width: 90%;
    max-width: 800px;
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 8px;
    position: relative;
   
}

.cerrar-modal-comp {
    position: absolute;
    top: 25px; right: 20px;
    font-size: 2rem;
    cursor: pointer;
    z-index: 1001;
}


/* CONGELAR Y LIMPIAR LA APARIENCIA DEL CARD EN MODO COMPARACIÓN */
body.modo-comparacion .container {
    background-color: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    transform: none !important;
    cursor: default;
    transition: all 0.4s ease-in-out !important; /* Importante: aplicar transición aquí también */
    
    /* Opcional: Centrar la imagen dentro de su espacio si es necesario */
    display: flex; /* Asegura flexbox para centrado si no lo tiene */
    justify-content: center;
    align-items: center;
    
    /* Pequeña reducción de tamaño para enfocar en la botella */
    transform: scale(0.95) !important; 
}

/* OCULTAR INFORMACIÓN DEL PRODUCTO EN MODO COMPARACIÓN CON TRANSICIÓN */
body.modo-comparacion .container .head,
body.modo-comparacion .container .description-text,
body.modo-comparacion .container .price,
body.modo-comparacion .container .opciones-presentacion,
body.modo-comparacion .container .cart,
body.modo-comparacion .container .btn-area,
body.modo-comparacion .stock-badge,
body.modo-comparacion .overlay { /* Incluye el overlay para que desaparezca suave */
    opacity: 0 !important; /* Haz que desaparezca gradualmente */
    pointer-events: none !important; /* Deshabilita clics mientras desaparece */
    transition: opacity 0.3s ease-out, transform 0.3s ease-out !important; /* Añade transición */
    transform: translateY(10px) !important; /* Pequeño desplazamiento hacia abajo al desaparecer */
}

/* Asegura que los checkboxes aparezcan suavemente */
.check-comparar-container {
    /* ... tus estilos de posicionamiento (bottom, right, z-index) ... */
    transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out; /* Transición para el checkbox */
    opacity: 0; /* Oculto por defecto, se mostrará con 1 */
    transform: translateY(10px); /* Pequeño desplazamiento hacia abajo al aparecer */
}

body.modo-comparacion .check-comparar-container {
    display: block; /* Asegura que se muestre */
    opacity: 1 !important; /* Aparece */
    transform: translateY(0) !important; /* Vuelve a su posición */
    transition-delay: 0.2s; /* Un ligero retraso para que aparezca después de que el card se limpie */
}


/* --- ESTILOS PARA EL MENSAJE DE LÍMITE --- */
.mensaje-limite {
    /* Posicionamiento y Apariencia */
    position: fixed; /* Fijo en la pantalla */
    top: 100px;      /* Ubicado debajo del header/barra de envío */
    left: 50%;
    transform: translateX(-50%); /* Centrado horizontalmente */
    
    /* Diseño */
    background-color: #f7d1d1; /* Fondo rojo suave */
    color: #c0392b; /* Texto rojo oscuro */
    border: 1px solid #c0392b;
    padding: 15px 30px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    
    /* Tipografía */
    font-size: 16px;
    font-weight: 600;
    
    /* Transición y Visibilidad */
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease-in-out, visibility 0.4s ease-in-out, transform 0.4s;
    z-index: 9999; /* Asegura que esté por encima de todo */
}

/* Clase para mostrar el mensaje */
.mensaje-limite.show {
    opacity: 1;
    visibility: visible;
    /* Efecto de "rebote" sutil al aparecer */
    transform: translateX(-50%) translateY(-5px); 
}

/* ========================================= */
/* 1. CONTENEDOR RESPONSIVE */
/* ========================================= */
.tabla-responsive-wrapper {
    max-width: 100%; 
    overflow-x: auto; 
    -webkit-overflow-scrolling: touch; 
    background-color: #FFFFFF; 
    /* 💡 AJUSTE: Si quieres un borde visible en la tabla, déjalo aquí. */
    /* Si el borde del .modal-content es suficiente, podrías quitarlo. */
    
    border-radius: 0;
    /* 💡 AJUSTE: Añadimos un pequeño padding *dentro* del contenedor responsive */
    /* Esto es si quieres un espacio entre el borde negro y el contenido de la tabla */
    padding: 5px;
}

/* ========================================= */
/* 2. ESTILO BASE - MONOCROMÁTICO */
/* ========================================= */
.tabla-comp {
    /* Aumentamos el ancho mínimo para dar espacio a las columnas fijas */
    min-width: 650px; 
    width: 100%;
    border-collapse: collapse;
    background-color: #FFFFFF;
    /* CLAVE: Usamos table-layout: fixed para que el ancho de las celdas sea predecible */
    table-layout: fixed; 
}

/* 3. CONTROL DE ANCHO DE COLUMNAS */

/* Columna de Etiquetas (Características) */
.tabla-comp thead th:first-child,
.tabla-comp tbody td:first-child {
    /* 🔴 ANCHO FIJO: Dejamos 200px para la columna de la característica/etiqueta */
   width: 200px;
    min-width: 200px;
    text-align: left;
    /* 💡 AJUSTE: Más padding a la izquierda para el texto */
    padding-left: 20px; 
    border-right: 2px solid #000000;
}

/* Columnas de Productos (Producto 1 y Producto 2) */
.tabla-comp thead th:not(:first-child),
.tabla-comp tbody td:not(:first-child) {
    /* 🔴 ANCHO RESTANTE: El 100% menos 200px (la primera columna), dividido por 2 */
    /* La propiedad 'width' restante hace que el espacio se reparta equitativamente */
    width: calc((100% - 200px) / 2);
    text-align: center;
}

/* ========================================= */
/* 4. ESTILOS VISUALES (Resto del B/N Puro) */
/* ========================================= */

.tabla-comp thead th {
    background-color: #FFFFFF; 
    color: #000000; 
    font-size: 1.2rem;
    font-weight: 900;
    /* 💡 AJUSTE CLAVE: Más padding en los encabezados para más "aire" */
    padding: 20px 15px; /* Aumentado el vertical y horizontal */
    border-bottom: 3px solid #000000;
}

.tabla-comp tbody td {
    padding: 18px 10px; /* Aumentado de 16px a 18px */
    color: #000000;
    font-size: 1rem;
    border-bottom: 1px solid #000000; 
    vertical-align: top;
}

.tabla-comp tbody td:first-child {
    font-weight: 700; 
}

/* Borde vertical que separa los dos productos */
.tabla-comp tbody td:nth-child(2) {
    border-right: 1px solid #000000; 
}

/* Imagen en la tabla */
.tabla-comp img {
    max-width: 90px;
    height: auto;
 
}

.tabla-comp tbody tr:last-child td {
    border-bottom: none; 
}

/* Estilos necesarios para el modal (SOLO USAR ESTE ID) */
#modal-comparacion {
   position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.7); /* Fondo semi-transparente oscuro */
    z-index: 9999; 
    
    display: none; /* Oculto por defecto, JS lo cambia */
    opacity: 0; 
    transition: opacity 0.3s ease-in-out; 
    
    justify-content: center;
    align-items: center;
}

/* El modal se muestra al añadir la clase 'show' con JavaScript */
#modal-comparacion.show {
    /* display: flex; lo pone el JS un momento antes */
    opacity: 1; /* Se vuelve totalmente visible */
}

/* Estilos para el contenido del modal (Asegúrate que el contenido tenga z-index implícito por ser hijo) */
.modal-content {
   background: white;
    /* 💡 AJUSTE CLAVE: Aumenta el padding para separar la tabla del borde del modal */
    padding: 30px; /* Aumentado de 20px a 30px para más aire alrededor de la tabla */
    
    width: 90%;
    max-width: 800px;
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 8px;
    position: relative; /* Esencial para posicionar el botón de cierre */

    transform: scale(0.95); /* Animación inicial reducida */
    transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Cuando el modal tiene la clase 'show', el contenido se escala a tamaño normal */
#modal-comparacion.show .modal-content {
    transform: scale(1);
}


/* ================================================= */
/* 📱 CORRECCIÓN DEFINITIVA: LISTA VERTICAL (NO TABLA)*/
/* ================================================= */

@media (max-width: 650px) {

    /* 1. ANULACIÓN Y BLOQUEO DE LA ESTRUCTURA DE TABLA */
    
    .tabla-comp, 
    .comparador-tarjetas table {
        min-width: 100% !important; 
        width: 100% !important;
        table-layout: auto !important; 
        border: none !important; 
        
        /* CLAVE: Forzar a que la tabla se comporte como un bloque que se apila */
        display: block !important; 
    }

    /* Ocultar el encabezado de la tabla (Nombres de productos en horizontal) */
    .tabla-comp thead,
    .comparador-tarjetas thead {
        display: none !important;
    }
    
    /* Mostrar el cuerpo de la tabla y las filas como bloques */
    .tabla-comp tbody,
    .comparador-tarjetas tbody,
    .tabla-comp tr,
    .comparador-tarjetas tr {
        display: block !important;
    }
    
    /* 2. REINICIO DE CELDAS (TD) PARA EL FORMATO DE LISTA/TARJETA */

    /* Cada fila (tr) es una tarjeta de característica completa (ej. "Marca") */
    .comparador-tarjetas tr {
        margin-bottom: 20px; 
        border: 1px solid #eee; 
        border-radius: 8px;
        box-shadow: 0 4px 6px rgba(0,0,0,0.05); 
        padding: 10px;
        background: #fff;
    }

    /* Cada celda (td) se convierte en una línea de información dentro de la tarjeta */
    .tabla-comp td, 
    .comparador-tarjetas td {
        display: block !important;
        width: 100% !important; /* Ocupa el 100% del ancho de la tarjeta */
        min-width: auto !important;
        border: none !important; /* Elimina todos los bordes de celda */
        padding: 8px 5px !important; 
        text-align: left !important;
    }

    /* 3. OCULTAR Y USAR LA ETIQUETA DE CARACTERÍSTICA (data-label) */

    /* Ocultar la primera celda (la etiqueta de la característica original, "Marca") */
    .tabla-comp tbody td:first-child,
    .comparador-tarjetas td:first-child {
        display: none !important; 
    }

    /* Usar el contenido del data-label como encabezado */
    .comparador-tarjetas td::before {
        content: attr(data-label); 
        display: block; /* Mueve la etiqueta a su propia línea */
        font-weight: 800; 
        color: #000;
        text-transform: uppercase;
        font-size: 14px;
        margin-bottom: 5px;
    }
    
    /* 4. LIMPIEZA ADICIONAL */

    /* Anular el borde vertical que separaba los dos productos */
    .tabla-comp tbody td:nth-child(2) {
        border-right: none !important; 
    }
    
    /* Centrar las imágenes */
    .comparador-tarjetas td img {
        display: block;
        margin: 5px auto;
        max-width: 120px;
    }
}

@media (max-width: 650px) {

    /* 🔴 CLAVE 1: Ocultar la tabla y mostrar los bloques */
    .vista-escritorio {
        display: none !important;
    }
    
    .vista-movil {
        display: flex !important;
        flex-direction: column; /* Apilar los productos */
        width: 100%;
    }

    /* 🔴 CLAVE 2: Estilo de Tarjeta de Producto (p1 y p2) */
    .tarjeta-producto {
        border: 1px solid #ddd;
        border-radius: 8px;
        padding: 15px;
        background: #fff;
        box-shadow: 0 4px 8px rgba(0,0,0,0.05);
        font-size: 13px;
    }
    
    .nombre-producto {
        font-size: 18px;
        font-weight: 700;
        margin-bottom: 15px;
        border-bottom: 2px solid #eee;
        padding-bottom: 10px;
    }

    /* 🔴 CLAVE 3: Estilo de las Características Apiladas */
    .dato-caracteristica {
        display: flex; /* Usar flexbox para alinear etiqueta y valor */
        justify-content: space-between;
        align-items: flex-start;
        padding: 10px 0;
        border-bottom: 1px dotted #f0f0f0;
    }

    .dato-caracteristica:last-child {
        border-bottom: none;
    }

    .dato-caracteristica .label {
        font-weight: 600;
        text-transform: uppercase;
        color: #555;
        flex-basis: 40%; /* Etiqueta ocupa 40% del ancho */
    }

    .dato-caracteristica .valor {
        text-align: right;
        flex-basis: 55%; /* Valor ocupa 55% del ancho */
    }
    
    /* Estilo especial para imágenes */
    .dato-imagen {
        flex-direction: column; /* Apilar label e imagen */
        text-align: center;
    }
    
    .dato-imagen .valor {
        width: 100%;
        text-align: center;
        margin-top: 10px;
    }
    
    .dato-imagen img {
        max-width: 100px;
        height: auto;
        display: block;
        margin: 0 auto;
    }
    
    /* Limpieza del modal para móvil */
    .modal-comp-content {
        width: 95% !important;
        padding: 20px !important;
    }

    .modal-comp-content h2{
        font-size: 19px;
    }
}

/* Estilos para el contenedor dual */
.comparador-contenedor {
    width: 100%;
}

/* Por defecto, muestra la tabla (para escritorio) */
.vista-escritorio {
    display: block; 
}

/* Por defecto, oculta la vista de bloques (para móvil) */
.vista-movil {
    display: none; 
}

