
/* Carousel heading */

/* Container for the entire carousel */
.multi-carousel-container {
    cursor: grab;
    margin: 0 auto;
    max-width: 100%;
    overflow: hidden;
    position: relative;
}

/* Cursor styles for dragging */
.multi-carousel-container.dragging,
#multiCarousel.dragging {
    cursor: grabbing;
}

/* Wrapper for all slides */
.multi-carousel-inner {
    display: flex;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Individual slide */
.multi-carousel-item,
.clone {
    box-sizing: border-box;
    flex: 0 0 33.333333%;
    padding: 0 5px;
    position: relative; /* Essential for item-number positioning */
    display: flex;
}

/* Media card - use flexbox to push button to bottom */
.media-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
}

/* Media content - use flexbox */
.media-content {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    padding: 1.5rem;
}

.media-content h3 {
    margin-bottom: 1rem;
}

.media-content p {
    flex-grow: 1;
    margin-bottom: 1rem;
}

.media-content .btn {
    margin-top: auto;
}

/* Control buttons */
.multi-carousel-control-prev,
.multi-carousel-control-next {
    align-items: center;
    background-color: rgba(0, 0, 0, 0.5);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    display: flex;
    height: 40px;
    justify-content: center;
    position: absolute;
    text-decoration: none;
    top: 50%;
    transform: translateY(-50%);
    transition: background-color 0.3s ease;
    width: 40px;
    z-index: 10;
}

.multi-carousel-control-prev:hover,
.multi-carousel-control-next:hover {
    background-color: rgba(0, 0, 0, 0.7);
}

.multi-carousel-control-prev {
    left: 10px;
}

.multi-carousel-control-next {
    right: 10px;
}

/* Image container with dynamic height */
.img-container {
    border-radius: 1.5rem;
    height: var(--carousel-height, 80vh);
    overflow: hidden;
    position: relative;
}

/* Image styling */
.img-container img,
#carouselInner img {
    height: 100%;
    object-fit: cover;
    object-position: top;
    pointer-events: none;
    user-drag: none;
    width: 100%;
    -webkit-user-drag: none;
    transition: transform 0.3s ease;
}

.img-container:hover img {
    transform: translateZ(0) scale(1.02);
}

/* Item number styling - guaranteed visibility */
.item-number {
    align-items: center;
    background-color: rgba(208, 208, 208, 0.58);
    border-radius: 20px;
    display: inline-flex;
    left: 1rem;
    position: absolute;
    top: 1rem;
    max-width: 100%;
    font-weight: bold;
    color: #595959;
    padding: 0.4rem 0.7rem;
    z-index: 2; /* Higher than default but below controls */
    /* Isolation prevents z-index context issues */
    isolation: isolate;
}

/* Carousel cursor styling */
#multiCarousel {
    cursor: grab;
    touch-action: pan-y;
}

/* Disable text selection during drag */
#multiCarousel.dragging {
    user-select: none;
    -webkit-user-select: none;
}

/* Responsive adjustments for screens smaller than 640px - 1 slide */
@media (max-width: 639px) {
    .multi-carousel-item,
    .clone {
        flex: 0 0 100%;
    }
}

/* For screens between 640px and 767px - show 2 items */
@media (min-width: 640px) and (max-width: 767px) {
    .multi-carousel-item,
    .clone {
        flex: 0 0 50%;
    }
}

/* For tablet landscape and larger (768px+) - show 3 items */
@media (min-width: 768px) {
    .multi-carousel-item,
    .clone {
        flex: 0 0 33.333333%;
    }
}
