/**
 * tienda.css — MultivitaLab Child Theme
 * Versión: 2.0
 */

/* ============================================================
   1. VARIABLES Y RESET
   ============================================================ */
:root {
    --color-primario:    #1a1a2e;
    --color-secundario:  #16213e;
    --color-acento:      #e94560;
    --color-fondo:       #f7f6f3;
    --color-card:        #ffffff;
    --color-texto:       #1a1a2e;
    --color-texto-muted: #888888;
    --color-borde:       #e8e6e0;
    --font-body:         'DM Sans', sans-serif;
    --font-display:      'Playfair Display', serif;
    --radio:             12px;
    --radio-sm:          8px;
    --gap:               16px;
    --trans:             all 0.2s ease;
    --cat-lateral-font-size: 14px;
}

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500&family=Playfair+Display:wght@600&display=swap');

.mtienda-catalogo *,
.mtienda-catalogo *::before,
.mtienda-catalogo *::after { box-sizing: border-box; }

/* ============================================================
   2. CONTENEDOR PRINCIPAL
   ============================================================ */
.mtienda-catalogo {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2rem 1rem;
    font-family: var(--font-body);
    background: var(--color-fondo);
    color: var(--color-texto);
}

/* ============================================================
   3. LAYOUT LATERAL — Sidebar + Productos lado a lado
   ============================================================ */
.mtienda-catalogo.layout-lateral .mtienda-layout-wrap {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 2rem;
    align-items: start;
}

.mtienda-sidebar-categorias {
    position: sticky;
    top: 1rem;
}

.sidebar-titulo {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-texto);
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-borde);
    position: relative;
}

.sidebar-titulo::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 40px;
    height: 2px;
    background: var(--color-acento);
}

.mtienda-categorias-lista {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mtienda-cat-lista-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-left: 3px solid transparent;
    cursor: pointer;
    transition: var(--trans);
    font-size: var(--cat-lateral-font-size, 14px);
    color: var(--color-texto);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
}

.mtienda-cat-lista-item:hover {
    border-left-color: var(--color-borde);
    color: var(--color-acento);
}

.mtienda-cat-lista-item.activa {
    border-left-color: var(--color-acento);
    color: var(--color-acento);
    font-weight: 600;
}

.cat-lista-imagen {
    width: 32px;
    height: 32px;
    border-radius: var(--radio-sm);
    overflow: hidden;
    flex-shrink: 0;
    background: var(--color-borde);
}

.cat-lista-imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cat-lista-info {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
}

/* Lista mobile — oculta en desktop siempre */
.mtienda-categorias-lista-mobile {
    display: none;
}

/* ============================================================
   4. LAYOUT ARRIBA — Categorías en grilla horizontal
   ============================================================ */
.mtienda-categorias-wrap {
    margin-bottom: 3rem;
}

.mtienda-categorias-wrap h2 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--color-borde);
    position: relative;
}

.mtienda-categorias-wrap h2::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 60px;
    height: 2px;
    background: var(--color-acento);
}

.mtienda-categorias-grid {
    display: grid;
    gap: var(--gap);
    width: 100%;
    min-width: 0;
}

.mtienda-categorias-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.mtienda-categorias-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mtienda-categorias-grid.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.mtienda-categorias-grid.cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }

.mtienda-cat-item {
    background: var(--color-card);
    border: 1px solid var(--color-borde);
    border-radius: var(--radio);
    overflow: hidden;
    cursor: pointer;
    transition: var(--trans);
    position: relative;
    user-select: none;
}

.mtienda-cat-item:hover {
    border-color: var(--color-acento);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

.mtienda-cat-item.activa {
    border-color: var(--color-acento);
    box-shadow: 0 0 0 3px rgba(233,69,96,0.12);
}

.mtienda-cat-item.activa::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-acento);
}

.cat-imagen {
    width: 100%;
    height: 120px;
    overflow: hidden;
    background: #f0ede6;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cat-imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}

.mtienda-cat-item:hover .cat-imagen img { transform: scale(1.05); }

.cat-info { padding: 12px 14px; }

.cat-nombre {
    display: block;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-texto);
    margin-bottom: 3px;
}

.cat-count {
    display: block;
    font-size: 0.75rem;
    color: var(--color-texto-muted);
}

.cat-desc {
    display: block;
    font-size: 0.75rem;
    color: var(--color-texto-muted);
    margin-top: 4px;
    line-height: 1.4;
}

/* ============================================================
   5. SECCIÓN DE PRODUCTOS
   ============================================================ */
.mtienda-productos-wrap { margin-top: 1rem; }

.productos-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.mtienda-buscador {
    padding: 8px 16px;
    border: 1px solid var(--color-borde);
    border-radius: 30px;
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-texto);
    background: var(--color-card);
    outline: none;
    width: 220px;
    transition: var(--trans);
}

.mtienda-buscador:focus {
    border-color: var(--color-acento);
    box-shadow: 0 0 0 3px rgba(233,69,96,0.1);
}

/* Grid de productos — especificidad alta para ganar a WooCommerce */
.mtienda-catalogo .mtienda-grid-productos,
#mtienda-catalogo .mtienda-grid-productos {
    display: grid;
    gap: var(--gap);
    list-style: none;
    padding: 0;
    margin: 0;
    min-height: 200px;
    transition: opacity 0.25s ease;
}

.mtienda-catalogo .mtienda-grid-productos.cols-2,
#mtienda-catalogo .mtienda-grid-productos.cols-2 { grid-template-columns: repeat(2, 1fr) !important; }

.mtienda-catalogo .mtienda-grid-productos.cols-3,
#mtienda-catalogo .mtienda-grid-productos.cols-3 { grid-template-columns: repeat(3, 1fr) !important; }

.mtienda-catalogo .mtienda-grid-productos.cols-4,
#mtienda-catalogo .mtienda-grid-productos.cols-4 { grid-template-columns: repeat(4, 1fr) !important; }

.mtienda-catalogo .mtienda-grid-productos.cols-5,
#mtienda-catalogo .mtienda-grid-productos.cols-5 { grid-template-columns: repeat(5, 1fr) !important; }

.mtienda-grid-productos.cargando {
    opacity: 0.4;
    pointer-events: none;
}

/* ============================================================
   6. TARJETA DE PRODUCTO
   ============================================================ */
.mtienda-producto {
    background: var(--color-card);
    border: 1px solid var(--color-borde);
    border-radius: var(--radio);
    overflow: hidden;
    transition: var(--trans);
    display: flex;
    flex-direction: column;
}

.mtienda-producto:hover {
    border-color: var(--color-acento);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

.producto-imagen {
    display: block;
    position: relative;
    overflow: hidden;
    background: #f7f6f3;
    aspect-ratio: 1 / 1;
    width: 100%;
}

.producto-imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
    display: block;
}

.mtienda-producto:hover .producto-imagen img { transform: scale(1.06); }

.badge-agotado {
    position: absolute;
    top: 10px;
    left: 10px;
    background: rgba(0,0,0,0.65);
    color: #fff;
    font-size: 0.7rem;
    padding: 3px 8px;
    border-radius: 4px;
    font-weight: 500;
}

.badge-oferta {
    position: absolute;
    top: 10px;
    right: 10px;
    background: var(--color-acento);
    color: #fff;
    font-size: 0.7rem;
    padding: 3px 8px;
    border-radius: 4px;
    font-weight: 500;
}

/* Badge "Más vendido" — esquina superior izquierda, dorado */
.badge-mas-vendido {
    position: absolute;
    top: 10px;
    left: 10px;
    background: #b8860b;
    color: #fff;
    font-size: 0.7rem;
    padding: 3px 8px;
    border-radius: 4px;
    font-weight: 600;
    letter-spacing: 0.02em;
}

/* Badge "Stock bajo" — borde inferior de la imagen, naranja */
.badge-stock-bajo {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(210, 90, 20, 0.88);
    color: #fff;
    font-size: 0.68rem;
    padding: 4px 8px;
    font-weight: 600;
    text-align: center;
    letter-spacing: 0.02em;
}

