/* MCPRO — Sélecteur de langue */
.lang-switcher {
  position: relative;
  margin-inline-end: 0.35rem;
}
.lang-switcher-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.65rem;
  border: 1px solid var(--cp-border);
  border-radius: 999px;
  background: #fff;
  color: var(--cp-text);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.lang-switcher-btn:hover,
.lang-switcher-btn[aria-expanded="true"] {
  border-color: var(--cp-primary);
  box-shadow: 0 0 0 2px rgba(232, 93, 4, 0.12);
}
.lang-switcher-menu {
  position: absolute;
  top: calc(100% + 0.35rem);
  inset-inline-end: 0;
  min-width: 180px;
  max-height: min(50vh, 280px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  margin: 0;
  padding: 0.35rem 0;
  list-style: none;
  background: #fff;
  border: 1px solid var(--cp-border);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
  z-index: 1600;
}

.lang-switcher-menu-head {
  position: sticky;
  top: 0;
  z-index: 1;
  margin: 0;
  padding: 0.5rem 0.75rem 0.4rem;
  list-style: none;
  background: #fff;
  border-bottom: 1px solid var(--cp-border);
}

.lang-switcher-menu-head span {
  display: block;
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--cp-muted);
}

.lang-switcher.is-open .lang-switcher-btn {
  border-color: var(--cp-primary);
  box-shadow: 0 0 0 2px rgba(232, 93, 4, 0.12);
}
.lang-option {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  width: 100%;
  padding: 0.55rem 0.65rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  text-align: start;
  cursor: pointer;
  font-size: 0.88rem;
  color: var(--cp-text);
}
.lang-option:hover,
.lang-option.is-active {
  background: rgba(232, 93, 4, 0.08);
  color: var(--cp-primary);
}
.lang-option-flag {
  font-size: 1.1rem;
  line-height: 1;
}
body.locale-switching {
  transition: opacity 0.15s ease;
}
body.locale-switching .site-header,
body.locale-switching .page-content,
body.locale-switching .hero-pro {
  opacity: 0.92;
}

/* Langue : uniquement dans la barre (pas dans le tiroir pages) */
.nav-mobile-drawer-hint {
  margin: 0 0 0.65rem;
  font-size: 0.78rem;
  line-height: 1.35;
  color: var(--cp-muted);
}

body.lang-menu-open .nav-mobile-drawer,
body.lang-menu-open .nav-mobile-drawer.is-open,
body.lang-menu-open .nav-mobile-backdrop,
body.lang-menu-open .nav-mobile-backdrop.is-open,
body.lang-menu-open .cat-drawer,
body.lang-menu-open .cat-drawer-backdrop {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  opacity: 0 !important;
}

html:not(.mcpro-lang-open) body.nav-mobile-open:not(.lang-menu-open) #mcpro-lang-sheet:not(.is-open),
html:not(.mcpro-lang-open) body.nav-mobile-open:not(.lang-menu-open) .mcpro-lang-sheet:not(.is-open) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body.nav-mobile-open:not(.lang-menu-open) #lang-switcher-menu {
  display: none !important;
}

body.lang-menu-open .mobile-bottom-nav {
  pointer-events: none;
}

/* Panneau langue Safari / mobile public — fenêtre CENTRÉE (jamais masquée par
   la barre d'adresse du navigateur en bas d'écran). */
.mcpro-lang-sheet {
  position: fixed;
  inset: 0;
  z-index: 2200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  pointer-events: none;
  visibility: hidden;
}

/* Ouvert : .is-open posé par JS (+ lang-menu-open sur body) */
#mcpro-lang-sheet.is-open,
.mcpro-lang-sheet.is-open,
body.lang-menu-open #mcpro-lang-sheet.is-open,
body.lang-menu-open .mcpro-lang-sheet.is-open {
  display: flex !important;
  visibility: visible !important;
  pointer-events: auto !important;
  opacity: 1 !important;
}

