/* =========================================
   MENU.CSS — MENU-FLOAT + DROPDOWN + CHAP-GRID
   À charger APRÈS les autres feuilles CSS
   ========================================= */


/* ========== 1. BASE ========== */

body {
  margin: 0;
  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
}


/* ========== 2. CONTENEUR PRINCIPAL ========== */

.menu-float {
  position: relative !important;
  z-index: 999999 !important;

  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap;
  gap: 14px !important;

  width: 100%;
  margin: 18px auto 26px;
  overflow: visible !important;

  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
}

.menu-float .menu-button {
  position: relative !important;
  display: inline-block !important;
  width: auto !important;
  overflow: visible !important;
}


/* ========== 3. BOUTONS PRINCIPAUX ========== */

.menu-float .menu-button > button,
.menu-button button,
#menu-btn,
#chap-btn,
.menu-float button {
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;

  min-width: 155px;
  padding: 12px 18px !important;

  border: 1px solid #a98e79 !important;
  border-radius: 14px;
  background-color: #a47864 !important;
  color: #ffffff !important;

  font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif !important;
  font-size: 2rem !important;
  font-weight: 300 !important;
  font-synthesis: none;
  line-height: 1.15;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;

  cursor: pointer;
  transition: background 0.2s ease, transform 0.15s ease, border-color 0.2s ease;
}

.menu-float .menu-button > button:hover,
.menu-float .menu-button > button:focus-visible,
.menu-button button:hover,
#menu-btn:hover,
#chap-btn:hover,
.menu-float button:hover {
  background-color: #a47864 !important;
  color: #ffffff !important;
  border-color: rgba(0, 0, 0, 0.35);
  outline: none;
  transform: translateY(-1px);
}

/* version arabe : bouton plus grand */
html[lang="ar"] .menu-float .menu-button > button,
html[dir="rtl"] .menu-float .menu-button > button {
  font-size: 5rem !important;
  line-height: 1.2;
}


/* ========== 4. DROPDOWN STANDARD ========== */

.menu-float .menu-button > .menu-dropdown,
.menu-float .menu-button > ul.menu-dropdown {
  display: none;
  position: absolute !important;
  top: calc(100% + 10px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;

  z-index: 1000000 !important;
  margin: 0 !important;
  padding: 10px;
  list-style: none;
  box-sizing: border-box;

  min-width: 250px !important;
  width: max-content !important;
  max-width: min(92vw, 520px) !important;
  max-height: min(70vh, 520px) !important;
  overflow: auto !important;

  background-color: #f5f1ea !important;
  border: 1px solid #b89f8a;
  border-radius: 16px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

/* ouverture via JS */
.menu-float .menu-button > .menu-dropdown.show,
.menu-float .menu-button > ul.menu-dropdown.show {
  display: block !important;
}


/* ========== 5. LIENS DU DROPDOWN ========== */

.menu-dropdown li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.menu-dropdown li > a,
.menu-dropdown a {
  display: block;
  box-sizing: border-box;

  padding: 11px 14px !important;
  border-radius: 12px;

  background-color: transparent !important;
  color: #3e2f25 !important;
  text-decoration: none;
  font-size: 2rem !important;
  font-weight: 500;
  line-height: 1.2;
}

.menu-dropdown li > a:hover,
.menu-dropdown li > a:focus-visible,
.menu-dropdown a:hover {
  background-color: #dcc8b8 !important;
  color: #1f1712 !important;
  outline: none;
}

.menu-dropdown li > a:hover *,
.menu-dropdown li > a:focus-visible * {
  color: #1f1712 !important;
}

/* version arabe dans les menus déroulants */
html[lang="ar"] .menu-dropdown li > a,
html[dir="rtl"] .menu-dropdown li > a {
  font-size: 1.28rem !important;
  line-height: 1.35;
}


/* ========== 6. CLASSES DÉJÀ UTILISÉES ========== */

.menu-lien,
.titre-noir5 {
  color: inherit !important;
}


/* ========== 7. CHAP-GRID ========== */

.menu-float .menu-button > ul.menu-dropdown.chap-grid {
  display: none !important;
  position: absolute !important;
  top: calc(100% + 10px) !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;

  z-index: 1000000 !important;
  box-sizing: border-box;

  width: min(500px, 92vw) !important;
  min-width: min(500px, 92vw) !important;
  max-width: min(500px, 92vw) !important;

  padding: 10px;
  gap: 8px;
  grid-template-columns: repeat(3, 1fr) !important;

  max-height: min(70vh, 520px) !important;
  overflow: auto !important;
}

.menu-float .menu-button > ul.menu-dropdown.chap-grid.show {
  display: grid !important;
}

.menu-float .menu-button > ul.menu-dropdown.chap-grid > li {
  margin: 0;
  padding: 0;
}

.menu-float .menu-button > ul.menu-dropdown.chap-grid > li > a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;

  min-height: 44px;
  padding: 10px 8px !important;
  border-radius: 10px;

  font-size: 2rem !important;
  font-weight: 800;
  line-height: 1.15;
}


/* ========== 8. RTL / ARABE ========== */

html[lang="ar"] .menu-float,
html[dir="rtl"] .menu-float {
  direction: rtl;
}

html[lang="ar"] .menu-dropdown,
html[dir="rtl"] .menu-dropdown {
  text-align: right;
}


/* ========== 9. SUPERPOSITION / PRIORITÉ ========== */

.menu-float,
.menu-float .menu-button,
.menu-float .menu-dropdown {
  position: relative;
  z-index: 999999 !important;
}

#controls-container,
#video-dropdown,
.film-current-title {
  position: relative;
  z-index: 1000 !important;
}


/* ========== 10. ALIGNEMENT OPTIONNEL ========== */

.menu-float .menu-button .menu-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  bottom: auto;
  margin: 0;
  z-index: 9999;
}

