/**
 * Custom Elementor Carousel Styling
 * 
 * Moves navigation arrows to top and aligns with heading/category
 * 
 * @package Leuven Child Theme
 * @since 1.0.0
 */

/* Carousel Container */
/*.custom-carousel-section {*/
/*    position: relative;*/
/*}*/

/*.product-carousel .swiper-wrapper {*/
/*    position: relative;*/
/*}*/

/* Carousel Header - Contains heading, category link, and arrows */
.carousel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    gap: 20px;
}

/* Right side - Heading */
.carousel-header-right {
    display: flex;
    align-items: center;
    gap: 15px;
}

.carousel-heading {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0;
}

/* Left side - Category link and arrows */
.carousel-header-left {
    display: flex;
    align-items: center;
    gap: 15px;
}

.carousel-category-link {
    font-size: 16px;
    color: var(--color-accent);
    text-decoration: none;
    transition: color 0.3s ease;
    font-weight: 500;
}

.carousel-category-link:hover {
    color: var(--color-primary);
}

/* Custom Navigation Arrows Container */
.carousel-nav-arrows {
    display: flex;
    gap: 10px;
    align-items: center;
}

/* Arrow Buttons */
.carousel-arrow {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: var(--color-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.carousel-arrow:hover {
    border-color: var(--color-accent);
    background: var(--color-accent);
}

.carousel-arrow:hover svg {
    stroke: var(--color-secondary);
}

.carousel-arrow svg {
    width: 20px;
    height: 20px;
    stroke: var(--color-primary);
    transition: stroke 0.3s ease;
}

/* Hide default Elementor arrows */
.custom-carousel-section .elementor-swiper-button {
    display: none !important;
}

/* Override Elementor carousel default navigation */
.elementor-widget-image-carousel.custom-carousel .elementor-swiper-button,
.elementor-widget-media-carousel.custom-carousel .elementor-swiper-button {
    display: none !important;
}

/* Product Carousel Specific Styles */
.product-carousel .elementor-swiper-button {
    position: absolute !important;
    top: -50px !important;
    width: 50px !important;
    height: 50px !important;
    margin: 0 !important;
    border-radius: 50% !important;
    border: 1px solid var(--color-border) !important;
    background: var(--color-secondary) !important;
    transition: all 0.3s ease !important;
}

.product-carousel .elementor-swiper-button:after {
    font-size: 14px !important;
    color: var(--color-primary) !important;
    font-weight: 700 !important;
}

.product-carousel .elementor-swiper-button:hover {
    border-color: var(--color-accent) !important;
    background: var(--color-accent) !important;
}

.product-carousel .elementor-swiper-button:hover:after {
    color: var(--color-secondary) !important;
}

.product-carousel .elementor-swiper-button.swiper-button-disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

/* RTL Support for product-carousel */
[dir="rtl"] .product-carousel .elementor-swiper-button-prev {
    right: auto !important;
    left: 60px !important;
}

[dir="rtl"] .product-carousel .elementor-swiper-button-next {
    right: auto !important;
    left: 0 !important;
}

.product-carousel .cs-pointers-grid {
    align-items: center;
    justify-content: center;
}

/* Custom Navigation Icons - cs-navigation-left */
.product-carousel .cs-navigation-left {
    border: 1px solid var(--color-text-secondary) !important;
    border-radius: 50% !important;
    height: 45px !important;
    width: 45px !important;
    display: flex !important;
    align-items: end !important;
    justify-content: center !important;
    cursor: pointer !important;
    margin-bottom: 5px !important;
    transition: all 0.3s ease !important;
    flex-shrink: 0 !important;
}

/* Custom Navigation Icons - cs-navigation-right */
.product-carousel .cs-navigation-right {
    border: 1px solid var(--color-text-secondary) !important;
    border-radius: 50% !important;
    height: 45px !important;
    width: 45px !important;
    display: flex !important;
    align-items: end !important;
    justify-content: center !important;
    cursor: pointer !important;
    margin-bottom: 5px !important;
    transition: all 0.3s ease !important;
    flex-shrink: 0 !important;
}

/* Hover states */
.product-carousel .cs-navigation-left:hover {
    border-color: var(--color-accent) !important;
}

.product-carousel .cs-navigation-right:hover {
    border-color: var(--color-accent) !important;
}

.product-carousel .cs-navigation-left:hover svg {
    color: var(--color-accent) !important;
}

.product-carousel .cs-navigation-right:hover svg {
    color: var(--color-accent) !important;
}

/* Disabled states */
.product-carousel .cs-navigation-left.disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}

.product-carousel .cs-navigation-right.disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
    pointer-events: none !important;
}

/* RTL Support for custom navigation */
[dir="rtl"] .product-carousel .cs-navigation-left svg,
[dir="rtl"] .product-carousel .cs-navigation-right svg {
    transform: scaleX(-1);
}

