/**
 * Product Archive AJAX Styles
 * Zapisz jako: /assets/css/product-archive.css
 * Wersja: 1.0.3 - Nowy design filtru ceny
 */

/* ===================================
   LOADER
   =================================== */
.agro-loader {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    z-index: 9999;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.agro-loader__spinner {
    width: 50px;
    height: 50px;
    margin: 0 auto 20px;
    border: 4px solid #f3f3f3;
    border-top: 4px solid #9CD279;
    border-radius: 50%;
    animation: agro-spin 1s linear infinite;
}

@keyframes agro-spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.agro-loader p {
    font-size: 16px;
    color: #666;
    margin: 0;
}

/* Products container podczas ładowania */
.products.columns-15 {
    transition: opacity 0.3s ease;
    position: relative;
}

/* Loading state - tylko w sekcji produktów */
._products.agro-loading select,
._products.agro-loading input,
._products.agro-loading button {
    opacity: 0.6;
    pointer-events: none;
    cursor: not-allowed;
}

/* ===================================
   CUSTOM PRICE FILTER
   =================================== */
.custom-price-filter {
    padding: 15px 0;
}

/* Range Slider Container */
.price-range-slider {
    margin: 20px 0 10px 0;
    padding: 0 10px;
}

/* noUiSlider - Base (cienki beżowy pasek) */
.price-range-slider .noUi-target {
    background: #9CD279;
    border: none;
    box-shadow: none;
    border-radius: 3px;
}

/* Połączony pasek między kółkami - UKRYTY */
.price-range-slider .noUi-connect {
    background: #9CD279;
    display: none;
}

/* Handlery - Zielone kółka */
.price-range-slider .noUi-handle {
    width: 12px!important;
    height: 12px!important;
    border: none;
    border-radius: 50%;
    background: #9CD279;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(0,0,0,0.15);
    top: -6px!important;
    right: -12px!important;
}
.noUi-horizontal{
    height: 3px!important;
}
.price-range-slider .noUi-handle:hover {
    box-shadow: 0 3px 8px rgba(156, 210, 121, 0.4);
}

.price-range-slider .noUi-handle:before,
.price-range-slider .noUi-handle:after {
    display: none;
}

/* UKRYJ tooltipsy (czarne etykiety) */
.price-range-slider .noUi-tooltip {
    display: none !important;
}

/* Wysokość slidera */
.price-range-slider .noUi-horizontal {
    height: 6px;
}

/* Wyświetlacz zakresu POD sliderem */
.price-range-display {
    text-align: center;
    font-size: 14px;
    color: #666;
    margin-top: 12px;
    font-weight: 500;
    letter-spacing: 0.3px;
}

/* UKRYJ inputy Min/Max */
.price-inputs {
    display: none !important;
}

.price-input-group {
    display: none !important;
}

.price-input {
    display: none !important;
}

.price-separator {
    display: none !important;
}

/* Buttons */
#apply-price-filter {
    width: 100%;
    margin-top: 20px;
    padding: 12px 24px;
    background: #9CD279;
    color: white;
    border: none;
    border-radius: 6px;
    font-size: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
}

#apply-price-filter:hover {
    background: #8bc067;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(156, 210, 121, 0.3);
}

#reset-price-filter {
    width: 100%;
    margin-top: 10px;
    padding: 10px 24px;
    background: #f5f5f5;
    color: #666;
    border: 1px solid #ddd;
    border-radius: 6px;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
}

#reset-price-filter:hover {
    background: #e8e8e8;
    border-color: #ccc;
}

.w-full {
    width: 100%;
}

/* ===================================
   PAGINACJA
   =================================== */
.facetwp-facet-paginacja {
    margin-top: 40px;
}

.facetwp-pager {
    display: flex;
    gap: 8px;
    justify-content: center;
    align-items: center;
}

.facetwp-page {
    padding: 8px 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #ddd;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    color: #333;
    min-width: 36px;
    text-align: center;
    background: #fff;
}

.facetwp-page:hover:not(.active):not(.dots) {
    background: #9CD279;
    color: white;
    border-color: #9CD279;
}

.facetwp-page.active {
    background: #9CD279;
    color: white;
    border-color: #9CD279;
    cursor: default;
}

.facetwp-page.dots {
    border: none;
    cursor: default;
    pointer-events: none;
}

.facetwp-page svg {
    display: block;
    width: 8px;
    height: auto;
}

/* ===================================
   SORTOWANIE & PER PAGE
   =================================== */
.products-head {
    margin-bottom: 30px;
}

.woocommerce-ordering select {
    padding: 8px 12px;
    /*border: 1px solid #ddd;*/
    /*border-radius: 4px;*/
    font-size: 14px;
    cursor: pointer;
    background: #fff;
    border-radius: 30px;
}

/* Produktów na stronę - radio buttons */
.woocommerce-products-per-page {
    display: flex;
    align-items: center;
    gap: 10px;
}

.woocommerce-products-per-page label {
    cursor: pointer;
}

.woocommerce-products-per-page input[type="radio"] {
    display: none;
}

.woocommerce-products-per-page .count {
    padding: 6px 12px;
    /*border: 1px solid #ddd;*/
    /*border-radius: 4px;*/
    border-bottom: 1px solid rgb(0 0 0)!important;
    transition: all 0.3s;
    display: inline-block;
}
.woocommerce-products-per-page .count:hover {
    padding: 6px 12px;
    /*border: 1px solid #ddd;*/
    /*border-radius: 4px;*/
    border-bottom: 1px solid #9CD279!important;
    transition: all 0.3s;
    display: inline-block;
}
.woocommerce-products-per-page input[type="radio"]:checked + .count {
    background: #9CD279;
    color: white;
    border-color: #9CD279;
    border: none!important;
}

/* ===================================
   RESPONSIVE
   =================================== */
@media (max-width: 768px) {
    .facetwp-pager {
        flex-wrap: wrap;
        gap: 6px;
    }

    .facetwp-page {
        padding: 6px 10px;
        font-size: 14px;
        min-width: 32px;
    }

    .agro-loader {
        padding: 40px 15px;
    }

    .agro-loader__spinner {
        width: 40px;
        height: 40px;
    }

    .price-range-slider {
        padding: 0 5px;
    }

    .price-range-display {
        font-size: 13px;
    }

    .products-head {
        flex-direction: column;
        gap: 15px;
        align-items: flex-start !important;
    }
}

/* ===================================
   UTILITIES
   =================================== */
.mt-small { margin-top: 15px; }
.mt-xs { margin-top: 10px; }
.mt-xxxs { margin-top: 5px; }

/* Load More Button */
.load-more-wrap {
    margin-top: 40px;
}

.load-more-btn {
    min-width: 200px;
    position: relative;
}

.load-more-btn.loading {
    pointer-events: none;
    opacity: 0.7;
}

.load-more-info {
    color: #666;
    font-size: 14px;
}

._listing_products.loading .products-container {
    pointer-events: none;
}