

/* ==== BURGER (mobile only) ==== */
.nav-toggle,
.nav-toggle-label {
  display: none;
}

.nav-toggle-label {
  position: absolute;
  top: 0;
  right: calc( calc(100% - var(--container-size)) / 1.8);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  cursor: pointer;
  min-width: 48px;
  min-height: 48px;

}

.burger {
  display: block;
  position: relative;
  width: 25px;
  height: 3px;
  background: var(--c-50);
  border-radius: 2px;
  transition: background 0.2s ease-in-out;
  
}

.burger::before,
.burger::after {
  content: '';
  position: absolute;
  left: 0;
  width: 25px;
  height: 3px;
  background: var(--c-50);
  border-radius: 2px;
    transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55),
    top 0.3s ease, bottom 0.3s ease;
}

.burger::before {
  top: -9px;
}

.burger::after {
  bottom: -9px;
}

.nav-toggle:checked + .nav-toggle-label .burger {
  width: 28px;
  background: transparent;
}

.nav-toggle:checked + .nav-toggle-label .burger::before {
  width: 28px;
  transform: rotate(45deg);
  top:0px;
}

.nav-toggle:checked + .nav-toggle-label .burger::after {
  width: 28px;
  transform: rotate(-45deg);
  top: 0.5px;
}



/* ==== NAVIGATION STRUCTURE ==== */
nav {
  
  width: 100%;
  padding-block: var(--fs-m);
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

.logo {
  display: block;
  width: 120px;
  aspect-ratio: 5 / 1;
  background: url(../media/logo_dixera.svg) center/contain no-repeat;
}

.nav-menu {
  display: flex;
  gap: var(--fs-xl);
  align-items: center;
  padding-block: 20px;
}

.nav-item {
  position: relative;
}



.nav-item a,
.nav-item summary {
  display: block;
  padding-block: 4px;
  font-size: var(--fs-m);
  color: var(--c-50);
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  opacity : 0.8;
}

.nav-item summary {
  padding-right: 15px;
}

.nav-item a:hover,
.nav-item summary:hover,
#menu-2 .nav-item2 summary, 
#menu-3 .nav-item3 summary, 
#menu-4 .nav-item4 a,
#menu-5 .nav-item4 a
{
  opacity: 1;
}



/* ==== SUBMENUS ==== */

.nav-submenu {
  position: absolute;
  top: calc(100% + var(--fs-m));
  left: -20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: white;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.8);
  min-width: 200px;
  z-index: 10;
  border-radius: 4px;
  overflow: hidden;
  padding-top: 20px;
}

.nav-item3 .nav-submenu { padding-block: 20px;   } 

.nav-submenu a  {
  width:100%;
  font-size: 0.9em;
  color : var(--c-900);
  transition: all 0.2s ease;
  padding-left: 20px;
  border-left: 0px solid rgba(255, 255, 255, 0);
  font-weight: 400;
  opacity: 1;
}

.nav-submenu p  {
  font-size: 0.75em;
  color: var(--c-350);
  margin-top: 14px;
  padding : 20px;
  border: none;
  background-color: var(--c-100);
  line-height: 120%;
}

.nav-submenu a:hover {
  border-left: 5px solid var(--c-500);
  opacity: 1;
}



summary::before {
  content: '';
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%) rotate(0deg);
  transition: transform 0.3s ease;

  width: 0;
  height: 0;
  
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid white; /* triangle pointant vers le bas */
}

/* Rotation quand le <details> est ouvert */
details[open] summary::before {
  transform: translateY(-50%) rotate(180deg);
}


/* ==== SAFE BUTTON ==== */

.nav-item.safe {
  border: none;
}