.producto-info {
    padding: 14px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.producto-info h3 {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-texto);
    line-height: 1.4;
    margin: 0;
}

.precio {
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-acento);
    display: block;
}

.precio del {
    color: var(--color-texto-muted);
    font-size: 0.8125rem;
    font-weight: 400;
    margin-right: 4px;
}

.producto-desc {
    font-size: 0.8125rem;
    color: var(--color-texto-muted);
    line-height: 1.5;
    margin: 0;
}

.btn-carrito {
    margin-top: auto;
    padding: 8px;
    background: var(--color-primario);
    color: #fff;
    border: none;
    border-radius: var(--radio-sm);
    font-size: 0.8125rem;
    font-family: var(--font-body);
    font-weight: 500;
    cursor: pointer;
    transition: var(--trans);
    width: 100%;
}

.btn-carrito:hover { background: var(--color-acento); }

.btn-carrito:disabled {
    background: #e0e0e0;
    color: var(--color-texto-muted);
    cursor: default;
}

.sin-resultados {
    text-align: center;
    color: var(--color-texto-muted);
    font-size: 0.9375rem;
    padding: 3rem;
    grid-column: 1 / -1;
}

/* ============================================================
   7. PAGINACIÓN
   ============================================================ */
.mtienda-paginacion {
    display: flex;
    gap: 6px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    padding: 0.5rem 0;
}

.mtienda-paginacion-info {
    font-size: 0.8125rem;
    color: var(--color-texto-muted);
    margin-left: 8px;
}

.mtienda-pagina {
    min-width: 36px;
    height: 36px;
    padding: 0 10px;
    white-space: nowrap;
    border: 1px solid var(--color-borde);
    background: var(--color-card);
    border-radius: var(--radio-sm);
    font-family: var(--font-body);
    font-size: 0.875rem;
    color: var(--color-texto);
    cursor: pointer;
    transition: var(--trans);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.mtienda-pagina:hover:not(.activa):not(.disabled) {
    border-color: var(--color-acento);
    color: var(--color-acento);
}

.mtienda-pagina.activa {
    background: var(--color-primario);
    color: #fff;
    border-color: var(--color-primario);
}

.mtienda-pagina.disabled {
    opacity: 0.4;
    cursor: default;
}

/* ============================================================
   8. ANIMACIONES
   ============================================================ */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

.mtienda-producto { animation: fadeInUp 0.3s ease both; }
.mtienda-cat-item { animation: fadeInUp 0.3s ease both; }

.mtienda-cat-item:nth-child(1) { animation-delay: 0.05s; }
.mtienda-cat-item:nth-child(2) { animation-delay: 0.10s; }
.mtienda-cat-item:nth-child(3) { animation-delay: 0.15s; }
.mtienda-cat-item:nth-child(4) { animation-delay: 0.20s; }
.mtienda-cat-item:nth-child(5) { animation-delay: 0.25s; }

/* ============================================================
   9. RESPONSIVE
   ============================================================ */

/* Tablet (900px) — cols-5 baja a 4 */
@media (max-width: 900px) {
    .mtienda-categorias-grid.cols-5 {
        grid-template-columns: repeat(4, 1fr);
    }
    .mtienda-catalogo .mtienda-grid-productos.cols-5,
    #mtienda-catalogo .mtienda-grid-productos.cols-5 {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* Mobile (600px) */
@media (max-width: 600px) {
    .mtienda-catalogo { padding: 1rem 0.75rem; }

    /* Categorías en grilla: máximo 2 columnas */
    .mtienda-categorias-grid,
    .mtienda-categorias-grid.cols-2,
    .mtienda-categorias-grid.cols-3,
    .mtienda-categorias-grid.cols-4,
    .mtienda-categorias-grid.cols-5 {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Productos: máximo 2 columnas */
    .mtienda-catalogo .mtienda-grid-productos.cols-2,
    .mtienda-catalogo .mtienda-grid-productos.cols-3,
    .mtienda-catalogo .mtienda-grid-productos.cols-4,
    .mtienda-catalogo .mtienda-grid-productos.cols-5,
    #mtienda-catalogo .mtienda-grid-productos.cols-2,
    #mtienda-catalogo .mtienda-grid-productos.cols-3,
    #mtienda-catalogo .mtienda-grid-productos.cols-4,
    #mtienda-catalogo .mtienda-grid-productos.cols-5 {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .productos-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .mtienda-buscador { width: 100%; }
    .cat-imagen { height: 90px; }

    /* Layout lateral colapsa a bloque */
    .mtienda-catalogo.layout-lateral .mtienda-layout-wrap {
        display: block;
    }

    .mtienda-sidebar-categorias {
        position: static;
        margin-bottom: 1.5rem;
    }

    /* Ocultar lista lateral en mobile */
    .mtienda-categorias-lista { display: none; }

    /* Mostrar botones pill en mobile */
    .mtienda-categorias-lista-mobile {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        padding: 0;
        margin: 0 0 1.5rem 0;
        list-style: none;
    }

    .mtienda-cat-btn-mobile {
        padding: 6px 14px;
        border: 1px solid var(--color-borde);
        border-radius: 30px;
        background: var(--color-card);
        font-family: var(--font-body);
        font-size: 0.8125rem;
        color: var(--color-texto);
        cursor: pointer;
        transition: var(--trans);
        white-space: nowrap;
    }

    .mtienda-cat-btn-mobile:hover {
        border-color: var(--color-acento);
        color: var(--color-acento);
    }

    .mtienda-cat-btn-mobile.activa {
        background: var(--color-acento);
        border-color: var(--color-acento);
        color: #fff;
    }
}

/* Mobile pequeño (380px) — 1 columna */
@media (max-width: 380px) {
    .mtienda-catalogo .mtienda-grid-productos,
    #mtienda-catalogo .mtienda-grid-productos {
        grid-template-columns: 1fr !important;
    }
}
/* ============================================================
   10. MODO SIN PANEL DE CATEGORÍAS
   ============================================================ */

/* Cuando mostrar_categorias=0 el shortcode agrega .sin-categorias */
.mtienda-catalogo.sin-categorias .mtienda-categorias-wrap,
.mtienda-catalogo.sin-categorias .mtienda-sidebar-categorias,
.mtienda-catalogo.sin-categorias .mtienda-layout-toggle {
    display: none !important;
}

/* En modo sin-categorias, los productos ocupan todo el ancho */
.mtienda-catalogo.sin-categorias .mtienda-layout-wrap {
    display: block;
}

.mtienda-catalogo.sin-categorias .mtienda-productos-wrap {
    width: 100%;
}

/* ============================================================
   11. PAGINADOR FLOTANTE
   ============================================================ */

/* ============================================================
   11. PAGINADOR FLOTANTE
   ============================================================ */
.mtienda-paginacion.paginador-flotante {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-top: 1.5rem;
    padding: 0;
}

.mtienda-paginacion.paginador-flotante .mtienda-paginacion-info {
    flex: 1;
    text-align: center;
}

.flecha-flotante {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-primario);
    color: #fff;
    border: none;
    font-size: 22px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--trans);
    flex-shrink: 0;
    position: static;
}

.flecha-flotante:hover {
    background: var(--color-acento);
}

.flecha-flotante[disabled] {
    opacity: 0.3;
    cursor: default;
    pointer-events: none;
}


/* Productos a ancho completo cuando no hay panel de categorías */
.mtienda-productos-wrap.ancho-completo {
    width: 100%;
}
/* ============================================================
   12. TOPBAR DE ANUNCIO
   ============================================================ */
