/* ==========================================================================
   ESTILOS PERSONALIZADOS - CHARO ARTESANAL
   ========================================================================== */

/* =========================================
   0. FUENTES LOCALES (Nunito)
   ========================================= */

/* Ajustamos la ruta: ../../vendor porque estamos en css/front/ */

/* regular (400) */
@font-face {
  font-display: swap;
  font-family: 'Nunito';
  font-style: normal;
  font-weight: 400;
  src: url('../../vendor/fonts/nunito/nunito-v32-latin-regular.woff2') format('woff2');
}

/* italic (400) */
@font-face {
  font-display: swap;
  font-family: 'Nunito';
  font-style: italic;
  font-weight: 400;
  src: url('../../vendor/fonts/nunito/nunito-v32-latin-italic.woff2') format('woff2');
}

/* semi-bold (600) */
@font-face {
  font-display: swap;
  font-family: 'Nunito';
  font-style: normal;
  font-weight: 600;
  src: url('../../vendor/fonts/nunito/nunito-v32-latin-600.woff2') format('woff2');
}

/* bold (700) */
@font-face {
  font-display: swap;
  font-family: 'Nunito';
  font-style: normal;
  font-weight: 700;
  src: url('../../vendor/fonts/nunito/nunito-v32-latin-700.woff2') format('woff2');
}

/* Aplicar fuente al sitio */
body {
    font-family: 'Nunito', sans-serif;
    color: #444; /* Color base suave */
}

/* Fuente elegante para títulos especiales */
.font-serif {
    font-family: 'Georgia', serif;
}

/* =========================================
   DEFINICIÓN DE PALETA DE COLORES (VARIABLES)
   ¡Descomenta la que quieras usar!
   ========================================= */

/*--- PALETA 1: ROSA PASTEL (La Activa) --- */
:root {
    --color-primario: #f4acb7;     
    --color-secundario: #ffcad4; 
    --color-fondo-hero: #fff0f3;   
    --color-texto-destacado: #b56576; 
} 

/*--- PALETA 2: Minimalista Sofisticado (Grises Cálidos y Dorado) ---
:root {
    --color-primario: #9c6644;    
    --color-secundario: #ddb892; 
    --color-fondo-hero: #fdf6f0;  
    --color-texto-destacado: #9c6644;
} */

/*--- PALETA 3: Elegancia Oscura ---
:root {
    --color-primario: #4a4a4a;    
    --color-secundario: #b08d57;  
    --color-fondo-hero: #f8f9fa;  
    --color-texto-destacado: #b08d57; 
}*/

/*--- PALETA 4: Frescura Botánica (Verdes vivos) ---
:root {
    --color-primario: #2d6a4f;    
    --color-secundario: #52b788;  
    --color-fondo-hero: #eef5f2;  
    --color-texto-destacado: #2d6a4f;
}*/


/* =========================================
   1. HEADER & NAVBAR (MEJORADO)
   ========================================= */

/* Efecto Vidrio (Glassmorphism) para el Navbar */
.navbar-glass {
    background-color: rgba(255, 255, 255, 0.95) !important; /* Blanco al 95% */
    backdrop-filter: blur(10px); /* El efecto borroso detrás */
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(0,0,0,0.05); /* Borde sutil */
    transition: all 0.3s ease;
}

/* Ajuste del Logo */
.navbar-brand img {
    transition: transform 0.3s ease;
}
.navbar-brand:hover img {
    transform: scale(1.05); /* Pequeño zoom al logo */
}

/* Enlaces del menú */
.nav-link-custom {
    position: relative;
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.5px;
    color: #444 !important; /* Un gris oscuro, no negro puro */
    transition: color 0.3s ease;
}

/* Línea animada */
.nav-link-custom::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 5px; /* Un poquito más arriba */
    left: 50%;
    background-color: var(--color-primario);
    transition: all 0.3s ease;
    transform: translateX(-50%);
}
.nav-link-custom:hover { color: var(--color-primario) !important; }
.nav-link-custom:hover::after { width: 80%; }

