/* ============================================================
   LISTING CAROUSEL — shared pattern for /servicios, /blog, /remates
   and home sections (auction + blog showcase).
   On desktop (≥992px): grid layout from each page's CSS is preserved.
   On tablet/mobile: grid becomes a horizontal scroll-snap carousel
   (drag/swipe). Arrow controls below let the user step prev/next.

   This file lives in public/ (NOT in the Vite bundle) so changes
   apply immediately on upload, no build step required.
   Critical rules use !important to defeat any cascade conflicts
   coming from page-specific stylesheets.
   ============================================================ */

.listing-carousel-controls {
    display: none !important;
}

@media (max-width: 991.98px) {
    .listing-carousel-track {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        gap: 16px !important;
        grid-template-columns: none !important;
        grid-template-rows: none !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-snap-type: x mandatory !important;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 12px;
        scroll-padding-inline: 0;
        max-width: 100% !important;
        width: 100% !important;
    }

    .listing-carousel-track > * {
        flex: 0 0 calc(50% - 8px) !important;
        scroll-snap-align: start !important;
        min-width: 0;
        max-width: calc(50% - 8px) !important;
    }

    .listing-carousel-track::-webkit-scrollbar {
        height: 4px;
    }

    .listing-carousel-track::-webkit-scrollbar-thumb {
        background: rgba(0, 23, 115, 0.2);
        border-radius: 2px;
    }

    .listing-carousel-track::-webkit-scrollbar-track {
        background: transparent;
    }

    .listing-carousel-controls {
        display: flex !important;
        justify-content: center !important;
        gap: 14px !important;
        margin-top: 24px !important;
        padding: 0 !important;
        background: transparent !important;
        border: none !important;
    }

    .listing-carousel-btn,
    button.listing-carousel-btn,
    .listing-carousel-controls .listing-carousel-btn {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;
        max-width: 44px !important;
        max-height: 44px !important;
        border-radius: 50% !important;
        background: #ffffff !important;
        border: 1px solid #001773 !important;
        color: #001773 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        transition: background .2s ease, color .2s ease, transform .15s ease !important;
        padding: 0 !important;
        margin: 0 !important;
        line-height: 1 !important;
        box-shadow: 0 2px 6px rgba(0, 23, 115, 0.08);
        appearance: none !important;
        -webkit-appearance: none !important;
        font-family: inherit;
    }

    .listing-carousel-btn:hover,
    button.listing-carousel-btn:hover {
        background: #001773 !important;
        color: #ffffff !important;
    }

    .listing-carousel-btn:active,
    button.listing-carousel-btn:active {
        transform: scale(.95) !important;
    }

    .listing-carousel-btn:disabled,
    button.listing-carousel-btn:disabled {
        opacity: .35 !important;
        cursor: not-allowed !important;
    }

    .listing-carousel-btn svg,
    button.listing-carousel-btn svg {
        width: 18px !important;
        height: 18px !important;
        display: block !important;
        stroke: currentColor !important;
        fill: none !important;
        pointer-events: none;
    }
}

@media (max-width: 575.98px) {
    .listing-carousel-track > * {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
}
