/* ================================================
   SÉLECTEUR LANGUE - Globe (Header)
   Position : Desktop droite / Mobile gauche
   ================================================ */

.header-language-selector {
  position: relative;
  display: inline-block;
}

/* Règles globales (landing + auth) - Style original */
.language-globe-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 50%;
  transition: all 0.3s ease;
}

/* Landing page - Style original (plus grand, visible) */
.landing-header .language-globe-btn {
  width: 48px;
  height: 48px;
  background: rgba(255, 255, 255, 0.15);
  border: 1.5px solid rgba(255, 255, 255, 0.4);
  color: white;
  font-size: 20px;
  backdrop-filter: blur(10px);
}

.landing-header .language-globe-btn:hover {
  background: rgba(255, 255, 255, 0.25);
  border-color: rgba(255, 255, 255, 0.6);
  transform: translateY(-2px);
}

.language-globe-btn svg {
  /* opacity: 0.95 supprimé - géré par règles haute spécificité dans header.css */
  width: 18px;
  height: 18px;
  flex-shrink: 0; /* Empêcher réduction de taille */
}

/* Dropdown menu */
.language-dropdown-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  
  background: white;
  border-radius: 16px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.25);
  
  padding: 8px;
  min-width: 220px;
  
  opacity: 0;
  visibility: hidden;
  transform: translateY(-12px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  
  z-index: 1000;
}

.header-language-selector.open .language-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Options du menu */
.language-menu-option {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 14px 16px;
  
  background: transparent;
  border: none;
  border-radius: 10px;
  
  cursor: pointer;
  transition: all 0.2s ease;
}

.language-menu-option:hover {
  background: rgba(230, 57, 92, 0.08);
}

.language-menu-option.active {
  background: rgba(230, 57, 92, 0.12);
}

.lang-name {
  color: #333;
  font-size: 0.95rem;
  font-weight: 500;
  text-align: left;
}

.lang-code {
  color: #999;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.language-menu-option.active .lang-name {
  color: #FF385C;
  font-weight: 700;
}

.language-menu-option.active .lang-code {
  color: #FF385C;
}

/* ================================================
   RESPONSIVE
   ================================================ */

/* DESKTOP (> 900px) - Position DROITE */
@media (min-width: 901px) {
  /* Cacher le globe mobile (celui qui n'est pas dans .landing-cta.desktop) */
  .landing-header > .header-language-selector:not(.landing-cta .header-language-selector) {
    display: none;
  }
  
  /* Globe desktop visible */
  .landing-cta.desktop .header-language-selector {
    display: inline-block;
    margin-left: 16px;
  }
  
  /* Dropdown aligné à droite */
  .landing-cta.desktop .language-dropdown-menu {
    right: 0;
    left: auto;
  }
}

/* MOBILE (≤ 900px) - Position à droite avant burger */
@media (max-width: 900px) {
  /* Cacher globe desktop */
  .landing-cta.desktop .header-language-selector {
    display: none;
  }
  
  /* Globe mobile à droite du logo, avant le burger */
  .landing-header > .header-language-selector:not(.landing-cta .header-language-selector) {
    display: inline-block;
    position: absolute;
    right: 70px; /* 70px = largeur burger (50px) + gap (20px) */
    top: 50%;
    transform: translateY(-50%);
  }
  
  .language-globe-btn {
    width: 38px;
    height: 38px;
  }
  
  .language-globe-btn svg {
    width: 16px;
    height: 16px;
  }
  
  /* Dropdown mobile aligné à droite */
  .landing-header > .header-language-selector:not(.landing-cta .header-language-selector) .language-dropdown-menu {
    right: 0;
    left: auto;
  }
}

/* Header scrolled - Adaptation */
/* Sélecteur plus spécifique que .landing-header.scrolled button (2 classes + 1 élément) */
.landing-header.scrolled button.language-globe-btn,
header.scrolled button.language-globe-btn {
  width: 42px;
  height: 42px;
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.5);
  padding: 0; /* Écrase padding: 6px 16px de header.css */
  font-size: inherit; /* Écrase font-size: 0.9rem de header.css */
}

.landing-header.scrolled button.language-globe-btn:hover,
header.scrolled button.language-globe-btn:hover {
  background: rgba(255, 255, 255, 0.25);
}

.landing-header.scrolled button.language-globe-btn svg,
header.scrolled button.language-globe-btn svg {
  width: 18px;
  height: 18px;
}
