/* ========================================
   HEADER & MENU FIX
   v2.0.0 - Header mobile corrigé
   ======================================== */

/* ==========================================
   HEADER MOBILE - Logo à gauche, Hamburger à droite
   ========================================== */

@media (max-width: 1024px) {

    /* FORCE le header en ligne */
    .site-header .container {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: space-between !important;
        align-items: center !important;
        gap: 0 !important;
        padding: 12px 16px !important;
    }

    /* Logo à gauche */
    .site-header .site-branding {
        order: 1 !important;
        flex-shrink: 0 !important;
    }

    /* Hamburger à droite */
    .site-header .mobile-menu-toggle {
        order: 3 !important;
        flex-shrink: 0 !important;
        margin-left: auto !important;
    }

    /* Navigation cachée (entre les deux dans le DOM mais invisible) */
    .site-header .main-navigation {
        order: 2 !important;
        position: absolute !important;
        top: 100% !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-height: 0 !important;
        overflow: hidden !important;
        background: #fff !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
        transition: max-height 0.3s ease, opacity 0.3s ease !important;
        z-index: 1000 !important;
        opacity: 0 !important;
        visibility: hidden !important;
    }

    /* Menu ouvert */
    .site-header .main-navigation.menu-open {
        max-height: 85vh !important;
        opacity: 1 !important;
        visibility: visible !important;
        overflow-y: auto !important;
    }

    /* Logo mobile - GRANDE TAILLE */
    .site-header .logo-img,
    .site-header .site-logo img,
    .site-header img.logo-img {
        height: 55px !important;
        min-height: 55px !important;
        max-width: 200px !important;
        width: auto !important;
    }

    /* Menu items en colonne */
    .main-navigation .nav-menu {
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .main-navigation .nav-menu > li {
        width: 100% !important;
        border-bottom: 1px solid #e5e7eb !important;
    }

    .main-navigation .nav-menu > li > a {
        display: block !important;
        padding: 16px 20px !important;
        font-size: 1.1rem !important;
        color: #1E2C52 !important;
        text-align: left !important;
    }

    /* ==========================================
       SOUS-MENUS OFFRES - Correction
       ========================================== */

    /* Sous-menus (incluant offres) */
    .main-navigation .nav-menu .sub-menu,
    .main-navigation .nav-menu .offers-submenu,
    .main-navigation .sub-menu,
    .nav-menu .sub-menu {
        position: static !important;
        display: none !important;
        width: 100% !important;
        max-width: 100% !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        background: #f3f4f6 !important;
        box-shadow: none !important;
        border: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* Sous-menu ouvert */
    .main-navigation .nav-menu .menu-item-has-children.sub-menu-open .sub-menu,
    .main-navigation .nav-menu .menu-item-offers.sub-menu-open .offers-submenu,
    .nav-menu .menu-item-has-children.sub-menu-open > .sub-menu {
        display: block !important;
    }

    /* Items des sous-menus */
    .main-navigation .sub-menu li,
    .nav-menu .sub-menu li {
        width: 100% !important;
        border-bottom: 1px solid #e5e7eb !important;
    }

    .main-navigation .sub-menu li:last-child,
    .nav-menu .sub-menu li:last-child {
        border-bottom: none !important;
    }

    .main-navigation .sub-menu a,
    .nav-menu .sub-menu a {
        display: block !important;
        padding: 14px 20px 14px 35px !important;
        font-size: 1rem !important;
        color: #1E2C52 !important;
        text-align: left !important;
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
    }

    /* Icône flèche pour sous-menus */
    .nav-menu .menu-item-has-children > a::after {
        content: "▼" !important;
        font-size: 0.7rem !important;
        margin-left: 8px !important;
        transition: transform 0.3s ease !important;
    }

    .nav-menu .menu-item-has-children.sub-menu-open > a::after {
        transform: rotate(180deg) !important;
    }
}

/* ==========================================
   PETIT MOBILE (< 768px)
   ========================================== */

@media (max-width: 768px) {

    .site-header .container {
        padding: 10px 12px !important;
    }

    .site-header .logo-img,
    .site-header .site-logo img,
    .site-header img.logo-img {
        height: 50px !important;
        min-height: 50px !important;
        max-width: 180px !important;
    }

    .main-navigation .nav-menu > li > a {
        padding: 14px 16px !important;
        font-size: 1rem !important;
    }

    .main-navigation .sub-menu a,
    .nav-menu .sub-menu a {
        padding: 12px 16px 12px 30px !important;
    }
}

/* ==========================================
   TRÈS PETIT MOBILE (< 480px)
   ========================================== */

@media (max-width: 480px) {

    .site-header .container {
        padding: 8px 10px !important;
    }

    .site-header .logo-img,
    .site-header .site-logo img,
    .site-header img.logo-img {
        height: 45px !important;
        min-height: 45px !important;
        max-width: 160px !important;
    }

    .hamburger-icon {
        width: 26px !important;
        height: 20px !important;
    }

    .main-navigation .nav-menu > li > a {
        padding: 12px 14px !important;
        font-size: 0.95rem !important;
    }
}

/* ==========================================
   BARRE NAVIGATION FILIALES - Collée au header
   ========================================== */

.filiales-nav,
.filiale-nav,
.subsidiary-nav,
.offers-nav {
    position: relative !important;
    top: 0 !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
}