/* Dropdown más elegante */
.dropdown-menu {
    border: none;
    border-radius: 12px; /* Más redondeado */
    box-shadow: 0 10px 30px rgba(0,0,0,0.1); /* Sombra difusa */
    margin-top: 15px !important; /* Separado del navbar */
    padding: 10px;
}
/* Flechita decorativa arriba del dropdown */
.dropdown-menu::before {
    content: '';
    position: absolute;
    top: -6px;
    left: 20px;
    width: 12px;
    height: 12px;
    background: white;
    transform: rotate(45deg);
    border-left: 1px solid rgba(0,0,0,0.05);
    border-top: 1px solid rgba(0,0,0,0.05);
}

.dropdown-item {
    border-radius: 8px;
    transition: all 0.2s;
}
.dropdown-item:active, .dropdown-item:focus, .dropdown-item:hover {
    background-color: #f1f3e9; /* Fondo muy clarito al pasar mouse */
    color: var(--color-primario) !important;
    font-weight: 600;
}

/* Iconos de navegación */
.icon-nav {
    font-size: 1.4rem; /* Un pelín más grandes */
    color: #555;
    transition: all 0.2s;
}
.icon-nav:hover {
    color: var(--color-primario);
    transform: translateY(-2px); /* Suben un poquito */
}

/* Badge del carrito */
.cart-badge {
    background-color: #bc4749;
    border: 2px solid #fff; /* Borde blanco para separar del icono */
    font-size: 0.65rem;
}

/* Input del Buscador Redondeado */
.input-search-rounded {
    border-radius: 50px 0 0 50px !important;
    border: 1px solid #eee;
    background-color: #f8f9fa;
}
.btn-search-rounded {
    border-radius: 0 50px 50px 0 !important;
    border: 1px solid #eee;
    background-color: #f8f9fa;
}
.input-search-rounded:focus {
    background-color: #fff;
    box-shadow: none;
    border-color: var(--color-primario);
}

/* --- Estado ACTIVO (Página Actual) --- */
.nav-link-custom.active {
    color: var(--color-primario) !important; /* Texto del color primario */
}

.nav-link-custom.active::after {
    width: 80%; /* La línea se queda fija */
}

/* =========================================
   SISTEMA DE MENÚ HÍBRIDO DEFINITIVO
   ========================================= */

/* Estilo base del submenú oculto */
.submenu-list {
    display: none;
    background-color: #fff;
    list-style: none;
    padding: 0;
    margin: 0;
    z-index: 1000;
}

/* -------------------------------------------
   🖥️ VERSIÓN ESCRITORIO (Pantallas Grandes)
   ------------------------------------------- */
@media (min-width: 992px) {
    
    /* 1. Submenús (Flyout) se abren con Hover a la derecha */
    .has-submenu {
        position: relative; 
    }

    .has-submenu:hover > .submenu-list {
        display: block;
        position: absolute;
        top: 0;
        left: 100%; /* Se pega a la derecha */
        margin-top: -5px;
        min-width: 220px;
        border-radius: 8px;
        box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.15);
        border: 1px solid rgba(0,0,0,0.1);
        animation: fadeInRight 0.3s ease;
    }
    
    /* Detalle visual al hacer hover en el padre */
    .has-submenu:hover > .dropdown-item {
        color: var(--color-primario);
        background-color: #f8f9fa;
        font-weight: 700; /* Negrita para indicar que está activo */
    }
}

/* -------------------------------------------
   📱 VERSIÓN MÓVIL (Pantallas Chicas)
   ------------------------------------------- */
@media (max-width: 991.98px) {
    
    /* El submenú se comporta como acordeón (empuja hacia abajo) */
    .submenu-list {
        position: static;
        width: 100%;
        box-shadow: none;
        background-color: #f8f9fa; /* Fondo gris para diferenciar */
        border-left: 3px solid var(--color-primario); /* Borde lateral decorativo */
    }

    /* Clase que activará el JS */
    .submenu-list.open {
        display: block;
        animation: slideDown 0.3s ease;
    }
    
    /* Rotación de la flechita */
    .arrow-rotate {
        transition: transform 0.3s ease;
    }
    .arrow-rotate.rotated {
        transform: rotate(90deg);
        color: var(--color-primario) !important;
    }
}

