/* ============================================
   ALGOLIA INSTANTSEARCH - MASCHERPA.IT
   ============================================ */

/* ---- Griglia prodotti ---- */
#algolia-hits .ais-Hits-list {
    counter-reset: none !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 30px !important;
    display: grid !important;
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 15px !important;
}
@media (max-width: 1200px) {
    #algolia-hits .ais-Hits-list { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (max-width: 999px) {
    #algolia-hits .ais-Hits-list { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
    #algolia-hits .ais-Hits-list { grid-template-columns: repeat(1, 1fr) !important; }
}

/* ---- Hit item ---- */
#algolia-hits .ais-Hits-item {
    padding: 0 !important;
    width: auto !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: column !important;
}
#algolia-hits .ais-Hits-item::before,
#algolia-hits .ais-Hits-item::marker {
    display: none !important;
    content: none !important;
}

/* ---- Card prodotto ---- */
.algolia-hit-card {
    flex: 1 !important;
    border: 1.5px solid rgba(0,0,0,0.07) !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    background: white !important;
    box-shadow: none !important;
    transition: box-shadow 0.2s, border-color 0.2s !important;
    height: 100% !important;
}
.algolia-hit-card:hover {
    box-shadow: 0 4px 20px rgba(52,82,255,0.08) !important;
    border-color: rgba(52,82,255,0.15) !important;
}
.algolia-hit-card a {
    text-decoration: none !important;
    color: inherit !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
}

/* ---- Immagine ---- */
.algolia-hit-img {
    height: 180px !important;
    overflow: hidden !important;
    background: white !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
#algolia-hits .algolia-hit-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    display: block !important;
}

/* ---- Meta ---- */
.algolia-hit-meta {
    padding: 12px 15px 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}
.algolia-hit-marchio {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    color: #3452ff !important;
    letter-spacing: 0.5px !important;
}
.algolia-hit-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    margin: 0 !important;
    padding: 0 !important;
    color: black !important;
    text-transform: uppercase !important;
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
}

/* ---- Bullet points card ---- */
.algolia-hit-bullets {
    margin: 8px 0 0 !important;
    padding: 0 !important;
    max-height: 80px !important;
    overflow: hidden !important;
    -webkit-mask-image: linear-gradient(to bottom, black 50%, transparent 100%) !important;
    mask-image: linear-gradient(to bottom, black 50%, transparent 100%) !important;
}
.algolia-hit-bullet {
    display: flex !important;
    align-items: flex-start !important;
    gap: 6px !important;
    margin: 0 0 2px !important;
    padding: 0 !important;
    list-style: none !important;
}
.algolia-hit-bullet-dot {
    color: #bbb !important;
    font-size: 10px !important;
    line-height: 1.7 !important;
    flex-shrink: 0 !important;
}
.algolia-hit-bullet-text {
    font-size: 12px !important;
    color: #555 !important;
    line-height: 1.6 !important;
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
}

/* ---- Highlight ---- */
.ais-Highlight-highlighted {
    background: rgba(52,82,255,0.12) !important;
    border-radius: 2px !important;
    font-style: normal !important;
    color: #3452ff !important;
}

/* ---- Nessun risultato ---- */
.algolia-no-results {
    grid-column: 1 / -1 !important;
    text-align: center !important;
    padding: 60px 20px !important;
    color: #666 !important;
}

/* ---- Sidebar ---- */
#algolia-filters-container {
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
}
.algolia-filter-section {
    background: rgba(255,255,255,0.4) !important;
    border-radius: 10px !important;
    padding: 15px !important;
    margin-bottom: 9px !important;
}
.algolia-filter-title {
    color: black !important;
    font-weight: 800 !important;
    font-size: 13px !important;
    margin: 0 0 10px !important;
}

/* ---- Sezioni filtro vuote: nascondi ---- */
.algolia-filter-section:has(.ais-MenuSelect--noRefinementRoot) {
    display: none !important;
}

