/* ============================================
   MEJORAS RESPONSIVE PARA DISPOSITIVOS MÓVILES - VERSIÓN CORREGIDA
   Optimizaciones profesionales para Morfeo Tienda
   Soluciona conflictos con tienda.css
   Autor: Claude Code
   Fecha: 2025-11-24
============================================ */

/* ============================================
   IMPORTANTE: Usar !important solo donde sea necesario
   para sobrescribir el CSS original que tiene conflictos
============================================ */

/* ============================================
   1. HERO SECTION - OPTIMIZACIÓN MÓVIL
============================================ */
@media (max-width: 768px) {
    .hero-section {
        height: 40vh !important;
        min-height: 300px !important;
        margin-top: 0 !important;
    }

    .hero-content {
        padding: 1.5rem 1rem !important;
    }

    .hero-subtitle {
        font-size: 0.75rem !important;
        letter-spacing: 1px !important;
        margin-bottom: 0.5rem !important;
    }

    .hero-title {
        font-size: 1.8rem !important;
        margin-bottom: 0.75rem !important;
        line-height: 1.2 !important;
    }

    .hero-text {
        font-size: 0.9rem !important;
        margin-bottom: 1.25rem !important;
        line-height: 1.5 !important;
    }

    .btn-elegant {
        padding: 10px 25px !important;
        font-size: 0.85rem !important;
    }
}

@media (max-width: 480px) {
    .hero-section {
        height: 35vh !important;
        min-height: 250px !important;
    }

    .hero-title {
        font-size: 1.5rem !important;
    }

    .hero-text {
        font-size: 0.85rem !important;
        margin-bottom: 1rem !important;
    }

    .btn-elegant {
        padding: 8px 20px !important;
        font-size: 0.8rem !important;
    }
}

/* ============================================
   2. FEATURES BAR - MEJOR DISTRIBUCIÓN MÓVIL
============================================ */
@media (max-width: 768px) {
    .features-bar {
        padding: 25px 0 !important;
    }

    .features-bar .col-6 {
        margin-bottom: 20px !important;
    }

    .feature-item {
        padding: 15px 10px !important;
        text-align: center !important;
    }

    .feature-icon {
        font-size: 1.8rem !important;
        margin-bottom: 8px !important;
    }

    .feature-title {
        font-size: 0.85rem !important;
        margin-bottom: 3px !important;
    }

    .feature-text {
        font-size: 0.7rem !important;
    }
}

@media (max-width: 480px) {
    .feature-icon {
        font-size: 1.5rem !important;
    }

    .feature-title {
        font-size: 0.75rem !important;
    }

    .feature-text {
        font-size: 0.65rem !important;
    }
}

/* ============================================
   3. SELECTOR DE LÍNEAS - OPTIMIZADO MÓVIL
============================================ */
@media (max-width: 768px) {
    .lineas-selector-section {
        padding: 30px 0 !important;
    }

    .lineas-selector-container {
        padding: 25px 15px !important;
    }

    .lineas-titulo {
        font-size: 1.6rem !important;
        margin-bottom: 8px !important;
    }

    .lineas-subtitulo {
        font-size: 0.9rem !important;
        margin-bottom: 25px !important;
    }

    .lineas-toggle {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        max-width: 100% !important;
    }

    .linea-option {
        padding: 20px 15px !important;
        flex-direction: row !important;
        gap: 15px !important;
        align-items: center !important;
    }

    .linea-icon {
        width: 50px !important;
        height: 50px !important;
        font-size: 1.3rem !important;
        margin-bottom: 0 !important;
        flex-shrink: 0 !important;
    }

    .linea-content {
        text-align: left !important;
    }

    .linea-content h4 {
        font-size: 1.1rem !important;
        margin-bottom: 5px !important;
    }

    .linea-content p {
        font-size: 0.8rem !important;
        line-height: 1.4 !important;
    }

    .linea-features {
        gap: 6px !important;
        margin-top: 8px !important;
    }

    .feature-dot {
        width: 8px !important;
        height: 8px !important;
    }
}

@media (max-width: 480px) {
    .lineas-titulo {
        font-size: 1.4rem !important;
    }

    .lineas-subtitulo {
        font-size: 0.85rem !important;
    }

    .linea-option {
        padding: 15px 12px !important;
    }

    .linea-icon {
        width: 45px !important;
        height: 45px !important;
        font-size: 1.1rem !important;
    }

    .linea-content h4 {
        font-size: 1rem !important;
    }

    .linea-content p {
        font-size: 0.75rem !important;
    }
}

/* ============================================
   4. CONTENEDOR PRINCIPAL - LAYOUT MÓVIL Y ESCRITORIO
============================================ */

/* Escritorio */
@media (min-width: 992px) {
    .tienda-contenedor-principal {
        padding-top: 20px !important;
    }

    .tienda-contenedor-principal .container-fluid {
        padding-left: 30px !important;
        padding-right: 30px !important;
    }
}