/* Animaciones */
@keyframes fadeInRight {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}
@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* =========================================
   BARRA DE ENVÍO GRATIS (CORREGIDO)
   ========================================= */

.top-bar-custom {
    /* Fondo Oficial */
    background: var(--color-primario) !important; 
    background: linear-gradient(90deg, #b56576 0%, var(--color-primario) 50%, #b56576 100%) !important;
    background-size: 200% 100% !important;
    animation: gradientMove 15s ease infinite;
    
    /* Texto Blanco */
    color: #ffffff !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    position: relative;
    z-index: 1031;
}

/* Efecto de Brillo (La capa que antes era blanca) */
.shine-effect {
    /* Degradado sutil blanco transparente */
    background: linear-gradient(
        45deg, 
        transparent 40%, 
        rgba(255, 255, 255, 0.1) 50%, 
        transparent 60%
    );
    opacity: 0.8;
}

/* Animaciones */
@keyframes gradientMove {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.icon-gift-animate {
    animation: giftBounce 2s infinite;
    color: #ffe6db !important; /* Amarillo */
}

@keyframes giftBounce {
    0%, 100% { transform: rotate(0deg); }
    10% { transform: rotate(-10deg); }
    20% { transform: rotate(10deg); }
    30% { transform: rotate(-10deg); }
    40% { transform: rotate(10deg); }
    50% { transform: rotate(0deg); }
}

/* Estilos para subcategorías en el menú */
.custom-subitem {
    font-size: 0.85rem !important;
    transition: all 0.2s ease;
    border-radius: 4px;
}
.custom-subitem:hover {
    background-color: transparent !important; /* Quitamos fondo gris default */
    color: var(--color-primario) !important;
    transform: translateX(5px); /* Se mueve un poquito a la derecha */
    font-weight: 700;
}

/* --- SUBMENÚ LATERAL (FLYOUT) CON SCROLL --- */

/* Solo aplicamos esto en pantallas grandes (Desktop) */
@media (min-width: 992px) {
    
    .has-submenu {
        position: relative; 
    }

    /* El menú hijo flotando a la derecha */
    .submenu-flyout {
        display: none; 
        position: absolute;
        left: 100%; /* A la derecha del padre */
        top: 0;    
        margin-top: -5px; 
        background-color: #fff;
        border-radius: 8px;
        box-shadow: 0 5px 15px rgba(0,0,0,0.1);
        min-width: 240px; /* Un poco más ancho para nombres largos */
        padding: 10px 0;
        z-index: 9999;
        border: 1px solid rgba(0,0,0,0.05);
        
        /* 🔥 LA SOLUCIÓN: Scroll SOLO aquí dentro 🔥 */
        max-height: 60vh; /* Máximo 60% de la pantalla */
        overflow-y: auto; /* Scroll vertical si se pasa */
    }

    /* Al pasar el mouse por el padre, mostramos el hijo */
    .has-submenu:hover > .submenu-flyout {
        display: block;
        animation: fadeInRight 0.3s ease;
    }

    /* Estilo de los items del submenú (Hijos) */
    .submenu-flyout .dropdown-item {
        padding: 5px 15px 5px 20px; /* Bien compacto verticalmente (5px) */
        font-size: 0.8rem; /* Letra un pelín más chica que el padre (12.8px aprox) */
        color: #555; /* Un gris un toque más suave */
        font-weight: 500; /* Normal */
    }
    
    .submenu-flyout .dropdown-item:hover {
        background-color: #f8f9fa;
        color: var(--color-primario) !important;
        border-left: 3px solid var(--color-primario);
        padding-left: 25px; /* El saltito al hacer hover */
    }
}

/* Animación de entrada lateral */
@keyframes fadeInRight {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}

/* En móviles (pantallas chicas) que se vea normal (abajo) */
@media (max-width: 991.98px) {
    .submenu-flyout {
        position: static; /* Comportamiento normal */
        box-shadow: none;
        border: none;
        padding-left: 20px;
        display: none; /* Oculto hasta click */
    }
    /* En móvil sí usamos un script o click para abrir, o lo dejamos siempre abierto si preferís */
    .has-submenu:hover > .submenu-flyout {
        display: block; /* En móvil también funciona el "tap" como hover a veces */
    }
}

/* =========================================
   ESTILOS DEL MENÚ DESPLEGABLE PERSONALIZADO
   ========================================= */

/* El contenedor principal del dropdown */
.custom-dropdown-menu {
    min-width: 280px;
    padding: 0;
    border-radius: 12px;
    
    /* CAMBIO CLAVE: Antes era hidden, ahora visible */
    overflow: visible !important; 
    
    border: 1px solid rgba(0,0,0,0.08);
    box-shadow: 0 10px 30px rgba(0,0,0,0.1) !important;
}

/* Contenedor con scroll para las categorías */
.dropdown-scroll-container {
    padding: 15px 0;
    max-height: none; /* Quitamos el límite al padre */
    overflow: visible; /* IMPORTANTE: Dejamos que se vea lo que sale para afuera */
}

/* --- DISEÑO DE BARRA DE SCROLL (Finita y elegante) --- */

/* Ancho de la barra */
.dropdown-scroll-container::-webkit-scrollbar,
.submenu-flyout::-webkit-scrollbar {
    width: 5px;
}

/* El camino de la barra (fondo) */
.dropdown-scroll-container::-webkit-scrollbar-track,
.submenu-flyout::-webkit-scrollbar-track {
    background: #f1f1f1; 
    border-radius: 4px;
}

/* La barra en sí (el "thumb") */
.dropdown-scroll-container::-webkit-scrollbar-thumb,
.submenu-flyout::-webkit-scrollbar-thumb {
    background: #ccc; 
    border-radius: 4px;
}

/* Al pasar el mouse por la barra */
.dropdown-scroll-container::-webkit-scrollbar-thumb:hover,
.submenu-flyout::-webkit-scrollbar-thumb:hover {
    background: var(--color-primario); /* Se pone color primario al tocarla */
}

/* Scrollbar personalizado (más finito y discreto) */
.dropdown-scroll-container::-webkit-scrollbar {
    width: 6px;
}
.dropdown-scroll-container::-webkit-scrollbar-track {
    background: #f1f1f1;
}
.dropdown-scroll-container::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 10px;
}
.dropdown-scroll-container::-webkit-scrollbar-thumb:hover {
    background: #aaa;
}

/* Títulos de Grupo (Headers) */
.custom-dropdown-header {
    font-size: 0.7rem; /* Antes 0.75rem */
    font-weight: 800;  /* Un poco más gordita para que se lea bien en chico */
    color: #adb5bd;
    text-transform: uppercase;
    letter-spacing: 1.5px; /* Más aire entre letras queda elegante */
    padding: 12px 20px 4px 20px; /* Menos relleno vertical */
    margin-bottom: 0;
}

/* Enlaces de Categoría (Menú Padre) */
.custom-dropdown-item {
    padding: 6px 20px; /* Antes era 8px 25px. Esto compacta la lista verticalmente */
    font-size: 0.85rem; /* Antes 0.95rem. Mucho más fino */
    color: #495057;
    font-weight: 600; /* Semi-bold para que no se pierda al ser chica */
    transition: all 0.2s ease-in-out;
    border-left: 3px solid transparent;
}

/* Efecto Hover en Categorías */
.custom-dropdown-item:hover,
.custom-dropdown-item:focus {
    background-color: #f8f9fa; /* Fondo gris muy clarito */
    color: var(--color-primario); /* Usa tu color primario */
    border-left-color: var(--color-primario); /* Línea de color a la izquierda */
    padding-left: 30px; /* Pequeño desplazamiento a la derecha */
}

/* Separadores */
.custom-dropdown-divider {
    margin: 10px 25px;
    border-top-color: rgba(0,0,0,0.05);
}

/* Link "Ver Todo el Catálogo" (Footer) */
.custom-view-all-link {
    display: block;
    width: 100%;
    padding: 10px;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primario); /* Color primario */
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background-color: transparent;
    transition: all 0.2s ease;
}

