/* MX Carousel Styles */
.mx-carousel { 
    position: relative; 
    width: 100%; 
    max-width: 100%; 
    overflow: hidden; 
    box-sizing: border-box; 
}
.mx-carousel-inner { 
    position: relative; 
    overflow: hidden; 
    width: 100%; 
    max-width: 100%; 
    box-sizing: border-box; 
}
.mx-carousel .swiper { 
    overflow: hidden; 
    box-sizing: border-box; 
    max-width: 100%; 
}

/* Spacing and main slide width (percentage mode) */
.mx-carousel { --mx-space: 24px; --mx-slide-pct: 85%; --mx-arrow-offset: 0px; }

/* Mobile responsive settings */
@media (max-width: 768px) {
    .mx-carousel { --mx-space: 16px; --mx-slide-pct: 100%; }
}

@media (max-width: 480px) {
    .mx-carousel { --mx-space: 12px; --mx-slide-pct: 100%; }
}

.mx-carousel .swiper .swiper-wrapper { 
    align-items: stretch; 
    display: flex; 
    flex-wrap: nowrap; 
    max-width: 100%; 
    box-sizing: border-box; 
}
.mx-carousel .swiper-slide { 
    width: var(--mx-slide-pct); 
    flex: 0 0 auto; 
    box-sizing: border-box; 
    max-width: calc(100vw - var(--mx-space)); 
}

/* Fallback spacing only when Swiper isn't active */
.mx-carousel.mx-fallback .swiper-slide { margin-right: var(--mx-space); }
.mx-carousel.mx-fallback .swiper-slide:last-child { margin-right: 0; }
.mx-carousel.mx-fallback .swiper-slide { width: var(--mx-slide-pct); }

/* Mobile fallback - prevent horizontal scrolling */
@media (max-width: 768px) {
    .mx-carousel.mx-fallback .swiper-wrapper {
        flex-wrap: wrap;
        overflow: hidden;
    }
    .mx-carousel.mx-fallback .swiper-slide {
        margin-right: 0;
        margin-bottom: var(--mx-space);
        width: 100%;
    }
    .mx-carousel.mx-fallback .swiper-slide:last-child {
        margin-bottom: 0;
    }
}