@media (max-width: 991px) {
    .tienda-contenedor-principal {
        padding-top: 10px !important;
    }

    .tienda-contenedor-principal .container-fluid {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
}

@media (max-width: 768px) {
    .tienda-contenedor-principal {
        padding-top: 5px !important;
    }

    .tienda-contenedor-principal .container-fluid {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    /* Ocultar barra lateral en móviles - MUY IMPORTANTE */
    .tienda-contenedor-principal .col-lg-2,
    .tienda-contenedor-principal .col-md-3 {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        height: 0 !important;
        width: 0 !important;
        overflow: hidden !important;
    }

    /* Ocultar directamente la barra lateral por clase */
    .tienda-barra-lateral {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        height: 0 !important;
        width: 0 !important;
        overflow: hidden !important;
    }

    /* Área principal ocupa todo el ancho */
    .tienda-contenedor-principal .col-lg-10,
    .tienda-contenedor-principal .col-md-9 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        width: 100% !important;
    }
}

/* ============================================
   5. BARRA DE BÚSQUEDA - MÓVIL Y ESCRITORIO MEJORADO
============================================ */

/* Estilos para escritorio */
@media (min-width: 769px) {
    .tienda-busqueda-superior {
        margin-bottom: 30px !important;
        margin-top: 20px !important;
        padding: 0 !important;
    }

    .tienda-busqueda-superior .input-group {
        max-width: 700px !important;
        margin: 0 auto !important;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important;
        border-radius: 12px !important;
        overflow: hidden !important;
    }

    .barra-busqueda-input {
        border: 2px solid #e0e0e0 !important;
        border-right: none !important;
        padding: 14px 20px !important;
        font-size: 0.95rem !important;
        transition: all 0.3s ease !important;
        background: white !important;
    }

    .barra-busqueda-input:focus {
        border-color: var(--primary-gold) !important;
        box-shadow: none !important;
        outline: none !important;
    }

    .barra-busqueda-boton {
        border: 2px solid #e0e0e0 !important;
        border-left: none !important;
        background: white !important;
        color: var(--dark-navy) !important;
        padding: 14px 20px !important;
        font-size: 1rem !important;
        transition: all 0.3s ease !important;
        min-width: 60px !important;
    }

    .barra-busqueda-boton:hover {
        background: var(--primary-gold) !important;
        color: var(--dark-navy) !important;
        border-color: var(--primary-gold) !important;
    }

    .barra-busqueda-boton:last-child {
        background: #dc3545 !important;
        color: white !important;
        border: 2px solid #dc3545 !important;
        margin-left: 0 !important;
    }

    .barra-busqueda-boton:last-child:hover {
        background: #c82333 !important;
        border-color: #c82333 !important;
    }

    #resultados-busqueda {
        text-align: center !important;
        margin-top: 12px !important;
        font-size: 0.9rem !important;
        font-weight: 500 !important;
    }
}

/* Estilos para móviles */
@media (max-width: 768px) {
    .tienda-busqueda-superior {
        margin-bottom: 80px !important;
        margin-top: 5px !important;
        padding: 0 10px 0 10px !important;
        position: relative !important;
        z-index: 10 !important;
        clear: both !important;
        display: block !important;
    }

    .tienda-busqueda-superior .input-group {
        box-shadow: 0 3px 12px rgba(0, 0, 0, 0.1) !important;
        border-radius: 12px !important;
        overflow: hidden !important;
        background: white !important;
        position: relative !important;
        z-index: 10 !important;
    }

    .barra-busqueda-input {
        font-size: 0.9rem !important;
        padding: 12px 15px !important;
        border: 2px solid #e0e0e0 !important;
        border-right: none !important;
        background: white !important;
        flex: 1 !important;
    }

    .barra-busqueda-input:focus {
        border-color: var(--primary-gold) !important;
        box-shadow: none !important;
        outline: none !important;
    }

    .barra-busqueda-input::placeholder {
        font-size: 0.85rem !important;
        color: #999 !important;
    }

    .barra-busqueda-boton {
        padding: 12px 15px !important;
        font-size: 1rem !important;
        border: 2px solid #e0e0e0 !important;
        border-left: none !important;
        background: white !important;
        color: var(--dark-navy) !important;
        transition: all 0.2s ease !important;
        min-width: 50px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .barra-busqueda-boton:active {
        background: var(--primary-gold) !important;
        color: var(--dark-navy) !important;
        transform: scale(0.95) !important;
    }

    /* Botón de limpiar (X roja) */
    .barra-busqueda-boton:last-child {
        background: #dc3545 !important;
        color: white !important;
        border: 2px solid #dc3545 !important;
        border-left: none !important;
        margin-left: 0 !important;
    }

    .barra-busqueda-boton:last-child:active {
        background: #c82333 !important;
        border-color: #c82333 !important;
    }

    #resultados-busqueda {
        font-size: 0.85rem !important;
        padding: 10px !important;
        margin-top: 10px !important;
        border-radius: 8px !important;
        font-weight: 500 !important;
    }
}

@media (max-width: 480px) {
    .tienda-busqueda-superior {
        margin-top: 5px !important;
        margin-bottom: 70px !important;
        padding: 0 8px 0 8px !important;
    }

    .barra-busqueda-input {
        font-size: 0.85rem !important;
        padding: 11px 12px !important;
    }

    .barra-busqueda-input::placeholder {
        font-size: 0.8rem !important;
    }

    .barra-busqueda-boton {
        padding: 11px 12px !important;
        font-size: 0.95rem !important;
        min-width: 45px !important;
    }

    #resultados-busqueda {
        font-size: 0.8rem !important;
        padding: 8px !important;
    }
}

@media (max-width: 360px) {
    .tienda-busqueda-superior {
        margin-top: 5px !important;
        margin-bottom: 65px !important;
    }

    .barra-busqueda-input {
        font-size: 0.82rem !important;
        padding: 10px 10px !important;
    }

    .barra-busqueda-boton {
        padding: 10px 10px !important;
        min-width: 42px !important;
    }
}

/* ============================================
   6. BANNER DE OFERTAS - OPTIMIZADO MÓVIL
============================================ */
@media (max-width: 768px) {
    .banner-ofertas {
        padding: 20px 15px !important;
        margin-bottom: 25px !important;
        margin-top: 0 !important;
        border-radius: 12px !important;
        display: block !important;
    }

    .banner-contenido {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        text-align: left !important;
        gap: 15px !important;
        align-items: center !important;
    }

    .oferta-icono {
        font-size: 2.5rem !important;
        flex-shrink: 0 !important;
    }

    .oferta-texto {
        flex: 1 !important;
        min-width: 200px !important;
    }

    .oferta-texto h3 {
        font-size: 1.3rem !important;
        line-height: 1.3 !important;
        margin-bottom: 5px !important;
    }

    .oferta-texto p {
        font-size: 0.9rem !important;
        margin: 0 !important;
    }

    .oferta-contador {
        gap: 10px !important;
        justify-content: flex-start !important;
        width: 100% !important;
        margin-top: 5px !important;
    }

    .contador-item {
        padding: 10px 15px !important;
        border-radius: 10px !important;
        min-width: 70px !important;
    }

    .contador-numero {
        font-size: 1.5rem !important;
        display: block !important;
    }

    .contador-label {
        font-size: 0.7rem !important;
        display: block !important;
        margin-top: 2px !important;
    }
}