.custom-view-all-link:hover {
    background-color: transparent;
    color: #b56576; /* Un tono más oscuro del primario */
    text-decoration: underline;
}

/* Ajuste para pantallas chicas */
@media (max-width: 991.98px) {
    .custom-dropdown-menu {
        border: none;
        box-shadow: none !important;
        padding-left: 20px; /* Indentación en móvil */
        background-color: transparent;
    }
    .custom-dropdown-header {
        padding-left: 0;
        color: #6c757d;
    }
    .custom-dropdown-item {
        padding-left: 0;
    }
    .custom-dropdown-item:hover {
        background-color: transparent;
        padding-left: 5px;
        border-left: none;
    }
    .dropdown-scroll-container {
        max-height: none;
        padding: 0;
    }
}

/* =========================================
   FIX: ARREGLO RAYITA EN "PRODUCTOS"
   ========================================= */

/* Eliminamos la flecha por defecto de Bootstrap que causa el conflicto */
.nav-link-custom.dropdown-toggle::after {
    border: none !important; /* Chau triángulo */
    content: '' !important;  /* Limpiamos el contenido */
    vertical-align: baseline !important;
    margin-left: 0 !important;
}


/* =========================================
   2. ESTILOS ESPECÍFICOS DEL HOME
   ========================================= */

