/* Header / Logo / Site Branding - Styles extracted from africa.css for consistency */

/* === STYLES ISOLÉS DU LOGO - LOGO CENTERED === */

/* Conteneur du branding - centré et avec hauteur fixe */
.site-branding {
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.site-branding-center {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center;
  height: auto !important;
  min-height: 80px !important;
  flex: 1;
  padding: 10px 0;
}

.site-header.clone .site-branding-center {
  min-height: 60px !important;
  padding: 8px 0;
}

/* Styles pour l'image du logo - dimensions et positionnement */
.logo-image {
  max-height: 50px;
  width: auto;
  display: block !important;
  margin: -50px auto 0 auto !important;
  opacity: 1 !important;
  visibility: visible !important;
  transition: all 0.3s ease;
  object-fit: contain;
}

/* Logo en mode normal (header transparent) */
.site-header:not(.clone) .logo-image {
  max-height: 50px;
  max-width: 100%;
}

/* Logo en mode scroll (header clone) */
.site-header.clone .logo-image {
  max-height: 45px;
  max-width: 100%;
}

/* Conteneur du titre du site */
.site-title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  padding: 0 !important;
}

.site-title a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.site-title a img {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  max-width: 100%;
  height: auto;
  margin: 0 !important;
  padding: 0 !important;
}

/* Masquer le texte du logo */
.logo-text {
  display: none !important;
}

/* === STYLES TABLETTE/MOYEN (991px) - Placé avant pour cascade correcte === */
@media screen and (max-width: 991px) {

  .logo-image,
  .site-header:not(.clone) .logo-image,
  .site-header.clone .logo-image {
    max-height: 55px !important;
    max-width: 85% !important;
    margin: 6px auto 0 auto !important;
    transform: translateX(-120px) !important;
  }
}


/* === STYLES MOBILES - LOGO CENTRÉ === */

/* === FIX ISOLÉ iPAD AIR 5 (769px - 850px) === */
@media screen and (min-width: 769px) and (max-width: 850px) {

  .logo-image,
  .site-header:not(.clone) .logo-image,
  .site-header.clone .logo-image {
    transform: translateX(-70px) translateY(-13px) !important;
    margin-top: 0 !important;
    max-width: 85% !important;
  }
}

@media screen and (max-width: 768px) {
  .elementor-element-7dcf136 {
    justify-content: flex-start !important;
  }

  .site-branding-center {
    min-height: 70px !important;
    padding: 0 0 !important;
    margin-top: -10px !important;
  }

  .logo-image,
  .site-header:not(.clone) .logo-image,
  .site-header.clone .logo-image {
    max-height: 55px !important;
    max-width: 80% !important;
    margin: 6px auto 0 auto !important;
    transform: translateX(-120px) translateY(-1px) !important;
  }

  .site-title {
    width: 100%;
  }

  .site-title a {
    width: 100%;
  }
}


@media screen and (max-width: 480px) {
  .site-branding-center {
    min-height: 60px !important;
    padding: 0 0 !important;
    margin-top: -10px !important;
  }

  .logo-image,
  .site-header:not(.clone) .logo-image,
  .site-header.clone .logo-image {
    max-height: 45px !important;
    max-width: 75% !important;
    margin: 11px auto 0 auto !important;
    transform: translateX(-70px) translateY(-1px) !important;
  }
}

/* --- AJUSTEMENT POSITION LOGO HEADER MOBILE (SANS SCROLL) --- */





/* === HEADER STYLES & LAYOUT === */

/* Styles pour le header - texte blanc par défaut */
.site-header:not(.clone) .nav-menu a,
.site-header:not(.clone) .menu-toggle .lines,
.site-header:not(.clone) .menu-toggle .lines:before,
.site-header:not(.clone) .menu-toggle .lines:after {
  color: #ffffff !important;
}

.site-header:not(.clone) .nav-menu a:hover {
  color: #000000 !important;
}

/* Styles pour l'élément actif - Noir */
.site-header .nav-menu .current-menu-item a,
.site-header.clone .nav-menu .current-menu-item a {
  color: #000000 !important;
}

