/**
 * RunLabs Menu - Styles Frontend
 * Version: 1.0.6
 */

/* ==========================================================================
   Variables CSS
   ========================================================================== */
:root {
    --runlabs-menu-bg: #ffffff;
    --runlabs-menu-text: #333333;
    --runlabs-menu-hover: #0073aa;
    --runlabs-submenu-bg: #f7f7f7;
    --runlabs-menu-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    --runlabs-menu-radius: 6px;
    --runlabs-menu-transition: 0.3s ease;
    --runlabs-menu-z-index: 9999;
}

/* ==========================================================================
   Container principal
   ========================================================================== */
.runlabs-menu-container {
    position: relative;
    width: 100%;
    background: var(--runlabs-menu-bg);
    z-index: var(--runlabs-menu-z-index);
    border-radius: var(--runlabs-menu-radius);
}

.runlabs-menu-container.is-sticky {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    box-shadow: var(--runlabs-menu-shadow);
    animation: runlabsSlideDown 0.3s ease;
    border-radius: 0;
    padding-right: 15px;
}

.runlabs-menu-container.is-sticky .runlabs-lang-item {
    margin-right: 15px;
}

@keyframes runlabsSlideDown {
    from {
        transform: translateY(-100%);
    }
    to {
        transform: translateY(0);
    }
}

/* ==========================================================================
   Menu principal
   ========================================================================== */
.runlabs-menu {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

.runlabs-menu-item {
    position: relative;
    margin: 0;
    padding: 0;
}

.runlabs-menu-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 15px 20px;
    color: var(--runlabs-menu-text);
    text-decoration: none;
    font-size: 15px;
    font-weight: 500;
    transition: color var(--runlabs-menu-transition), background-color var(--runlabs-menu-transition);
}

.runlabs-menu-link:hover,
.runlabs-menu-link:focus,
.runlabs-menu-item.current-menu-item > .runlabs-menu-link,
.runlabs-menu-item.current-menu-ancestor > .runlabs-menu-link {
    color: var(--runlabs-menu-hover);
}

/* ==========================================================================
   Éléments du menu
   ========================================================================== */
.runlabs-menu-text {
    display: inline-block;
}

.runlabs-menu-icon {
    font-size: 18px;
    line-height: 1;
}

.runlabs-menu-arrow {
    display: none !important;
}

/* Badge */
.runlabs-menu-badge {
    display: inline-block;
    padding: 2px 8px;
    margin-left: 8px;
    font-size: 11px;
    font-weight: 600;
    color: #ffffff;
    background-color: #ff6b6b;
    border-radius: 10px;
    text-transform: uppercase;
}

/* Description (Mega Menu) */
.runlabs-menu-description {
    display: block;
    padding: 5px 20px 15px;
    font-size: 13px;
    color: #666;
}

/* Image (Mega Menu) */
.runlabs-menu-image-wrap {
    padding: 10px 20px;
}

.runlabs-menu-image {
    max-width: 100%;
    height: auto;
    border-radius: var(--runlabs-menu-radius);
}

/* ==========================================================================
   Sous-menus
   ========================================================================== */
.runlabs-sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: var(--runlabs-submenu-bg);
    box-shadow: var(--runlabs-menu-shadow);
    border-radius: var(--runlabs-menu-radius);
    list-style: none !important;
    list-style-type: none !important;
    margin: 0;
    padding: 10px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity var(--runlabs-menu-transition), 
                visibility var(--runlabs-menu-transition), 
                transform var(--runlabs-menu-transition);
    z-index: calc(var(--runlabs-menu-z-index) + 1);
}

/* =====================================================================
   CORRECTION THEME ASTRA - Masquer les coches/chevrons du thème
   ===================================================================== */

/* Reset complet des listes */
.runlabs-menu-container ul,
.runlabs-menu-container li {
    list-style: none !important;
    list-style-type: none !important;
}

.runlabs-menu-container ul li::before,
.runlabs-menu-container ul li::marker {
    content: none !important;
    display: none !important;
}

