/* ============================================================================
   GLOBAL SEARCH DROPDOWN — Responsive con clamp()
   Coherente con ProductSlider card-producto design system
   ============================================================================ */

/* ——— Desktop override: search bar debe ocupar todo el espacio disponible ——— */
.header-row-main .header-nuevo-busqueda-inline {
    max-width: none;
    flex: 1;
    min-width: 0;
}


/* ——— CSS Custom Properties (design tokens) ——— */
.search-dropdown-enhanced {
    --search-sidebar-w: clamp(200px, 16vw, 260px);
    --search-pad: clamp(12px, 1.5vw, 24px);
    --search-gap: clamp(12px, 1.25vw, 20px);
    --search-radius: clamp(8px, 0.8vw, 15px);
    --search-card-radius: clamp(7px, 0.73vw, 14px);
    --search-img-h: clamp(120px, 12vw, 200px);
    --search-font-body: clamp(12px, 0.85vw, 15px);
    --search-font-price: clamp(14px, 1.15vw, 22px);
    --search-font-badge: clamp(9px, 0.52vw, 10px);
    --search-font-small: clamp(10px, 0.7vw, 13px);
    --search-btn-cart: clamp(32px, 2.6vw, 44px);
    --search-btn-icon: clamp(14px, 1.1vw, 18px);
    --negro: #212121;
    --blanco: #FFFFFF;
    --primario: #3CAA36;
    --primario-dark: #2d8b2a;
    --gris-10: #F5F5F5;
    --gris-30: #E0E0E0;
    --gris-50: #9E9E9E;
    --gris-70: #757575;
    --oferta-60: #DE3730;
    --primary-10: #EBF6EB;
}

/* ——— Dropdown container ——— */
.search-dropdown-enhanced {
    display: none;
    position: fixed;
    top: var(--header-height, clamp(90px, 8vw, 153px));
    left: clamp(16px, 6vw, 115px);
    right: clamp(16px, 6vw, 115px);
    background: var(--blanco);
    border: none;
    border-radius: 0 0 var(--search-radius) var(--search-radius);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    clip-path: inset(0px -24px -24px -24px);
    max-height: 75vh;
    overflow: visible;
    z-index: 1100;
    animation: searchSlideDown 0.2s ease-out;
}


.search-dropdown-enhanced.visible {
    display: block;
}

/* Wrapper — overflow visible for filter panel */
.search-dropdown-content-wrapper {
    position: relative;
    overflow: visible;
}

/* Content flex layout */
.search-content {
    display: flex;
    min-height: clamp(200px, 20vw, 300px);
    max-height: calc(80vh - 100px);
    overflow: hidden;
    border-radius: 0px 0px 15px 15px;
}

/* ——— Animations ——— */
@keyframes searchSlideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes searchSpin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* ——— Loading state ——— */
.search-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: clamp(30px, 4vw, 60px) clamp(12px, 1.5vw, 20px);
    gap: clamp(10px, 1vw, 16px);
    background: var(--blanco);
    border-radius: 0 0 var(--search-radius) var(--search-radius);
}

.search-loading-spinner {
    width: clamp(28px, 2.5vw, 40px);
    height: clamp(28px, 2.5vw, 40px);
    border: 3px solid var(--gris-10);
    border-top: 3px solid var(--primario);
    border-radius: 50%;
    animation: searchSpin 1s linear infinite;
}

.search-loading span {
    color: var(--negro);
    font-size: var(--search-font-body);
    font-weight: 500;
    font-family: 'Nunito Sans', sans-serif;
}

/* ============================================================================
   TOOLBAR ROW — Estilo Productos.razor (Categories + Filtres toggles)
   ============================================================================ */

.search-toolbar-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: clamp(6px, 0.6vw, 10px) clamp(12px, 1.2vw, 20px);
    background: var(--blanco);
    border-bottom: 1px solid var(--gris-30);
    flex-shrink: 0;
    box-shadow: inset 0 3px 6px -3px rgba(0, 0, 0, 0.12);
}

.search-toolbar-left {
    display: flex;
    align-items: center;
    gap: clamp(4px, 0.5vw, 8px);
}

.search-dropdown-enhanced .toolbar-action-btn {
    display: inline-flex;
    align-items: center;
    gap: clamp(4px, 0.4vw, 8px);
    padding: clamp(4px, 0.4vw, 8px) clamp(8px, 0.7vw, 12px);
    background: none;
    border: none;
    cursor: pointer;
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-size: clamp(12px, 0.85vw, 14px);
    font-weight: 600;
    color: #212121;
    border-radius: clamp(4px, 0.4vw, 6px);
    transition: background-color 0.2s ease, color 0.2s ease;
}

.search-dropdown-enhanced .toolbar-action-btn:hover {
    background-color: var(--gris-10);
}

.search-dropdown-enhanced .toolbar-action-btn.active {
    color: var(--primario);
}

.search-dropdown-enhanced .toolbar-action-btn.active .toolbar-icon path {
    fill: var(--primario);
    stroke: var(--primario);
}

