/* Slider Styles */
.slider-viewport {
    position: relative;
    overflow: hidden;
}

.slider-container {
    display: flex;
    transition: transform var(--transition-time) ease;
}

/* Individual Page Styles */
.page {
    flex: 0 0 100%;
    display: flex;
    flex-direction: column;
}

/* Controls Area */
.controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    opacity: 0;
    transition: opacity var(--transition-time) ease;
}

/* Show controls only when hovering over pagination-container */
.pagination-container:hover .controls {
    opacity: 1;
}

/* Navigation Buttons (Prev/Next) */
.nav-btn {
    background-color: transparent;
    border: none;
    padding: 0.5rem 0;
    cursor: pointer;
    position: relative;
    /* Needed for ::before positioning */
}

.nav-btn:disabled {
    cursor: default;
}

.nav-btn svg {
    color: var(--dark-gray-text-color);
    width: 1.5rem;
    height: 1.5rem;
    transition: color var(--transition-time) ease, opacity var(--transition-time) ease;
}

/* Only change color on hover if nav-btn is not disabled */
.nav-btn:not(:disabled):hover svg {
    color: var(--text-color);
}

/* Larger invisible clickable area */
.nav-btn::before {
    content: '';
    position: absolute;
    top: -1rem;
    bottom: -1rem;
    left: -2rem;
    right: -2rem;
    /* Make sure it doesn't interfere visually */
    background: transparent;
    pointer-events: auto;
    z-index: 1;
}

/* Ensure the button content is above the hit area */
.nav-btn>* {
    position: relative;
    z-index: 2;
}

/* Pagination Dots */
#pagination-dots {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.dot {
    height: 0.5rem;
    width: 0.5rem;
    border-radius: 9999px;
    background-color: var(--dark-gray-text-color);
    border: none;
    cursor: pointer;
    padding: 0;
    transition: width var(--transition-time) ease, background-color var(--transition-time) ease, opacity var(--transition-time) ease;
}

.dot:hover {
    background-color: var(--text-color);
}

.dot.active {
    width: 1.5rem;
}

@media (max-width: 600px) {

    /* Always show controls (and thus dots) on narrow screens */
    .controls {
        opacity: 1 !important;
    }

    /* Disable hover effect for dot and nav-btn in mobile mode */
    .dot:hover {
        background-color: var(--dark-gray-text-color) !important;
    }

    .nav-btn:not(:disabled):hover svg {
        color: var(--dark-gray-text-color) !important;
    }
}