/* ---- Searchbox ---- */
.algolia-search-input {
    width: 100% !important;
    border: 1px solid rgba(0,0,0,0.1) !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    font-family: inherit !important;
    background: white !important;
    outline: none !important;
    box-shadow: none !important;
}
.algolia-search-input:focus { border-color: #3452ff !important; }
.ais-SearchBox-submit { display: none !important; }
.ais-SearchBox-reset {
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #999 !important;
}

/* ---- Dropdown ---- */
.algolia-select {
    width: 100% !important;
    border: 1px solid rgba(0,0,0,0.1) !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    font-family: inherit !important;
    background: white !important;
    color: #333 !important;
    outline: none !important;
    cursor: pointer !important;
}
.algolia-select:focus { border-color: #3452ff !important; }

/* ---- Brand list griglia ---- */
.algolia-brand-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 6px !important;
    width: 100% !important;
}
.algolia-brand-item {
    margin: 0 !important;
    border: none !important;
    padding: 0 !important;
    list-style: none !important;
    list-style-type: none !important;
}
.algolia-brand-item::before,
.algolia-brand-item::marker {
    display: none !important;
    content: none !important;
}

/* ---- Brand label base ---- */
.algolia-brand-label {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    border: 1.5px solid rgba(0,0,0,0.1) !important;
    border-radius: 8px !important;
    background: white !important;
    transition: border-color 0.15s, box-shadow 0.15s !important;
    width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    padding: 0 !important;
    min-height: 50px !important;
    height: 50px !important;
}
.algolia-brand-label:hover {
    border-color: rgba(52,82,255,0.3) !important;
}
.algolia-brand-label.is-refined {
    border-color: #3452ff !important;
    box-shadow: 0 0 0 2px rgba(52,82,255,0.15) !important;
}

/* ---- Brand con logo ---- */
#sidebar .algolia-filter-section .algolia-brand-label.has-logo {
    padding: 0 !important;
    width: 100% !important;
    height: 30px !important;
    min-height: 30px !important;
    max-height: 30px !important;
}
#sidebar .algolia-brand-label.has-logo .algolia-brand-logo,
.algolia-filter-section .algolia-brand-label.has-logo .algolia-brand-logo {
    width: 100% !important;
    height: 30px !important;
    max-width: 100% !important;
    max-height: 30px !important;
    object-fit: contain !important;
    display: block !important;
    margin: 0 !important;
}

/* ---- Brand senza logo ---- */
.algolia-brand-label.no-logo {
    min-height: 30px !important;
    height: 30px !important;
}
.algolia-brand-text {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #333 !important;
    text-align: center !important;
    white-space: normal !important;
    word-break: break-word !important;
    line-height: 1.3 !important;
}

/* ---- Clear ---- */
.algolia-clear-btn {
    background: none !important;
    border: 1px solid rgba(52,82,255,0.3) !important;
    color: #3452ff !important;
    border-radius: 20px !important;
    padding: 6px 14px !important;
    font-size: 12px !important;
    cursor: pointer !important;
    margin-bottom: 10px !important;
    font-family: inherit !important;
}
.algolia-clear-btn:hover { background: rgba(52,82,255,0.08) !important; }
.algolia-clear-btn[disabled] { opacity: 0.3 !important; cursor: default !important; }

/* ---- Stats ---- */
#algolia-stats-top {
    font-size: 12px !important;
    color: #888 !important;
    margin: 20px 0 35px !important;
    display: block !important;
}

/* ---- Paginazione ---- */
.algolia-pagination-list {
    display: flex !important;
    justify-content: center !important;
    gap: 6px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 20px 0 !important;
    flex-wrap: wrap !important;
}
.algolia-pagination-link {
    display: block !important;
    padding: 6px 12px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    color: #3452ff !important;
    border: 1px solid rgba(52,82,255,0.2) !important;
    text-decoration: none !important;
}
.algolia-pagination-selected .algolia-pagination-link {
    background: #3452ff !important;
    color: white !important;
    border-color: #3452ff !important;
}
.algolia-pagination-disabled .algolia-pagination-link {
    opacity: 0.3 !important;
    cursor: default !important;
}