.site-header .nav-menu .current-menu-item a:hover,
.site-header.clone .nav-menu .current-menu-item a:hover {
  color: #000000 !important;
}

/* Styles pour le bouton de langue - noir par défaut */
.language-btn {
  background: none;
  border: none;
  color: #ffffff;
  font-weight: bold;
  font-size: 14px;
  padding: 8px 16px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  letter-spacing: 1px;
  min-width: 40px;
  text-align: center;
  white-space: nowrap;
}

.language-btn:hover {
  background: none;
  color: #ffffff;
  transform: none;
}

.language-btn.active {
  background: none;
  color: #ffffff;
}

/* Lang toggle showing both EN-FR with active highlight */
.language-btn .lang-part,
.menu-item-language .lang-part {
  opacity: 0.6;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.language-btn .lang-part.active,
.menu-item-language .lang-part.active {
  opacity: 1;
  color: #d4af37;
  /* highlight active language */
  font-weight: 700;
}

.language-btn .lang-sep,
.menu-item-language .lang-sep {
  display: inline-block;
  margin: 0 8px;
  /* small spacing around dash */
  opacity: 0.6;
}

/* Styles pour le header en mode scroll - texte blanc, header noir */
.site-header.clone .header-wrap:before {
  background: #000000 !important;
  opacity: 1 !important;
}

/* S'assurer que le header reste noir quand le menu est ouvert, même en mode scroll */
.is-menu-toggled-on .site-header.clone .header-wrap:before {
  background: #000000 !important;
  opacity: 1 !important;
}

/* Styles pour le hamburger en mode scroll quand le menu est ouvert */
.is-menu-toggled-on .site-header.clone .menu-toggle .lines,
.is-menu-toggled-on .site-header.clone .menu-toggle .lines:before,
.is-menu-toggled-on .site-header.clone .menu-toggle .lines:after {
  background-color: #ffffff !important;
}

/* S'assurer que le menu lui-même n'est pas affecté par l'animation du hamburger */
.is-menu-toggled-on .nav-menu {
  /* Le menu garde son comportement normal */
  display: block !important;
}

.is-menu-toggled-on .nav-menu ul {
  /* La liste du menu garde son comportement normal */
  display: block !important;
}

.is-menu-toggled-on .nav-menu li {
  /* Les éléments du menu gardent leur comportement normal */
  display: block !important;
}

.is-menu-toggled-on .nav-menu a {
  /* Les liens du menu gardent leur comportement normal */
  display: block !important;
}

/* Décalage de 30px vers la droite pour les titres du menu (desktop uniquement) */
@media screen and (min-width: 992px) {
  .site-header .nav-menu>ul#menu-mymenu {
    transform: translateX(90px);
  }
}

/* Styles pour le menu mobile quand il est ouvert - Demi-écran comme l'exemple */
@media screen and (max-width: 991px) {
  .language-switcher {
    display: none !important;
  }

  .menu-item-language {
    display: block !important;
  }

  /* Styles pour le texte du header en mobile - Texte blanc */
  .site-header:not(.clone) .nav-menu a,
  .site-header:not(.clone) .menu-toggle .lines,
  .site-header:not(.clone) .menu-toggle .lines:before,
  .site-header:not(.clone) .menu-toggle .lines:after {
    color: #ffffff !important;
  }

  .site-header:not(.clone) .menu-toggle .lines,
  .site-header:not(.clone) .menu-toggle .lines:before,
  .site-header:not(.clone) .menu-toggle .lines:after {
    background-color: #ffffff !important;
  }

  /* Quand le menu est ouvert en mobile - Texte blanc */
  .is-menu-toggled-on .site-header:not(.clone) .nav-menu a,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
    color: #ffffff !important;
  }

  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
    background-color: #ffffff !important;
  }

  /* Animation d'entrée du menu - slide depuis la droite */
  .nav-menu {
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
  }

  .is-menu-toggled-on .nav-menu {
    transform: translateX(0);
  }

  /* Suppression de l'overlay car le menu est plein écran noir */
  .is-menu-toggled-on::before {
    display: none !important;
  }
}