.mx-carousel-slide { position: relative; border-radius: 0px; overflow: hidden; }
.mx-carousel-slide__media { position: absolute; inset: 0; background-size: cover; background-position: center center; }
.mx-carousel-slide__overlay { position: absolute; inset: 0; display: grid; place-items: center; background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.45) 100%); }
.mx-carousel-slide__text { text-align: center; padding: 24px; color: #fff; }
.mx-carousel-slide__title { margin: 0 0 8px 0; font-size: clamp(18px, 2.6vw, 36px); line-height: 1.2; }
.mx-carousel-slide__byline { font-size: clamp(13px, 1.6vw, 18px); opacity: 0.95; }

/* Byline Link Styling */
.mx-carousel-byline-link {
	color: #fff !important;
	text-decoration: none;
	transition: opacity 0.2s ease;
	position: relative;
	display: inline-block;
}

.mx-carousel-byline-link:hover {
	color: #fff !important;
	opacity: 0.8;
}

.mx-carousel-byline-link:visited {
	color: #fff !important;
}

/* Add small white arrow after byline link */
.mx-carousel-byline-link::after {
	content: '→';
	margin-left: 6px;
	font-size: 0.9em;
	color: #fff;
	transition: transform 0.2s ease;
}

.mx-carousel-byline-link:hover::after {
	transform: translateX(2px);
}

/* Remove text shadow from byline to avoid fuzzy appearance */
.mx-carousel .mx-carousel-slide__byline,
.mx-carousel .mx-carousel-byline-link {
    text-shadow: none !important;
}

/* Also remove on hover/focus to avoid Elementor hover styles re-applying it */
.mx-carousel .mx-carousel-slide__byline:hover,
.mx-carousel .mx-carousel-byline-link:hover,
.mx-carousel .mx-carousel-slide__byline:focus,
.mx-carousel .mx-carousel-byline-link:focus {
    text-shadow: none !important;
}

.mx-carousel-button svg { display: block; width: 32px; height: 32px; }
/* Center arrows exactly within the side gaps determined by slide percentage.
   Each side gap = (100% - slide%) / 2; midpoint of gap = gap / 2 = (100% - slide%) / 4. */
/* To be perfectly between slides, add half of the inter-slide space to the gap midpoint */
/* Updated to use custom positioning properties for better control */
.mx-carousel-button-prev { left: calc(((100% - var(--mx-slide-pct)) / 4) + (var(--mx-space)/2) + var(--mx-arrow-offset) + var(--mx-arrow-left-offset, 0px)); transform: translate(-50%, -50%); }
.mx-carousel-button-next { right: calc(((100% - var(--mx-slide-pct)) / 4) + (var(--mx-space)/2) + var(--mx-arrow-offset) + var(--mx-arrow-right-offset, 0px)); transform: translate(50%, -50%); }

/* Enhanced mobile arrow positioning - ensure arrows are always visible */
@media (max-width: 768px) {
    .mx-carousel-button {
        width: 36px !important;
        height: 36px !important;
        background: transparent !important;
        border: none !important;
        z-index: 999999 !important;
        position: absolute !important;
        top: 50% !important;
        color: #fff !important;
    }
    .mx-carousel-button:hover {
        color: rgba(255,255,255,0.7) !important;
    }
    .mx-carousel-button-prev {
        left: 10px !important;
        transform: translateY(-50%) !important;
    }
    .mx-carousel-button-next {
        right: 10px !important;
        transform: translateY(-50%) !important;
    }
    .mx-carousel-button svg {
        width: 24px !important;
        height: 24px !important;
        fill: #fff !important;
    }
}

/* Ensure the carousel height is respected */
.mx-carousel-inner, .mx-carousel .swiper, .mx-carousel .swiper-wrapper, .mx-carousel .swiper-slide, .mx-carousel-slide { height: 100%; }

/* Elementor Pro compatibility - prevent horizontal overflow */
.elementor-widget-mx-carousel,
.elementor-widget-mx-carousel .elementor-widget-container,
.elementor-widget-mx-carousel .mx-carousel {
    max-width: 100% !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* Enhanced Elementor Pro compatibility for multiple carousel instances */
.elementor-section .elementor-widget-mx-carousel {
    width: 100% !important;
    position: relative !important;
    isolation: isolate !important;
}

/* Ensure each carousel instance is properly isolated */
.elementor-widget-mx-carousel .mx-carousel {
    position: relative !important;
    z-index: 1 !important;
    contain: layout style !important;
}

/* Fix Swiper wrapper positioning for multiple instances */
.elementor-widget-mx-carousel .swiper {
    position: relative !important;
    overflow: hidden !important;
    z-index: 1 !important;
}

.elementor-widget-mx-carousel .swiper-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: stretch !important;
    transform-style: preserve-3d !important;
}

/* Ensure slides are properly positioned in multiple instances */
.elementor-widget-mx-carousel .swiper-slide {
    position: relative !important;
    flex-shrink: 0 !important;
    transform-style: preserve-3d !important;
}

/* Fix navigation buttons for multiple instances */
.elementor-widget-mx-carousel .mx-carousel-button {
    position: absolute !important;
    z-index: 10 !important;
    pointer-events: auto !important;
}

/* Elementor Pro: Fix carousel spacing and prevent interference between instances */
.elementor-widget-mx-carousel + .elementor-widget-mx-carousel {
    margin-top: 0 !important;
}

/* Elementor Pro: Ensure proper Swiper initialization for multiple instances */
.elementor-widget-mx-carousel .mx-carousel {
    opacity: 1 !important;
}

/* Elementor Pro: Fix transform issues with multiple carousels */
.elementor-widget-mx-carousel .swiper-wrapper {
    will-change: transform !important;
    backface-visibility: hidden !important;
}

/* Elementor Pro: Prevent carousel overlap issues */
.elementor-section .elementor-container .elementor-widget-mx-carousel {
    clear: both !important;
    display: block !important;
}

/* Elementor Pro: Fix slide positioning in multiple instances */
.elementor-widget-mx-carousel .swiper-slide .mx-carousel-slide {
    width: 100% !important;
    height: 100% !important;
    position: relative !important;
}

/* Conservative centering fix for multiple carousel instances */
.elementor-widget-mx-carousel .swiper {
    text-align: center;
}

/* Force desktop carousel to respect viewport boundaries */
@media (min-width: 769px) {
    /* Desktop: show pointer cursor on navigation buttons */
    .mx-carousel .mx-carousel-button,
    .mx-carousel .mx-carousel-navigation .mx-carousel-button {
        cursor: pointer !important;
    }
    /* Avoid constraining swiper-wrapper width to prevent loop jumps */
    .mx-carousel .swiper-wrapper {
        max-width: none !important;
        transform-origin: center center !important;
    }
}

/* FORCE MOBILE LAYOUT - Override everything */
@media (max-width: 768px) {
    /* Force container to not overflow */
    .mx-carousel {
        overflow: hidden !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    
    /* Force swiper wrapper to not extend beyond viewport */
    .mx-carousel .swiper-wrapper {
        width: 100% !important;
        max-width: 100% !important;
        transform: none !important;
    }
    
    /* Force each slide to be 100% width and stack vertically if needed */
    .mx-carousel .swiper-slide {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        margin-right: 0 !important;
    }
    
    /* Force fallback layout to stack vertically */
    .mx-carousel.mx-fallback .swiper-wrapper {
        display: block !important;
        width: 100% !important;
    }
    
    .mx-carousel.mx-fallback .swiper-slide {
        display: block !important;
        width: 100% !important;
        margin-right: 0 !important;
        margin-bottom: 16px !important;
        float: none !important;
    }
    
}

/* NUCLEAR OPTION - MOBILE-ONLY LAYOUT - Only apply to mobile mode class */
@media (max-width: 768px) {
    /* Force the entire page to not scroll horizontally */
    html, body {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    /* Only apply mobile layout to mobile mode carousels */
    .mx-carousel.mx-mobile-mode,
    .mx-carousel.mx-mobile-mode .swiper,
    .mx-carousel.mx-mobile-mode .swiper-wrapper,
    .mx-carousel.mx-mobile-mode .swiper-slide {
        max-width: 100vw !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    /* Force slides to stack and show only one - MOBILE MODE ONLY */
    .mx-carousel.mx-mobile-mode .swiper-wrapper {
        display: flex !important;
        flex-direction: column !important;
        height: auto !important;
        transform: none !important;
    }
    
    .mx-carousel.mx-mobile-mode .swiper-slide {
        flex: none !important;
        width: 100% !important;
        margin: 0 !important;
        display: none !important;
        height: var(--mx-carousel-height, 80vh) !important;
        min-height: 300px !important;
    }
    
    .mx-carousel.mx-mobile-mode .swiper-slide:first-child {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    
    /* Ensure carousel container has proper height - MOBILE MODE ONLY */
    .mx-carousel.mx-mobile-mode {
        height: var(--mx-carousel-height, 80vh) !important;
        min-height: 300px !important;
        display: block !important;
        visibility: visible !important;
    }
    
    .mx-carousel.mx-mobile-mode .swiper {
        height: var(--mx-carousel-height, 80vh) !important;
        min-height: 300px !important;
        display: block !important;
        visibility: visible !important;
    }
    
    /* Show navigation on mobile but adjust positioning */
    .mx-carousel .mx-carousel-button {
        display: block !important;
        width: 36px !important;
        height: 36px !important;
        z-index: 999999 !important;
        position: absolute !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        background: rgba(0,0,0,0.7) !important;
        border: 1px solid rgba(255,255,255,0.8) !important;
        color: #fff !important;
    }
    
    .mx-carousel .mx-carousel-button-prev {
        left: 10px !important;
        transform: translateY(-50%) !important;
    }
    
    .mx-carousel .mx-carousel-button-next {
        right: 10px !important;
        transform: translateY(-50%) !important;
    }
    
    .mx-carousel .mx-carousel-button svg {
        fill: #fff !important;
        width: 20px !important;
        height: 20px !important;
    }
}

/* NUCLEAR ARROW VISIBILITY - Override everything */
.mx-carousel .mx-carousel-button,
.mx-carousel .mx-carousel-button-prev,
.mx-carousel .mx-carousel-button-next {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 999999 !important;
    pointer-events: auto !important;
    position: absolute !important;
}

/* Force arrows to stay visible even with inline styles */
.mx-carousel .mx-carousel-button[style*="display: none"],
.mx-carousel .mx-carousel-button[style*="visibility: hidden"],
.mx-carousel .mx-carousel-button[style*="opacity: 0"] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Bottom navigation (safe styles) */
.mx-carousel .mx-carousel-navigation {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    width: 100%;
    margin-top: 12px;
}
.mx-carousel .mx-carousel-navigation .mx-carousel-button {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    background: transparent !important;
    border: none !important;
}

/* Targeted centering for subsequent carousel instances (safer than nth-child) */
.elementor-section .elementor-widget-mx-carousel:not(:first-of-type) .mx-carousel,
.elementor-container .elementor-widget-mx-carousel:not(:first-of-type) .mx-carousel {
    margin: 0 auto !important;
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    position: relative !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
}

/* Do not alter slide sizing here to avoid breaking Swiper's centering */

/* General fallback-mode centering (applies when Swiper not initialized) */
.mx-carousel.mx-fallback .swiper-wrapper {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}
.mx-carousel.mx-fallback .swiper-slide {
    margin: 0 auto !important;
    max-width: calc(100% - var(--mx-space)) !important;
}

/* Mobile-only CSS mode (when Swiper is disabled) */
.mx-carousel.mx-mobile-mode {
    overflow: hidden !important;
}

.mx-carousel.mx-mobile-mode .swiper-wrapper {
    display: block !important;
    width: 100% !important;
    transform: none !important;
}

.mx-carousel.mx-mobile-mode .swiper-slide {
    display: none !important; /* Hide all slides by default */
    width: 100% !important;
    margin: 0 !important;
}

.mx-carousel.mx-mobile-mode .swiper-slide:first-child {
    display: block !important; /* Show only the first slide */
}

/* Hide arrows on mobile mode */
.mx-carousel.mx-mobile-mode .mx-carousel-button {
    display: none !important;
}

/* Override: when using bottom navigation, keep buttons visible on mobile */
@media (max-width: 768px) {
  .mx-carousel.mx-mobile-mode .mx-carousel-navigation .mx-carousel-button {
    display: inline-flex !important;
    position: static !important;
    left: auto !important; right: auto !important; top: auto !important;
    transform: none !important;
    z-index: 5 !important;
    pointer-events: auto !important;
  }
  .mx-carousel .mx-carousel-navigation { margin-top: 12px; }
}

/* Mobile-only: overlay navigation on top of slides with correct stacking */
@media (max-width: 768px) {
  .mx-carousel { position: relative; }
  .mx-carousel .mx-carousel-navigation {
    position: absolute !important;
    left: 0; right: 0; bottom: 10px;
    margin-top: 0;
    z-index: 6 !important; /* above overlay/text */
    pointer-events: auto;
  }
  .mx-carousel .mx-carousel-navigation .mx-carousel-button {
    width: 36px !important; height: 36px !important;
  }
  /* Ensure slide overlay sits below nav but above media */
  .mx-carousel .mx-carousel-slide__overlay { z-index: 2; }
}