.search-dropdown-enhanced .toolbar-action-btn .toolbar-icon {
    width: clamp(16px, 1.2vw, 22px);
    height: clamp(16px, 1.2vw, 22px);
    flex-shrink: 0;
}

.search-toolbar-separator {
    width: 1px;
    height: clamp(16px, 1.4vw, 24px);
    background-color: var(--gris-30);
    margin: 0 clamp(4px, 0.5vw, 10px);
}

.search-toolbar-count {
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-size: clamp(11px, 0.75vw, 13px);
    font-weight: 400;
    color: var(--gris-50);
    margin-left: clamp(4px, 0.4vw, 8px);
}

/* ============================================================================
   SIDEBAR — Categories / Filters toggle
   ============================================================================ */

.search-sidebar {
    width: var(--search-sidebar-w);
    background: var(--blanco);
    border-right: none;
    padding: 0;
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
}

.search-sidebar-categories {
    display: flex;
    flex-direction: column;
    gap: 0;
    background: var(--blanco);
}

.search-category-btn {
    background: var(--blanco);
    border: none;
    padding-left: clamp(16px, 1.8vw, 29px);
    padding-right: clamp(8px, 1vw, 12px);
    height: clamp(36px, 3vw, 45px);
    text-align: left;
    font-size: clamp(12px, 0.85vw, 14px);
    color: var(--negro);
    cursor: pointer;
    transition: all 0.2s ease;
    font-weight: 400;
    font-family: 'Nunito Sans', sans-serif;
    letter-spacing: 0.25px;
    border-bottom: 1px solid var(--gris-30);
    position: relative;
}

.search-category-btn:last-child {
    border-bottom: none;
}

.search-category-btn:hover {
    background: var(--gris-10);
}

.search-category-btn.active {
    background: var(--gris-10);
    color: var(--negro);
    font-weight: 700;
}

.search-category-btn.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--primario);
}

/* ——— Inline Filters sidebar ——— */
.search-sidebar-filters {
    display: flex;
    flex-direction: column;
    gap: clamp(2px, 0.2vw, 4px);
    padding: clamp(8px, 0.6vw, 12px);
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.search-filter-section-inline {
    border-top: 1px solid var(--gris-30);
    padding-top: clamp(4px, 0.4vw, 8px);
}

.search-filter-actions {
    display: flex;
    gap: clamp(4px, 0.3vw, 6px);
    padding: clamp(6px, 0.5vw, 10px);
    border-top: 1px solid var(--gris-30);
    margin-top: auto;
    position: sticky;
    bottom: 0;
    background: var(--blanco);
    z-index: 1;
}

.search-filter-actions .search-apply-filters-btn,
.search-filter-actions .search-clear-filters-btn {
    flex: 1;
    padding: clamp(5px, 0.4vw, 8px) clamp(8px, 0.6vw, 12px);
    font-size: clamp(10px, 0.7vw, 12px);
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 600;
    border-radius: clamp(4px, 0.3vw, 6px);
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid var(--primario);
}

.search-filter-actions .search-apply-filters-btn {
    background: var(--primario);
    color: var(--blanco);
}

.search-filter-actions .search-apply-filters-btn:hover {
    background: var(--primary-dark, #2d9e28);
}

.search-filter-actions .search-clear-filters-btn {
    background: var(--blanco);
    color: var(--primario);
}

.search-filter-actions .search-clear-filters-btn:hover {
    background: var(--gris-10);
}

/* ============================================================================
   PRODUCTS CONTAINER + GRID — Coherente con ProductSlider card-producto
   ============================================================================ */

.search-products-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    padding: 0 var(--search-pad) var(--search-pad) var(--search-pad);
    background: var(--gris-10);
}

.search-products-container.full-width {
    width: 100%;
}


/* ——— Product grid ——— */
.search-products-grid {
    --producto-card-padding: clamp(6px, 0.52vw, 10px);
    --font-body: clamp(10px, 0.68vw, 13px);
    --font-price: clamp(11px, 0.78vw, 15px);
    --font-badge: clamp(7px, 0.47vw, 9px);
    --radius-card: clamp(4px, 0.36vw, 7px);
    --btn-cart-size: clamp(28px, 2.08vw, 40px);
    --btn-icon-size: clamp(12px, 0.83vw, 16px);

    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(clamp(130px, 10.4vw, 200px), 1fr));
    gap: var(--search-gap);
    padding-top: var(--search-gap);
    padding-bottom: clamp(4px, 0.5vw, 8px);
}

/* ——— card-producto (idéntico a ProductSlider) ——— */
.search-products-grid .card-producto {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(4px, 0.42vw, 8px);
    padding: clamp(8px, 0.78vw, 15px) clamp(8px, 0.78vw, 15px) clamp(5px, 0.52vw, 10px) clamp(8px, 0.78vw, 15px);
    cursor: pointer;
    flex: 0 0 auto;
    position: relative;
    text-decoration: none;
    color: inherit;
    background: var(--blanco);
}

.search-products-grid .card-producto::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 1px;
    background-color: var(--gris-30);
    transition: background-color 0.35s ease, width 0.35s ease;
}

