/* Carousel Navigation Buttons - Flicker Fix */
/* This file fixes button flickering and provides smooth animations */

/* Override carousel track transition for smoother animation */
.products-carousel-track {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Navigation Button Base Styles */
.carousel-nav-btn {
    position: absolute !important;
    top: 50% !important;
    margin-top: -24px !important;
    transform: none !important;
    z-index: 20 !important;
    width: 48px !important;
    height: 48px !important;
    border-radius: 50% !important;
    background-color: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1) !important;
    color: #1E5CAA !important;
    outline: none !important;
    padding: 0 !important;
    -webkit-tap-highlight-color: transparent !important;
    /* Smooth transitions - only animate specific properties to prevent flicker */
    transition-property: background-color, border-color, box-shadow, color !important;
    transition-duration: 0.2s !important;
    transition-timing-function: ease-out !important;
}

/* Hover State - No transform to prevent flickering */
.carousel-nav-btn:hover {
    background-color: #1E5CAA !important;
    color: #ffffff !important;
    border-color: #1E5CAA !important;
    box-shadow: 0 6px 20px rgba(30, 92, 170, 0.4) !important;
    transform: none !important;
}

/* Active/Click State */
.carousel-nav-btn:active {
    background-color: #174a85 !important;
    border-color: #174a85 !important;
    box-shadow: 0 2px 10px rgba(30, 92, 170, 0.3) !important;
    transform: none !important;
}

/* Focus State for Accessibility */
.carousel-nav-btn:focus,
.carousel-nav-btn:focus-visible {
    outline: 2px solid #1E5CAA !important;
    outline-offset: 2px !important;
}

/* Disabled State */
.carousel-nav-btn.disabled,
.carousel-nav-btn:disabled {
    opacity: 0.3 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
    background-color: #f3f4f6 !important;
    color: #9ca3af !important;
}

/* SVG Icon Styling */
.carousel-nav-btn svg {
    width: 20px !important;
    height: 20px !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
    stroke-width: 2.5 !important;
    /* Prevent any transform on the icon */
    transform: none !important;
    transition: none !important;
}

/* Position: Previous Button */
.carousel-nav-prev {
    left: 12px !important;
}

/* Position: Next Button */
.carousel-nav-next {
    right: 12px !important;
}

/* Desktop - Position buttons outside carousel */
@media (min-width: 1200px) {
    .carousel-nav-prev {
        left: -60px !important;
    }
    
    .carousel-nav-next {
        right: -60px !important;
    }
}

/* Large Desktop */
@media (min-width: 1400px) {
    .carousel-nav-prev {
        left: -70px !important;
    }
    
    .carousel-nav-next {
        right: -70px !important;
    }
}

/* Tablet */
@media (max-width: 991px) {
    .carousel-nav-btn {
        width: 44px !important;
        height: 44px !important;
        margin-top: -22px !important;
    }
    
    .carousel-nav-btn svg {
        width: 18px !important;
        height: 18px !important;
    }
    
    .carousel-nav-prev {
        left: 10px !important;
    }
    
    .carousel-nav-next {
        right: 10px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .carousel-nav-btn {
        width: 40px !important;
        height: 40px !important;
        margin-top: -20px !important;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12) !important;
    }
    
    .carousel-nav-btn svg {
        width: 16px !important;
        height: 16px !important;
    }
    
    .carousel-nav-prev {
        left: 8px !important;
    }
    
    .carousel-nav-next {
        right: 8px !important;
    }
}

/* Ensure wrapper has proper positioning for absolute buttons */
.products-carousel-wrapper {
    position: relative !important;
    overflow: visible !important;
}

/* Container needs padding for buttons on desktop */
@media (min-width: 1200px) {
    .features-carousel-section .container,
    .features-carousel-section .container-fluid {
        padding-left: 80px !important;
        padding-right: 80px !important;
    }
}

