/**
 * Image Carousel Widget - Frontend Styles
 */

/* ========================
   Wrapper
   ======================== */
.leo-carousel-wrapper {
    position: relative;
    width: 100%;
}

/* ========================
   Container & Track
   ======================== */
.leo-carousel-container {
    overflow: hidden;
    width: 100%;
}

.leo-carousel-track {
    display: flex;
    transition-property: transform;
    transition-timing-function: ease-out;
    will-change: transform;
}

.leo-carousel-track.is-dragging {
    transition: none;
    cursor: grabbing;
}

/* ========================
   Slides
   ======================== */
.leo-carousel-slide {
    flex-shrink: 0;
    box-sizing: border-box;
}

.leo-carousel-slide a {
    display: block;
    text-decoration: none;
}

/* ========================
   Image Container
   ======================== */
.leo-carousel-image-container {
    position: relative;
    overflow: hidden;
    width: 100%;
}

/* Ratio mode - use padding-bottom trick */
.leo-carousel-image-container.ratio-mode {
    height: 0;
}

.leo-carousel-image-container.ratio-mode .leo-carousel-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* Fixed height mode */
.leo-carousel-image-container:not(.ratio-mode) .leo-carousel-image {
    width: 100%;
    height: 100%;
    display: block;
}

/* ========================
   Images
   ======================== */
.leo-carousel-image {
    display: block;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ========================
   Navigation Arrows
   ======================== */
.leo-carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    line-height: 1;
}

.leo-carousel-arrow:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.leo-carousel-arrow svg {
    display: block;
}

.leo-carousel-prev {
    left: 10px;
}

.leo-carousel-next {
    right: 10px;
}

/* Arrows outside */
.leo-carousel-wrapper.arrows-outside .leo-carousel-prev {
    left: -50px;
}

.leo-carousel-wrapper.arrows-outside .leo-carousel-next {
    right: -50px;
}

@media (max-width: 1200px) {
    .leo-carousel-wrapper.arrows-outside .leo-carousel-prev {
        left: 10px;
    }

    .leo-carousel-wrapper.arrows-outside .leo-carousel-next {
        right: 10px;
    }
}

/* ========================
   Pagination Dots
   ======================== */
.leo-carousel-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.leo-carousel-dot {
    display: inline-block;
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
    padding: 0;
}

.leo-carousel-dot:hover {
    opacity: 0.8;
}

/* ========================
   Fade Effect
   ======================== */
.leo-carousel-wrapper.effect-fade .leo-carousel-track {
    position: relative;
}

.leo-carousel-wrapper.effect-fade .leo-carousel-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.leo-carousel-wrapper.effect-fade .leo-carousel-slide.is-active {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

/* ========================
   Touch/Drag Support
   ======================== */
.leo-carousel-container {
    touch-action: pan-y;
    -webkit-user-select: none;
    user-select: none;
}

.leo-carousel-image {
    -webkit-user-drag: none;
    user-drag: none;
    pointer-events: none;
}

.leo-carousel-slide a {
    -webkit-user-drag: none;
}
