/* =========================================
   SWIMRUN SMART MENU
   ========================================= */

/* Header de base */
.site-header {
    position: fixed !important;
    top: 30px;
    right: calc((100vw - 1400px) / 2);
    z-index: 9999;
    transition: transform 0.3s ease, top 0.3s ease, background-color 0.3s ease, padding 0.3s ease;
}

@media (max-width: 1400px) {
    .site-header {
        right: 20px;
    }
}

.site-header.header-hidden {
    transform: translateY(-150%);
}

/* Header avec fond noir quand on scroll (menu complet uniquement) */
.site-header.header-scrolled:not(.cta-only-mode) {
    background-color: #000000;
    padding: 15px 25px;
    border-radius: 100px;
}

/* =========================================
   Items du menu desktop
   ========================================= */
.site-header .elementor-nav-menu > li,
.site-header .menu > li {
    transition: opacity 0.3s ease, transform 0.3s ease, max-width 0.3s ease;
    overflow: visible;
}

.site-header .elementor-nav-menu--main > .elementor-nav-menu > li.menu-item-hidden,
.site-header .menu > li.menu-item-hidden {
    opacity: 0;
    max-width: 0;
    padding-left: 0;
    padding-right: 0;
    margin-left: 0;
    margin-right: 0;
    pointer-events: none;
    overflow: hidden !important;
}

/* =========================================
   BOUTONS CTA - DESKTOP ET MOBILE
   ========================================= */
.site-header .menu-cta-inscription.cta-active,
.site-header .menu-cta-resultats.cta-active {
    opacity: 1 !important;
    max-width: none !important;
    pointer-events: auto !important;
    display: block !important;
}

/* IMPORTANT: Cacher le bouton inactif PARTOUT */
.site-header .menu-cta-inscription.cta-hidden,
.site-header .menu-cta-resultats.cta-hidden,
.site-header .elementor-nav-menu--dropdown .menu-cta-inscription.cta-hidden,
.site-header .elementor-nav-menu--dropdown .menu-cta-resultats.cta-hidden,
.site-header nav.elementor-nav-menu--dropdown .menu-cta-inscription.cta-hidden,
.site-header nav.elementor-nav-menu--dropdown .menu-cta-resultats.cta-hidden {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

.site-header .menu-cta-inscription > a,
.site-header .menu-cta-resultats > a {
    background-color: #fedd02 !important;
    color: #000000 !important;
    padding: 12px 25px !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    transition: all 0.3s ease !important;
}

.site-header .menu-cta-inscription > a:hover,
.site-header .menu-cta-resultats > a:hover {
    transform: scale(1.03) !important;
}

/* =========================================
   OVERLAY MOBILE - Z-INDEX 999
   ========================================= */
.swimrun-mobile-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    background: rgba(0, 0, 0, 0.7) !important;
    z-index: 999 !important;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    pointer-events: none;
}

.swimrun-mobile-overlay.active {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto;
}

/* =========================================
   BOUTON CLOSE
   ========================================= */
