/* ========== Event Carousel Styles ========== */
/* Shared carousel styling untuk event cards dengan hover-only arrows */

/* Carousel Container */
.event-carousel-wrapper {
    position: relative;
    padding: 0 50px;
    overflow: hidden;
}

/* Carousel Track & Slides - Equal Height Cards */
.event-carousel .slick-track {
    display: flex !important;
    align-items: stretch !important;
}

.event-carousel .slick-slide {
    padding: 0 12px;
    height: auto !important;
    display: flex !important;
}

.event-carousel .slick-slide>div {
    height: 100%;
    width: 100%;
    display: flex;
}

.event-carousel .slick-slide .carousel-slide {
    height: 100%;
    width: 100%;
    display: flex;
}

.event-carousel .slick-slide .popular-item {
    height: 100%;
    width: 100%;
    display: flex;
    flex-direction: column;
}

/* Card content wrapper should fill remaining space */
.event-carousel .popular-item .popular-item__wrapper {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Push price to bottom */
.event-carousel .popular-item .popular-item__content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.event-carousel .popular-item .event-price-box {
    margin-top: auto;
}

/* Arrow Base Styles */
.event-carousel-wrapper .slick-prev,
.event-carousel-wrapper .slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: hsl(var(--white));
    border: 1px solid hsl(var(--border-color));
    color: hsl(var(--heading-color));
    font-size: 18px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.event-carousel-wrapper .slick-prev:hover,
.event-carousel-wrapper .slick-next:hover {
    background: hsl(var(--base));
    color: hsl(var(--white));
    border-color: hsl(var(--base));
}

.event-carousel-wrapper .slick-prev:disabled,
.event-carousel-wrapper .slick-next:disabled {
    opacity: 0.3 !important;
    cursor: not-allowed;
}

/* Hover to Show Arrows */
.event-carousel-wrapper:hover .slick-prev,
.event-carousel-wrapper:hover .slick-next {
    opacity: 1;
    visibility: visible;
}

.event-carousel-wrapper:hover .slick-prev:disabled,
.event-carousel-wrapper:hover .slick-next:disabled {
    opacity: 0.3;
}

/* Arrow Positioning */
.event-carousel-wrapper .slick-prev {
    left: 0;
}

.event-carousel-wrapper .slick-next {
    right: 0;
}

/* Responsive: Tablet */
@media (max-width: 991px) {
    .event-carousel-wrapper {
        padding: 0 40px;
    }

    .event-carousel-wrapper .slick-prev,
    .event-carousel-wrapper .slick-next {
        width: 38px;
        height: 38px;
        font-size: 16px;
    }
}

/* Responsive: Mobile - Hide arrows, use swipe */
@media (max-width: 767px) {
    .event-carousel-wrapper {
        padding: 0;
    }

    .event-carousel-wrapper .slick-prev,
    .event-carousel-wrapper .slick-next {
        display: none !important;
    }

    .event-carousel .slick-slide {
        padding: 0 8px;
    }
}

/* Fix untuk first/last slide padding */
.event-carousel .slick-list {
    margin: 0 -12px;
}

@media (max-width: 767px) {
    .event-carousel .slick-list {
        margin: 0 -8px;
    }
}

/* ========== Swipe Indicator Overlay - Mobile Only ========== */
.swipe-overlay {
    display: none;
}

@media (max-width: 767px) {
    .swipe-overlay {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        width: 40px;
        z-index: 20;
        background: linear-gradient(to left, rgba(0, 0, 0, 0.5) 0%, transparent 100%);
        pointer-events: none;
        transition: opacity 0.4s ease, visibility 0.4s ease;
    }

    .swipe-overlay.hidden {
        opacity: 0;
        visibility: hidden;
    }

    .swipe-overlay .swipe-text {
        writing-mode: vertical-rl;
        text-orientation: mixed;
        color: #fff;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        opacity: 0.9;
    }

    .swipe-overlay .swipe-arrow {
        color: #fff;
        font-size: 16px;
        margin-top: 8px;
        animation: swipeArrowDown 1s ease-in-out infinite;
    }

    @keyframes swipeArrowDown {
        0%, 100% {
            transform: translateY(0);
        }
        50% {
            transform: translateY(4px);
        }
    }
}