@media (max-width: 480px) {
    .banner-ofertas {
        padding: 18px 12px !important;
        margin-bottom: 20px !important;
    }

    .oferta-icono {
        font-size: 2rem !important;
    }

    .oferta-texto h3 {
        font-size: 1.1rem !important;
    }

    .oferta-texto p {
        font-size: 0.85rem !important;
    }

    .contador-item {
        padding: 8px 12px !important;
        min-width: 65px !important;
    }

    .contador-numero {
        font-size: 1.3rem !important;
    }

    .contador-label {
        font-size: 0.65rem !important;
    }
}

@media (max-width: 360px) {
    .banner-ofertas {
        padding: 15px 10px !important;
    }

    .oferta-texto h3 {
        font-size: 1rem !important;
    }

    .oferta-texto p {
        font-size: 0.8rem !important;
    }

    .contador-item {
        padding: 7px 10px !important;
        min-width: 60px !important;
    }

    .contador-numero {
        font-size: 1.2rem !important;
    }
}

/* ============================================
   7. ENCABEZADO DE TIENDA - MÓVIL Y ESCRITORIO
============================================ */

/* Escritorio */
@media (min-width: 769px) {
    .tienda-encabezado {
        padding: 0 15px 20px 15px !important;
        text-align: center !important;
        margin-bottom: 0 !important;
        margin-top: 0 !important;
    }

    .tienda-titulo-principal {
        font-size: 2rem !important;
        margin-bottom: 8px !important;
        font-weight: 700 !important;
        color: var(--dark-navy) !important;
    }

    .tienda-subtitulo {
        font-size: 1rem !important;
        line-height: 1.5 !important;
        color: #666 !important;
        margin-bottom: 0 !important;
    }
}

/* Móviles */
@media (max-width: 768px) {
    .tienda-encabezado {
        padding: 0 10px 30px 10px !important;
        text-align: center !important;
        margin-bottom: 0 !important;
        margin-top: 0 !important;
        position: relative !important;
        z-index: 5 !important;
    }

    .tienda-titulo-principal {
        font-size: 1.5rem !important;
        margin-bottom: 6px !important;
        font-weight: 700 !important;
        color: var(--dark-navy) !important;
        line-height: 1.3 !important;
    }

    .tienda-subtitulo {
        font-size: 0.85rem !important;
        line-height: 1.4 !important;
        color: #666 !important;
        margin-bottom: 0 !important;
    }
}

@media (max-width: 480px) {
    .tienda-encabezado {
        padding: 0 8px 25px 8px !important;
    }

    .tienda-titulo-principal {
        font-size: 1.3rem !important;
        margin-bottom: 5px !important;
    }

    .tienda-subtitulo {
        font-size: 0.8rem !important;
    }
}

@media (max-width: 360px) {
    .tienda-encabezado {
        padding: 0 6px 10px 6px !important;
    }

    .tienda-titulo-principal {
        font-size: 1.2rem !important;
    }

    .tienda-subtitulo {
        font-size: 0.78rem !important;
    }
}

/* ============================================
   8. GRID DE PRODUCTOS - RESPONSIVE MEJORADO (FIX CRÍTICO)
============================================ */

/* Desktop grande (más de 1200px) */
@media (min-width: 1201px) {
    .tienda-grid-productos {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 30px !important;
        padding: 0 10px !important;
        margin-top: 0 !important;
    }
}

/* Móviles - IMPORTANTE: Agregar margen superior al grid */
@media (max-width: 768px) {
    .tienda-grid-productos {
        margin-top: 30px !important;
        position: relative !important;
        z-index: 1 !important;
        clear: both !important;
    }
}

/* Desktop mediano (992px - 1200px) */
@media (min-width: 992px) and (max-width: 1200px) {
    .tienda-grid-productos {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 25px !important;
        padding: 0 10px !important;
    }
}

/* Tablets (768px - 991px) */
@media (min-width: 768px) and (max-width: 991px) {
    .tienda-grid-productos {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
        padding: 0 10px !important;
    }
}

/* Móviles grandes (577px - 767px) */
@media (min-width: 577px) and (max-width: 767px) {
    .tienda-grid-productos {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
        padding: 0 10px !important;
    }
}

/* Móviles (hasta 576px) */
@media (max-width: 576px) {
    .tienda-grid-productos {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
        padding: 0 5px !important;
    }
}