/* =====================================================================
   MASQUER LES ÉLÉMENTS ASTRA DROPDOWN (HTML)
   ===================================================================== */
.runlabs-menu-container .dropdown-menu-toggle,
.runlabs-menu-container .ast-header-navigation-arrow,
.runlabs-menu-container .ast-icon,
.runlabs-menu-container .icon-arrow,
.runlabs-menu-container .ast-arrow-svg,
.runlabs-menu-container .ast-menu-toggle,
.runlabs-menu-container .sub-arrow,
.runlabs-menu-container [class*="ast-arrow"],
.runlabs-menu-container [class*="dropdown-menu-toggle"],
.runlabs-menu-container [class*="navigation-arrow"],
.runlabs-menu-container span[role="application"] {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    opacity: 0 !important;
    position: absolute !important;
    left: -9999px !important;
    pointer-events: none !important;
}

/* MASQUAGE AGRESSIF - Tous les pseudo-éléments dans les sous-menus */
.runlabs-menu-container .runlabs-sub-menu *::before {
    content: none !important;
    content: "" !important;
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0 !important;
}

/* Masquer les chevrons Astra spécifiquement dans les sous-menus */
.runlabs-menu-container .runlabs-sub-menu li > a::before,
.runlabs-menu-container .runlabs-sub-menu .menu-item > a::before,
.runlabs-menu-container .runlabs-sub-menu .menu-link::before,
.runlabs-menu-container .sub-menu li > a::before,
.runlabs-menu-container .sub-menu .menu-link::before,
.runlabs-sub-menu a::before,
.runlabs-sub-menu li::before,
.runlabs-sub-menu .runlabs-menu-item::before {
    content: none !important;
    content: "" !important;
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 0 !important;
    position: absolute !important;
    left: -9999px !important;
}

/* Masquer les icônes textuelles du thème Astra (›, ✓, etc.) */
.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-link::before {
    content: none !important;
    display: none !important;
}

/* Masquer les flèches dropdown Astra */
.runlabs-menu-container .ast-menu-toggle,
.runlabs-menu-container .sub-arrow,
.runlabs-menu-container .dropdown-menu-toggle {
    display: none !important;
}

/* Masquer les ::after sur les sous-menus UNIQUEMENT */
.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-link::after,
.runlabs-menu-container .runlabs-sub-menu a::after {
    content: none !important;
    display: none !important;
}

/* Empêcher le thème d'ajouter du padding-left pour les icônes */
.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-link {
    padding-left: 20px !important;
    text-indent: 0 !important;
}

/* S'assurer que le texte du menu est propre */
.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-text {
    display: inline !important;
}

.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-text::before,
.runlabs-menu-container .runlabs-sub-menu .runlabs-menu-text::after {
    content: none !important;
    display: none !important;
}

.runlabs-menu-item:hover > .runlabs-sub-menu,
.runlabs-menu-item.is-open > .runlabs-sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Sous-menus imbriqués */
.runlabs-sub-menu .runlabs-sub-menu {
    top: -10px;
    left: 100%;
}

.runlabs-sub-menu .runlabs-menu-link {
    padding: 10px 20px;
    font-weight: 400;
}

.runlabs-sub-menu .runlabs-menu-link:hover {
    background-color: rgba(0, 0, 0, 0.05);
}

.runlabs-sub-menu .runlabs-menu-arrow {
    margin-left: auto;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid currentColor;
}

/* ==========================================================================
   Compatibilité Thème Astra - Masquer les indicateurs de dropdown
   ========================================================================== */
/* Masquer les chevrons › ajoutés par Astra */
.runlabs-menu-container .ast-menu-toggle,
.runlabs-menu-container .dropdown-menu-toggle,
.runlabs-menu-container .menu-item .sub-arrow,
.runlabs-menu-container .caret,
.runlabs-menu-container .indicator {
    display: none !important;
}