.site-header.clone .nav-menu a,
.site-header.clone .menu-toggle .lines,
.site-header.clone .menu-toggle .lines:before,
.site-header.clone .menu-toggle .lines:after {
  color: #ffffff !important;
}

.site-header.clone .nav-menu a:hover {
  color: #000000 !important;
}

/* Style pour le bouton quand on scrolle - blanc */
.site-header.clone .language-btn {
  color: #ffffff !important;
}

/* Fix: Do not force hover/active states to white in clone mode, let language.css handle it */
/* Removed overriding rules to allow language.css to take precedence */

/* S'assurer que le logo reste blanc dans tous les cas */
.site-header:not(.clone) .logo-image,
.site-header.clone .logo-image {
  filter: brightness(0) invert(1) !important;
}

/* Forcer le positionnement à droite dans le header */
.layout-medium {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.nav-menu {
  flex: 1;
  display: flex;
  justify-content: center;
}

.language-switcher {
  flex-shrink: 0;
}

/* Styles et ordre des éléments (Menu burger à droite pour mobile) */
.menu-toggle {
  order: 1 !important;
  margin-left: auto !important;
}

.nav-menu {
  order: 2 !important;
}

.language-switcher {
  order: 3 !important;
}

/* Masquer le language switcher sur mobile et afficher l'option dans le menu */
@media screen and (max-width: 991px) {
  .language-switcher {
    display: none !important;
  }

  .menu-item-language {
    display: block !important;
  }

  /* Styles pour le texte du header en mobile - Texte blanc */
  .site-header:not(.clone) .nav-menu a,
  .site-header:not(.clone) .menu-toggle .lines,
  .site-header:not(.clone) .menu-toggle .lines:before,
  .site-header:not(.clone) .menu-toggle .lines:after {
    color: #ffffff !important;
  }

  .site-header:not(.clone) .menu-toggle .lines,
  .site-header:not(.clone) .menu-toggle .lines:before,
  .site-header:not(.clone) .menu-toggle .lines:after {
    background-color: #ffffff !important;
  }

  /* Quand le menu est ouvert en mobile - Texte blanc */
  .is-menu-toggled-on .site-header:not(.clone) .nav-menu a,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
    color: #ffffff !important;
  }

  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
  .is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
    background-color: #ffffff !important;
  }

  /* Animation d'entrée du menu - slide depuis la droite */
  .nav-menu {
    transform: translateX(100%);
    transition: transform 0.3s ease-in-out;
  }

  .is-menu-toggled-on .nav-menu {
    transform: translateX(0);
  }

  /* Suppression de l'overlay car le menu est plein écran noir */
  .is-menu-toggled-on::before {
    display: none !important;
  }
}

/* Afficher le language switcher sur desktop et masquer l'option dans le menu */
@media screen and (min-width: 992px) {
  .language-switcher {
    display: flex !important;
  }

  .menu-item-language {
    display: none !important;
  }
}

/* Styles pour le header quand le menu est ouvert - Header noir */
.is-menu-toggled-on .site-header:not(.clone) .header-wrap:before {
  background: #000000 !important;
  opacity: 1 !important;
}

/* Styles pour le hamburger quand le menu est ouvert - Texte blanc */
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
  background-color: #ffffff !important;
}

/* Isolation complète de l'animation du hamburger - ne s'applique qu'au bouton */
.is-menu-toggled-on .menu-toggle .lines {
  /* Animation spécifique au hamburger uniquement */
  background-color: transparent !important;
}

.is-menu-toggled-on .menu-toggle .lines:before {
  /* Animation spécifique au hamburger uniquement */
  top: 0 !important;
  transform: rotate(45deg) !important;
  background-color: #ffffff !important;
}

.is-menu-toggled-on .menu-toggle .lines:after {
  /* Animation spécifique au hamburger uniquement */
  bottom: 0 !important;
  transform: rotate(-45deg) !important;
  background-color: #ffffff !important;
}