/* ============================================
   9. TARJETAS DE PRODUCTO - MÓVIL (FIX CRÍTICO)
============================================ */
@media (max-width: 768px) {
    .tienda-card-producto {
        border-radius: 15px !important;
        margin-bottom: 0 !important;
        min-height: auto !important; /* FIX: Eliminar altura mínima excesiva */
    }

    .tienda-imagen-contenedor,
    .tienda-contenedor-imagen {
        height: 200px !important; /* FIX: Altura optimizada para móvil */
    }

    .tienda-imagen-producto {
        height: 100% !important;
        object-fit: cover !important;
    }

    .producto-badges {
        top: 10px !important;
        left: 10px !important;
    }

    .badge-nutricion,
    .badge-belleza {
        font-size: 0.7rem !important;
        padding: 4px 10px !important;
    }

    .tienda-info-producto {
        padding: 15px !important;
        min-height: auto !important;
    }

    .tienda-categoria-producto {
        font-size: 0.7rem !important;
        margin-bottom: 6px !important;
    }

    .tienda-nombre-producto {
        font-size: 1rem !important;
        line-height: 1.3 !important;
        margin-bottom: 8px !important;
        min-height: auto !important; /* FIX: Eliminar altura mínima */
    }

    .tienda-descripcion-corta {
        font-size: 0.8rem !important;
        line-height: 1.4 !important;
        margin-bottom: 10px !important;
        min-height: auto !important; /* FIX: Eliminar altura mínima */
        /* Limitar a 2 líneas en móvil */
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .tienda-precio-contenedor {
        margin-bottom: 10px !important;
    }

    .tienda-precio-actual {
        font-size: 1.3rem !important;
    }

    .tienda-stock-info {
        font-size: 0.75rem !important;
        margin-bottom: 12px !important;
    }

    /* Overlay de acciones - Siempre visible en móvil con diseño glassmorphism */
    .tienda-overlay-acciones {
        position: relative !important;
        opacity: 1 !important;
        transform: none !important;
        top: auto !important;
        left: auto !important;
        justify-content: space-around !important;
        margin-top: 10px !important;
        gap: 10px !important;
        background: transparent !important;
    }

    .tienda-boton-accion {
        width: 40px !important;
        height: 40px !important;
        font-size: 15px !important;
        background: rgba(255, 255, 255, 0.95) !important;
        backdrop-filter: blur(10px) !important;
        -webkit-backdrop-filter: blur(10px) !important;
    }

    /* Botón principal más grande y táctil */
    .tienda-acciones-producto {
        margin-top: 12px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        margin-bottom: 0 !important;
        padding: 0 !important;
    }

    .tienda-acciones-producto::before {
        display: none !important; /* Eliminar línea decorativa en móvil */
    }

    .tienda-boton-principal {
        width: 100% !important;
        padding: 12px 20px !important;
        font-size: 0.9rem !important;
        border-radius: 10px !important;
    }

    /* Desactivar hover en móvil */
    .tienda-card-producto:hover {
        transform: none !important;
    }

    .tienda-card-producto:hover .tienda-imagen-producto {
        transform: none !important;
    }
}

@media (max-width: 576px) {
    .tienda-imagen-contenedor,
    .tienda-contenedor-imagen {
        height: 180px !important; /* Más compacto en pantallas muy pequeñas */
    }
}

@media (max-width: 480px) {
    .tienda-imagen-contenedor,
    .tienda-contenedor-imagen {
        height: 200px !important;
    }

    .tienda-info-producto {
        padding: 12px !important;
    }

    .tienda-nombre-producto {
        font-size: 0.95rem !important;
    }

    .tienda-descripcion-corta {
        font-size: 0.75rem !important;
    }

    .tienda-precio-actual {
        font-size: 1.2rem !important;
    }

    .tienda-boton-principal {
        padding: 10px 15px !important;
        font-size: 0.85rem !important;
    }

    .tienda-boton-accion {
        width: 32px !important;
        height: 32px !important;
        font-size: 0.85rem !important;
    }
}

/* ============================================
   10. HERRAMIENTAS INTERACTIVAS - MÓVIL
============================================ */
@media (max-width: 768px) {
    .herramientas-interactivas {
        padding: 30px 0 !important;
    }

    .herramienta-card {
        padding: 20px 15px !important;
        margin-bottom: 15px !important;
    }

    .herramienta-icon {
        font-size: 2rem !important;
        margin-bottom: 12px !important;
    }

    .herramienta-card h4 {
        font-size: 1.1rem !important;
        margin-bottom: 8px !important;
    }

    .herramienta-card p {
        font-size: 0.85rem !important;
        line-height: 1.4 !important;
    }

    .btn-herramienta {
        padding: 8px 20px !important;
        font-size: 0.85rem !important;
    }
}

@media (max-width: 480px) {
    .herramienta-icon {
        font-size: 1.8rem !important;
    }

    .herramienta-card h4 {
        font-size: 1rem !important;
    }

    .herramienta-card p {
        font-size: 0.8rem !important;
    }
}

/* ============================================
   11. SECCIÓN EDUCATIVA - MÓVIL
============================================ */
@media (max-width: 768px) {
    .seccion-educativa {
        padding: 40px 15px !important;
        margin-top: 30px !important;
        background: #FAF8F5 !important;
    }

    .seccion-educativa h3 {
        font-size: 1.4rem !important;
        margin-bottom: 25px !important;
        text-align: center !important;
        font-weight: 700 !important;
        color: var(--dark-navy) !important;
    }

    .seccion-educativa .row {
        margin-left: 0 !important;
        margin-right: 0 !important;
        gap: 20px !important;
    }

    .seccion-educativa .col-md-6 {
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-bottom: 20px !important;
    }

    .consejo-card {
        padding: 25px 20px !important;
        margin-bottom: 0 !important;
        border-radius: 16px !important;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important;
        background: white !important;
        border: 1px solid #f0f0f0 !important;
    }

    .consejo-header {
        font-size: 0.9rem !important;
        margin-bottom: 12px !important;
        font-weight: 600 !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .consejo-header i {
        font-size: 1.1rem !important;
    }

    .consejo-card h5 {
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
        font-weight: 700 !important;
        color: var(--dark-navy) !important;
    }

    .consejo-card p {
        font-size: 0.9rem !important;
        line-height: 1.6 !important;
        color: #555 !important;
        margin-bottom: 15px !important;
    }

    .consejo-link {
        font-size: 0.9rem !important;
        margin-top: 10px !important;
        font-weight: 600 !important;
        display: inline-flex !important;
        align-items: center !important;
        gap: 5px !important;
    }
}

/* Móviles pequeños - Mayor separación */
@media (max-width: 480px) {
    .seccion-educativa {
        padding: 35px 12px !important;
    }

    .seccion-educativa h3 {
        font-size: 1.3rem !important;
        margin-bottom: 22px !important;
    }

    .seccion-educativa .row {
        gap: 18px !important;
    }

    .seccion-educativa .col-md-6 {
        margin-bottom: 18px !important;
    }

    .consejo-card {
        padding: 22px 18px !important;
        border-radius: 14px !important;
    }

    .consejo-card h5 {
        font-size: 1.05rem !important;
    }

    .consejo-card p {
        font-size: 0.88rem !important;
    }

    .consejo-link {
        font-size: 0.88rem !important;
    }
}

/* Pantallas muy pequeñas */
@media (max-width: 360px) {
    .seccion-educativa {
        padding: 30px 10px !important;
    }

    .seccion-educativa h3 {
        font-size: 1.2rem !important;
    }

    .consejo-card {
        padding: 20px 16px !important;
    }
}

/* ============================================
   12. TESTIMONIOS - MÓVIL
============================================ */
@media (max-width: 768px) {
    .seccion-testimonios {
        padding: 30px 15px !important;
    }

    .seccion-testimonios h3 {
        font-size: 1.3rem !important;
        margin-bottom: 20px !important;
    }

    .testimonios-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }

    .testimonio-card {
        padding: 20px 15px !important;
    }

    .testimonio-header {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
    }

    .cliente-avatar {
        width: 45px !important;
        height: 45px !important;
    }

    .cliente-avatar img {
        width: 45px !important;
        height: 45px !important;
    }

    .cliente-datos h5 {
        font-size: 0.95rem !important;
    }

    .estrellas {
        font-size: 0.85rem !important;
    }

    .tiempo-uso {
        font-size: 0.75rem !important;
    }

    .testimonio-card p {
        font-size: 0.85rem !important;
        line-height: 1.5 !important;
    }

    .producto-resenado small {
        font-size: 0.75rem !important;
    }

    .linea-badge {
        font-size: 0.7rem !important;
        padding: 4px 10px !important;
    }

    .btn-ver-mas-testimonios {
        padding: 10px 25px !important;
        font-size: 0.9rem !important;
    }
}

/* ============================================
   13. BOTONES FLOTANTES - MÓVIL
============================================ */

/* Ocultar botón de filtros en escritorio */
@media (min-width: 769px) {
    .btn-filtros-movil {
        display: none !important;
    }
}

/* Mostrar botón de filtros SOLO en móviles */
@media (max-width: 768px) {
    /* Botón de filtros móvil */
    .btn-filtros-movil {
        position: fixed !important;
        bottom: 20px !important;
        left: 20px !important;
        width: 60px !important;
        height: 60px !important;
        border-radius: 50% !important;
        background: var(--primary-gold) !important;
        color: var(--dark-navy) !important;
        border: none !important;
        box-shadow: 0 6px 20px rgba(212, 175, 55, 0.4) !important;
        font-size: 1.2rem !important;
        z-index: 999 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        transition: all 0.3s ease !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    .btn-filtros-movil:active {
        transform: scale(0.95) !important;
    }

    /* Carrito flotante optimizado - ESTILOS MOVIDOS A carrito-badge-mobile.css */
    /* Para evitar conflictos, los estilos del carrito ahora están centralizados */
}

@media (max-width: 480px) {
    .btn-filtros-movil {
        width: 55px !important;
        height: 55px !important;
        font-size: 1.1rem !important;
        bottom: 20px !important;
        left: 15px !important;
    }

    /* Estilos del carrito en carrito-badge-mobile.css */
}

/* ============================================
   14. MODAL DE FILTROS MÓVIL
============================================ */
@media (max-width: 768px) {
    .modal-filtros-movil {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(0, 0, 0, 0.5) !important;
        z-index: 9998 !important;
        display: none !important;
        opacity: 0 !important;
        transition: opacity 0.3s ease !important;
    }

    .modal-filtros-movil.show {
        display: block !important;
        opacity: 1 !important;
    }

    .modal-filtros-contenido {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        max-height: 80vh !important;
        background: white !important;
        border-radius: 20px 20px 0 0 !important;
        padding: 20px !important;
        overflow-y: auto !important;
        transform: translateY(100%) !important;
        transition: transform 0.3s ease !important;
    }

    .modal-filtros-movil.show .modal-filtros-contenido {
        transform: translateY(0) !important;
    }

    .modal-filtros-header {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        margin-bottom: 20px !important;
        padding-bottom: 15px !important;
        border-bottom: 2px solid var(--silver) !important;
    }

    .modal-filtros-header h3 {
        font-size: 1.2rem !important;
        color: var(--dark-navy) !important;
        margin: 0 !important;
    }

    .btn-cerrar-filtros {
        background: none !important;
        border: none !important;
        font-size: 1.5rem !important;
        color: var(--charcoal) !important;
        padding: 0 !important;
        width: 35px !important;
        height: 35px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 50% !important;
        transition: all 0.2s ease !important;
    }

    .btn-cerrar-filtros:active {
        background: var(--silver) !important;
    }

    .btn-aplicar-filtros {
        width: 100% !important;
        padding: 14px !important;
        background: var(--gold-gradient) !important;
        color: var(--dark-navy) !important;
        border: none !important;
        border-radius: 12px !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
        margin-top: 20px !important;
        box-shadow: 0 4px 15px rgba(212, 175, 55, 0.3) !important;
        transition: all 0.3s ease !important;
    }

    .btn-aplicar-filtros:active {
        transform: scale(0.98) !important;
    }

    /* Estilos para los filtros dentro del modal */
    .modal-filtros-movil .tienda-card-filtro {
        margin-bottom: 20px !important;
        border: 1px solid var(--silver) !important;
        border-radius: 12px !important;
    }

    .modal-filtros-movil .tienda-card-encabezado {
        padding: 15px !important;
        background: var(--pearl) !important;
        border-radius: 12px 12px 0 0 !important;
    }

    .modal-filtros-movil .tienda-card-titulo {
        font-size: 1rem !important;
        margin: 0 !important;
    }

    .modal-filtros-movil .tienda-enlace-categoria {
        padding: 12px 15px !important;
        font-size: 0.9rem !important;
    }

    .modal-filtros-movil .tienda-item-categoria.active {
        background: var(--secondary-gold) !important;
    }
}

/* ============================================
   15. MODAL DEL CARRITO - ESTILOS BASE (DESKTOP)
============================================ */
/* Estilos para escritorio (se sobrescriben en móvil) */
.carrito-modal-dialog {
    margin: 0 auto;
    height: 100vh;
    max-height: 100vh;
}

.carrito-modal-content {
    border-radius: 0;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    height: 100%;
    display: flex;
    flex-direction: column;
}

.carrito-modal-body {
    padding: 0;
    overflow-y: auto;
    flex: 1 1 auto;
}

.carrito-header {
    flex-shrink: 0;
}

/* ============================================
   15. MODAL DEL CARRITO - MÓVIL MEJORADO
============================================ */
@media (max-width: 768px) {
    /* Modal dialog - Ocupar 85% de la altura en lugar del 100% */
    #carritoModal .modal-dialog,
    #carritoModal .carrito-modal-dialog,
    .carrito-modal-dialog {
        margin: 0 auto !important;
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
        max-height: 85vh !important;
        position: fixed !important;
        bottom: 0 !important;
        top: auto !important;
        transform: none !important;
        left: 0 !important;
        right: 0 !important;
    }

    #carritoModal .modal-content,
    #carritoModal .carrito-modal-content,
    .carrito-modal-content {
        height: auto !important;
        max-height: 85vh !important;
        border-radius: 20px 20px 0 0 !important;
        display: flex !important;
        flex-direction: column !important;
        box-shadow: 0 -4px 30px rgba(0, 0, 0, 0.3) !important;
    }

    #carritoModal .modal-header,
    #carritoModal .carrito-header,
    .carrito-header {
        flex-shrink: 0 !important;
        padding: 15px 20px !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    #carritoModal .modal-body,
    #carritoModal .carrito-modal-body,
    .carrito-modal-body {
        flex: 1 1 auto !important;
        overflow-y: auto !important;
        padding: 15px !important;
        max-height: calc(85vh - 140px) !important; /* Altura máxima restando header y footer */
    }

    #carritoModal .modal-footer {
        flex-shrink: 0 !important;
        padding: 15px !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .carrito-header {
        padding: 15px !important;
    }

    .carrito-header h5 {
        font-size: 1.1rem !important;
        margin: 0 !important;
    }

    /* Carrito vacío - Más compacto */
    #carrito-vacio {
        padding: 30px 20px !important;
    }

    #carrito-vacio i {
        font-size: 2.5rem !important;
    }

    #carrito-vacio h4 {
        font-size: 1.1rem !important;
        margin-bottom: 10px !important;
    }

    #carrito-vacio p {
        font-size: 0.85rem !important;
        line-height: 1.4 !important;
    }

    /* Items del carrito - Diseño compacto y limpio */
    .carrito-items-container,
    #carrito-lista {
        padding: 0 !important;
        background: transparent !important;
    }

    /* DISEÑO COMPLETAMENTE NUEVO Y OPTIMIZADO PARA MÓVIL */
    .carrito-item {
        display: flex !important;
        flex-direction: column !important;
        padding: 15px !important;
        margin-bottom: 12px !important;
        border-radius: 12px !important;
        background: white !important;
        border: 1px solid #e8e8e8 !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
        gap: 12px !important;
        position: relative !important;
    }

    .carrito-item:hover {
        transform: none !important;
        padding-left: 15px !important;
        border-left: 1px solid #e8e8e8 !important;
    }

    /* FILA SUPERIOR: Imagen + Info + Eliminar */
    .carrito-item > * {
        margin: 0 !important;
    }

    .carrito-item-imagen {
        width: 80px !important;
        height: 80px !important;
        border-radius: 10px !important;
        object-fit: cover !important;
        border: 1px solid #e8e8e8 !important;
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08) !important;
        flex-shrink: 0 !important;
        float: left !important;
        margin-right: 12px !important;
    }

    .carrito-item-info {
        flex: 1 !important;
        padding: 0 !important;
        gap: 6px !important;
        overflow: hidden !important;
    }

    .carrito-item-nombre {
        font-size: 0.95rem !important;
        margin-bottom: 4px !important;
        line-height: 1.3 !important;
        font-weight: 600 !important;
        color: #2C2C2C !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 2 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }

    .carrito-item-detalles {
        font-size: 0.7rem !important;
        padding: 3px 8px !important;
        margin-bottom: 4px !important;
        background: rgba(212, 175, 55, 0.1) !important;
        border-radius: 4px !important;
        width: fit-content !important;
        display: inline-block !important;
    }

    .carrito-item-precio-unitario {
        font-size: 0.8rem !important;
        color: #666 !important;
        margin-top: 4px !important;
    }

    .carrito-item-precio-unitario strong {
        color: #D4AF37 !important;
        font-size: 0.95rem !important;
        font-weight: 700 !important;
    }

    /* Botón eliminar - Esquina superior derecha */
    .carrito-item-acciones {
        position: absolute !important;
        top: 10px !important;
        right: 10px !important;
        margin: 0 !important;
    }

    .btn-eliminar-item {
        width: 32px !important;
        height: 32px !important;
        font-size: 0.85rem !important;
        padding: 0 !important;
        border-radius: 8px !important;
        background: #fff !important;
        border: 1px solid #e8e8e8 !important;
        color: #dc3545 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08) !important;
        transition: all 0.2s ease !important;
    }

    .btn-eliminar-item:active {
        background: #dc3545 !important;
        color: white !important;
        transform: scale(0.95) !important;
    }

    /* FILA INFERIOR: Controles de cantidad + Subtotal */
    .carrito-item-controles {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 12px 0 0 0 !important;
        border-top: 1px solid #f0f0f0 !important;
        gap: 12px !important;
        margin-top: 8px !important;
        clear: both !important;
        min-width: auto !important;
    }

    /* Control de cantidad - Diseño compacto y profesional */
    .cantidad-control {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        background: #f8f8f8 !important;
        border-radius: 10px !important;
        padding: 6px 12px !important;
        box-shadow: none !important;
        border: 1px solid #e8e8e8 !important;
        width: auto !important;
        flex-shrink: 0 !important;
    }

    .cantidad-btn {
        background: white !important;
        border: 1px solid #d4d4d4 !important;
        width: 28px !important;
        height: 28px !important;
        border-radius: 6px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        color: #2C2C2C !important;
        font-weight: 600 !important;
        font-size: 0.85rem !important;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08) !important;
        padding: 0 !important;
    }

    .cantidad-btn:active {
        background: #D4AF37 !important;
        color: white !important;
        border-color: #D4AF37 !important;
        transform: scale(0.95) !important;
    }

    .cantidad-btn:hover {
        transform: none !important;
    }

    .cantidad-valor {
        min-width: 30px !important;
        text-align: center !important;
        font-weight: 700 !important;
        font-size: 1rem !important;
        color: #2C2C2C !important;
        user-select: none !important;
    }

    /* Subtotal - Alineado a la derecha */
    .carrito-item-subtotal {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-end !important;
        text-align: right !important;
        padding: 0 !important;
        margin: 0 !important;
        gap: 2px !important;
    }

    .carrito-item-subtotal-label {
        font-size: 0.7rem !important;
        color: #999 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        font-weight: 500 !important;
    }

    .carrito-item-subtotal-valor {
        font-size: 1.1rem !important;
        font-weight: 700 !important;
        color: #2C2C2C !important;
    }

    /* Resumen y totales - Compacto y moderno */
    .carrito-resumen {
        padding: 16px !important;
        background: #f8f9fa !important;
        border-radius: 12px !important;
        margin: 16px 15px !important;
        border: 1px solid #e8e8e8 !important;
    }

    .resumen-item {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 10px 0 !important;
        font-size: 0.9rem !important;
        color: #555 !important;
    }

    .resumen-item:not(:last-child) {
        border-bottom: 1px solid #e8e8e8 !important;
    }

    .resumen-item span:first-child {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        font-weight: 500 !important;
    }

    .resumen-item span:last-child {
        font-weight: 600 !important;
        color: #2C2C2C !important;
    }

    .resumen-item.total {
        padding: 14px 0 10px 0 !important;
        border-top: 2px solid #D4AF37 !important;
        border-bottom: none !important;
        margin-top: 8px !important;
    }

    .resumen-item.total span {
        font-size: 1.15rem !important;
        font-weight: 700 !important;
        color: #2C2C2C !important;
    }

    .resumen-item.total span:last-child {
        color: #D4AF37 !important;
    }

    /* Iconos en el resumen */
    .resumen-item i {
        font-size: 0.9rem !important;
        opacity: 0.8 !important;
    }

    /* Footer del carrito - Botones de acción */
    .carrito-footer {
        flex-direction: column !important;
        gap: 10px !important;
        padding: 15px !important;
        background: white !important;
        border-top: 1px solid #e8e8e8 !important;
    }

    .carrito-footer .btn,
    .carrito-footer a.btn {
        width: 100% !important;
        padding: 14px 20px !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
        border-radius: 10px !important;
        border: none !important;
        transition: all 0.2s ease !important;
        text-decoration: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
    }

    /* Botón continuar comprando */
    .carrito-footer .btn:not(#btn-proceder-pago):not([href*="checkout"]) {
        background: #f8f9fa !important;
        color: #2C2C2C !important;
        border: 1px solid #e8e8e8 !important;
    }

    .carrito-footer .btn:not(#btn-proceder-pago):active {
        background: #e9ecef !important;
        transform: scale(0.98) !important;
    }

    /* Botón proceder al pago - Destacado */
    #btn-proceder-pago,
    .carrito-footer a[href*="checkout"] {
        background: linear-gradient(135deg, #28a745 0%, #20c997 100%) !important;
        color: white !important;
        box-shadow: 0 4px 12px rgba(40, 167, 69, 0.3) !important;
        font-weight: 700 !important;
    }

    #btn-proceder-pago:active,
    .carrito-footer a[href*="checkout"]:active {
        background: linear-gradient(135deg, #20c997 0%, #28a745 100%) !important;
        transform: scale(0.98) !important;
        box-shadow: 0 2px 8px rgba(40, 167, 69, 0.4) !important;
    }

    /* Estado deshabilitado del botón */
    #btn-proceder-pago:disabled,
    #btn-proceder-pago[disabled] {
        background: #ccc !important;
        color: #666 !important;
        box-shadow: none !important;
        cursor: not-allowed !important;
        opacity: 0.6 !important;
    }

    /* Slider de promociones en el carrito - ELIMINADO
       Los estilos están en carrito-promociones-slider.css
       para evitar conflictos y mantener el diseño de 1.5 productos visible */

    /* Botón proceder al pago */
    #btn-proceder-pago {
        padding: 14px !important;
        font-size: 1rem !important;
        font-weight: 600 !important;
    }

    /* Indicador de scroll */
    #scroll-indicator {
        padding: 8px !important;
        font-size: 0.8rem !important;
    }
}