/* Fondo del Hero usando la variable */
.hero-section {
    background-color: var(--color-fondo-hero);
}

/* Clases personalizadas para usar el color primario */
.text-primary-custom {
    color: var(--color-primario) !important;
}

.btn-primary-custom {
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    color: #fff;
    transition: all 0.3s ease;
}

.btn-primary-custom:hover {
    background-color: #b56576; /* Un poquito más oscuro para el hover */
    border-color: #b56576;
    color: #fff;
}

/* Separador de Secciones */
.section-divider {
    width: 60px;
    height: 3px;
    background-color: var(--color-secundario); 
    margin: 0 auto;
    border-radius: 2px;
}

/* Efecto Hover en Tarjetas Generales */
.card-hover {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-hover:hover {
    transform: translateY(-5px);
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.15)!important;
}

/* Sección CTA (Llamada a la acción) */
.cta-img-col {
    min-height: 300px;
}

.cta-img-fit {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Utilidades de texto */
.ls-1 { letter-spacing: 1px; }
.ls-2 { letter-spacing: 2px; }
.w-max-content { width: max-content; }

/* Sombras suavizadas */
.shadow-xl { box-shadow: 0 20px 40px rgba(0,0,0,0.15); }

/* Animaciones */
.hover-lift {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.hover-lift:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.2) !important;
}

.hover-link:hover {
    color: var(--color-primario) !important;
    border-color: var(--color-primario) !important;
}

/* Efecto Zoom en Cards de Colección */
.card-zoom { display: block; }
.card-zoom .card-img {
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.card-zoom:hover .card-img {
    transform: scale(1.08);
}

/* Degradados */
.bg-gradient-fade {
    background: linear-gradient(to top, rgba(41, 54, 46, 0.8) 0%, rgba(0,0,0,0) 60%);
}
.bg-gradient-fade-side {
    background: linear-gradient(to right, rgba(41, 54, 46, 0.7) 0%, rgba(0,0,0,0) 70%);
}

/* Bordes responsivos */
@media (min-width: 768px) {
    .border-end-md { border-right: 1px solid #eee; }
}

/* EFECTO SUAVE PARA EL CARRUSEL */
.carousel-fade .carousel-item {
    opacity: 0;
    transition-duration: 1.5s !important; /* Más lento = Más elegante */
    transition-property: opacity;
}

.carousel-fade .carousel-item.active,
.carousel-fade .carousel-item-next.carousel-item-start,
.carousel-fade .carousel-item-prev.carousel-item-end {
    opacity: 1;
}

.carousel-fade .active.carousel-item-start,
.carousel-fade .active.carousel-item-end {
    opacity: 0;
}

/* Oscurecer un poco la imagen para que el texto blanco se lea bien */
.slider-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(0,0,0,0.2), rgba(0,0,0,0.5));
    z-index: 1;
}

/* =========================================
   3. FOOTER (ESTILO NATURALEZA + OLA)
   ========================================= */