/* Masquer les pseudo-éléments de navigation Astra */
.runlabs-menu-container .ast-header-navigation a::before,
.runlabs-menu-container .ast-header-navigation a::after,
.runlabs-menu-container .main-header-menu a::before,
.runlabs-menu-container .main-header-menu a::after,
.runlabs-menu-container .primary-menu a::before,
.runlabs-menu-container .primary-menu a::after {
    content: none !important;
    display: none !important;
}

/* Masquer les indicateurs de sous-menu dans tous les thèmes */
.runlabs-menu-container .sub-menu .menu-item > a::before,
.runlabs-menu-container .sub-menu .menu-item > a::after,
.runlabs-menu-container ul.sub-menu li a::before,
.runlabs-menu-container ul.sub-menu li a::after {
    content: none !important;
    display: none !important;
}

/* Override pour le texte des liens dans les sous-menus */
.runlabs-sub-menu .runlabs-menu-link .runlabs-menu-text {
    display: inline !important;
}

/* Masquer tout caractère avant le texte dans les sous-menus */
.runlabs-sub-menu .runlabs-menu-link::before {
    content: none !important;
    display: none !important;
}

/* ==========================================================================
   Mega Menu
   ========================================================================== */
.runlabs-mega-menu > .runlabs-sub-menu {
    left: 0;
    right: 0;
    min-width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding: 20px;
}

.runlabs-mega-cols-2 > .runlabs-sub-menu > .runlabs-menu-item { width: 50%; }
.runlabs-mega-cols-3 > .runlabs-sub-menu > .runlabs-menu-item { width: 33.333%; }
.runlabs-mega-cols-4 > .runlabs-sub-menu > .runlabs-menu-item { width: 25%; }
.runlabs-mega-cols-5 > .runlabs-sub-menu > .runlabs-menu-item { width: 20%; }
.runlabs-mega-cols-6 > .runlabs-sub-menu > .runlabs-menu-item { width: 16.666%; }

.runlabs-mega-menu > .runlabs-sub-menu > .runlabs-menu-item {
    padding: 10px;
}

.runlabs-mega-menu > .runlabs-sub-menu > .runlabs-menu-item > .runlabs-menu-link {
    font-weight: 600;
    color: var(--runlabs-menu-text);
    padding: 10px;
    border-bottom: 2px solid var(--runlabs-menu-hover);
    margin-bottom: 10px;
}

.runlabs-mega-menu > .runlabs-sub-menu .runlabs-sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    background: transparent;
    padding: 0;
}

.runlabs-mega-menu > .runlabs-sub-menu .runlabs-sub-menu .runlabs-menu-link {
    padding: 8px 10px;
    font-size: 14px;
}

/* ==========================================================================
   Sélecteur de langue
   ========================================================================== */
.runlabs-lang-item {
    margin-left: auto !important;
    margin-right: 15px !important;
}

.runlabs-language-switcher {
    position: relative;
    display: inline-block;
}

.runlabs-lang-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 15px;
    background: transparent;
    border: 1px solid #ddd;
    border-radius: var(--runlabs-menu-radius);
    cursor: pointer;
    font-size: 14px;
    color: var(--runlabs-menu-text);
    transition: all var(--runlabs-menu-transition);
}

.runlabs-lang-toggle:hover {
    border-color: var(--runlabs-menu-hover);
}

.runlabs-flag {
    width: 24px;
    height: 18px;
    object-fit: cover;
    border-radius: 2px;
}

.runlabs-lang-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 150px;
    background: var(--runlabs-menu-bg);
    box-shadow: var(--runlabs-menu-shadow);
    border-radius: var(--runlabs-menu-radius);
    list-style: none;
    margin: 5px 0 0;
    padding: 5px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--runlabs-menu-transition);
    z-index: calc(var(--runlabs-menu-z-index) + 2);
}

.runlabs-language-switcher.is-open .runlabs-lang-dropdown,
.runlabs-language-switcher:hover .runlabs-lang-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.runlabs-lang-dropdown li {
    margin: 0;
}