/* Dispositivos móviles pequeños (menos de 480px) */
@media (max-width: 480px) {
    #carritoModal .modal-dialog,
    .carrito-modal-dialog {
        max-height: 90vh !important;
    }

    #carritoModal .modal-content,
    .carrito-modal-content {
        max-height: 90vh !important;
        border-radius: 16px 16px 0 0 !important;
    }

    #carritoModal .modal-body,
    .carrito-modal-body {
        max-height: calc(90vh - 130px) !important;
        padding: 12px !important;
    }

    .carrito-header h5 {
        font-size: 1rem !important;
    }

    /* Items del carrito más compactos */
    .carrito-item {
        padding: 12px !important;
        margin-bottom: 10px !important;
    }

    .carrito-item-imagen {
        width: 70px !important;
        height: 70px !important;
        margin-right: 10px !important;
    }

    .carrito-item-nombre {
        font-size: 0.9rem !important;
    }

    .carrito-item-detalles {
        font-size: 0.65rem !important;
        padding: 2px 6px !important;
    }

    .carrito-item-precio-unitario {
        font-size: 0.75rem !important;
    }

    .carrito-item-precio-unitario strong {
        font-size: 0.9rem !important;
    }

    .btn-eliminar-item {
        width: 30px !important;
        height: 30px !important;
        font-size: 0.8rem !important;
    }

    /* Controles de cantidad */
    .cantidad-control {
        padding: 5px 10px !important;
        gap: 8px !important;
    }

    .cantidad-btn {
        width: 26px !important;
        height: 26px !important;
        font-size: 0.8rem !important;
    }

    .cantidad-valor {
        min-width: 25px !important;
        font-size: 0.95rem !important;
    }

    .carrito-item-subtotal-label {
        font-size: 0.65rem !important;
    }

    .carrito-item-subtotal-valor {
        font-size: 1rem !important;
    }

    /* Resumen */
    .carrito-resumen {
        margin: 12px !important;
        padding: 14px !important;
    }

    .resumen-item {
        font-size: 0.85rem !important;
        padding: 8px 0 !important;
    }

    .resumen-item.total span {
        font-size: 1.1rem !important;
    }

    /* Footer */
    .carrito-footer {
        padding: 12px !important;
    }

    .carrito-footer .btn {
        padding: 12px 16px !important;
        font-size: 0.95rem !important;
    }
}