.site-footer {
    background-color: var(--color-primario); /* Color Principal */
    color: #dad7cd; /* Texto Beige/Piedra claro */
    margin-top: 5rem;
    padding-top: 0; /* Importante en 0 para que la ola pegue bien */
    padding-bottom: 30px;
    font-size: 0.95rem;
    position: relative;
}

/* --- LOGICA DE LA OLA (SVG) --- */
.footer-wave {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
    transform: rotate(180deg) translateY(99%); /* La ubica arriba */
}

.footer-wave svg {
    position: relative;
    display: block;
    width: calc(100% + 1.3px);
    height: 60px; /* Altura de la ola */
}

.footer-wave .shape-fill {
    fill: var(--color-primario); /* EXACTAMENTE el mismo color del fondo del footer */
}

/* Espacio interno para que el texto no toque la ola */
.site-footer > .container {
    padding-top: 80px; 
}

/* --- ESTILOS DE CONTENIDO --- */

/* Títulos de las columnas */
.site-footer .footer-heading {
    color: #ffffff;
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    position: relative;
    padding-bottom: 10px;
}

/* La rayita debajo del título */
.site-footer .footer-heading::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 40px;
    height: 2px;
    background-color: var(--color-secundario);
}

/* Texto genérico */
.site-footer .footer-text {
    line-height: 1.6;
    margin-bottom: 1rem;
}

.texto-footer {
    color: #ffe6db
}

.bg-personalizado {
    background-color: var(--color-primario);
}

.banner-personalizado {
    background-color: #ffe6db;
}

/* ENLACES (Links) */
.site-footer .footer-links a {
    color: #ffe6db;
    text-decoration: none;
    transition: all 0.3s ease;
    display: block;
    margin-bottom: 10px;
    width: fit-content; /* Para que el hover no ocupe todo el ancho */
}

.site-footer .footer-links a:hover {
    color: #fff;
    padding-left: 5px;
    font-weight: 500;
}

/* CONTACTO */
.site-footer .footer-contact li {
    margin-bottom: 15px;
    display: flex;
    align-items: start;
}

/* REDES SOCIALES */
.site-footer .footer-socials a {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 50%;
    margin-right: 10px;
    text-decoration: none;
    transition: 0.3s;
    font-size: 1.2rem;
}

.site-footer .footer-socials a:hover {
    background: var(--color-secundario); 
    border-color: var(--color-secundario);
    color: #fff; 
    transform: translateY(-3px);
}

/* Divisor */
.site-footer .footer-divider {
    border-color: rgba(255, 255, 255, 0.2);
    margin: 40px 0 20px 0;
}

/* Copyright */
.site-footer .copyright-text {
    font-size: 0.85rem;
    color: var(--color-secundario); 
}

.site-footer .copyright-text strong {
    color: #fff;
}

/* =========================================
   4. ESTILOS PÁGINA DE REGISTRO / LOGIN
   ========================================= */

/* Tarjeta de Registro */
.card-registration {
    border: none;
    border-radius: 1rem;
    background-color: #ffffff;
}

.form-floating > label {
    color: #6c757d;
}

/* Botón de Login/Registro animado */
.btn-login {
    font-weight: 600;
    letter-spacing: 0.5px;
    transition: all 0.3s ease;
}

.btn-login:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.cursor-pointer {
    cursor: pointer;
}