/* Desktop : menu déroulant au clic FR (≥901px, aligné desktop.css) */
@media (min-width: 901px) {
  .site-header--public .lang-switcher {
    position: relative;
    overflow: visible;
    z-index: 1500;
  }

  .site-header--public .navbar-actions-tools {
    overflow: visible !important;
  }

  body.lang-menu-open .site-header--public #lang-switcher-menu,
  .site-header--public .lang-switcher.is-open #lang-switcher-menu,
  html.mcpro-lang-open .site-header--public #lang-switcher-menu {
    display: block !important;
    visibility: visible !important;
    pointer-events: auto !important;
    opacity: 1 !important;
  }

  body.lang-menu-open .site-header--public #lang-switcher-menu[hidden] {
    display: block !important;
  }
}

/* Mobile sheet actif : pas de dropdown */
@media (max-width: 900px) {
  .site-header--public #lang-switcher-menu,
  .nav-mobile-drawer #lang-switcher-menu {
    display: none !important;
  }
  /* Ensure lang sheet starts hidden on mobile */
  #mcpro-lang-sheet:not(.is-open),
  .mcpro-lang-sheet:not(.is-open) {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

#mcpro-lang-sheet[hidden]:not(.is-open),
.mcpro-lang-sheet[hidden]:not(.is-open) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

body.cat-drawer-open:not(.lang-menu-open) #mcpro-lang-sheet,
body.cat-drawer-open:not(.lang-menu-open) .mcpro-lang-sheet:not(.is-open) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.mcpro-lang-sheet-backdrop {
  position: absolute;
  inset: 0;
  border: none;
  padding: 0;
  margin: 0;
  background: rgba(15, 23, 42, 0.5);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.mcpro-lang-sheet-panel {
  position: relative;
  z-index: 1;
  width: min(82vw, 280px);
  max-width: 280px;
  max-height: min(55vh, 380px);
  margin: auto;
  background: var(--cp-surface, #fff);
  border-radius: 16px;
  box-shadow: 0 18px 48px rgba(15, 23, 42, 0.32);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.mcpro-lang-sheet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.65rem 0.75rem 0.5rem;
  border-bottom: 1px solid var(--cp-border, #e2e8f0);
}

.mcpro-lang-sheet-head strong {
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--cp-muted, #64748b);
}

.mcpro-lang-sheet-close {
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: 8px;
  background: var(--cp-bg, #f1f5f9);
  color: var(--cp-text, #0f172a);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
}

.mcpro-lang-sheet-list {
  /* La liste porte aussi .lang-switcher-menu (menu desktop) qui force position:absolute :
     on l'annule pour que les langues coulent DANS le panneau flex et ne soient pas
     rognées par son overflow:hidden. C'était la cause du sélecteur "vide" sur mobile. */
  position: static !important;
  inset: auto !important;
  min-width: 0 !important;
  max-height: none !important;
  flex: 1 1 auto;
  min-height: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  box-shadow: none;
  z-index: auto;
  list-style: none;
  margin: 0;
  padding: 0.25rem 0 0.5rem;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}

.mcpro-lang-sheet-list .lang-option {
  min-height: 44px;
  padding: 0.55rem 0.75rem;
  font-size: 0.95rem;
  gap: 0.5rem;
}

html[data-theme="dark"] .mcpro-lang-sheet-panel,
body.theme-dark .mcpro-lang-sheet-panel {
  background: #1e293b;
  border-top: 1px solid #475569;
}

html[data-theme="dark"] .mcpro-lang-sheet-head strong,
html[data-theme="dark"] .mcpro-lang-sheet-close,
body.theme-dark .mcpro-lang-sheet-head strong,
body.theme-dark .mcpro-lang-sheet-close {
  color: #e2e8f0;
}

html[data-theme="dark"] .mcpro-lang-sheet-close,
body.theme-dark .mcpro-lang-sheet-close {
  background: #334155;
}

body.nav-mobile-open .lang-switcher {
  z-index: 1200;
}

body.nav-mobile-open .site-header--public .lang-switcher {
  z-index: 1700;
}

@media (max-width: 900px) {
  .site-header--public .lang-switcher:not(.lang-switcher--mobile-off) {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  .auth-lang-switcher,
  .lang-switcher--mobile-off {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  #mcpro-lang-sheet:not(.is-open),
  .mcpro-lang-sheet:not(.is-open) {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