.mh-topbar {
    background: var(--mh-topbar-bg, #f72bc1);
    color: var(--mh-topbar-color, #fff);
    font-family: var(--mh-fuente, 'Montserrat', sans-serif);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.3px;
    line-height: 1.4;
    overflow: hidden;
    white-space: nowrap;
    height: 36px;
    display: flex;
    align-items: center;
}

/* Ticker estático (1 solo mensaje) */
.mh-ticker-estatico {
    width: 100%;
    text-align: center;
    justify-content: center;
    display: flex;
}

/* Ticker animado */
.mh-ticker-wrap {
    width: 100%;
    overflow: hidden;
    display: flex;
    align-items: center;
}

.mh-ticker-track {
    display: inline-flex;
    white-space: nowrap;
    will-change: transform;
}

.mh-ticker-item {
    display: inline-block;
    padding: 0 4rem;
}

.mh-ticker-item::before {
    content: '•';
    margin-right: 4rem;
    opacity: 0.6;
}

.mh-ticker-item:first-child::before {
    display: none;
}

@media (prefers-reduced-motion: reduce) {
    .mh-ticker-track {
        will-change: auto;
    }
}

/* ============================================================
   13. HEADER PRINCIPAL
   ============================================================ */
.site-header,
header.site-header {
    background: var(--mh-bg, #0a0a0a) !important;
    border-bottom: 2px solid var(--mh-linea, #f72bc1) !important;
    box-shadow: none !important;
}

/* Logo */
.site-header .site-branding a,
.site-header .site-title a,
.site-header .custom-logo-link {
    color: #fff !important;
    text-decoration: none;
}

/* ============================================================
   14. NAVEGACIÓN PRINCIPAL
   ============================================================ */
.main-navigation,
.storefront-primary-navigation {
    background: transparent !important;
}

/* Items de primer nivel */
.main-navigation ul.menu > li > a,
.main-navigation ul.nav-menu > li > a,
.storefront-primary-navigation ul > li > a {
    font-family:      var(--mh-fuente, 'Montserrat', sans-serif) !important;
    font-size:        var(--mh-size, 13px) !important;
    font-weight:      var(--mh-weight, 600) !important;
    color:            var(--mh-link, #fff) !important;
    text-transform:   var(--mh-mayus, uppercase) !important;
    letter-spacing:   var(--mh-spacing, 0.8px) !important;
    padding:          0 var(--mh-gap, 14px) !important;
    height:           62px !important;
    display:          flex !important;
    align-items:      center !important;
    border-bottom:    2px solid transparent !important;
    transition:       color .2s, border-color .2s !important;
    text-decoration:  none !important;
}

/* Hover y current en nivel 1 */
.main-navigation ul.menu > li > a:hover,
.main-navigation ul.nav-menu > li > a:hover,
.main-navigation ul.menu > li.current-menu-item > a,
.main-navigation ul.menu > li.current-menu-ancestor > a,
.storefront-primary-navigation ul > li > a:hover {
    color:        var(--mh-hover, #f72bc1) !important;
    border-bottom-color: var(--mh-acento, #f72bc1) !important;
}

.main-navigation ul.menu > li.current-menu-item > a,
.main-navigation ul.menu > li.current-menu-ancestor > a {
    color: var(--mh-activo, #f72bc1) !important;
    border-bottom-color: var(--mh-activo, #f72bc1) !important;
}

/* ============================================================
   15. DROPDOWN SIMPLE (submenús estándar de WordPress)
   ============================================================ */
.main-navigation ul.menu ul,
.main-navigation ul.nav-menu ul,
.storefront-primary-navigation ul ul {
    background:    var(--mh-dd-bg, #111) !important;
    border:        1px solid rgba(255,255,255,0.08) !important;
    border-top:    2px solid var(--mh-acento, #f72bc1) !important;
    border-radius: 0 0 10px 10px !important;
    box-shadow:    0 8px 32px rgba(0,0,0,0.4) !important;
    min-width:     200px !important;
    padding:       8px 0 !important;
    top:           100% !important;
}

.main-navigation ul.menu ul li a,
.main-navigation ul.nav-menu ul li a,
.storefront-primary-navigation ul ul li a {
    font-family:   var(--mh-fuente, 'Montserrat', sans-serif) !important;
    font-size:     13px !important;
    font-weight:   400 !important;
    color:         var(--mh-dd-color, #ccc) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    padding:       9px 18px !important;
    height:        auto !important;
    border-bottom: none !important;
    transition:    color .15s, background .15s !important;
    display:       block !important;
}

.main-navigation ul.menu ul li a:hover,
.storefront-primary-navigation ul ul li a:hover {
    color:      var(--mh-dd-hover, #f72bc1) !important;
    background: rgba(255,255,255,0.04) !important;
}

/* ============================================================
   16. MEGAMENÚ
   ============================================================ */
.main-navigation ul.menu > li.menu-item-megamenu {
    position: static;
}

.main-navigation ul.menu > li.menu-item-megamenu > ul.sub-menu {
    position:  absolute !important;
    left:      0 !important;
    right:     0 !important;
    width:     100% !important;
    max-width: 900px !important;
    margin:    0 auto !important;
    display:   none;
    grid-template-columns: 1fr 1fr 240px;
    gap:       24px;
    padding:   28px 28px !important;
    border-radius: 0 0 14px 14px !important;
    top:       100% !important;
}

.main-navigation ul.menu > li.menu-item-megamenu:hover > ul.sub-menu,
.main-navigation ul.menu > li.menu-item-megamenu.focus > ul.sub-menu {
    display: grid !important;
}

/* Ocultar los ítems del sub-menu dentro del megamenú como lista normal */
.main-navigation ul.menu > li.menu-item-megamenu > ul.sub-menu > li {
    list-style: none;
    padding:    0;
}

/* Columnas del megamenú */
.mmenu-col-title {
    font-family:    var(--mh-fuente, 'Montserrat', sans-serif);
    font-size:      10px;
    font-weight:    700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color:          var(--mh-acento, #f72bc1);
    margin-bottom:  12px;
    padding-bottom: 10px;
    border-bottom:  1px solid rgba(255,255,255,0.08);
}

.mmenu-items {
    list-style:     none;
    padding:        0;
    margin:         0;
    display:        flex;
    flex-direction: column;
    gap:            2px;
}

.mmenu-items li a {
    display:         flex !important;
    align-items:     center !important;
    gap:             10px !important;
    padding:         8px 10px !important;
    border-radius:   6px !important;
    color:           var(--mh-dd-color, #ccc) !important;
    font-size:       13px !important;
    font-weight:     400 !important;
    text-transform:  none !important;
    letter-spacing:  0 !important;
    height:          auto !important;
    border-bottom:   none !important;
    transition:      background .15s, color .15s !important;
}

.mmenu-items li a:hover {
    background: rgba(255,255,255,0.06) !important;
    color:      var(--mh-dd-hover, #f72bc1) !important;
}

.mmenu-icon {
    width:         30px;
    height:        30px;
    border-radius: 6px;
    display:       flex;
    align-items:   center;
    justify-content: center;
    font-size:     14px;
    flex-shrink:   0;
    background:    rgba(255,255,255,0.06);
}

.mmenu-count {
    margin-left: auto;
    font-size:   11px;
    color:       rgba(255,255,255,0.25);
}

/* Panel promo dentro del megamenú */
.mmenu-promo {
    background:    rgba(247,43,193,0.08);
    border:        1px solid rgba(247,43,193,0.2);
    border-radius: 10px;
    padding:       20px 16px;
    display:       flex;
    flex-direction: column;
    justify-content: space-between;
}

.mmenu-promo-tag {
    font-size:      10px;
    font-weight:    700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color:          var(--mh-acento, #f72bc1);
    margin-bottom:  6px;
    display:        block;
}

.mmenu-promo-title {
    font-family: var(--mh-fuente, 'Montserrat', sans-serif);
    font-size:   15px;
    font-weight: 700;
    color:       #fff;
    line-height: 1.3;
    margin:      0 0 6px;
}

.mmenu-promo-sub {
    font-size:   12px;
    color:       rgba(255,255,255,0.55);
    line-height: 1.5;
    margin:      0 0 16px;
}

.mmenu-promo-btn {
    display:       inline-block;
    background:    var(--mh-acento, #f72bc1);
    color:         #fff !important;
    font-family:   var(--mh-fuente, 'Montserrat', sans-serif);
    font-size:     12px;
    font-weight:   700;
    padding:       9px 16px;
    border-radius: 6px;
    text-align:    center;
    text-decoration: none !important;
    text-transform:  none !important;
    letter-spacing:  0 !important;
    height:          auto !important;
    border-bottom:   none !important;
    transition:      background .2s !important;
}

.mmenu-promo-btn:hover {
    background: rgba(247,43,193,0.8) !important;
    color: #fff !important;
}

/* ============================================================
   17. BADGES DE MENÚ (Nuevo, Hot, etc.)
   ============================================================ */
.menu-badge {
    display:        inline-block;
    font-size:      9px;
    font-weight:    700;
    letter-spacing: .5px;
    padding:        2px 7px;
    border-radius:  10px;
    text-transform: uppercase;
    vertical-align: middle;
    margin-left:    4px;
    line-height:    1.6;
}

.menu-badge-nuevo  { background: var(--mh-acento, #f72bc1); color: #fff; }
.menu-badge-hot    { background: #ff6b2b; color: #fff; }
.menu-badge-oferta { background: #f5a623; color: #fff; }
.menu-badge-pronto { background: #4a90d9; color: #fff; }

/* ============================================================
   18. BOTÓN DESTACADO EN EL MENÚ
       Agregar clase CSS "menu-item-btn" al ítem en WP Admin
   ============================================================ */
.main-navigation ul.menu > li.menu-item-btn > a,
.storefront-primary-navigation ul > li.menu-item-btn > a {
    background:    var(--mh-btn-bg, #f72bc1) !important;
    color:         var(--mh-btn-color, #fff) !important;
    border-radius: 6px !important;
    margin-left:   8px !important;
    height:        36px !important;
    padding:       0 18px !important;
    border-bottom: none !important;
    align-self:    center !important;
}

.main-navigation ul.menu > li.menu-item-btn > a:hover,
.storefront-primary-navigation ul > li.menu-item-btn > a:hover {
    background:    color-mix(in srgb, var(--mh-btn-bg, #f72bc1) 80%, black) !important;
    border-bottom: none !important;
}

/* ============================================================
   19. MOBILE — hamburguesa y menú colapsado
   ============================================================ */
@media (max-width: 768px) {
    .main-navigation ul.menu > li.menu-item-megamenu > ul.sub-menu {
        display:   none !important;
        position:  static !important;
        width:     100% !important;
        max-width: 100% !important;
        grid-template-columns: 1fr !important;
        padding:   12px !important;
    }

    .main-navigation ul.menu > li.menu-item-megamenu.toggled-on > ul.sub-menu {
        display: grid !important;
    }

    .site-header .menu-toggle {
        color:        var(--mh-link, #fff) !important;
        border-color: rgba(255,255,255,0.2) !important;
        background:   transparent !important;
    }

    .site-header .menu-toggle:hover {
        color:        var(--mh-hover, #f72bc1) !important;
        border-color: var(--mh-acento, #f72bc1) !important;
    }

    .main-navigation ul.menu,
    .main-navigation ul.nav-menu {
        background: var(--mh-bg, #0a0a0a) !important;
        border-top: 1px solid rgba(255,255,255,0.08) !important;
    }

    .main-navigation ul.menu > li > a,
    .main-navigation ul.nav-menu > li > a {
        height:     auto !important;
        padding:    16px 20px !important;
        font-size:  17px !important;
        letter-spacing: 0.02em !important;
        text-transform: none !important;
        border-bottom: 1px solid rgba(255,255,255,0.06) !important;
    }

    .mmenu-promo { display: none; }
}

/* ============================================================
   20. VARIANTES DE ÍTEMS DE MENÚ
   ============================================================ */

/* ── Botón Outline (menu-item-outline) ── */
.main-navigation ul.menu > li.menu-item-outline > a,
.storefront-primary-navigation ul > li.menu-item-outline > a {
    border:        2px solid var(--mh-outline-color, #f72bc1) !important;
    color:         var(--mh-outline-color, #f72bc1) !important;
    border-radius: 6px !important;
    margin-left:   6px !important;
    height:        36px !important;
    padding:       0 16px !important;
    border-bottom: none !important;
    align-self:    center !important;
    background:    transparent !important;
    transition:    background .2s, color .2s !important;
}

.main-navigation ul.menu > li.menu-item-outline > a:hover,
.storefront-primary-navigation ul > li.menu-item-outline > a:hover {
    background: var(--mh-outline-hover-bg, #f72bc1) !important;
    color:      #fff !important;
    border-color: var(--mh-outline-hover-bg, #f72bc1) !important;
    border-bottom: none !important;
}

/* ── Botón Ghost semitransparente (menu-item-ghost) ── */
.main-navigation ul.menu > li.menu-item-ghost > a,
.storefront-primary-navigation ul > li.menu-item-ghost > a {
    background:    var(--mh-ghost-bg, rgba(255,255,255,0.10)) !important;
    color:         var(--mh-ghost-color, #ffffff) !important;
    border-radius: 6px !important;
    margin-left:   6px !important;
    height:        36px !important;
    padding:       0 16px !important;
    border-bottom: none !important;
    align-self:    center !important;
    backdrop-filter: blur(4px);
    transition:    background .2s !important;
}

.main-navigation ul.menu > li.menu-item-ghost > a:hover,
.storefront-primary-navigation ul > li.menu-item-ghost > a:hover {
    background: rgba(255,255,255,0.20) !important;
    border-bottom: none !important;
}

/* ── Ítem acento — texto en color destacado (menu-item-accent) ── */
.main-navigation ul.menu > li.menu-item-accent > a,
.storefront-primary-navigation ul > li.menu-item-accent > a {
    color: var(--mh-accent-color, #f72bc1) !important;
}

.main-navigation ul.menu > li.menu-item-accent > a:hover,
.storefront-primary-navigation ul > li.menu-item-accent > a:hover {
    color: var(--mh-accent-color, #f72bc1) !important;
    opacity: 0.8;
}

/* ── Botón OFERTAS — naranja con efecto de pulso sutil (menu-item-oferta) ──
   Agregar clase CSS "menu-item-oferta" al ítem en WP Admin → Menús
   ═════════════════════════════════════════════════════════════════════════ */
.main-navigation ul.menu > li.menu-item-oferta > a,
.storefront-primary-navigation ul > li.menu-item-oferta > a {
    background:    #e8640a !important;
    color:         #ffffff !important;
    border-radius: 6px !important;
    margin-left:   8px !important;
    height:        36px !important;
    padding:       0 18px !important;
    border-bottom: none !important;
    align-self:    center !important;
    font-weight:   700 !important;
    letter-spacing: 0.04em !important;
    animation:     mOfertaPulso 2.5s ease-in-out infinite;
}

@keyframes mOfertaPulso {
    0%, 100% { box-shadow: 0 0 0 0 rgba(232, 100, 10, 0.5); }
    50%       { box-shadow: 0 0 0 6px rgba(232, 100, 10, 0); }
}

.main-navigation ul.menu > li.menu-item-oferta > a:hover,
.storefront-primary-navigation ul > li.menu-item-oferta > a:hover {
    background:    #c4530a !important;
    border-bottom: none !important;
    animation:     none !important;
}

/* Móvil: sin pulso ni margen extra */
@media (max-width: 768px) {
    .main-navigation ul.menu > li.menu-item-oferta > a,
    .storefront-primary-navigation ul > li.menu-item-oferta > a {
        animation:   none !important;
        margin-left: 0 !important;
        border-radius: 4px !important;
    }
}

/* ============================================================
   21. DROPDOWN Y MEGAMENÚ — variables nuevas aplicadas
   ============================================================ */

/* Tamaño de fuente configurable en dropdowns */
.main-navigation ul.menu ul li a,
.main-navigation ul.nav-menu ul li a,
.storefront-primary-navigation ul ul li a {
    font-size: var(--mh-dd-font-size, 13px) !important;
}

/* Fondo hover configurable en dropdowns */
.main-navigation ul.menu ul li a:hover,
.storefront-primary-navigation ul ul li a:hover {
    background: var(--mh-dd-hover-bg, rgba(255,255,255,0.04)) !important;
    color:      var(--mh-dd-hover, #f72bc1) !important;
}

/* Títulos de columna del megamenú */
.mmenu-col-title {
    color: var(--mh-mega-titulo, #f72bc1) !important;
}

/* Panel promo fondo configurable */
.mmenu-promo {
    background: var(--mh-mega-promo-bg, #1a0a1e) !important;
}

/* Items del megamenú con font size configurable */
.mmenu-items li a {
    font-size: var(--mh-dd-font-size, 13px) !important;
}

/* ============================================================
   22. BADGE "NUEVO" EN ÍTEMS (menu-item-badge-new)
   ============================================================ */
.main-navigation ul.menu > li.menu-item-badge-new > a::after {
    content:        'Nuevo';
    display:        inline-block;
    background:     var(--mh-acento, #f72bc1);
    color:          #fff;
    font-size:      9px;
    font-weight:    700;
    letter-spacing: .5px;
    padding:        2px 6px;
    border-radius:  10px;
    text-transform: uppercase;
    margin-left:    6px;
    vertical-align: middle;
    line-height:    1.6;
}


/* ============================================================
   23. HEADER — LAYOUT Y BUSCADOR
   Estructura real de Storefront:
   header.site-header
     div.col-full
       div.site-branding  (logo)
       div.site-search    (buscador)
     div.storefront-primary-navigation
       div.col-full
         nav.main-navigation
         a.storefront-header-cart
   ============================================================ */

/* Fila del logo */
.site-header > .col-full {
    display:         flex !important;
    flex-direction:  row !important;
    align-items:     center !important;
    justify-content: space-between !important;
    flex-wrap:       nowrap !important;
    padding:         0 2rem !important;
    max-width:       1200px !important;
    margin:          0 auto !important;
    width:           100% !important;
    box-sizing:      border-box !important;
    position:        relative !important;
}

/* Logo */
.site-header .site-branding {
    flex:           0 0 auto !important;
    display:        flex !important;
    align-items:    center !important;
    padding-top:    var(--mlogo-padding, 16px) !important;
    padding-bottom: var(--mlogo-padding, 16px) !important;
    width:          auto !important;
    max-width:      none !important;
}

.site-header .custom-logo,
.site-header .custom-logo-link img {
    max-width:  var(--mlogo-ancho, 160px) !important;
    width:      var(--mlogo-ancho, 160px) !important;
    height:     auto !important;
    display:    block !important;
}

/* Alineación IZQUIERDA (default) */
body.mlogo-alin-izquierda .site-header .site-branding {
    order:        1 !important;
    margin-right: auto !important;
    margin-left:  0 !important;
}
body.mlogo-alin-izquierda .site-header .site-search {
    order: 2 !important;
}

/* Alineación DERECHA */
body.mlogo-alin-derecha .site-header .site-branding {
    order:        2 !important;
    margin-left:  auto !important;
    margin-right: 0 !important;
}
body.mlogo-alin-derecha .site-header .site-search {
    order:        1 !important;
    margin-right: auto !important;
}

/* Alineación CENTRO */
body.mlogo-alin-centro .site-header .site-branding {
    position:  absolute !important;
    left:      50% !important;
    transform: translateX(-50%) !important;
    order:     1 !important;
}
body.mlogo-alin-centro .site-header .site-search {
    order:       2 !important;
    margin-left: auto !important;
}

/* Buscador */
.site-header .site-search {
    flex:        0 0 auto !important;
    display:     flex !important;
    align-items: center !important;
}

.site-header .site-search .woocommerce-product-search {
    display:     flex !important;
    align-items: center !important;
    gap:         0 !important;
    position:    relative !important;
}

/* Campo de búsqueda */
.site-header .site-search .search-field {
    background:    rgba(255,255,255,0.08) !important;
    border:        1px solid rgba(255,255,255,0.2) !important;
    border-radius: 30px 0 0 30px !important;  /* campo izquierdo */
    color:         #fff !important;
    padding:       8px 16px !important;
    font-size:     13px !important;
    width:         200px !important;
    transition:    border .2s, background .2s !important;
    outline:       none !important;
    font-family:   var(--mh-fuente, 'Montserrat', sans-serif) !important;
    height:        38px !important;
    box-sizing:    border-box !important;
}

.site-header .site-search .search-field:focus {
    background:   rgba(255,255,255,0.12) !important;
    border-color: var(--mh-acento, #f72bc1) !important;
}

.site-header .site-search .search-field::placeholder {
    color: rgba(255,255,255,0.4) !important;
}

/* Botón submit: estilos gestionados desde customizer.php con máxima especificidad */

/* Fila del menú */
.storefront-primary-navigation > .col-full {
    display:         flex !important;
    align-items:     center !important;
    justify-content: flex-start !important;
    padding:         0 2rem !important;
    max-width:       1200px !important;
    margin:          0 auto !important;
    width:           100% !important;
    box-sizing:      border-box !important;
}

.storefront-primary-navigation .storefront-header-cart {
    margin-left: auto !important;
    flex-shrink: 0 !important;
}

.storefront-header-cart a,
.storefront-header-cart a:visited {
    color: #fff !important;
}

/* Mobile */
@media (max-width: 768px) {
    .site-header > .col-full {
        flex-wrap: wrap !important;
        padding:   0 1rem !important;
    }
    .site-header .site-branding {
        flex:  1 1 auto !important;
        order: 1 !important;
    }
    .site-header .site-search {
        width:  100% !important;
        order:  3 !important;
        padding: 0.5rem 0 !important;
    }
    .site-header .site-search .search-field {
        width: 100% !important;
    }
    body.mlogo-alin-centro .site-header .site-branding,
    body.mlogo-alin-derecha .site-header .site-branding {
        position:  static !important;
        transform: none !important;
        margin:    0 !important;
    }
    .storefront-primary-navigation > .col-full {
        padding: 0 1rem !important;
    }
}

/* ============================================================
   25. LOGO TEXTO EN MENÚ (menu-logo-texto)
   ============================================================ */
.main-navigation ul.menu > li.menu-logo-texto,
.storefront-primary-navigation ul > li.menu-logo-texto {
    margin-right: 24px !important;
}

.main-navigation ul.menu > li.menu-logo-texto > a,
.storefront-primary-navigation ul > li.menu-logo-texto > a {
    font-family:    'Montserrat', sans-serif !important;
    font-size:      20px !important;
    font-weight:    700 !important;
    color:          #ffffff !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    padding:        0 !important;
    height:         62px !important;
    border-bottom:  none !important;
    text-decoration: none !important;
    display:        flex !important;
    align-items:    center !important;
}

/* Resalta "VITA" en color acento */
.main-navigation ul.menu > li.menu-logo-texto > a span,
.storefront-primary-navigation ul > li.menu-logo-texto > a span {
    color: var(--mh-acento, #f72bc1) !important;
}

/* Hover sin subrayado */
.main-navigation ul.menu > li.menu-logo-texto > a:hover {
    border-bottom: none !important;
    opacity: 0.85 !important;
    color: #ffffff !important;
}

/* ============================================================
   26. BUSCADOR PROPIO (mtienda-search-custom)
   ============================================================ */
.mtienda-search-custom {
    display:     flex;
    align-items: center;
    flex-shrink: 0;
}

.mtienda-search-form {
    display:       flex;
    align-items:   stretch;
    height:        38px;
    border-radius: 30px;
    overflow:      hidden;
    border:        1px solid rgba(255,255,255,0.2);
    background:    rgba(255,255,255,0.08);
}

.mtienda-search-input {
    background:  transparent;
    border:      none;
    outline:     none;
    color:       #fff;
    padding:     0 16px;
    font-size:   13px;
    width:       180px;
    font-family: var(--mh-fuente, 'Montserrat', sans-serif);
    box-shadow:  none;
}

.mtienda-search-input::placeholder {
    color: rgba(255,255,255,0.4);
}

.mtienda-search-input:focus {
    outline: none;
}

.mtienda-search-btn {
    border:          none;
    color:           #fff;
    font-size:       11px;
    font-weight:     700;
    font-family:     var(--mh-fuente, 'Montserrat', sans-serif);
    letter-spacing:  0.5px;
    text-transform:  uppercase;
    padding:         0 16px;
    cursor:          pointer;
    white-space:     nowrap;
    transition:      opacity .2s;
    flex-shrink:     0;
}

.mtienda-search-btn:hover {
    opacity: 0.85;
}

/* ============================================================
   27. FIX DROPDOWN — eliminar gap entre ítem y submenú
   ============================================================ */
.main-navigation ul.menu ul,
.main-navigation ul.nav-menu ul,
.storefront-primary-navigation ul ul {
    margin-top:  0 !important;
    padding-top: 8px !important;
}

/* Pseudo-elemento que cubre el gap entre el ítem y el dropdown */
.main-navigation ul.menu > li.menu-item-has-children > a::after,
.storefront-primary-navigation ul > li.menu-item-has-children > a::after {
    content:  '';
    display:  block;
    position: absolute;
    bottom:   -8px;
    left:     0;
    width:    100%;
    height:   8px;
}

.main-navigation ul.menu > li.menu-item-has-children,
.storefront-primary-navigation ul > li.menu-item-has-children {
    position: relative;
}

/* ============================================================
   28. TAREA 0.3 — TOGGLE SUBÍTEMS EN MÓVIL
   ============================================================ */
@media (max-width: 768px) {

    /* Submenú en móvil — posicionamiento estático */
    .main-navigation ul.menu > li.menu-item-has-children > ul.sub-menu {
        position:      static !important;
        width:         100% !important;
        background:    rgba(255,255,255,0.04) !important;
        border:        none !important;
        border-top:    none !important;
        box-shadow:    none !important;
        padding:       0 !important;
        margin:        0 !important;
        border-radius: 0 !important;
        float:         none !important;
        left:          auto !important;
        top:           auto !important;
        min-width:     0 !important;
    }

    /* Ítems del submenú en móvil */
    .main-navigation ul.menu > li.menu-item-has-children > ul.sub-menu li a {
        padding:     10px 32px !important;
        font-size:   13px !important;
        color:       var(--mh-dd-color, #ccc) !important;
        border-bottom: 1px solid rgba(255,255,255,0.04) !important;
        display:     block !important;
    }

    .main-navigation ul.menu > li.menu-item-has-children > ul.sub-menu li a:hover {
        color:      var(--mh-hover, #f72bc1) !important;
        background: rgba(255,255,255,0.04) !important;
    }

    /* Submenú visible con clase mob-open — supera Storefront */
    .main-navigation ul.menu > li.menu-item-has-children.mob-open > ul.sub-menu {
        display:  block !important;
        overflow: visible !important;
        height:   auto !important;
        opacity:  1 !important;
    }

    /* Flecha indicadora en móvil */
    .mobile-arrow {
        float:      right;
        font-size:  10px;
        opacity:    0.5;
        transition: transform .2s;
        margin-left: 8px;
    }
}

/* ============================================================
   29. TAREA 0.4 — PROPORCIONES DEL HEADER
   ============================================================ */

/* Reducir la altura general del header */
.site-header > .col-full {
    padding-top:    0 !important;
    padding-bottom: 0 !important;
}

/* Logo más compacto */
.site-header .site-branding {
    padding-top:    12px !important;
    padding-bottom: 12px !important;
}

/* Logo: solo controlar el ancho, altura proporcional automática */
.site-header .custom-logo,
.site-header .custom-logo-link img {
    max-width:  var(--mlogo-ancho, 200px) !important;
    width:      var(--mlogo-ancho, 200px) !important;
    height:     auto !important;
    max-height: none !important;
}

/* Menú de navegación — altura de ítems más compacta */
.main-navigation ul.menu > li > a,
.main-navigation ul.nav-menu > li > a,
.storefront-primary-navigation ul > li > a {
    height: 52px !important;
}

/* Buscador alineado verticalmente con el logo */
.mtienda-search-custom {
    align-self: center !important;
}

.mtienda-search-form {
    height: 36px !important;
}

.mtienda-search-input {
    height: 36px !important;
    font-size: 12px !important;
    width: 170px !important;
}

.mtienda-search-btn {
    height:    36px !important;
    font-size: 10px !important;
    padding:   0 12px !important;
}

/* Carrito más compacto */
.storefront-header-cart a {
    font-size: 13px !important;
}

/* Mobile — buscador debajo del logo más compacto */
@media (max-width: 768px) {
    .site-header .site-branding {
        padding-top:    8px !important;
        padding-bottom: 8px !important;
    }

    .mtienda-search-input {
        width: 100% !important;
    }

    .mtienda-search-form {
        width: 100% !important;
    }
}


/* ============================================================
   30. MENÚ MÓVIL — botón dropdown nativo de Storefront
   ============================================================ */
@media (max-width: 768px) {

    /* Ocultar nuestra flecha JS en móvil — Storefront tiene la suya */
    .mobile-arrow {
        display: none !important;
    }

    /* Estilizar el botón nativo de Storefront */
    .main-navigation ul.menu > li.menu-item-has-children > button.dropdown-toggle {
        background:   transparent !important;
        border:       1px solid rgba(255,255,255,0.2) !important;
        border-radius: 4px !important;
        color:        var(--mh-link, #fff) !important;
        width:        32px !important;
        height:       32px !important;
        padding:      0 !important;
        cursor:       pointer !important;
        float:        right !important;
        margin-top:   10px !important;
        margin-right: 8px !important;
    }

    .main-navigation ul.menu > li.menu-item-has-children > button.dropdown-toggle:hover,
    .main-navigation ul.menu > li.menu-item-has-children > button.dropdown-toggle.toggled-on {
        border-color: var(--mh-acento, #f72bc1) !important;
        color:        var(--mh-acento, #f72bc1) !important;
    }

    /* Ocultar texto screen-reader del botón */
    .main-navigation ul.menu > li.menu-item-has-children > button.dropdown-toggle .screen-reader-text {
        position: absolute !important;
        width:    1px !important;
        height:   1px !important;
        overflow: hidden !important;
        clip:     rect(0,0,0,0) !important;
    }
}

/* ============================================================
   31. OCULTAR WIDGET CATEGORÍAS EN PÁGINAS DE ARCHIVO
       Solo visible en página principal de tienda (/tienda/)
   ============================================================ */

/* Ocultar en páginas de categoría, etiqueta y búsqueda de productos */
.tax-product_cat .widget_product_categories,
.tax-product_tag .widget_product_categories,
.tax-product_cat .woocommerce-widget-layered-nav,
.tax-product_tag .woocommerce-widget-layered-nav,
.tax-product_cat .widget_layered_nav,
.tax-product_tag .widget_layered_nav {
    display: none !important;
}

/* También ocultar el bloque de categorías que aparece arriba del catálogo
   en páginas de archivo que no son la tienda principal */
.tax-product_cat .mtienda-categorias-wrap,
.tax-product_tag .mtienda-categorias-wrap {
    display: none !important;
}
/* ============================================================
   32. PIE DE PÁGINA PERSONALIZADO (mfooter)
   ============================================================ */

/* ── Contenedor general ──────────────────────────────────── */
.mfooter-wrapper {
    background-color: var(--mfooter-bg, #ffffff);
    color: var(--mfooter-texto, #555555);
    border-top: 1px solid var(--mfooter-barra, #eeeeee);
    padding: 56px 0 0;
    font-size: 14px;
    line-height: 1.7;
}

/* ── Fila de columnas ────────────────────────────────────── */
.mfooter-columnas {
    display: grid;
    grid-template-columns: 2fr 1.5fr 1.5fr;
    gap: 48px;
    padding-bottom: 48px;
}

/* ── Títulos de columna ──────────────────────────────────── */
.mfooter-col-titulo {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--mfooter-titulos, #111111);
    margin: 0 0 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--mfooter-acento, #f72bc1);
    display: inline-block;
}

/* ── Columna 1: Marca ────────────────────────────────────── */
.mfooter-col--marca {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.mfooter-logo-texto {
    font-size: 22px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--mfooter-titulos, #111111);
    text-decoration: none;
    line-height: 1;
}

.mfooter-logo-texto span {
    color: var(--mfooter-acento, #f72bc1);
}

.mfooter-logo-texto:hover {
    color: var(--mfooter-titulos, #111111);
    text-decoration: none;
}

.mfooter-slogan {
    margin: 0;
    color: var(--mfooter-texto, #555555);
    font-size: 13px;
    max-width: 260px;
}

/* ── Columna 2: Navegación ───────────────────────────────── */
.mfooter-col--nav {
    display: flex;
    flex-direction: column;
}

.mfooter-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mfooter-menu li {
    margin-bottom: 8px;
}

.mfooter-menu li a {
    color: var(--mfooter-texto, #555555);
    text-decoration: none;
    font-size: 14px;
    transition: color 0.2s ease;
}

.mfooter-menu li a:hover {
    color: var(--mfooter-acento, #f72bc1);
}

/* ── Columna 3: Redes sociales ───────────────────────────── */
.mfooter-col--redes {
    display: flex;
    flex-direction: column;
}

.mfooter-red {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--mfooter-texto, #555555);
    text-decoration: none;
    font-size: 14px;
    margin-bottom: 12px;
    transition: color 0.2s ease;
}

.mfooter-red:hover {
    color: var(--mfooter-acento, #f72bc1);
    text-decoration: none;
}

.mfooter-red svg {
    flex-shrink: 0;
    transition: color 0.2s ease;
}

/* Colores propios por red (en hover) */
.mfooter-red--whatsapp:hover  { color: #25d366; }
.mfooter-red--instagram:hover { color: #e1306c; }
.mfooter-red--facebook:hover  { color: #1877f2; }
.mfooter-red--tiktok:hover    { color: #010101; }
.mfooter-red--youtube:hover   { color: #ff0000; }

/* ── Barra inferior: copyright + legales ─────────────────── */
.mfooter-barra-inferior {
    border-top: 1px solid var(--mfooter-barra, #eeeeee);
    padding: 18px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 12px;
    color: var(--mfooter-texto, #555555);
    max-width: 1200px;
    margin: 0 auto;
    box-sizing: border-box;
    width: 100%;
}

.mfooter-copyright {
    color: inherit;
}

.mfooter-legales {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
}

.mfooter-legales a {
    color: var(--mfooter-texto, #555555);
    text-decoration: none;
    font-size: 12px;
    transition: color 0.2s ease;
}

.mfooter-legales a:hover {
    color: var(--mfooter-acento, #f72bc1);
}

/* ── Responsive: tablet ──────────────────────────────────── */
@media (max-width: 900px) {
    .mfooter-columnas {
        grid-template-columns: 1fr 1fr;
        gap: 32px;
    }

    .mfooter-col--marca {
        grid-column: 1 / -1;
    }
}

/* ── Responsive: móvil ───────────────────────────────────── */
@media (max-width: 600px) {
    .mfooter-wrapper {
        padding-top: 40px;
    }

    .mfooter-columnas {
        grid-template-columns: 1fr;
        gap: 28px;
        padding-bottom: 32px;
    }

    .mfooter-col--marca {
        grid-column: auto;
        align-items: center;
        text-align: center;
    }

    .mfooter-slogan {
        max-width: 100%;
        text-align: center;
    }

    .mfooter-barra-inferior {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .mfooter-legales {
        justify-content: center;
    }
}

/* ============================================================
   33. BOTÓN FLOTANTE DE WHATSAPP
   ============================================================ */

.mwa-flotante {
    position: fixed;
    bottom: 28px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}

.mwa-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background-color: #25d366;
    color: #ffffff;
    text-decoration: none;
    transition: transform 0.2s ease, background-color 0.2s ease;
    box-shadow: 0 4px 12px rgba(37, 211, 102, 0.4);
}

.mwa-btn:hover {
    background-color: #1da851;
    transform: scale(1.08);
    text-decoration: none;
    color: #ffffff;
}

.mwa-btn:active {
    transform: scale(0.96);
}

.mwa-btn svg {
    display: block;
    flex-shrink: 0;
}

/* Tooltip */
.mwa-tooltip {
    background-color: #0a0a0a;
    color: #ffffff;
    font-size: 13px;
    line-height: 1.4;
    padding: 7px 12px;
    border-radius: 6px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    position: relative;
}

.mwa-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    right: 20px;
    border: 6px solid transparent;
    border-top-color: #0a0a0a;
}

.mwa-flotante:hover .mwa-tooltip {
    opacity: 1;
    transform: translateY(0);
}

/* Móvil: ajuste para no solapar paginador flotante */
@media (max-width: 768px) {
    .mwa-flotante {
        bottom: 80px;
        right: 16px;
    }

    .mwa-btn {
        width: 52px;
        height: 52px;
    }
}

/* ============================================================
   34. OCULTAR TÍTULO EN PÁGINAS ESPECÍFICAS
       Solución temporal — se parametrizará en el plugin
   ============================================================ */

/* Página HOME (ID 5817) */
.page-id-5817 .elementor-page-title,
.page-id-5817 h1.entry-title {
    display: none !important;
}
.page-id-5817 .entry-header {
    display: none !important;
}

/* Página OFERTAS (ID 6117) */
.page-id-6117 .elementor-page-title,
.page-id-6117 h1.entry-title {
    display: none !important;
}
.page-id-6117 .entry-header {
    display: none !important;
}

/* ============================================================
   36. BUNDLE / OFERTA — Badge, franja ahorro y sección "incluye"
   ============================================================ */

/* Badge "OFERTA" — esquina superior izquierda, color configurable */
.badge-bundle {
    position: absolute;
    top: 10px;
    left: 10px;
    background: var(--mbundle-badge-bg, #6a0dad);
    color: var(--mbundle-badge-color, #ffffff);
    font-size: 0.7rem;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 4px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* Franja inferior "Ahorras $X" — color configurable, diseño prominente */
.badge-bundle-ahorro {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--mbundle-ahorro-bg, #1a7a1a);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 800;
    padding: 7px 8px;
    text-align: center;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    box-shadow: 0 -2px 8px rgba(0,0,0,0.25);
}

.badge-bundle-ahorro .woocommerce-Price-amount,
.badge-bundle-ahorro .woocommerce-Price-currencySymbol {
    color: #fff !important;
    font-weight: 800;
    font-size: 0.85rem;
}

/* Borde sutil en tarjeta bundle para distinguirla */
.mtienda-producto.es-bundle {
    border-color: var(--mbundle-badge-bg, #6a0dad);
}

.mtienda-producto.es-bundle:hover {
    border-color: var(--mbundle-badge-bg, #6a0dad);
    box-shadow: 0 8px 24px rgba(106, 13, 173, 0.15);
}

/* ── Sección "Este bundle incluye" en página de producto ── */
.mtienda-bundle-incluye {
    margin: 2rem 0;
    padding: 1.75rem;
    background: var(--color-card);
    border: 1px solid var(--color-borde);
    border-left: 4px solid var(--mbundle-badge-bg, #6a0dad);
    border-radius: var(--radio);
}

.mtienda-bundle-incluye-titulo {
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-texto);
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--color-borde);
}

.mtienda-bundle-incluye-grid {
    list-style: none;
    margin: 0 0 1rem;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.875rem;
}

.mtienda-bundle-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    background: var(--color-fondo);
    border: 1px solid var(--color-borde);
    border-radius: var(--radio-sm);
    overflow: hidden;
    transition: var(--trans);
}

.mtienda-bundle-item:hover {
    border-color: var(--mbundle-badge-bg, #6a0dad);
    box-shadow: 0 3px 10px rgba(0,0,0,0.07);
}

.mtienda-bundle-item-img {
    display: block;
    aspect-ratio: 1 / 1;
    overflow: hidden;
}

.mtienda-bundle-item-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.mtienda-bundle-item:hover .mtienda-bundle-item-img img {
    transform: scale(1.05);
}

.mtienda-bundle-item-info {
    padding: 0 0.625rem 0.625rem;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.mtienda-bundle-item-nombre {
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--color-texto);
    text-decoration: none;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mtienda-bundle-item-nombre:hover {
    color: var(--mbundle-badge-bg, #6a0dad);
}

.mtienda-bundle-item-precio {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-acento);
}

.mtienda-bundle-ahorro-total {
    margin: 0;
    padding: 0.75rem 1rem;
    background: rgba(26, 122, 26, 0.08);
    border-radius: var(--radio-sm);
    font-size: 0.875rem;
    color: #1a5c1a;
    border-left: 3px solid var(--mbundle-ahorro-bg, #1a7a1a);
}

.mtienda-bundle-ahorro-total .woocommerce-Price-amount {
    color: #1a5c1a;
}

/* Responsive: tablet → 2 columnas */
@media (max-width: 900px) {
    .mtienda-bundle-incluye-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Responsive: móvil → 2 columnas */
@media (max-width: 600px) {
    .mtienda-bundle-incluye {
        padding: 1.25rem;
    }
    .mtienda-bundle-incluye-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.625rem;
    }
}

.mtienda-crosssells {
    margin: 2.5rem 0;
    padding: 2rem;
    background: var(--color-card);
    border: 1px solid var(--color-borde);
    border-radius: var(--radio);
}

.mtienda-crosssells-titulo {
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-texto);
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--color-borde);
    position: relative;
}

.mtienda-crosssells-titulo::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 40px;
    height: 2px;
    background: var(--color-acento);
}

.mtienda-crosssells-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.mtienda-crosssell-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    background: var(--color-fondo);
    border: 1px solid var(--color-borde);
    border-radius: var(--radio-sm);
    overflow: hidden;
    transition: var(--trans);
}

.mtienda-crosssell-item:hover {
    border-color: var(--color-acento);
    box-shadow: 0 4px 12px rgba(0,0,0,0.07);
}

.crosssell-imagen-wrap {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: #f7f6f3;
}

.crosssell-imagen-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.35s ease;
}

.mtienda-crosssell-item:hover .crosssell-imagen-wrap img {
    transform: scale(1.05);
}

.mtienda-crosssell-info {
    padding: 0 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.crosssell-nombre {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-texto);
    text-decoration: none;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.crosssell-nombre:hover {
    color: var(--color-acento);
}

.crosssell-precio {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-acento);
}

.crosssell-btn {
    margin: 0 0.75rem 0.75rem;
    padding: 7px 10px;
    background: var(--color-primario);
    color: #fff;
    border: none;
    border-radius: var(--radio-sm);
    font-size: 0.75rem;
    font-family: var(--font-body);
    font-weight: 500;
    cursor: pointer;
    transition: var(--trans);
    width: calc(100% - 1.5rem);
    text-align: center;
}

.crosssell-btn:hover { background: var(--color-acento); }

.crosssell-btn:disabled {
    background: #e0e0e0;
    color: var(--color-texto-muted);
    cursor: default;
}

/* Responsive: tablet → 2 columnas */
@media (max-width: 900px) {
    .mtienda-crosssells-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Responsive: móvil → 2 columnas compactas */
@media (max-width: 600px) {
    .mtienda-crosssells {
        padding: 1.25rem;
    }
    .mtienda-crosssells-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }
}

/* ============================================================
   37. PÁGINA DE OFERTAS — [mtienda_ofertas]
   ============================================================ */

.mtienda-ofertas-wrap {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 2.5rem;
    font-family: var(--font-body);
}

.mtienda-ofertas-vacio {
    text-align: center;
    padding: 3rem;
    color: var(--color-texto-muted);
    font-family: var(--font-body);
}

/* ── Bloque de un bundle ── */
.mtienda-oferta-bloque {
    background: var(--color-card);
    border: 2px solid var(--mbundle-badge-bg, #6a0dad);
    border-radius: var(--radio);
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(106, 13, 173, 0.1);
}

/* ── Encabezado del bundle ── */
.mtienda-oferta-header {
    background: linear-gradient(135deg,
        var(--mbundle-badge-bg, #6a0dad) 0%,
        color-mix(in srgb, var(--mbundle-badge-bg, #6a0dad) 70%, black) 100%);
    color: #fff;
    padding: 1.25rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.mtienda-oferta-header-info {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.mtienda-oferta-badge {
    display: inline-block;
    background: rgba(255,255,255,0.2);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 4px;
    border: 1px solid rgba(255,255,255,0.4);
    width: fit-content;
}

.mtienda-oferta-nombre {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    margin: 0;
    line-height: 1.3;
}

.mtienda-oferta-precios {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
}

.mtienda-oferta-precio-pack {
    font-size: 0.9rem;
    color: rgba(255,255,255,0.9);
}

.mtienda-oferta-precio-pack strong {
    color: #fff;
    font-size: 1.1rem;
}

.mtienda-oferta-precio-pack .woocommerce-Price-amount {
    color: #fff;
    font-size: 1.1rem;
    font-weight: 700;
}

.mtienda-oferta-ahorro {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--mbundle-ahorro-bg, #1a7a1a);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
}

.mtienda-oferta-ahorro strong,
.mtienda-oferta-ahorro .woocommerce-Price-amount {
    color: #fff;
    font-weight: 800;
}

.mtienda-oferta-btn-pack {
    background: #fff !important;
    color: var(--mbundle-badge-bg, #6a0dad) !important;
    border: none;
    border-radius: var(--radio-sm);
    padding: 10px 20px;
    font-size: 0.9rem;
    font-family: var(--font-body);
    font-weight: 700;
    cursor: pointer;
    transition: var(--trans);
    white-space: nowrap;
    flex-shrink: 0;
}

.mtienda-oferta-btn-pack:hover {
    background: rgba(255,255,255,0.88) !important;
    transform: translateY(-1px);
}

.mtienda-oferta-btn-pack:disabled {
    background: rgba(255,255,255,0.4) !important;
    color: rgba(255,255,255,0.7) !important;
    cursor: default;
    transform: none;
}

/* ── Grilla de productos hijo ── */
.mtienda-oferta-grid {
    list-style: none;
    margin: 0;
    padding: 1.25rem;
    display: grid;
    gap: 1rem;
    background: var(--color-fondo);
}

.mtienda-oferta-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.mtienda-oferta-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.mtienda-oferta-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.mtienda-oferta-grid.cols-5 { grid-template-columns: repeat(5, 1fr); }

/* ── Responsive: tablet ── */
@media (max-width: 900px) {
    .mtienda-oferta-grid.cols-4,
    .mtienda-oferta-grid.cols-5 {
        grid-template-columns: repeat(3, 1fr);
    }
    .mtienda-oferta-header {
        flex-direction: column;
        align-items: flex-start;
    }
    .mtienda-oferta-btn-pack {
        width: 100%;
        text-align: center;
    }
}

/* ── Responsive: móvil ── */
@media (max-width: 600px) {
    .mtienda-ofertas-wrap {
        padding: 0.5rem;
        gap: 1.5rem;
    }
    .mtienda-oferta-header {
        padding: 1rem;
    }
    .mtienda-oferta-nombre {
        font-size: 1.05rem;
    }
    .mtienda-oferta-grid,
    .mtienda-oferta-grid.cols-2,
    .mtienda-oferta-grid.cols-3,
    .mtienda-oferta-grid.cols-4,
    .mtienda-oferta-grid.cols-5 {
        grid-template-columns: repeat(2, 1fr);
        padding: 0.75rem;
        gap: 0.75rem;
    }
}