/* Custom arrows positioning for Elementor carousel */
.custom-carousel .swiper-button-prev,
.custom-carousel .swiper-button-next {
    position: static !important;
    width: 40px;
    height: 40px;
    margin: 0;
    border-radius: 50%;
    border: 1px solid var(--color-border);
    background: var(--color-secondary);
    transition: all 0.3s ease;
}

.custom-carousel .swiper-button-prev:after,
.custom-carousel .swiper-button-next:after {
    font-size: 16px;
    color: var(--color-primary);
    font-weight: 700;
}

.custom-carousel .swiper-button-prev:hover,
.custom-carousel .swiper-button-next:hover {
    border-color: var(--color-accent);
    background: var(--color-accent);
}

.custom-carousel .swiper-button-prev:hover:after,
.custom-carousel .swiper-button-next:hover:after {
    color: var(--color-secondary);
}

/* RTL Support */
[dir="rtl"] .carousel-header {
    flex-direction: row-reverse;
}

[dir="rtl"] .carousel-arrow svg {
    transform: scaleX(-1);
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .carousel-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }

    .carousel-header-right,
    .carousel-header-left {
        width: 100%;
        justify-content: space-between;
    }

    .carousel-heading {
        font-size: 22px;
    }

    .carousel-category-link {
        font-size: 14px;
    }

    .carousel-arrow {
        width: 36px;
        height: 36px;
    }

    .carousel-arrow svg {
        width: 18px;
        height: 18px;
    }
    
    /* Product Carousel Header Mobile */
    .product-carousel-header {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 10px !important;
        margin-bottom: 20px !important;
    }
    
    /* Title container - smaller and less prominent */
    .product-carousel-header > *:first-child {
        flex: 0 0 auto !important;
        max-width: 35% !important;
    }
    
    .product-carousel-header h2,
    .product-carousel-header h3,
    .product-carousel-header .elementor-heading-title {
        font-size: 16px !important;
        line-height: 1.3 !important;
        margin: 0 !important;
        font-weight: 600 !important;
    }
    
    /* Navigation container - main focus */
    .product-carousel-nav {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        flex: 1 1 auto !important;
        justify-content: flex-end !important;
    }
    
    /* View all link */
    .product-carousel-nav a,
    .product-carousel-nav .carousel-category-link {
        font-size: 14px !important;
        white-space: nowrap !important;
        font-weight: 500 !important;
    }
    
    /* Navigation arrows container */
    .product-carousel-nav > *:last-child {
        display: flex !important;
        gap: 8px !important;
    }
    
    /* Navigation arrows */
    .product-carousel .cs-navigation-left,
    .product-carousel .cs-navigation-right {
        width: 38px !important;
        height: 38px !important;
        margin-bottom: 0 !important;
    }
    
    .product-carousel .cs-navigation-left svg,
    .product-carousel .cs-navigation-right svg {
        width: 18px !important;
        height: 18px !important;
    }
}

/* Small Mobile (< 480px) */
@media (max-width: 480px) {
    .product-carousel-header h2,
    .product-carousel-header h3,
    .product-carousel-header .elementor-heading-title {
        font-size: 14px !important;
    }
    
    .product-carousel-header > *:first-child {
        max-width: 40% !important;
    }

    .product-carousel-nav {
        display: grid !important;
        grid-template-columns: 1fr 1fr;
        gap: 12px !important;
        justify-items: end;
    }
    
    .product-carousel-nav a,
    .product-carousel-nav .carousel-category-link {
        font-size: 13px !important;
    }
    
    .product-carousel .cs-navigation-left,
    .product-carousel .cs-navigation-right {
        width: 35px !important;
        height: 35px !important;
    }
}

/* Tablet */
@media (max-width: 1024px) and (min-width: 769px) {
    .carousel-heading {
        font-size: 24px;
    }
}

/* Product Cards in Carousel */
.custom-carousel .leuven-product-card {
    height: 100%;
}

.custom-carousel .swiper-slide {
    height: auto;
}

/* Pagination Dots Styling (if enabled) */
/*.custom-carousel .swiper-pagination {*/
/*    position: relative;*/
/*    margin-top: 20px;*/
/*}*/

.custom-carousel .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: var(--color-border);
    opacity: 1;
    transition: all 0.3s ease;
}

.custom-carousel .swiper-pagination-bullet-active {
    background: var(--color-accent);
    width: 24px;
    border-radius: 5px;
}

/* Smooth transitions */
.custom-carousel .swiper-slide {
    transition: transform 0.3s ease;
}

/* Focus states for accessibility */
.carousel-arrow:focus,
.custom-carousel .swiper-button-prev:focus,
.custom-carousel .swiper-button-next:focus {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.carousel-category-link:focus {
    outline: 2px solid var(--color-accent);
    outline-offset: 4px;
}