.search-products-grid .card-producto:first-child::before {
    display: block;
}

.search-products-grid .card-producto:hover::before {
    background-color: var(--primario);
    width: clamp(2px, 0.156vw, 3px);
}

/* first-child no longer needs special padding — symmetric on all cards */

/* hover animation removed — only green left border on hover */

/* ——— frame-wrapper (imagen) ——— */
.search-products-grid .frame-wrapper {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: var(--radius-card);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.search-products-grid .product-image-wrapper {
    width: 100%;
    height: 100%;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: var(--radius-card);
    position: relative;
}

/* Badges */
.search-products-grid .frame-8 {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(3px, 0.31vw, 6px);
    position: absolute;
    top: clamp(5px, 0.52vw, 10px);
    left: clamp(5px, 0.52vw, 10px);
}

.search-products-grid .grupo {
    display: inline-flex;
    align-items: center;
    gap: clamp(3px, 0.35vw, 6px);
    padding: clamp(1px, 0.08vw, 2px) clamp(4px, 0.3vw, 7px);
    position: relative;
    flex: 0 0 auto;
    border-radius: 2px;
    box-shadow: 0px 1px 3px 0px rgba(0, 0, 0, 0.2);
}

.search-products-grid .grupo-oferta {
    background-color: #FF5449;
}

.search-products-grid .grupo-eco {
    background-color: var(--primario);
}

.search-products-grid .badge-text {
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 700;
    font-size: var(--font-badge);
    text-align: center;
    letter-spacing: 0;
    line-height: normal;
    color: var(--blanco);
    white-space: nowrap;
}

.search-products-grid .grupo-stock {
    background-color: var(--primary-10);
    display: inline-flex;
    align-items: center;
    gap: clamp(3px, 0.31vw, 6px);
    padding: clamp(1px, 0.1vw, 2px) clamp(3px, 0.31vw, 6px);
    position: absolute;
    top: clamp(5px, 0.52vw, 10px);
    right: clamp(5px, 0.52vw, 10px);
    border-radius: 2px;
    box-shadow: 0px 1px 3px 0px rgba(0, 0, 0, 0.2);
    justify-content: flex-end;
}

.search-products-grid .stock-dot {
    width: clamp(5px, 0.47vw, 9px);
    height: clamp(5px, 0.47vw, 9px);
    background-color: var(--primario);
    border-radius: 50%;
}

.search-products-grid .stock-text {
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 700;
    font-size: var(--font-badge);
    text-align: center;
    letter-spacing: 0;
    line-height: normal;
    color: #000000;
}

/* ——— pack-info-text (info + botón) ——— */
.search-products-grid .pack-info-text {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: clamp(4px, 0.42vw, 8px);
    flex-shrink: 0;
}

.search-products-grid .info-producto {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    gap: clamp(2px, 0.21vw, 4px);
    flex: 1;
    min-width: 0;
    max-width: calc(100% - var(--btn-cart-size) - clamp(4px, 0.42vw, 8px));
}

.search-products-grid .text-wrapper-5 {
    display: block;
    width: 100%;
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 400;
    color: #141718;
    font-size: var(--font-body);
    letter-spacing: 0px;
    line-height: normal;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-products-grid .text-wrapper-5 span {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* marquee hover animation removed — was causing layout shifts */

/* Precios */
.search-products-grid .price {
    display: inline-flex;
    align-items: flex-end;
    gap: clamp(4px, 0.42vw, 8px);
    position: relative;
    flex: 0 0 auto;
}

.search-products-grid .text-wrapper-6 {
    position: relative;
    width: fit-content;
    margin-top: -1px;
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 700;
    color: var(--oferta-60);
    font-size: var(--font-price);
    letter-spacing: 0;
    line-height: normal;
}

.search-products-grid .text-wrapper-7 {
    position: relative;
    width: fit-content;
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 400;
    color: var(--gris-50);
    font-size: clamp(9px, 0.57vw, 11px);
    letter-spacing: 0;
    line-height: normal;
    text-decoration: line-through;
}

.search-products-grid .text-wrapper-8 {
    position: relative;
    width: fit-content;
    margin-top: -1px;
    font-family: "Nunito Sans", Helvetica, sans-serif;
    font-weight: 700;
    color: #121212;
    font-size: var(--font-price);
    letter-spacing: 0;
    line-height: normal;
}

/* ——— Botón carrito ——— */
.search-products-grid .boton {
    width: var(--btn-cart-size);
    height: var(--btn-cart-size);
    position: relative;
    background-color: var(--blanco);
    border-radius: clamp(4px, 0.31vw, 6px);
    border: 1px solid var(--primario);
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.search-products-grid .boton:hover {
    background-color: var(--primario);
}

.search-products-grid .boton:hover .iconos-2 {
    color: var(--blanco);
}

.search-products-grid .iconos-2 {
    width: var(--btn-icon-size);
    height: var(--btn-icon-size);
    color: var(--primario);
    transition: color 0.3s ease;
    transform: translateY(1px);
}

/* ——— Empty state when filters yield no results ——— */
.search-filters-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: clamp(30px, 4vw, 60px) clamp(20px, 3vw, 40px);
    text-align: center;
    flex: 1;
    min-height: 200px;
    background: var(--gris-10);
    height: 100%;
    box-sizing: border-box;
    border-radius: 0 0 var(--search-radius) var(--search-radius);
}

.search-filters-empty-icon {
    margin-bottom: clamp(12px, 1.3vw, 20px);
    color: #BDBDBD;
}

.search-filters-empty-icon svg {
    width: clamp(36px, 3vw, 48px);
    height: clamp(36px, 3vw, 48px);
}

.search-filters-empty-title {
    font-size: clamp(14px, 1.15vw, 18px);
    font-weight: 700;
    color: var(--negro);
    margin: 0 0 clamp(6px, 0.5vw, 10px) 0;
    font-family: 'Nunito Sans', sans-serif;
}

.search-filters-empty-text {
    font-size: clamp(12px, 0.78vw, 14px);
    color: var(--gris-70);
    line-height: 1.5;
    max-width: 360px;
    margin: 0 0 clamp(16px, 1.5vw, 24px) 0;
    font-family: 'Nunito Sans', sans-serif;
}

.search-filters-empty-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: clamp(8px, 0.6vw, 10px) clamp(16px, 1.2vw, 24px);
    background: transparent;
    color: var(--primario);
    border: 1.5px solid var(--primario);
    border-radius: clamp(4px, 0.36vw, 7px);
    font-size: clamp(12px, 0.78vw, 14px);
    font-weight: 600;
    font-family: 'Nunito Sans', sans-serif;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.search-filters-empty-btn:hover {
    background: var(--primario);
    color: #fff;
    transform: translateY(-1px);
}

.search-filters-empty-btn svg {
    flex-shrink: 0;
}

/* ============================================================================
   FOOTER DEL DROPDOWN
   ============================================================================ */

.search-view-all {
    display: inline-flex;
    align-items: center;
    gap: clamp(4px, 0.4vw, 6px);
    font-size: clamp(11px, 0.78vw, 13px);
    color: var(--primario);
    font-weight: 700;
    text-decoration: none;
    transition: all 0.2s ease;
    font-family: 'Nunito Sans', sans-serif;
    letter-spacing: 0.25px;
    white-space: nowrap;
}

.search-view-all:hover {
    color: var(--primario-dark);
    text-decoration: underline;
}

/* ============================================================================
   ESTADO VACÍO
   ============================================================================ */

.search-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: clamp(30px, 4vw, 60px) clamp(20px, 3vw, 40px);
    text-align: center;
    background: var(--gris-10);
    flex: 1;
    min-height: 250px;
    border-radius: 0 0 var(--search-radius) var(--search-radius);
}

.search-empty-icon {
    margin-bottom: clamp(12px, 1.3vw, 20px);
    color: #BDBDBD;
}

.search-empty-icon svg {
    width: clamp(36px, 3vw, 48px);
    height: clamp(36px, 3vw, 48px);
}

.search-empty-title {
    font-size: clamp(14px, 1.15vw, 18px);
    font-weight: 700;
    color: var(--negro);
    margin: 0 0 clamp(6px, 0.5vw, 10px) 0;
    font-family: 'Nunito Sans', sans-serif;
}

.search-empty-text {
    font-size: clamp(12px, 0.78vw, 14px);
    color: var(--gris-70);
    line-height: 1.5;
    max-width: 400px;
    margin: 0;
    font-family: 'Nunito Sans', sans-serif;
}

/* ============================================================================
   BOTÓN X LIMPIAR BÚSQUEDA
   ============================================================================ */

.header-nuevo-busqueda-clear {
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    width: clamp(20px, 1.5vw, 24px);
    height: clamp(20px, 1.5vw, 24px);
    background: transparent;
    border: none;
    color: #999;
    font-size: clamp(18px, 1.5vw, 24px);
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s ease;
    z-index: 10;
    padding: 0;
}

.header-nuevo-busqueda-clear:hover {
    color: #666;
    background: var(--gris-10);
}

.header-nuevo-busqueda-clear:active {
    transform: translateY(-50%) scale(0.9);
}

/* ============================================================================
   FILTER TOOLBAR (STICKY GREEN BAR)
   ============================================================================ */

.search-filter-toolbar {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    background: var(--primario);
    height: clamp(32px, 2.6vw, 40px);
    display: flex;
    align-items: center;
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    margin: 0 calc(var(--search-pad) * -1) 0 calc(var(--search-pad) * -1);
    padding: 0;
    min-height: clamp(32px, 2.6vw, 40px);
    max-height: clamp(32px, 2.6vw, 40px);
}

.search-filter-toolbar-content {
    width: 100%;
    height: 100%;
    padding: 0 clamp(16px, 1.8vw, 29px);
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.search-filter-toolbar-title {
    display: none;
}

.search-filter-toggle-btn {
    display: flex;
    align-items: center;
    gap: clamp(4px, 0.5vw, 8px);
    background: transparent;
    color: var(--blanco);
    border: none;
    padding: 0;
    height: 100%;
    cursor: pointer;
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 700;
    font-size: clamp(12px, 0.85vw, 14px);
    line-height: 20px;
    letter-spacing: 0.25px;
    transition: opacity 0.2s ease;
}

.search-filter-toggle-btn:hover {
    opacity: 0.85;
}

.search-filter-toggle-btn i {
    font-size: clamp(12px, 0.85vw, 14px);
    color: var(--blanco);
}

.search-filter-badge {
    background: var(--blanco);
    color: var(--primario);
    font-size: clamp(9px, 0.7vw, 11px);
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    min-width: clamp(16px, 1.1vw, 18px);
    height: clamp(16px, 1.1vw, 18px);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* ============================================================================
   PANEL LATERAL DE FILTROS
   ============================================================================ */

.search-filter-overlay-external {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: transparent;
    z-index: 19;
    pointer-events: auto;
}

.search-filter-panel {
    position: absolute;
    top: 0;
    left: 100%;
    height: 100%;
    width: clamp(260px, 22vw, 320px);
    background: var(--blanco);
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.12);
    transition: all 0.3s ease;
    z-index: 20;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 0 0 var(--search-radius) 0;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
}

.search-filter-panel.open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.search-filter-panel-header {
    background: var(--primario);
    color: var(--blanco);
    padding: clamp(3px, 0.3vw, 4px) clamp(14px, 1.3vw, 20px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.search-filter-panel-header h5 {
    margin: 0;
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 700;
    font-size: clamp(13px, 1vw, 16px);
    line-height: 1.3;
    letter-spacing: 0.15px;
}

.search-filter-close-btn {
    background: transparent;
    border: none;
    color: var(--blanco);
    font-size: clamp(22px, 1.8vw, 28px);
    line-height: 1;
    cursor: pointer;
    padding: 0;
    width: clamp(26px, 2vw, 32px);
    height: clamp(26px, 2vw, 32px);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: background 0.2s ease;
}

.search-filter-close-btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

.search-filter-panel-body {
    flex: 1;
    overflow-y: auto;
    padding: clamp(14px, 1.3vw, 20px);
}

/* ——— Filter sections ——— */
.search-filter-section {
    margin-bottom: clamp(14px, 1.3vw, 20px);
    padding-bottom: clamp(14px, 1.3vw, 20px);
    border-bottom: 1px solid var(--gris-30);
}

.search-filter-section:last-of-type {
    border-bottom: none;
}

.search-filter-checkbox-option {
    display: flex;
    align-items: center;
    gap: clamp(6px, 0.5vw, 8px);
    padding: clamp(5px, 0.4vw, 8px) clamp(6px, 0.5vw, 8px);
    cursor: pointer;
    border-radius: clamp(3px, 0.3vw, 5px);
    transition: background 0.2s ease;
    user-select: none;
    margin-bottom: clamp(2px, 0.15vw, 3px);
}

.search-filter-checkbox-option:hover {
    background: var(--gris-10);
}

.search-filter-checkbox-option input[type="checkbox"] {
    width: clamp(15px, 1.1vw, 18px);
    height: clamp(15px, 1.1vw, 18px);
    cursor: pointer;
    flex-shrink: 0;
    accent-color: var(--primario);
}

.search-filter-checkbox-option label {
    cursor: pointer;
    font-size: clamp(12px, 0.85vw, 14px);
    color: var(--negro);
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 500;
    margin: 0;
    flex: 1;
}

/* ——— Collapsible filter header ——— */
.search-filter-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: clamp(5px, 0.4vw, 8px) clamp(6px, 0.5vw, 8px);
    cursor: pointer;
    border-radius: clamp(3px, 0.3vw, 5px);
    transition: background 0.2s ease;
    user-select: none;
}

.search-filter-header:hover {
    background: var(--gris-10);
}

.search-filter-label {
    font-size: clamp(12px, 0.85vw, 14px);
    font-weight: 700;
    color: var(--negro);
    font-family: 'Nunito Sans', sans-serif;
    letter-spacing: 0.15px;
}

.search-filter-current {
    font-size: clamp(10px, 0.7vw, 12px);
    color: var(--gris-70);
    font-weight: 500;
    margin-left: clamp(4px, 0.5vw, 8px);
}

.search-filter-header i {
    font-size: clamp(13px, 1vw, 16px);
    color: var(--gris-70);
    transition: transform 0.2s ease;
}

.search-filter-content {
    margin-top: clamp(8px, 0.8vw, 12px);
    padding: 0 clamp(8px, 0.8vw, 12px);
}

/* ——— Price range slider (matching Productos.razor) ——— */
.search-price-range {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: clamp(4px, 0.4vw, 8px) 0;
}

.search-range-slider-wrapper {
    position: relative;
    width: 100%;
    height: 11px;
}

.search-range-track {
    position: absolute;
    top: 50%;
    left: 5.5px;
    right: 5.5px;
    height: 2px;
    background: #BDBDBD;
    transform: translateY(-50%);
    border-radius: 1px;
    pointer-events: none;
}

.search-range-active {
    position: absolute;
    top: 50%;
    height: 2px;
    background: #3CAA36;
    transform: translateY(-50%);
    border-radius: 1px;
    pointer-events: none;
    z-index: 2;
    margin-left: 5.5px;
    margin-right: 5.5px;
}

.search-range-slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 11px;
    background: transparent;
    pointer-events: none;
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
    padding: 0;
}

.search-range-slider::-webkit-slider-runnable-track {
    width: 100%;
    height: 2px;
    background: transparent;
    border: none;
}

.search-range-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 11px;
    height: 11px;
    background: #3CAA36;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    pointer-events: all;
    box-shadow: none;
    margin-top: -5px;
    transition: transform 0.15s ease;
}

.search-range-slider::-webkit-slider-thumb:hover {
    transform: scale(1.3);
}

.search-range-slider::-webkit-slider-thumb:active {
    transform: scale(1.4);
}

.search-range-slider::-moz-range-track {
    width: 100%;
    height: 2px;
    background: transparent;
    border: none;
}

.search-range-slider::-moz-range-thumb {
    width: 11px;
    height: 11px;
    background: #3CAA36;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    pointer-events: all;
    box-shadow: none;
}

.search-range-slider::-moz-range-thumb:hover {
    transform: scale(1.3);
}

.search-range-slider--min {
    z-index: 3;
}

.search-range-slider--max {
    z-index: 4;
}

.search-range-slider:focus {
    outline: none;
}

.search-range-slider:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 3px rgba(60, 170, 54, 0.15);
}

.search-range-slider:focus::-moz-range-thumb {
    box-shadow: 0 0 0 3px rgba(60, 170, 54, 0.15);
}

.search-price-labels {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.search-price-label {
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 600;
    font-size: clamp(11px, 0.75vw, 14px);
    line-height: 20px;
    letter-spacing: 0.1px;
    color: #000000;
}

/* ——— Action buttons ——— */
.search-apply-filters-btn,
.search-clear-filters-btn {
    width: 100%;
    padding: clamp(10px, 0.9vw, 14px) clamp(14px, 1.3vw, 20px);
    border: none;
    border-radius: clamp(4px, 0.5vw, 8px);
    font-family: 'Nunito Sans', sans-serif;
    font-weight: 700;
    font-size: clamp(12px, 0.85vw, 14px);
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(4px, 0.5vw, 8px);
    margin-top: clamp(8px, 0.8vw, 12px);
}

.search-apply-filters-btn {
    background: var(--primario);
    color: var(--blanco);
}

.search-apply-filters-btn:hover {
    background: var(--primario-dark);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(60, 170, 54, 0.3);
}

.search-clear-filters-btn {
    background: transparent;
    color: var(--gris-70);
    border: 1px solid var(--gris-30);
}

.search-clear-filters-btn:hover {
    background: var(--gris-10);
    color: var(--negro);
    border-color: #D0D0D0;
}

/* ——— Brand/option filter list ——— */
.search-filter-list {
    display: flex;
    flex-direction: column;
    gap: clamp(4px, 0.5vw, 8px);
    max-height: clamp(180px, 16vw, 250px);
    overflow-y: auto;
    padding-right: 4px;
}

.search-filter-list::-webkit-scrollbar {
    width: 6px;
}

.search-filter-list::-webkit-scrollbar-track {
    background: var(--gris-10);
    border-radius: 3px;
}

.search-filter-list::-webkit-scrollbar-thumb {
    background: #D0D0D0;
    border-radius: 3px;
}

.search-filter-list::-webkit-scrollbar-thumb:hover {
    background: #BDBDBD;
}

.search-filter-count {
    color: #999;
    font-size: clamp(10px, 0.7vw, 12px);
    font-weight: 400;
    margin-left: 4px;
}

/* ============================================================================
   RESPONSIVE — TABLET (≤1024px)
   ============================================================================ */

@media (max-width: 1024px) {
    .search-dropdown-enhanced {
        max-height: 85vh;
    }

    .search-content {
        flex-direction: column;
    }

    .search-sidebar {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid var(--gris-30);
        max-height: 140px;
    }

    .search-sidebar-title {
        border-radius: 0;
    }

    .search-sidebar-categories {
        flex-direction: row;
        overflow-x: auto;
        gap: 0;
        padding-bottom: 0;
        scrollbar-width: none;
        -ms-overflow-style: none;
    }

    .search-sidebar-categories::-webkit-scrollbar {
        display: none;
    }

    .search-category-btn {
        white-space: nowrap;
        flex-shrink: 0;
        min-width: 140px;
        border-bottom: none;
        border-right: 1px solid var(--gris-30);
    }

    .search-category-btn:last-child {
        border-right: none;
    }

    .search-category-btn.active::before {
        left: auto;
        right: 0;
        top: auto;
        bottom: 0;
        width: 100%;
        height: 3px;
    }

    .search-products-grid {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }

    .search-filter-panel {
        width: 300px;
    }
}

/* ============================================================================
   RESPONSIVE — MÓVIL (≤768px)
   ============================================================================ */

@media (max-width: 768px) {
    .search-dropdown-enhanced {
        max-height: 90vh;
        border-radius: 0 0 10px 10px;
        top: calc(100% + 16px);
    }

    .search-content {
        flex-direction: column;
    }

    .search-sidebar {
        max-height: 120px;
    }

    .search-category-btn {
        min-width: 120px;
        height: 36px;
        font-size: 12px;
    }

    .search-products-container {
        padding: 0 12px 12px 12px;
    }

    .search-products-grid {
        grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
        gap: 10px;
        padding-top: 10px;
    }

    .search-product-image-vertical {
        height: 110px;
        padding: 6px;
    }

    .search-product-info-vertical {
        padding: 8px 6px 6px;
    }

    .search-product-name-vertical {
        font-size: 12px;
        min-height: 2.4em;
    }

    .search-product-price-vertical {
        font-size: 16px;
    }

    .search-cart-btn-overlay {
        width: 30px;
        height: 30px;
        opacity: 1;
        transform: scale(1) translateY(0);
    }

    .search-cart-btn-overlay svg {
        width: 14px;
        height: 14px;
    }

    .search-filter-toolbar {
        height: 36px;
        min-height: 36px;
        max-height: 36px;
        margin: 0 -12px 0 -12px;
    }

    .search-filter-toolbar-content {
        padding: 0 12px;
    }


    .search-filter-panel {
        width: 100%;
        max-width: 300px;
    }
}

/* ============================================================================
   RESPONSIVE — MÓVIL PEQUEÑO (≤480px)
   ============================================================================ */

@media (max-width: 480px) {
    .search-products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .search-product-image-vertical {
        height: 90px;
    }

    .search-product-name-vertical {
        font-size: 11px;
        -webkit-line-clamp: 1;
        line-clamp: 1;
    }

    .search-product-price-vertical {
        font-size: 14px;
    }
}

/* ============================================================================
   MOBILE SEARCH FULLSCREEN OVERLAY
   ============================================================================ */

/* --- Overlay container --- */
.mobile-search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #FFFFFF;
    z-index: 2500;
    display: flex;
    flex-direction: column;
    transform: translateY(-100%);
    opacity: 0;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.2s ease;
    pointer-events: none;
    overflow: hidden;
}

.mobile-search-overlay.open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

/* --- Mobile search header bar --- */
.mobile-search-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: #FFFFFF;
    border-bottom: 1px solid #E0E0E0;
    flex-shrink: 0;
    min-height: 56px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.06);
    z-index: 2502;
    position: relative;
}