.nav-item.safe a {
  background: var(--c-900);
  color: var(--c-350);
  border-radius: 5px;
  padding-inline:  var(--fs-s) 40px;
  background-image: url(../media/picto_safe_close.svg);
  background-repeat: no-repeat;
  background-size: 25px;
  background-position: right 10px center;
  text-align: center;
  opacity: 1;
  transition: background ease-in-out 150ms;
  box-shadow: 0 2px 5px rgb(0, 0, 0, 0.15);
  border-top: 0.5px solid #464635;

}

.nav-item.safe a:hover {
  color: white;
  background: var(--c-600);
  background-image: url(../media/picto_safe_open.svg);
  background-repeat: no-repeat;
  background-size: 25px;
  background-position: right 10px center;
  border-top: 1px solid #d58a02;
  box-shadow: 0 2px 5px rgb(0, 0, 0, 0.2);
}

.nav-item.safe:hover::after {
  width: 0;
}


/* ==== MOBILE STYLE ==== */
@media (max-width: 1000px) {
  
 
 header .container {width: 100%; }
 
  nav {
    max-width: 100%;
    padding-block: 30px;
    padding-inline: calc( calc(100% - var(--container-size)) / 2);
  }
  
  .logo {
    width: 100px;
    aspect-ratio: 5 / 1;
  }
  
  .nav-toggle-label {
    display: flex;
    min-width: 48px;
    min-height: 48px;
  }


.nav-menu .nav-item {
    opacity: 0;
    transition: opacity linear 200ms 200ms;
    pointer-events: none;
  }
  
  
.nav-toggle:checked ~ .nav-menu .nav-item {
    opacity: 1;
    pointer-events: auto;
  }
  
  
  .nav-menu {
    position: absolute;
    top: 110%;
    left: 0;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    background: white;
    box-shadow: 0 150px 400px rgba(0, 0, 0, 0.65);
    padding: 2rem 5%;
    transform: scale(1, 0);
    transform-origin: top;
    transition: transform 0.2s ease-in-out;
    z-index: 100;
  }

  .nav-toggle:checked ~ .nav-menu {
    transform: scale(1, 1);
  }

  .nav-item {
    width: 100%;
    border-top: 1px solid rgb(215, 215, 215); 
  }
  
  .nav-item a,
  .nav-item summary {
    padding-inline: 0;
    padding: 18px 0 7px 0;
    color : var(--c-900);

  }
  
  .nav-item.safe a, .nav-item.safe a:hover {
    margin-top: 30px;
    padding : 7px;
    box-shadow: 0 0 0 0;
  }
   
  .nav-item:hover::after,
  .nav-item:has(details[open])::after,
  #menu-2 .nav-item2::after,
  #menu-3 .nav-item3::after,
  #menu-4 .nav-item4::after {
    width: 0;
  }
  
 
  summary::before {
    top: 30px;
    right: 2px;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 8px solid var(--c-700); 
}
  
  .nav-submenu {
    position: static;
    padding: 0; 
    display: flex;
    flex-direction: column;
    box-shadow: none;
    border-radius: 0;
  }

  .nav-submenu a {
    padding-block: 10px;
    padding-left: 5px;
    font-size: 0.8rem;
    font-weight: 400;  
    opacity: 0.6;
  }
  
  .nav-submenu a:hover {
    padding-left: 8px;
    opacity: 1;
  }

}


/* ==== DESKTOP STYLE ==== */
@media (min-width: 1000px) {
  .nav-toggle-label {
    display: none;
  }

  .nav-toggle {
    display: none;
  }

  .nav-menu {
    display: flex;
    transform: none !important;
  }
}


.sr-only {
   position: absolute;
   left: 30%;
   transform: translateX(-50%);
   top: -100px;
   overflow: hidden;
   display: inline;
   background-color: white;
   padding: 5px 10px;
   font-size: var(--fs-s);
   transition: all ease-in-out 0.2s;
   z-index: 50;
   border-radius: 10px;
   color: black;
}

.sr-only:focus {
  left: 30%;
  transform: translateX(-50%);
  top: 38px;
}
