/* =====================================================
   PRODUCT SLIDER
   Layout overrides and navigation arrows for the
   #product-slider (or .product-slider) shop module turned into a Swiper.
   ===================================================== */

/* The module is the positioning context for the arrows,
   so they can be placed OUTSIDE the white product area. */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) {
    position: relative;
}

/* Slider viewport - products run edge to edge, no inner padding.
   overflow:hidden clips the slides (but NOT the arrows, which live
   on the module, one level up). */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .product-swiper-container {
    position: relative;
    overflow: hidden;
}

/* Override WooCommerce/Divi float-grid so Swiper can use flexbox */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.swiper-wrapper {
    display: flex !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: stretch;
}

/* Neutralize Divi's column-based margins on the wrapper. */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-1,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-2,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-3,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-4,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-5,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products.columns-6 {
    margin: 0 !important;
}

/* Each product becomes a slide.
   - Swiper controls the WIDTH inline, so we never force width here.
   - The 20px right margin is the gap between products; it MUST match
     the Swiper "spaceBetween" value (also 20) so the math lines up.
     Divi sets its own margins with !important, so we need !important
     here to win and keep a consistent gap. */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) ul.products li.product.swiper-slide {
    float: none !important;
    margin: 0 20px 0 0 !important;
    clear: none !important;
    height: auto;          /* equal-height cards via stretch */
    box-sizing: border-box;
}

/* =====================================================
   Navigation arrows - OUTSIDE the white product area
   ===================================================== */

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next {
    width: 38px;
    height: 38px;
    margin-top: 0;
    top: -15%;
    background: var(--gcid-link-color);
    transition: background 0.2s ease;
    z-index: 10;
}

/* Sit just outside the module on both sides */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev { left: calc(100% - 100px);; }
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next { right: 0px; }

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev:hover,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next:hover {
    background: #000000;
}

/* Arrow glyph - defined here so it never depends on Swiper's icon font */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev::after,
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next::after {
    font-family: inherit !important;
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    color: #000;
}

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev::after { content: url('/wp-content/uploads/2026/05/ChevronLinks.svg'); } /* ❮ */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next::after { content: url('/wp-content/uploads/2026/05/ChevronRechts.svg'); } /* ❯ */

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-next .swiper-navigation-icon { display: none; }
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-prev .swiper-navigation-icon { display: none; }

/* Hide arrows when there is nothing to slide (watchOverflow) */
:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-button-disabled {
    opacity: 0;
    pointer-events: none;
}

/* =====================================================
   Pagination dots - below the slider
   ===================================================== */

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-pagination.product-swiper-pagination {
    position: static;          /* flows below the slider, not overlapping it */
    margin-top: 18px;
    text-align: center;
    line-height: 1;
}

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    margin: 0 5px !important;
    background: #d3d3d3;
    opacity: 1;
    border-radius: 50%;
    transition: background 0.2s ease;
}

:is(#product-slider, #ProductSlider, .product-slider, .ProductSlider) .swiper-pagination-bullet-active {
    background: #000000;        /* gold accent, matches the cart button */
}