/* --- Back button --- */
.mobile-search-back {
    width: 40px;
    height: 40px;
    min-width: 40px;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background-color 0.2s ease;
    padding: 0;
    flex-shrink: 0;
}

.mobile-search-back:hover {
    background-color: #F5F5F5;
}

.mobile-search-back:active {
    background-color: #E0E0E0;
}

/* ============================================================================
   GlobalSearch component inside mobile overlay — override desktop styles
   ============================================================================ */

/* The inline search bar wrapper: full width, green border, rounded */
.mobile-search-header .header-nuevo-busqueda-inline.mobile-mode {
    flex: 1;
    min-width: 0;
    max-width: none !important;
    border: 1px solid #B1DDAF;
    border-radius: 8px;
    padding: 8px 12px;
    gap: 8px;
    background: #FAFAFA;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    position: static;
}

.mobile-search-header .header-nuevo-busqueda-inline.mobile-mode:focus-within {
    border-color: #3CAA36;
    background: #FFFFFF;
    box-shadow: 0 0 0 3px rgba(60, 170, 54, 0.1);
}

/* Search icon */
.mobile-search-header .header-nuevo-busqueda-icono {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* The line wrapper — remove desktop underline, make it flow */
.mobile-search-header .header-nuevo-busqueda-linea-wrapper {
    border-bottom: none !important;
    padding-bottom: 0 !important;
    flex: 1;
    min-width: 0;
    position: relative;
    display: flex;
    align-items: center;
    min-height: 20px;
}

/* CRITICAL: Hide the ::before pseudo so the input takes the space */
.mobile-search-header .header-nuevo-busqueda-linea-wrapper::before {
    display: none !important;
}

/* CRITICAL: Override desktop position:absolute — make input flow normally */
.mobile-search-header .header-nuevo-busqueda-input.mobile-search-input {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    font-size: 16px !important;
    /* Prevent iOS zoom on focus */
    line-height: 20px;
    padding: 0 !important;
    padding-right: 24px !important;
    height: auto;
    color: #2D2E2E;
    background: transparent;
}

/* Clear (×) button */
.mobile-search-header .header-nuevo-busqueda-clear {
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}

/* ============================================================================
   MOBILE DROPDOWN: position:fixed, fills screen below search header
   ============================================================================ */

/* The dropdown renders inside .header-nuevo-busqueda-linea-wrapper by default.
   In mobile, break it out to fill the entire screen below the header. */
.mobile-search-overlay .search-dropdown-enhanced.mobile-dropdown {
    position: fixed !important;
    top: 57px !important;
    /* height of mobile-search-header (56px + 1px border) */
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    max-height: none !important;
    z-index: 2501;
    border-radius: 0 !important;
    box-shadow: none !important;
    clip-path: none !important;
    overflow-y: auto;
    animation: none !important;
    background: #FFFFFF;
}

.mobile-search-overlay .search-dropdown-enhanced.mobile-dropdown.visible {
    display: flex !important;
    flex-direction: column;
}

/* Content wrapper fills the dropdown */
.mobile-search-overlay .search-dropdown-content-wrapper {
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow: hidden;
    min-height: 0;
}

/* --- Toolbar row --- */
.mobile-search-overlay .search-toolbar-row {
    padding: 8px 16px;
    flex-wrap: wrap;
    gap: 8px;
}

.mobile-search-overlay .search-toolbar-left {
    flex: 1;
    min-width: 0;
    flex-wrap: wrap;
}

.mobile-search-overlay .search-view-all {
    font-size: 13px;
    padding: 4px 0;
}

/* On very small screens, hide button text — icons only */
@media (max-width: 480px) {
    .mobile-search-overlay .toolbar-action-btn span {
        display: none;
    }
}

/* --- Content area (categories sidebar + product grid) --- */
.mobile-search-overlay .search-content {
    flex: 1;
    max-height: none !important;
    overflow-y: auto;
    border-radius: 0;
    flex-direction: column;
}

/* Sidebar → horizontal scroll bar on top */
.mobile-search-overlay .search-sidebar {
    width: 100% !important;
    border-right: none;
    border-bottom: 1px solid #E0E0E0;
    flex-shrink: 0;
    max-height: none;
}

.mobile-search-overlay .search-sidebar-categories {
    flex-direction: row;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: 0;
}

.mobile-search-overlay .search-sidebar-categories::-webkit-scrollbar {
    display: none;
}

.mobile-search-overlay .search-category-btn {
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 120px;
    border-bottom: none;
    border-right: 1px solid #E0E0E0;
    height: 40px;
    font-size: 13px;
    padding-left: 16px;
    padding-right: 12px;
}

.mobile-search-overlay .search-category-btn:last-child {
    border-right: none;
}

.mobile-search-overlay .search-category-btn.active::before {
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    width: 100%;
    height: 3px;
}

/* Filters sidebar — full width */
.mobile-search-overlay .search-sidebar-filters {
    padding: 12px 16px;
}

/* --- Products grid --- */
.mobile-search-overlay .search-products-container {
    padding: 0 12px 12px 12px;
    flex: 1;
    overflow-y: auto;
}

.mobile-search-overlay .search-products-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 10px !important;
    padding-top: 12px;
}

