/* Carousel Mobile Fix - Ensures carousels work properly on mobile */

/* Featured Bundles Carousel Mobile Fixes */
@media (max-width: 768px) {
    /* Fix carousel container padding and overflow */
    .featured-bundles-carousel-container {
        padding: 0 !important;
        margin: 1rem 0;
        overflow: visible !important;
    }
    
    /* Fix carousel track for mobile */
    .featured-bundles-track {
        display: flex;
        gap: 16px;
        overflow-x: auto !important;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        padding: 10px 16px 20px;
        margin: 0;
        /* Enable momentum scrolling on iOS */
        scroll-snap-type: x mandatory;
    }
    
    /* Fix slide width for mobile */
    .featured-bundle-slide {
        flex: 0 0 85vw !important; /* Use viewport width for responsiveness */
        max-width: 320px !important;
        min-width: 280px !important;
        scroll-snap-align: start;
    }
    
    /* Hide carousel navigation arrows on mobile */
    .featured-carousel-btn,
    .featured-carousel-prev,
    .featured-carousel-next {
        display: none !important;
    }
    
    /* Show scroll indicator on mobile */
    .featured-bundles-track::after {
        content: '';
        display: block;
        min-width: 16px;
        height: 1px;
        flex-shrink: 0;
    }
    
    /* Style carousel dots for mobile */
    .featured-carousel-dots {
        display: flex;
        justify-content: center;
        gap: 6px;
        margin-top: 16px;
        padding: 0 20px;
    }
    
    .carousel-dot {
        width: 8px;
        height: 8px;
        background: #d1d5db;
        border-radius: 50%;
        transition: all 0.3s ease;
        cursor: pointer;
        /* Ensure dots are tappable on mobile */
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
    }
    
    .carousel-dot::before {
        content: '';
        position: absolute;
        width: 8px;
        height: 8px;
        background: inherit;
        border-radius: 50%;
    }
    
    .carousel-dot.active::before {
        background: #3b82f6;
        width: 20px;
        border-radius: 4px;
    }
}

/* Testimonials Carousel Mobile Fixes */
@media (max-width: 768px) {
    .testimonials-carousel-container {
        padding: 0 !important;
        overflow: visible !important;
    }
    
    .testimonials-track {
        display: flex;
        gap: 16px;
        overflow-x: auto !important;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        padding: 10px 16px 20px;
        scroll-snap-type: x mandatory;
    }
    
    .testimonial-card {
        flex: 0 0 85vw !important;
        max-width: 320px !important;
        min-width: 280px !important;
        scroll-snap-align: start;
    }
    
    /* Hide testimonial navigation arrows */
    .carousel-button,
    .carousel-prev,
    .carousel-next {
        display: none !important;
    }
    
    /* Testimonial dots */
    .carousel-dots {
        display: flex;
        justify-content: center;
        gap: 6px;
        margin-top: 16px;
        padding: 0 20px;
    }
}

/* General carousel improvements for touch devices */
@media (hover: none) and (pointer: coarse) {
    /* Remove hover effects on touch devices */
    .featured-bundle-slide:hover,
    .testimonial-card:hover {
        transform: none !important;
        box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1) !important;
    }
    
    /* Add active state for touch feedback */
    .featured-bundle-slide:active,
    .testimonial-card:active {
        transform: scale(0.98);
        transition: transform 0.1s ease;
    }
    
    /* Ensure scrollbar is visible on mobile for better UX */
    .featured-bundles-track::-webkit-scrollbar,
    .testimonials-track::-webkit-scrollbar {
        display: block !important;
        height: 4px;
    }
    
    .featured-bundles-track::-webkit-scrollbar-track,
    .testimonials-track::-webkit-scrollbar-track {
        background: #f1f5f9;
        border-radius: 2px;
    }
    
    .featured-bundles-track::-webkit-scrollbar-thumb,
    .testimonials-track::-webkit-scrollbar-thumb {
        background: #cbd5e1;
        border-radius: 2px;
    }
}

/* Prevent layout shift when carousel initializes */
.featured-bundles-carousel-container,
.testimonials-carousel-container {
    min-height: 300px;
}

/* Ensure proper z-index hierarchy */
@media (max-width: 768px) {
    .featured-bundles-track,
    .testimonials-track {
        z-index: 1;
    }
    
    .carousel-dots,
    .featured-carousel-dots {
        z-index: 2;
        position: relative;
    }
    
    /* Ensure carousel doesn't interfere with mobile menu */
    .header,
    .mobile-menu-toggle {
        z-index: 999 !important;
    }
    
    .mobile-menu-overlay {
        z-index: 1000 !important;
    }
    
    .mobile-menu {
        z-index: 1001 !important;
    }
}

/* Fix for carousel breaking page responsiveness */
@media (max-width: 768px) {
    /* Ensure carousel doesn't cause horizontal scroll */
    .featured-bundles,
    .testimonials {
        overflow-x: hidden;
        width: 100%;
    }
    
    /* Reset any absolute positioning that might break layout */
    .featured-bundles-carousel-container *,
    .testimonials-carousel-container * {
        position: static !important;
    }
    
    /* Exception for elements that need positioning */
    .carousel-dot::before,
    .featured-bundle-slide .bundle-badge,
    .testimonial-card .quote-icon {
        position: absolute !important;
    }
}

/* Accessibility improvements for mobile carousels */
@media (max-width: 768px) {
    /* Add focus indicators for keyboard navigation */
    .featured-bundle-slide:focus,
    .testimonial-card:focus {
        outline: 3px solid #3b82f6;
        outline-offset: 2px;
    }
    
    /* Ensure carousel is keyboard navigable */
    .featured-bundles-track,
    .testimonials-track {
        -webkit-tap-highlight-color: transparent;
        outline: none;
    }
    
    .featured-bundles-track:focus,
    .testimonials-track:focus {
        outline: 2px solid #3b82f6;
        outline-offset: -2px;
    }
}

/* Performance optimizations for mobile */
@media (max-width: 768px) {
    /* Disable animations in carousels on mobile */
    .featured-bundle-slide *,
    .testimonial-card * {
        animation: none !important;
        transition: transform 0.2s ease, opacity 0.2s ease !important;
    }
    
    /* Use GPU acceleration for smooth scrolling */
    .featured-bundles-track,
    .testimonials-track {
        transform: translateZ(0);
        will-change: scroll-position;
    }
}