/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~           SEARCH BAR (LAYOUT, MOBILE & AJAX FIX)            ~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/

/* 1. CONTENITORE PRINCIPALE
 * Impostato per centrare la barra e gestire i risultati AJAX */
.bspc-category-search {
    margin: 0 auto 40px auto;
    max-width: 600px;
    position: relative; /* Necessario per ancorare i risultati */
    padding: 0 15px;
    box-sizing: border-box;
    width: 100%;
    display: block;
    
    /* FIX per AJAX + header sticky:
     * z-index abbastanza alto da stare sopra le card, ma sotto l'header.
     * In questo modo la barra (e gli eventuali risultati) non "copre" il menu.
     */
    z-index: 50;
    overflow: visible; /* Permette al menu a tendina di uscire dal box senza essere tagliato */
}

/* 2. CAMPO DI INPUT
 * Stile estetico (Apple style) e funzionale */
.bspc-category-search input,
.bspc-category-search .bpc-category-search {
    width: 100%;
    height: 54px;
    padding: 12px 50px 12px 24px; /* Spazio a destra per l'icona */
    
    /* Tipografia */
    font-family: inherit;
    font-size: 1.05rem;
    font-weight: 400;
    color: var(--bspc-text-primary, #333);
    
    /* Bordo e Sfondo */
    border: 1px solid var(--bspc-border-light, #e1e1e1);
    border-radius: 12px;
    background-color: var(--bspc-bg-white, #fff);
    
    /* Icona Lente (SVG) */
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="22" height="22" viewBox="0 0 24 24" fill="none" stroke="%2386868b" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line></svg>');
    background-repeat: no-repeat;
    background-position: right 20px center;
    background-size: 20px;
    
    /* Effetti e Reset */
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    /* Limita le proprietà animate per migliorare le performance */
    transition: border-color 0.25s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.25s cubic-bezier(0.25, 0.8, 0.25, 1), background-color 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
    -webkit-appearance: none;
    appearance: none;
    box-sizing: border-box !important; /* Impedisce che il padding allarghi l'elemento */
}

/* 3. STATI INTERATTIVI (Focus, Hover, Placeholder) */

/* Placeholder (Testo "Cerca...") */
.bspc-category-search input::placeholder,
.bspc-category-search .bpc-category-search::placeholder {
    color: #9ca3af;
    opacity: 1;
}

/* Hover (Mouse sopra) */
.bspc-category-search input:hover,
.bspc-category-search .bpc-category-search:hover {
    border-color: #b0b0b5;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* Focus (Quando si scrive) */
.bspc-category-search input:focus,
.bspc-category-search .bpc-category-search:focus {
    border-color: var(--bspc-blue-primary, #0071e3);
    outline: none;
    background-color: #fff;
    box-shadow: 0 0 0 4px rgba(0, 113, 227, 0.15), 0 8px 24px rgba(0,0,0,0.12);
}

/* 4. GESTIONE CARICAMENTO AJAX (Loading)
 * Se il plugin aggiunge una classe 'loading', nascondiamo la nostra lente
 * per far vedere lo spinner del plugin */
.bspc-category-search input.loading,
.bspc-category-search .bpc-category-search.loading,
.ui-autocomplete-loading {
    background-image: none !important;
}

/* Forza i risultati della ricerca a stare sopra tutto */
.autocomplete-suggestions, 
.ui-autocomplete,
.wcas-search-wrapp {
    /* Evita che i suggerimenti si sovrappongano all'header sticky.
     * Rimangono comunque sopra le card e sopra la griglia.
     */
    z-index: calc(var(--header-z-index, 1000) - 1) !important;
    text-align: left;
}

/* 5. OTTIMIZZAZIONE MOBILE
 * Risolve il problema del disallineamento e dello zoom */
@media (max-width: 767px) {
    .bspc-category-search {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 0 30px 0 !important;
        padding: 0 20px !important; /* Allineato con le card sottostanti */
        left: auto !important;
        right: auto !important;
    }

    .bspc-category-search input,
    .bspc-category-search .bpc-category-search {
        font-size: 16px !important; /* Previene zoom su iPhone */
        height: 50px;
        width: 100% !important;
        padding-right: 45px; /* Spazio icona leggermente ridotto */
        background-position: right 15px center;
    }
}