/* Pantallas muy pequeñas (menos de 360px) */
@media (max-width: 360px) {
    #carritoModal .modal-dialog,
    .carrito-modal-dialog {
        max-height: 92vh !important;
    }

    #carritoModal .modal-content,
    .carrito-modal-content {
        max-height: 92vh !important;
        border-radius: 14px 14px 0 0 !important;
    }

    #carritoModal .modal-body,
    .carrito-modal-body {
        max-height: calc(92vh - 120px) !important;
        padding: 10px !important;
    }

    .carrito-header h5 {
        font-size: 0.95rem !important;
    }

    /* Items ultra compactos */
    .carrito-item {
        padding: 10px !important;
        margin-bottom: 8px !important;
    }

    .carrito-item-imagen {
        width: 65px !important;
        height: 65px !important;
        margin-right: 8px !important;
    }

    .carrito-item-nombre {
        font-size: 0.85rem !important;
    }

    .carrito-item-detalles {
        font-size: 0.6rem !important;
    }

    .carrito-item-precio-unitario {
        font-size: 0.7rem !important;
    }

    .carrito-item-precio-unitario strong {
        font-size: 0.85rem !important;
    }

    .btn-eliminar-item {
        width: 28px !important;
        height: 28px !important;
        font-size: 0.75rem !important;
    }

    .cantidad-btn {
        width: 24px !important;
        height: 24px !important;
        font-size: 0.75rem !important;
    }

    .cantidad-valor {
        min-width: 22px !important;
        font-size: 0.9rem !important;
    }

    .carrito-item-subtotal-valor {
        font-size: 0.95rem !important;
    }

    .carrito-resumen {
        margin: 10px !important;
        padding: 12px !important;
    }

    .resumen-item {
        font-size: 0.8rem !important;
    }

    .resumen-item.total span {
        font-size: 1rem !important;
    }

    .carrito-footer .btn {
        padding: 11px 14px !important;
        font-size: 0.9rem !important;
    }
}

