@media (max-width: 768px) {
    .carousel-inner .carousel-item>div {
        display: none;
    }

    .carousel-inner .carousel-item>div:first-child {
        display: block;
    }
}

.carousel-inner .carousel-item.active,
.carousel-inner .carousel-item-start,
.carousel-inner .carousel-item-next,
.carousel-inner .carousel-item-prev {
    display: flex;
}

/* RESPONSIVE CAROUSEL SCROLL AMOUNTS
   These are aligned to bs5 breakpoints

    TODO CS: awful hardcoding (sorry), replace with a dynamic solution
             started working on one for Aspen but couldn't get it working in good time
             productCarouselWidthSetting()
*/

/* MEDIUM - 2 products*/
@media (min-width: 768px) {
    .product-carousel .carousel-inner .carousel-item-right.active,
    .product-carousel .carousel-inner .carousel-item-next,
    .product-carousel .carousel-inner .carousel-item-next:not(.carousel-item-start) {
        transform: translateX(50%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-left.active,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end),
    .product-carousel .carousel-inner .active.carousel-item-start,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-50%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-next.carousel-item-start,
    .product-carousel .carousel-inner .active.carousel-item-end {
        transform: translateX(0) !important;
    }

    .product-carousel .carousel-inner .carousel-item-prev,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-50%) !important;
    }
}

/* LARGE - 3 products */
@media (min-width: 992px) {
    .product-carousel .carousel-inner .carousel-item-right.active,
    .product-carousel .carousel-inner .carousel-item-next,
    .product-carousel .carousel-inner .carousel-item-next:not(.carousel-item-start) {
        transform: translateX(33.33%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-left.active,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end),
    .product-carousel .carousel-inner .active.carousel-item-start,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-33.33%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-next.carousel-item-start,
    .product-carousel .carousel-inner .active.carousel-item-end {
        transform: translateX(0) !important;
    }

    .product-carousel .carousel-inner .carousel-item-prev,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-33.33%) !important;
    }
}

/* XLARGE - 4 products */
@media (min-width: 1200px) {
    .product-carousel .carousel-inner .carousel-item-right.active,
    .product-carousel .carousel-inner .carousel-item-next,
    .product-carousel .carousel-inner .carousel-item-next:not(.carousel-item-start) {
        transform: translateX(25%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-left.active,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end),
    .product-carousel .carousel-inner .active.carousel-item-start,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-25%) !important;
    }

    .product-carousel .carousel-inner .carousel-item-next.carousel-item-start,
    .product-carousel .carousel-inner .active.carousel-item-end {
        transform: translateX(0) !important;
    }

    .product-carousel .carousel-inner .carousel-item-prev,
    .product-carousel .carousel-inner .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-25%) !important;
    }
}

/* XXLARGE - 6 products, only if full width. */
@media (min-width: 1400px) {
    .product-carousel .carousel-inner.fullwidth .carousel-item-right.active,
    .product-carousel .carousel-inner.fullwidth .carousel-item-next,
    .product-carousel .carousel-inner.fullwidth .carousel-item-next:not(.carousel-item-start) {
        transform: translateX(16.66%) !important;
    }

    .product-carousel .carousel-inner.fullwidth .carousel-item-left.active,
    .product-carousel .carousel-inner.fullwidth .carousel-item-prev:not(.carousel-item-end),
    .product-carousel .carousel-inner.fullwidth .active.carousel-item-start,
    .product-carousel .carousel-inner.fullwidth .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-16.66%) !important;
    }

    .product-carousel .carousel-inner.fullwidth .carousel-item-next.carousel-item-start,
    .product-carousel .carousel-inner.fullwidth .active.carousel-item-end {
        transform: translateX(0) !important;
    }

    .product-carousel .carousel-inner.fullwidth .carousel-item-prev,
    .product-carousel .carousel-inner.fullwidth .carousel-item-prev:not(.carousel-item-end) {
        transform: translateX(-16.66%) !important;
    }
}