.runlabs-lang-dropdown a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 15px;
    color: var(--runlabs-menu-text);
    text-decoration: none;
    transition: background-color var(--runlabs-menu-transition);
}

.runlabs-lang-dropdown a:hover,
.runlabs-lang-dropdown li.active a {
    background-color: rgba(0, 0, 0, 0.05);
}

.runlabs-lang-dropdown li.active a {
    font-weight: 600;
}

/* ==========================================================================
   Bouton hamburger (mobile)
   ========================================================================== */
.runlabs-menu-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    padding: 0;
    background: transparent;
    border: none;
    cursor: pointer;
    z-index: calc(var(--runlabs-menu-z-index) + 5);
}

.runlabs-hamburger {
    position: relative;
    display: block;
    width: 24px;
    height: 2px;
    background: var(--runlabs-menu-text);
    transition: background-color var(--runlabs-menu-transition);
}

.runlabs-hamburger::before,
.runlabs-hamburger::after {
    content: '';
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background: var(--runlabs-menu-text);
    transition: transform var(--runlabs-menu-transition);
}

.runlabs-hamburger::before {
    top: -8px;
}

.runlabs-hamburger::after {
    bottom: -8px;
}

/* État ouvert */
.runlabs-menu-toggle[aria-expanded="true"] .runlabs-hamburger {
    background: transparent;
}

.runlabs-menu-toggle[aria-expanded="true"] .runlabs-hamburger::before {
    transform: translateY(8px) rotate(45deg);
}

.runlabs-menu-toggle[aria-expanded="true"] .runlabs-hamburger::after {
    transform: translateY(-8px) rotate(-45deg);
}

/* Bouton toggle sous-menu mobile */
.runlabs-submenu-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: transparent;
    border: none;
    border-left: 1px solid #ddd;
    cursor: pointer;
}

.runlabs-toggle-icon {
    position: relative;
    display: block;
    width: 12px;
    height: 2px;
    background: var(--runlabs-menu-text);
}

.runlabs-toggle-icon::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    width: 2px;
    height: 12px;
    background: var(--runlabs-menu-text);
    transform: translate(-50%, -50%);
    transition: transform var(--runlabs-menu-transition);
}

.runlabs-submenu-toggle[aria-expanded="true"] .runlabs-toggle-icon::after {
    transform: translate(-50%, -50%) rotate(90deg);
}

/* ==========================================================================
   Styles de menu (variantes)
   ========================================================================== */

/* Style: Minimal */
.runlabs-style-minimal .runlabs-menu-link {
    padding: 12px 15px !important;
}

.runlabs-style-minimal .runlabs-sub-menu {
    border-radius: 0 !important;
}

/* Style: Encadré (Boxed) */
.runlabs-style-boxed .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link:hover {
    background-color: rgba(0, 0, 0, 0.05) !important;
}

.runlabs-style-boxed .runlabs-menu > .runlabs-menu-item.current-menu-item > .runlabs-menu-link {
    background-color: var(--runlabs-menu-hover) !important;
    color: #ffffff !important;
}

/* Style: Souligné (Underline) - RENFORCÉ */
.runlabs-style-underline .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link {
    position: relative !important;
}

.runlabs-style-underline .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 10px !important;
    left: 20px !important;
    right: 20px !important;
    height: 2px !important;
    background: var(--runlabs-menu-hover) !important;
    transform: scaleX(0) !important;
    transition: transform var(--runlabs-menu-transition) !important;
    pointer-events: none !important;
}

.runlabs-style-underline .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link:hover::after,
.runlabs-style-underline .runlabs-menu > .runlabs-menu-item.current-menu-item > .runlabs-menu-link::after,
.runlabs-style-underline .runlabs-menu > .runlabs-menu-item:hover > .runlabs-menu-link::after {
    transform: scaleX(1) !important;
}

/* Style: Pilule (Pill) - RENFORCÉ */
.runlabs-style-pill .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link {
    margin: 5px !important;
    border-radius: 25px !important;
    transition: all var(--runlabs-menu-transition) !important;
}