/* On small screens (mobile phones), use 2 columns */
@media (max-width: 480px) {
    .mobile-search-overlay .search-products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
}

/* Constrain card image height in mobile overlay */
.mobile-search-overlay .search-products-grid .frame-wrapper {
    max-height: 130px;
    overflow: hidden;
}

.mobile-search-overlay .search-products-grid .product-image-wrapper {
    height: 100%;
    max-height: 130px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}

.mobile-search-overlay .search-products-grid .card-producto {
    min-width: 0;
    overflow: hidden;
}

.mobile-search-overlay .search-products-grid .pack-info-text {
    padding: 6px 8px;
}

.mobile-search-overlay .search-products-grid .text-wrapper-5 {
    font-size: 11px;
    line-height: 1.3;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-search-overlay .search-products-grid .text-wrapper-6,
.mobile-search-overlay .search-products-grid .text-wrapper-8 {
    font-size: 13px;
}

.mobile-search-overlay .search-products-grid .boton {
    padding: 4px;
}

.mobile-search-overlay .search-products-grid .iconos-2 {
    width: 18px;
    height: 18px;
}

/* On very small screens, constrain even more */
@media (max-width: 480px) {
    .mobile-search-overlay .search-products-grid .frame-wrapper {
        max-height: 100px;
    }

    .mobile-search-overlay .search-products-grid .product-image-wrapper {
        max-height: 100px;
    }

    .mobile-search-overlay .search-products-grid .text-wrapper-5 {
        font-size: 10px;
    }

    .mobile-search-overlay .search-products-grid .text-wrapper-6,
    .mobile-search-overlay .search-products-grid .text-wrapper-8 {
        font-size: 12px;
    }

    .mobile-search-overlay .search-products-grid .pack-info-text {
        padding: 4px 6px;
    }
}

/* --- Loading state --- */
.mobile-search-overlay .search-loading {
    padding: 40px 20px;
    flex: 1;
    border-radius: 0;
}

/* --- Empty state --- */
.mobile-search-overlay .search-empty {
    flex: 1;
    padding: 40px 20px;
}

/* --- Filter panel: slide from right --- */
.mobile-search-overlay .search-filter-panel {
    position: fixed;
    left: auto;
    right: 0;
    top: 0;
    bottom: 0;
    width: 85%;
    max-width: 320px;
    z-index: 2600;
    border-radius: 0;
}