/* ============================================
   16. FOOTER - MÓVIL
============================================ */
@media (max-width: 768px) {
    #footer {
        padding: 30px 0 80px 0 !important; /* Espacio para botones flotantes */
    }

    #footer .widget {
        margin-bottom: 25px !important;
    }

    #footer h4 {
        font-size: 1rem !important;
        margin-bottom: 12px !important;
    }

    #footer .links li {
        margin-bottom: 8px !important;
    }

    #footer .links a {
        font-size: 0.85rem !important;
    }

    #footer p {
        font-size: 0.85rem !important;
        line-height: 1.5 !important;
    }

    .contact-info p {
        font-size: 0.85rem !important;
        margin-bottom: 8px !important;
    }

    .certificaciones .badge {
        font-size: 0.75rem !important;
        padding: 4px 8px !important;
    }

    #footer-bottom {
        padding: 15px 0 !important;
    }

    .copyright-text {
        font-size: 0.75rem !important;
        text-align: center !important;
        margin-bottom: 15px !important;
    }

    .social-links {
        justify-content: center !important;
        margin-bottom: 15px !important;
    }

    .payment-security h6 {
        font-size: 0.75rem !important;
    }

    .payment-methods img {
        height: 25px !important;
        margin-right: 8px !important;
    }

    .security-badges span {
        font-size: 0.7rem !important;
        padding: 2px 5px !important;
    }
}

