
/* Slideshow container fills available space in the tile */
.slideshow-container {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: stretch;
    justify-content: stretch;
}


/* Ken Burns effect: only forward, no reverse */
@keyframes kenBurns {
    0% {
        transform: scale(1) translate(0, 0);
        opacity: 1;
    }
    100% {
        transform: scale(1.12) translate(-2%, -2%);
        opacity: 1;
    }
}


/* Ken Burns effect for slide images */
.slide-kenburns {
    animation: kenBurns 7s linear forwards;
}


/* Ken Burns effect for Swiper images */
.kenburns-img {
    animation: kenburns-zoom 7s linear forwards;
}


@keyframes kenburns-zoom {
    0% {
        transform: scale(1) translate(0, 0);
    }
    100% {
        transform: scale(1.12) translate(-2%, -2%);
    }
}





/* Slide image fade-in and fade-out for smooth transitions */
@keyframes slideImageIn {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slideImageOut {
    0% {
        opacity: 1;
        transform: translateY(0);
    }
    100% {
        opacity: 0;
        transform: translateY(-30px);
    }
}

.slide-image-in {
    animation: slideImageIn 0.7s forwards;
}
.slide-image-out {
    animation: slideImageOut 0.7s forwards;
}


.slide {
    display: none;
    width: 100%;
    height: 100%;
    object-fit: cover;
    background: #f4f4f4;
    transition: opacity 0.7s ease;
    /* Remove animation here so it doesn't override kenBurns */
    position: relative;
    z-index: 1;
}

.slide.active {
    display: block;
    opacity: 1;
}


/* Floating dust/particles overlay */
.slide::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    pointer-events: none;
    z-index: 3;
    opacity: 0.10;
    background: radial-gradient(circle at 20% 30%, #fff 0%, transparent 60%),
                radial-gradient(circle at 70% 80%, #fff 0%, transparent 70%),
                radial-gradient(circle at 50% 50%, #fff 0%, transparent 80%);
    animation: dustMove 18s linear infinite alternate;
}


@keyframes dustMove {
    0% { background-position: 20% 30%, 70% 80%, 50% 50%; }
    100% { background-position: 30% 40%, 60% 70%, 55% 60%; }
}


/* Navigation arrows */
.prev, .next {
    cursor: pointer;
    position: absolute;
    top: 50%;
    width: 40px;
    height: 40px;
    margin-top: -20px;
    color: #fff;
    background: rgba(0,0,0,0.4);
    border: none;
    border-radius: 50%;
    font-size: 24px;
    line-height: 40px;
    text-align: center;
    z-index: 10;
    transition: background 0.3s;
    transform: translateY(-50%);
}
.prev:hover, .next:hover {
    background: rgba(0,0,0,0.7);
}
.prev {
    left: 16px;
}
.next {
    right: 16px;
}


/* Dots */
.slideshow-dots {
    text-align: center;
    position: absolute;
    width: 100%;
    bottom: 15px;
    left: 0;
    z-index: 10;
}
.slideshow-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin: 0 4px;
    background: #bbb;
    border-radius: 50%;
    cursor: pointer;
    transition: background 0.3s;
}
.slideshow-dot.active {
    background: #4a8fdb;
}


@media (max-width: 800px) {
    .slideshow-container {
        max-width: 98vw;
        height: 220px;
    }
}