.projets-container {
  display: grid;
  grid-template-columns: 70% auto;
  grid-template-rows: repeat(2, 1fr);
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  width: 100%;
  height: 100%;
}

.image-container {
  grid-area: 1 / 1 / 3 / 2;
  overflow: hidden;
  border-radius: 20px;
  height: 100%;
  width: 100%;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 1.5s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}


.image-container img {
  min-width: 100%;
  height: auto;
  transition: 0.5s cubic-bezier(0.9, 0, 0.3, 1);

}

.infos {
  grid-area: 1 / 2 / 2 / 3;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  height: 290px;
  transition: 1.5s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}



.infos h3 {
  margin-bottom: 20px;
}



.navigation {
  grid-area: 2 / 2 / 3 / 3;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
  animation: nav 1.5s cubic-bezier(0.25, 0.5, 0.5, 1) 01s forwards;
  transform: translateY(80px);
  opacity: 0;
  filter: blur(10px);
}

@keyframes nav {
  to {
    transform: none;
    opacity: 1;
    filter: none;
  }
}

.navigation .ctrl {
  display: flex;
  width: 100%;
  justify-content: space-around;
  align-items: center;
}

.navigation button {
  width: 70px;
  border: none;
  background: none;
  cursor: pointer;
  transition: all 0.1s cubic-bezier(0.9, 0, 0.3, 1);

}

.navigation button img {
  width: 100%;
  border-radius: 0;
  transition: all 0.5s cubic-bezier(0.9, 0, 0.3, 1);
}

.navigation button:active {
  scale: 0.9;
  transition: all 0.1s cubic-bezier(0.9, 0, 0.3, 1);

}


.navigation .ctrl :nth-child(1):hover img {
  transform: translateX(-10px);
}

.navigation .ctrl :nth-child(3):hover img {
  transform: translateX(10px);
}

.navigation .ctrl a {
  width: 100px;
  height: 100px;
  overflow: hidden;
  display: block;
  border-radius: 20px;
  display: flex;
  justify-content: center;
  transition: 0.3s cubic-bezier(0.9, 0, 0.3, 1);
}

.navigation a:hover {
  box-shadow: 0 5px 10px black;
  transform: translateY(-10px);
  transition: 0.3s cubic-bezier(0.9, 0, 0.3, 1);
}


.slider-progress {
  position: relative;
  width: 100%;
}

/* Barre (track du slider) */
#sliderRange {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 10px;
  background: transparent;
  /* on laisse transparent, on stylise via track */
  border: none;
  margin: 0;
  padding: 0;
  cursor: pointer;
  position: relative;
  z-index: 2;
  border-radius: 5px;
}

/* Piste réelle */
#sliderRange::-webkit-slider-runnable-track {
  height: 10px;
  background-color: #ffffff28;
  border-radius: 5px;
}

#sliderRange::-moz-range-track {
  height: 10px;
  background-color: #ffffff28;
  border-radius: 5px;
}

/* On masque complètement le thumb natif */
#sliderRange::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 0;
  height: 10px;
  margin: 0;
  border: 0;
}

#sliderRange::-moz-range-thumb {
  width: 0;
  height: 10px;
  border: none;
}

/* Faux thumb animé */
.slider-thumb {
  position: absolute;
  left: 0;
  top: 55%;
  width: 25px;
  height: 10px;
  background: #ffffff;
  border-radius: 4px;
  box-shadow: 0 0 5px rgb(0, 0, 0);
  transform: translate(-50%, -50%);
  /* centré verticalement */
  transition: all .3s cubic-bezier(0.9, 0, 0.3, 1);
  pointer-events: none;
  /* ne bloque pas la souris */
  z-index: 3;
}

/* État actif (drag ou clic) */
.slider-thumb.active {
  background: #ffffff0d;
  backdrop-filter: blur(50px);
  width: 35px;
  height: 20px;
  border-radius: 8px;
  box-shadow: 0 0 10px rgb(0, 0, 0), inset 0 0 8px rgb(255, 255, 255);
}

/* Conteneur des points */
.slider-marks {
  position: absolute;
  padding: 0 12.5px;
  /* moitié de la largeur du thumb (25px/2) */
  top: 55%;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  transform: translateY(-50%);
}

/* Style des points */
.slider-mark {
  width: 2px;
  height: 10px;
  background-color: #ffffff46;
}





.image-container.anime {
  transform: translateX(-80px);
  opacity: 0;
  filter: blur(10px);
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}

.infos.case.anime {
  transform: translateY(-80px);
  opacity: 0;
  filter: blur(10px);
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}



/* Classe pour la disparition */
.image-container.anime-out {
  transform: translateX(-50px);
  opacity: 0;
  filter: blur(10px);
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}

.infos.anime-out {
  transform: translateX(50px);
  opacity: 0;
  filter: blur(10px);
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}

.miniature.anime-out {
  transform: translateY(-20px);
  opacity: 0;
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}

/* Classe pour l'apparition */
.image-container.anime-in,
.infos.anime-in,
.miniature.anime-in {
  opacity: 1 !important;
  transform: translate(0) !important;
  filter: blur(0px);
  transition: 1s cubic-bezier(0.25, 0.5, 0.5, 1) !important;
}

@media (max-width:1150px) {
  .projets-container {
    grid-template-columns: 60% auto;
  }

  .navigation .ctrl a {
    width: 70px;
    height: 70px;
  }

}

@media (max-width:850px) {
  .projets-container {
    margin-top: 0;
    display: grid;
    grid-template-columns: 100%;
    grid-template-rows: 200px 250px auto;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    height: 100%;
    padding: 0 10px;
  }

  .porjets-container div {
    padding: 15px;
  }

  .image-container {
    grid-area: 2 / 1 / 3 / 2;
  }

  .infos {
    grid-area: 1 / 1 / 2 / 2;
    height: auto;
  }

  .infos h3 {
    margin-bottom: 10px;
  }

  .infos a {
    font-size: 15px;
    width: 45%;
    padding: 5px;
  }


  .navigation {
    grid-area: 3 / 1 / 4 / 2;
    justify-content: flex-start;
    gap: 30px;
  }

  .navigation .ctrl {
    justify-content: center;
    gap: 20px;
    padding: 0;
  }

  .navigation .ctrl button {
    width: 60px;
  }

  .navigation .ctrl button:hover {
    transform: none;
  }

  .navigation .ctrl .miniature {
    width: 60px;
    height: 60px;
    border-radius: 15px;
  }

  .navigation .inputs {
    padding: 0;
    width: 80%;
  }

}