button.swimrun-mobile-close {
    position: absolute !important;
    top: 25px !important;
    left: 25px !important;
    width: 44px !important;
    height: 44px !important;
    background: transparent !important;
    border: none !important;
    color: #fedd02 !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin: 0 !important;
    z-index: 100 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

button.swimrun-mobile-close:hover {
    transform: scale(1.1);
}

button.swimrun-mobile-close svg {
    width: 32px !important;
    height: 32px !important;
    fill: #fedd02 !important;
}

/* =========================================
   MENU MOBILE OFF-CANVAS
   ========================================= */
@media screen and (max-width: 1024px) {
    .site-header {
        top: 15px;
        right: 15px;
    }
    
    /* Reset items cachés sur mobile */
    .site-header .elementor-nav-menu--main > .elementor-nav-menu > li.menu-item-hidden {
        opacity: 1;
        max-width: none;
        pointer-events: auto;
        overflow: visible;
    }
    
    /* Cacher menu horizontal */
    .site-header .elementor-nav-menu--main {
        display: none !important;
    }
    
    /* =========================================
       PANNEAU OFF-CANVAS
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container,
    .site-header nav.elementor-nav-menu--dropdown.elementor-nav-menu__container {
        --menu-height: 100vh !important;
        position: fixed !important;
        top: 0 !important;
        right: -380px !important;
        left: auto !important;
        bottom: 0 !important;
        width: 320px !important;
        max-width: 85vw !important;
        height: 100vh !important;
        height: 100dvh !important;
        min-height: 100vh !important;
        max-height: none !important;
        margin: 0 !important;
        padding: 100px 25px 40px 25px !important;
        background-color: #000000 !important;
        z-index: 99999 !important;
        display: block !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        box-shadow: -10px 0 40px rgba(0, 0, 0, 0.5) !important;
        transition: right 0.3s ease !important;
        transform: none !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
        box-sizing: border-box !important;
    }
    
    /* Menu OUVERT */
    .site-header.mobile-menu-open nav.elementor-nav-menu--dropdown,
    .site-header.mobile-menu-open .elementor-nav-menu--dropdown.elementor-nav-menu__container,
    .site-header.mobile-menu-open nav.elementor-nav-menu--dropdown.elementor-nav-menu__container,
    .site-header nav.elementor-nav-menu--dropdown.swimrun-nav-open,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container.swimrun-nav-open {
        right: 0 !important;
    }
    
    /* =========================================
       LISTE UL PRINCIPALE
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown > ul,
    .site-header nav.elementor-nav-menu--dropdown > ul.elementor-nav-menu,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul.elementor-nav-menu {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        gap: 0 !important;
        background: transparent !important;
    }
    
    /* =========================================
       ITEMS LI
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown > ul > li,
    .site-header nav.elementor-nav-menu--dropdown > ul.elementor-nav-menu > li,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul > li,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul.elementor-nav-menu > li {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        text-align: right !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
        background: transparent !important;
        display: block !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown > ul > li:last-child,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul > li:last-child {
        border-bottom: none !important;
    }
    
    /* =========================================
       LIENS A
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown > ul > li > a,
    .site-header nav.elementor-nav-menu--dropdown > ul.elementor-nav-menu > li > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul > li > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul.elementor-nav-menu > li > a,
    .site-header nav.elementor-nav-menu--dropdown a.elementor-item,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container a.elementor-item {
        display: block !important;
        width: 100% !important;
        padding: 18px 0 !important;
        padding-right: 25px !important; /* Décalage pour aligner avec les menus à flèche */
        margin: 0 !important;
        color: #ffffff !important;
        font-size: 17px !important;
        font-weight: 500 !important;
        text-decoration: none !important;
        text-align: right !important;
        background: transparent !important;
        border: none !important;
        box-sizing: border-box !important;
        line-height: 1.4 !important;
    }
    
    /* Les items AVEC sous-menu : pas de padding-right supplémentaire */
    .site-header nav.elementor-nav-menu--dropdown > ul > li.menu-item-has-children > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul > li.menu-item-has-children > a {
        padding-right: 0 !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown a.elementor-item:hover,
    .site-header nav.elementor-nav-menu--dropdown a.elementor-item:focus,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container a.elementor-item:hover,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container a.elementor-item:focus {
        color: #fedd02 !important;
        background: transparent !important;
    }
    
    /* =========================================
       FLÈCHE SOUS-MENU
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown .sub-arrow,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .sub-arrow {
        display: inline-block !important;
        margin-left: 10px !important;
        vertical-align: middle !important;
        transition: transform 0.2s ease !important;
        width: 15px !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown .submenu-open > a .sub-arrow,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .submenu-open > a .sub-arrow {
        transform: rotate(180deg) !important;
    }
    
    /* =========================================
       SOUS-MENUS
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown ul.sub-menu,
    .site-header nav.elementor-nav-menu--dropdown .sub-menu,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container ul.sub-menu,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .sub-menu {
        display: none !important;
        position: static !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
        margin: 0 !important;
        padding: 0 0 10px 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        border: none !important;
        list-style: none !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown .submenu-open > ul.sub-menu,
    .site-header nav.elementor-nav-menu--dropdown .submenu-open > .sub-menu,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .submenu-open > ul.sub-menu,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .submenu-open > .sub-menu {
        display: block !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown ul.sub-menu > li,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container ul.sub-menu > li {
        width: 100% !important;
        text-align: right !important;
        border: none !important;
        background: transparent !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown ul.sub-menu > li > a,
    .site-header nav.elementor-nav-menu--dropdown ul.sub-menu a.elementor-sub-item,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container ul.sub-menu > li > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container ul.sub-menu a.elementor-sub-item {
        display: block !important;
        padding: 12px 25px 12px 0 !important;
        color: rgba(255, 255, 255, 0.7) !important;
        font-size: 15px !important;
        text-decoration: none !important;
        text-align: right !important;
        background: transparent !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown ul.sub-menu > li > a:hover,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container ul.sub-menu > li > a:hover {
        color: #fedd02 !important;
        background: transparent !important;
    }
    
    /* =========================================
       BOUTONS CTA DANS MENU MOBILE
       Même style que les autres items, ferré à droite
       ========================================= */
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-inscription.cta-active,
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-resultats.cta-active,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-inscription.cta-active,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-resultats.cta-active {
        margin-top: 10px !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
        text-align: right !important;
        display: block !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-inscription.cta-active > a,
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-resultats.cta-active > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-inscription.cta-active > a,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-resultats.cta-active > a {
        display: block !important;
        width: 100% !important;
        padding: 18px 25px 18px 0 !important;
        background: transparent !important;
        color: #ffffff !important;
        font-size: 17px !important;
        font-weight: 500 !important;
        text-transform: none !important;
        text-align: right !important;
        border-radius: 0 !important;
    }
    
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-inscription.cta-active > a:hover,
    .site-header nav.elementor-nav-menu--dropdown .menu-cta-resultats.cta-active > a:hover,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-inscription.cta-active > a:hover,
    .site-header .elementor-nav-menu--dropdown.elementor-nav-menu__container .menu-cta-resultats.cta-active > a:hover {
        color: #fedd02 !important;
        background: transparent !important;
        transform: none !important;
    }
}

/* =========================================
   BLOQUER SCROLL BODY
   ========================================= */
body.swimrun-menu-open {
    overflow: hidden !important;
}

/* =========================================
   FIX ANTI-FLASH
   ========================================= */
body.home .site-header:not(.smart-menu-ready) .elementor-nav-menu--main > .elementor-nav-menu > li:not(.menu-cta-inscription):not(.menu-cta-resultats) {
    opacity: 0 !important;
    visibility: hidden !important;
}

.site-header:not(.smart-menu-ready) .menu-cta-inscription,
.site-header:not(.smart-menu-ready) .menu-cta-resultats {
    display: none !important;
}