.header-icon-container {
    width: 70px; 
    height: 70px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* =========================================
   5. BURBUJAS DE REQUISITOS (VALIDACIÓN)
   ========================================= */

.requirements-bubble {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 10;
    background-color: #fff;
    border: 1px solid #e9ecef;
    border-radius: 0.5rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    padding: 10px 15px;
    width: 100%;
    margin-top: 5px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
}

.requirements-bubble.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.req-item {
    font-size: 0.85rem;
    color: #6c757d;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    transition: color 0.3s ease;
}

.req-item i {
    font-size: 1rem;
    margin-right: 8px;
}

.req-item.valid {
    color: #b56576; 
    font-weight: 500;
}

.req-item.valid i::before {
    content: "\F26A"; /* bi-check-circle-fill */
}

.req-item i::before {
    content: "\F287"; /* bi-circle */
}

/* =========================================
   6. CATÁLOGO
   ========================================= */

/* Efecto Zoom en imagen */
.img-zoom-container { 
    overflow: hidden; 
}
.img-zoom { 
    transition: transform 0.5s ease; 
}
.card-hover:hover .img-zoom { 
    transform: scale(1.1); 
}

/* Botones con transición suave */
.transition-btn { 
    transition: all 0.3s ease; 
    opacity: 0.9; 
}
.card-hover:hover .transition-btn { 
    opacity: 1; 
    transform: scale(1.02); 
}

.text-decoration-line-through { 
    text-decoration: line-through !important; 
}

/* =========================================
   7. CHECKOUT Y CARRITO
   ========================================= */

/* Animación para cuando cambia el precio */
.precio-pop { 
    animation: popVerde 0.4s ease; 
    color: #b56576 !important;
    font-weight: 800 !important; 
}
@keyframes popVerde { 
    0% { transform: scale(1); } 
    50% { transform: scale(1.2); } 
    100% { transform: scale(1); } 
}

.option-card {
    transition: all 0.2s ease-in-out;
    border: 1px solid #dee2e6;
}

.option-card:hover {
    border-color: #adb5bd;
    background-color: #f8f9fa;
}

.card-option-active { 
    border-color: #b56576 !important; 
    background-color: #fff0f3 !important; 
    box-shadow: 0 0 0 1px #b56576; 
}

/* =========================================
   FIX: RESUMEN DE COMPRA PEGAJOSO (STICKY)
   ========================================= */

/* Por defecto (Móviles y Tablets): Comportamiento normal, NO sticky */
.resumen-sticky {
    position: relative;
    z-index: 1; /* Bajo nivel para que no tape nada */
}

/* Solo en Pantallas Grandes (Desktop > 992px) */
@media (min-width: 992px) {
    .resumen-sticky {
        position: sticky;
        top: 110px; /* Separación desde el techo (ajustar según altura de tu navbar) */
        z-index: 900; /* Menor que el Navbar (que suele ser 1000+) */
        transition: top 0.3s ease;
    }
}

/* =========================================
   8. DETALLE DE PRODUCTO
   ========================================= */

.product-title {
    font-family: 'Georgia', serif;
    color: var(--color-primario);
}

.main-image-card {
    border: none;
    border-radius: 1rem;
    background-color: #fff;
    box-shadow: 0 0.5rem 1rem #fff;
    transition: all 0.3s ease;
    height: 460px;
}

.gallery-thumb {
    width: 80px;
    height: 80px;
    min-width: 80px;
    cursor: pointer;
    border: 2px solid transparent;
    border-radius: 8px;
    opacity: 0.7;
    transition: all 0.3s ease;
}

.gallery-thumb:hover {
    opacity: 1;
    border-color: var(--color-secundario);
}

.gallery-thumb.active-thumb {
    opacity: 1;
    border-color: #b56576;
    transform: scale(0.95);
}

.btn-buy {
    background-color: var(--color-primario);
    border-color: var(--color-primario);
    color: #fff;
    transition: all 0.3s ease;
}
.btn-buy:hover {
    background-color: #b56576;
    transform: translateY(-2px);
}

/* Quitar flechas (spinners) en inputs numéricos */

/* Para Chrome, Safari, Edge, Opera */
input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
  -webkit-appearance: none; 
  margin: 0; 
}

/* Para Firefox y navegadores modernos */
input[type=number] {
  appearance: textfield;      /* Estándar moderno */
  -moz-appearance: textfield; /* Específico para Firefox (para asegurarnos) */
}

/* =========================================
   BOTÓN WHATSAPP FLOTANTE
   ========================================= */
.btn-whatsapp {
    position: fixed; /* Se queda quieto aunque hagas scroll */
    bottom: 30px;    /* Distancia desde abajo */
    right: 30px;     /* Distancia desde la derecha */
    width: 60px;
    height: 60px;
    background-color: #25d366; /* Verde oficial de WhatsApp */
    color: #fff;
    border-radius: 50%; /* Redondo perfecto */
    text-align: center;
    font-size: 30px;
    box-shadow: 0px 4px 10px rgba(0,0,0,0.3); /* Sombrita para que resalte */
    z-index: 9999; /* Para que flote arriba de todo */
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: all 0.3s ease; /* Suavidad en la animación */
}