.menu-float .menu-button.center-dropdown .menu-dropdown {
  left: 50%;
  transform: translateX(-50%);
}


/* ========== 11. TABLETTE / MOBILE ========== */

@media (max-width: 768px) {
  .menu-float {
    gap: 10px !important;
    margin: 14px auto 20px;
  }

  .menu-float .menu-button > button,
  .menu-button button,
  #menu-btn,
  #chap-btn,
  .menu-float button {
    min-width: 128px;
    padding: 10px 14px !important;
    border-radius: 12px;
    font-size: 1.08rem !important;
  }

  .menu-float .menu-button > ul.menu-dropdown {
    min-width: 210px !important;
    max-width: 86vw !important;
    padding: 8px;
    border-radius: 14px;
  }

  .menu-dropdown li > a {
    padding: 10px 12px !important;
    font-size: 1rem !important;
  }

  html[lang="ar"] .menu-float .menu-button > button,
  html[dir="rtl"] .menu-float .menu-button > button {
    font-size: 1.2rem !important;
  }

  html[lang="ar"] .menu-dropdown li > a,
  html[dir="rtl"] .menu-dropdown li > a {
    font-size: 1.14rem !important;
    line-height: 1.3;
  }

  .menu-float .menu-button > ul.menu-dropdown.chap-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    min-width: 235px !important;
    max-width: 86vw !important;
  }

  .menu-float .menu-button > ul.menu-dropdown.chap-grid > li > a {
    padding: 9px 4px !important;
    font-size: 2rem !important;
  }

  html[lang="ar"] .menu-dropdown.chap-grid > li > a,
  html[dir="rtl"] .menu-dropdown.chap-grid > li > a {
    font-size: 2rem !important;
  }
}


/* ========== 12. TRÈS PETITS ÉCRANS ========== */

@media (max-width: 480px) {
  .menu-float {
    gap: 8px !important;
  }

  .menu-float .menu-button > button,
  .menu-button button,
  #menu-btn,
  #chap-btn,
  .menu-float button {
    min-width: 116px;
    padding: 9px 12px !important;
    font-size: 1rem !important;
  }

  .menu-float .menu-button > ul.menu-dropdown {
    min-width: 190px !important;
    max-width: 90vw !important;
  }

  .menu-dropdown li > a {
    padding: 9px 10px !important;
    font-size: 0.95rem !important;
  }

  html[lang="ar"] .menu-float .menu-button > button,
  html[dir="rtl"] .menu-float .menu-button > button {
    font-size: 1.12rem !important;
  }

  html[lang="ar"] .menu-dropdown li > a,
  html[dir="rtl"] .menu-dropdown li > a {
    font-size: 1.08rem !important;
  }

  .menu-float .menu-button > ul.menu-dropdown.chap-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    min-width: 220px !important;
  }
}