/* Icône hamburger -> X quand ouvert (même règle que ton ancien CSS) */
#et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before,
.et_pb_module.et_pb_menu .et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before {
  content: '\4d';
}

/* Positionnement du toggle ajouté */
ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,
ul.et_mobile_menu li.page_item_has_children .mobile-toggle {
  width: 44px;
  height: 100%;
  max-height: 44px;
  padding: 0 !important;
  border: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 3;
  background: transparent;
  text-align: center;
  opacity: 1;
}

/* Le LI parent doit être positionné */
ul.et_mobile_menu > li.menu-item-has-children,
ul.et_mobile_menu > li.page_item_has_children,
ul.et_mobile_menu li.menu-item-has-children .sub-menu li.menu-item-has-children {
  position: relative;
}

/* Espace à droite du lien parent pour la zone cliquable */
ul.et_mobile_menu li.menu-item-has-children > a,
ul.et_mobile_menu li.page_item_has_children > a {
  display: block;
  padding-right: 56px;
}

/* Masquer les sous-menus par défaut (le JS pose display:none mais on bétonne) */
ul.et_mobile_menu .menu-item-has-children > .sub-menu,
ul.et_mobile_menu .page_item_has_children > .children {
  display: none !important;
  visibility: hidden !important;
}

/* Montrer quand visible */
ul.et_mobile_menu .menu-item-has-children > .sub-menu.visible,
ul.et_mobile_menu .page_item_has_children > .children.visible {
  display: block !important;
  visibility: visible !important;
}

/* Icône (font ETModules) état fermé */
ul.et_mobile_menu li.menu-item-has-children > .mobile-toggle::after,
ul.et_mobile_menu li.page_item_has_children > .mobile-toggle::after {
  position: relative;
  top: 10px;
  font-family: "ETModules";
  content: '\33'; /* chevron down */
  color: #0f3762; /* adapte si besoin */
  background: #f0f3f6;
  border-radius: 50%;
  padding: 3px;
  display: inline-block;
  line-height: 1;
}

/* Icône état ouvert */
ul.et_mobile_menu li.menu-item-has-children.dt-open > .mobile-toggle::after,
ul.et_mobile_menu li.page_item_has_children.dt-open > .mobile-toggle::after {
  content: '\32'; /* chevron up */
}

/* Look du panneau (optionnel) */
.et_pb_menu .et_mobile_menu,
.et_pb_menu .et_mobile_menu ul {
  background-color: #ffffff !important;
  border-radius: 10px;
}
.et_pb_menu .et_pb_menu__menu>nav>ul>li>ul {width: 300px;}

.et-menu li li a {width: 250px;}
.et_pb_menu .et_mobile_menu, .et_pb_menu .et_mobile_menu ul {border-radius: unset;}
@media (max-width: 980px) {.et_pb_menu .et_mobile_menu, .et_pb_menu .et_mobile_menu ul {
list-style: none !important;
text-align: left;
width: 80vw;
}
}