/* Efecto al pasar el mouse */
.btn-whatsapp:hover {
    background-color: #128c7e; /* Verde un poco más oscuro */
    color: #fff;
    transform: scale(1.1) translateY(-5px); /* Se agranda y sube un poquito */
    box-shadow: 0px 8px 15px rgba(0,0,0,0.4);
}

/* =======================================================
   FIX PARA DISPOSITIVOS TÁCTILES REALES
   ======================================================= */

/* Aumentar el área táctil de la flechita para que sea fácil de embocar */
@media (max-width: 991.98px) {
    
    /* 1. ESTO ARREGLA EL SCROLL DEL MENÚ */
    .navbar-collapse {
        /* Altura máxima: 80% de la pantalla (dejamos espacio para el logo arriba) */
        max-height: 80vh; 
        
        /* Habilitamos scroll vertical INTERNO */
        overflow-y: auto; 
        
        /* Evita que el scroll "traspase" al body cuando llegás al final */
        overscroll-behavior: contain; 
        
        /* Un poquito de aire abajo para que no se corte el último ítem */
        padding-bottom: 20px;
    }
    .dropdown-item {
        /* Evita que el navegador haga zoom al tocar rápido */
        touch-action: manipulation; 
    }

    .arrow-rotate {
        /* Hacemos la flechita más grande y con padding invisible */
        padding: 10px 15px; 
        margin-right: -10px; /* Compensamos el padding */
        font-size: 1.2rem !important; /* Icono más grande */
        display: inline-block;
        pointer-events: none; /* CLAVE: Que el click traspase la flecha y vaya al <a> */
    }
}

/* Asegurarnos de que el HOVER esté desactivado en pantallas táctiles */
@media (hover: none) {
    .submenu-list {
        display: none !important; /* Forzamos oculto hasta que entre la clase .open */
    }
    .submenu-list.open {
        display: block !important;
    }
}

/* =========================================
   AJUSTE DE BUSCADOR (POSICIÓN Y ANCHO)
   ========================================= */

.dropdown-menu-search {
    min-width: 300px;
}

/* Solo para celulares (ajuste fino) */
@media (max-width: 576px) {
    .dropdown-menu-search {
        position: absolute;
        /* Forzamos que se pegue al borde derecho de la pantalla, no del ícono */
        right: -50px !important; 
        /* Que no se salga del ancho de la pantalla */
        width: 320px;
        max-width: 95vw;
        /* Un poquito más arriba si queda muy separado */
        margin-top: 10px !important;
    }
}

/* =======================================================
   FIX DE POSICIONAMIENTO EN MÓVIL (Buscador y Usuario)
   ======================================================= */

@media (max-width: 576px) {
    
    /* --- 1. BUSCADOR FIJO Y CENTRADO --- */
    .dropdown-menu-search {
        position: fixed !important; /* Se libera del contenedor */
        top: 85px !important;       /* Altura aprox debajo del navbar */
        left: 5% !important;        /* Margen izquierdo */
        width: 90% !important;      /* Ocupa casi todo el ancho */
        max-width: none !important;
        right: auto !important;
        transform: none !important; /* Anula transformaciones de Bootstrap */
        z-index: 2000 !important;   /* Arriba de todo */
    }
    
    /* Ocultamos la flechita del buscador porque queda rara flotando */
    .dropdown-menu-search::before {
        display: none;
    }

    /* --- 2. MENÚ USUARIO CENTRADO AL ÍCONO --- */
    .dropdown-menu-user {
        /* Centrado perfecto debajo del ícono */
        right: auto !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        min-width: 200px !important;
        margin-top: 15px !important; /* Un poco de aire */
    }

    /* Movemos la flechita (triángulo) al medio de la caja */
    .dropdown-menu-user::before {
        left: 50% !important;
        transform: translateX(-50%) rotate(45deg) !important;
        right: auto !important; /* Anular estilos anteriores */
    }
}