/* Animation du hamburger pour fermer (X) */
.is-menu-toggled-on .menu-toggle .lines {
  background-color: transparent !important;
}

/* ==========================================================================
   DESIGN DU MENU MOBILE PLEIN ÉCRAN NOIR (RÉPONSE USER)
   ========================================================================== */
@media screen and (max-width: 991px) {

  /* Conteneur principal du menu quand ouvert */
  .is-menu-toggled-on .nav-menu {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100vh !important;
    background: #000000 !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    padding-top: 140px !important;
    /* Espace pour logo et hamburger */
    z-index: 9999 !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow-y: auto !important;
  }

  /* Liste des menus */
  .is-menu-toggled-on .nav-menu ul {
    width: 100% !important;
    padding: 0 40px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
  }

  /* Éléments de liste */
  .is-menu-toggled-on .nav-menu li {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* Liens du menu */
  .is-menu-toggled-on .nav-menu a {
    font-size: 20px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    padding: 22px 0 !important;
    border-bottom: 1px solid #ffffff !important;
    /* Ligne blanche demandée */
    display: block !important;
    width: 100% !important;
    color: #ffffff !important;
    text-align: left !important;
    background: transparent !important;
    transition: all 0.3s ease !important;
  }

  .is-menu-toggled-on .nav-menu a:hover {
    padding-left: 10px !important;
    background: transparent !important;
  }

  /* Style spécial LANGUAGE */
  .is-menu-toggled-on .menu-item-language {
    margin-top: 20px !important;
  }

  .is-menu-toggled-on .menu-item-language a {
    border-bottom: none !important;
    font-size: 15px !important;
    color: #ffffff !important;
    opacity: 0.8 !important;
    padding: 15px 0 !important;
    letter-spacing: 1px !important;
  }

  .is-menu-toggled-on .menu-item-language .lang-part.active {
    color: #d4af37 !important;
    /* Or pour la langue active pour lisibilité */
    font-weight: 700 !important;
    opacity: 1 !important;
  }

  /* Hamburger Toggle (X) - S'assurer qu'il reste au dessus et à droite */
  .is-menu-toggled-on .menu-toggle {
    z-index: 10000 !important;
    position: fixed !important;
    top: 30px !important;
    right: 30px !important;
  }

  /* Branding (Logo) - S'assurer qu'il est visible au dessus du noir */
  .is-menu-toggled-on .site-branding {
    z-index: 10000 !important;
    position: fixed !important;
    top: 20px !important;
    left: 20px !important;
    width: auto !important;
    pointer-events: none !important;
  }

  .is-menu-toggled-on .site-branding a {
    pointer-events: auto !important;
  }
}

.is-menu-toggled-on .menu-toggle .lines:before {
  transform: rotate(45deg) translate(5px, 5px) !important;
  background-color: #ffffff !important;
}

.is-menu-toggled-on .menu-toggle .lines:after {
  transform: rotate(-45deg) translate(7px, -6px) !important;
  background-color: #ffffff !important;
}

/* Styles pour le language switcher quand le menu est ouvert */
.is-menu-toggled-on .site-header:not(.clone) .language-btn {
  color: #ffffff !important;
}

.is-menu-toggled-on .site-header:not(.clone) .language-btn:hover {
  color: #ffffff !important;
}

/* Styles de base pour le hamburger */
.menu-toggle {
  position: relative;
  cursor: pointer;
  z-index: 1000;
  display: block;
  width: 30px;
  height: 30px;
}

.menu-toggle .lines {
  display: block;
  width: 25px;
  height: 2px;
  background-color: #ffffff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all 0.3s ease;
}

.menu-toggle .lines:before,
.menu-toggle .lines:after {
  content: '';
  position: absolute;
  width: 25px;
  height: 2px;
  background-color: #ffffff;
  transition: all 0.3s ease;
}

.menu-toggle .lines:before {
  top: -8px;
}

.menu-toggle .lines:after {
  bottom: -8px;
}

/* Animation du hamburger pour fermer (X) */
.is-menu-toggled-on .menu-toggle .lines {
  background-color: transparent !important;
}