/* ============================================
   17. PAGINACIÓN - MÓVIL
============================================ */
@media (max-width: 768px) {
    .tienda-paginacion-premium {
        flex-wrap: wrap !important;
        justify-content: center !important;
        gap: 5px !important;
    }

    .tienda-paginacion-premium .page-item {
        margin: 0 !important;
    }

    .tienda-paginacion-premium .page-link {
        padding: 8px 12px !important;
        font-size: 0.85rem !important;
    }

    #info-paginacion {
        font-size: 0.85rem !important;
        text-align: center !important;
        width: 100% !important;
        margin-bottom: 15px !important;
    }

    .d-flex.justify-content-between {
        flex-direction: column !important;
        gap: 15px !important;
    }
}

/* ============================================
   18. MEJORAS DE ACCESIBILIDAD TÁCTIL
============================================ */
@media (max-width: 768px) {
    /* Aumentar área táctil de enlaces y botones */
    a, button, .btn {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    /* Mejorar espacio entre elementos clicables */
    .tienda-enlace-categoria {
        margin-bottom: 2px !important;
    }
}

/* ============================================
   19. OPTIMIZACIÓN DE RENDIMIENTO MÓVIL
============================================ */
@media (max-width: 768px) {
    /* Reducir animaciones complejas en móvil */
    * {
        animation-duration: 0.3s !important;
        transition-duration: 0.3s !important;
    }

    /* Simplificar sombras para mejor rendimiento */
    .tienda-card-producto {
        box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important;
    }

    .tienda-card-producto:hover {
        box-shadow: 0 6px 20px rgba(0,0,0,0.15) !important;
    }
}

/* ============================================
   20. ORIENTACIÓN LANDSCAPE EN MÓVILES
============================================ */
@media (max-width: 768px) and (orientation: landscape) {
    .hero-section {
        height: 50vh !important;
        min-height: 300px !important;
    }

    .modal-filtros-contenido {
        max-height: 90vh !important;
    }
}

/* ============================================
   21. MEJORAS PARA PANTALLAS MUY PEQUEÑAS
============================================ */
@media (max-width: 360px) {
    .container {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .tienda-grid-productos {
        padding: 0 3px !important;
        gap: 10px !important;
    }

    .tienda-card-producto {
        border-radius: 12px !important;
    }

    .tienda-imagen-contenedor,
    .tienda-contenedor-imagen {
        height: 180px !important;
    }

    .tienda-info-producto {
        padding: 10px !important;
    }

    .tienda-nombre-producto {
        font-size: 0.9rem !important;
    }

    .tienda-precio-actual {
        font-size: 1.1rem !important;
    }

    .tienda-boton-principal {
        padding: 8px 12px !important;
        font-size: 0.8rem !important;
    }
}

/* ============================================
   22. FIXED - Prevenir scroll horizontal
============================================ */
@media (max-width: 768px) {
    body, html {
        overflow-x: hidden !important;
        max-width: 100vw !important;
        position: relative;
    }

    .row {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .container, .container-fluid {
        padding-left: 10px !important;
        padding-right: 10px !important;
        max-width: 100% !important;
    }

    /* Ajustar imágenes que puedan causar overflow */
    img {
        max-width: 100% !important;
        height: auto !important;
    }
}

/* ============================================
   23. MEJORAS DE UX - FEEDBACK VISUAL
============================================ */
@media (max-width: 768px) {
    /* Feedback táctil para botones */
    button:active, .btn:active {
        opacity: 0.8 !important;
        transform: scale(0.98) !important;
    }

    /* Smooth scroll mejorado */
    html {
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch !important;
    }
}

/* ============================================
   FIN DE MEJORAS RESPONSIVE MÓVILES - VERSIÓN CORREGIDA
============================================ */