.runlabs-style-pill .runlabs-menu > .runlabs-menu-item > .runlabs-menu-link:hover,
.runlabs-style-pill .runlabs-menu > .runlabs-menu-item:hover > .runlabs-menu-link {
    background-color: var(--runlabs-menu-hover) !important;
    color: #ffffff !important;
}

/* ==========================================================================
   Responsive - Tablette et Mobile
   ========================================================================== */
@media screen and (max-width: 992px) {
    .runlabs-menu-toggle {
        display: flex;
    }
    
    .runlabs-submenu-toggle {
        display: flex;
    }
    
    .runlabs-menu-container {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        padding: 0 15px;
    }
    
    .runlabs-menu {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        flex-direction: column;
        align-items: stretch;
        background: var(--runlabs-menu-bg);
        padding: 70px 0 20px;
        overflow-y: auto;
        opacity: 0;
        visibility: hidden;
        transform: translateX(-100%);
        transition: opacity var(--runlabs-menu-transition),
                    visibility var(--runlabs-menu-transition),
                    transform var(--runlabs-menu-transition);
    }
    
    .runlabs-menu.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateX(0);
    }
    
    .runlabs-menu-item {
        border-bottom: 1px solid #eee;
    }
    
    .runlabs-menu-link {
        padding: 15px 20px;
    }
    
    .runlabs-has-children > .runlabs-menu-link {
        padding-right: 60px;
    }
    
    .runlabs-has-children {
        position: relative;
    }
    
    .runlabs-has-children > .runlabs-submenu-toggle {
        position: absolute;
        right: 0;
        top: 0;
        height: 100%;
    }
    
    .runlabs-menu-arrow {
        display: none;
    }
    
    /* Sous-menus mobile */
    .runlabs-sub-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        border-radius: 0;
        padding: 0;
        max-height: 0;
        overflow: hidden;
        transition: max-height var(--runlabs-menu-transition);
    }
    
    .runlabs-menu-item.is-open > .runlabs-sub-menu {
        max-height: 1000px;
    }
    
    .runlabs-sub-menu .runlabs-menu-link {
        padding-left: 40px;
    }
    
    .runlabs-sub-menu .runlabs-sub-menu .runlabs-menu-link {
        padding-left: 60px;
    }
    
    /* Mega menu mobile */
    .runlabs-mega-menu > .runlabs-sub-menu {
        flex-direction: column;
        padding: 0;
    }
    
    .runlabs-mega-cols-2 > .runlabs-sub-menu > .runlabs-menu-item,
    .runlabs-mega-cols-3 > .runlabs-sub-menu > .runlabs-menu-item,
    .runlabs-mega-cols-4 > .runlabs-sub-menu > .runlabs-menu-item,
    .runlabs-mega-cols-5 > .runlabs-sub-menu > .runlabs-menu-item,
    .runlabs-mega-cols-6 > .runlabs-sub-menu > .runlabs-menu-item {
        width: 100%;
        padding: 0;
    }
    
    /* Sélecteur de langue mobile */
    .runlabs-language-switcher {
        order: -1;
        margin-left: 0;
        margin-right: auto;
    }
    
    .runlabs-lang-toggle {
        padding: 8px 12px;
    }
    
    .runlabs-lang-name {
        display: none;
    }
}

/* Small phones */
@media screen and (max-width: 480px) {
    .runlabs-menu-link {
        font-size: 14px;
        padding: 12px 15px;
    }
    
    .runlabs-sub-menu .runlabs-menu-link {
        padding-left: 30px;
    }
}

/* ==========================================================================
   Utilitaires d'accessibilité
   ========================================================================== */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

/* Focus visible */
.runlabs-menu-link:focus-visible,
.runlabs-submenu-toggle:focus-visible,
.runlabs-menu-toggle:focus-visible,
.runlabs-lang-toggle:focus-visible {
    outline: 2px solid var(--runlabs-menu-hover);
    outline-offset: 2px;
}

/* ==========================================================================
   Animations
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
