/* Lazy Load Placeholder */
#banner-slider,
#category-carousel {
    z-index: 10;
}

#banner-slider img,
#category-carousel img {
    opacity: 0;
    transition: opacity 250ms ease-in-out;
}

#banner-slider .loaded img,
#category-carousel .loaded img {
    opacity: 1;
}
    
/* placeholder animation */
.banner-image-placeholder:before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0;
    animation: pulse 1s infinite;
    background-color: rgba(255, 255, 255, 0.5);
    z-index: 1;
    pointer-events: none;
}

@keyframes pulse {
    0% {
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

.banner-image-placeholder:has(+ #banner-slider li.loaded),
.banner-image-placeholder:has(+ #category-carousel li.loaded) {
    display: none;
}

.banner-image-placeholder:has(+ #banner-slider li.loaded):before,
.banner-image-placeholder:has(+ #category-carousel li.loaded):before {
    animation: none;
    content: none;
}

.splide-cats .loaded .splide-image {
    border: 3px solid #e5e7eb;
}