/* ============================================
   ALGOLIA AUTOCOMPLETE - RICERCA GLOBALE
   ============================================ */

.algolia-autocomplete .aa-dropdown-menu {
    background: white !important;
    border: none !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 40px rgba(0,0,0,0.12) !important;
    margin-top: 8px !important;
    padding: 12px 0 !important;
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
    overflow: hidden !important;
    min-width: 500px !important;
}
.algolia-autocomplete .aa-dropdown-menu .autocomplete-header {
    padding: 8px 20px 4px !important;
}
.algolia-autocomplete .aa-dropdown-menu .autocomplete-header-title {
    font-size: 10px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: #aaa !important;
}
.algolia-autocomplete .aa-dropdown-menu .aa-suggestion {
    padding: 0 !important;
    cursor: pointer !important;
}
.algolia-autocomplete .aa-dropdown-menu .aa-suggestion .suggestion-link {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 8px 20px !important;
    text-decoration: none !important;
    transition: background 0.1s !important;
}
.algolia-autocomplete .aa-dropdown-menu .aa-suggestion:hover .suggestion-link,
.algolia-autocomplete .aa-dropdown-menu .aa-suggestion.aa-cursor .suggestion-link {
    background: #f5f6ff !important;
}
.algolia-autocomplete .suggestion-post-thumbnail {
    width: 44px !important;
    height: 44px !important;
    object-fit: contain !important;
    border-radius: 8px !important;
    background: #f5f5f5 !important;
    flex-shrink: 0 !important;
    padding: 4px !important;
}
.algolia-autocomplete .suggestion-post-attributes {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}
.algolia-autocomplete .suggestion-post-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #111 !important;
    line-height: 1.3 !important;
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
}
.algolia-autocomplete .suggestion-post-content {
    font-size: 11px !important;
    color: #999 !important;
    line-height: 1.4 !important;
}
.algolia-autocomplete em {
    font-style: normal !important;
    color: #3452ff !important;
    font-weight: 700 !important;
    background: rgba(52,82,255,0.08) !important;
    border-radius: 3px !important;
    padding: 0 2px !important;
}
.algolia-autocomplete .autocomplete-footer {
    border-top: 1px solid #f0f0f0 !important;
    padding: 8px 20px 4px !important;
    margin-top: 8px !important;
}
.algolia-autocomplete .autocomplete-footer-branding {
    display: flex !important;
    justify-content: flex-end !important;
}
.algolia-autocomplete .autocomplete-empty {
    padding: 20px !important;
    text-align: center !important;
    color: #999 !important;
    font-size: 13px !important;
}

/* ---- Nasconde refinementList usati come base per multi-select ---- */
.algolia-reflist-hidden .algolia-reflist-list {
    display: none !important;
}

/* ---- Checkbox filtri multi-value ---- */
.algolia-checkbox-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    max-height: 200px !important;
    overflow-y: auto !important;
}
.algolia-checkbox-item {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}
.algolia-checkbox-item::before,
.algolia-checkbox-item::marker {
    display: none !important;
    content: none !important;
}
.algolia-checkbox-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 5px 0 !important;
    cursor: pointer !important;
    font-size: 12px !important;
    color: #444 !important;
    font-family: 'Plus Jakarta Sans', 'Open Sans', sans-serif !important;
}
.algolia-checkbox-input {
    accent-color: #3452ff !important;
    width: 14px !important;
    height: 14px !important;
    flex-shrink: 0 !important;
}
.algolia-checkbox-count {
    font-size: 10px !important;
    color: #aaa !important;
    margin-left: auto !important;
}
.algolia-checkbox-count::before { content: '(' !important; }
.algolia-checkbox-count::after { content: ')' !important; }
.algolia-checkbox-selected .algolia-checkbox-label {
    color: #3452ff !important;
    font-weight: 700 !important;
}

/* ---- Nasconde refinementList nascosti ---- */
.algolia-reflist-hidden .algolia-reflist-list {
    display: none !important;
}