@charset "UTF-8";
::-webkit-input-placeholder { /* Chrome/Opera/Safari */
  color: #1C5D74;
}

::-moz-placeholder { /* Firefox 19+ */
  color: #1C5D74;
}

:-ms-input-placeholder { /* IE 10+ */
  color: #1C5D74;
}

:-moz-placeholder { /* Firefox 18- */
  color: #1C5D74;
}

*::-moz-selection {
  background-color: #D49A6A;
  color: white;
}

*::selection {
  background-color: #D49A6A;
  color: white;
}

.couleur-Blanc {
  background-color: white;
}

.couleur-Rouge {
  background-color: #C85538;
}

.texte-Rouge {
  color: #C85538;
}

.couleur-Bleu {
  background-color: #0195CB;
}
.couleur-Bleu h1, .couleur-Bleu h2, .couleur-Bleu h3, .couleur-Bleu li, .couleur-Bleu a, .couleur-Bleu p {
  color: white;
}

.couleur-BleuBardage {
  background-color: #597da1;
}
.couleur-BleuBardage h1, .couleur-BleuBardage h2, .couleur-BleuBardage h3, .couleur-BleuBardage li, .couleur-BleuBardage a, .couleur-BleuBardage p {
  color: white;
}
.couleur-BleuBardage h1::before, .couleur-BleuBardage h2::before, .couleur-BleuBardage h3::before, .couleur-BleuBardage li::before, .couleur-BleuBardage a::before, .couleur-BleuBardage p::before {
  color: white !important;
}

.couleur-BleuFonc {
  background-color: #1C5D74;
}
.couleur-BleuFonc h1, .couleur-BleuFonc h2, .couleur-BleuFonc h3, .couleur-BleuFonc li, .couleur-BleuFonc a, .couleur-BleuFonc p {
  color: white;
}

.texte-Bleu {
  color: #0195CB;
}

.couleur-Beige {
  background-color: #F5F1EC;
}

.texte-Beige {
  color: #F5F1EC;
}

.couleur-Vert {
  background-color: #01746C;
}
.couleur-Vert h1, .couleur-Vert h2, .couleur-Vert h3, .couleur-Vert li, .couleur-Vert a, .couleur-Vert p {
  color: white;
}

.couleur-VertDurolage {
  background-color: #32472D;
}
.couleur-VertDurolage h1, .couleur-VertDurolage h2, .couleur-VertDurolage h3, .couleur-VertDurolage li, .couleur-VertDurolage a, .couleur-VertDurolage p {
  color: white;
}

.texte-Vert {
  color: #01746C;
}

.couleur-Marron {
  background-color: #A87B54;
}

.texte-Marron {
  color: #A87B54;
}

.images-horizontales {
  aspect-ratio: 4/3;
}

.images-verticales {
  aspect-ratio: 3/4;
}

.bloc_txt a {
  margin-top: 2rem;
}

.hz-separateur {
  border: 2px solid #F5F1EC;
  width: 100%;
  max-width: 1620px;
  margin: 0 auto;
}

.Swiper1 {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.Swiper1 .swiper-wrapper {
  padding-bottom: 4rem;
}
.Swiper1 .swiper-wrapper .swiper-slide {
  overflow: hidden;
  position: relative;
}
.Swiper1 .swiper-wrapper .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.Swiper1 .slider-controls {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  bottom: 12px;
  right: 0;
  z-index: 10;
}
.Swiper1 .slider-controls .swiper-pagination {
  position: static;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 2rem;
}
.Swiper1 .slider-controls .swiper-pagination .swiper-pagination-bullet {
  background: #D49A6A;
  margin: 0;
}
.Swiper1 .slider-controls .swiper-button-prev,
.Swiper1 .slider-controls .swiper-button-next {
  border: 0;
  background-color: inherit;
  color: #D49A6A;
  display: -ms-grid;
  display: grid;
  place-items: center;
  width: auto;
}
.Swiper1 .slider-controls .swiper-button-prev {
  left: 0;
}
.Swiper1 .slider-controls .swiper-button-prev::after {
  content: "\f060";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 1.2rem;
  display: inline-block;
  line-height: 1;
  speak: none;
}
.Swiper1 .slider-controls .swiper-button-next {
  right: 0;
}
.Swiper1 .slider-controls .swiper-button-next::after {
  content: "\f061";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 1.2rem;
  display: inline-block;
  line-height: 1;
}

/* BLOC IMAGE/SLIDER TEXTE*/
.hz-block-img-txt .container {
  /* Image Texte */
  /* SLIDER TEXTE */
}
.hz-block-img-txt .container .bloc_image_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.hz-block-img-txt .container .bloc_slider_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.hz-block-img-txt .container .bloc_slider_txt .bloc_txt {
  padding-bottom: 4rem;
}
@media screen and (max-width: 1680px) {
  .hz-block-img-txt .container .bloc_slider_txt .bloc_txt {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 768px) {
  .hz-block-img-txt.is-right .bloc_media {
    margin-top: 3rem;
  }
  .hz-block-img-txt.is-right .bloc_slider_txt {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .hz-block-img-txt.is-right .bloc_slider_txt .bloc_media {
    margin-top: 0;
    margin-bottom: 3rem;
  }
  .hz-block-img-txt.is-left .bloc_media {
    margin-bottom: 3rem;
  }
}

/* BANDEAU IMAGE TEXTE */
.hz-bandeau-img-txt {
  overflow: hidden;
}
@media screen and (max-width: 1920px) {
  .hz-bandeau-img-txt {
    padding-top: 6rem;
  }
}
@media screen and (max-width: 1440px) {
  .hz-bandeau-img-txt {
    padding-top: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .hz-bandeau-img-txt {
    padding-top: 1rem;
  }
}
.hz-bandeau-img-txt img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.hz-bandeau-img-txt.couleur-Blanc .bandeau_image_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.hz-bandeau-img-txt.couleur-Blanc .bandeau_image_txt::before {
  content: "";
  position: absolute;
  top: -40px;
  bottom: 40px;
  left: 40px;
  right: calc((100dvw - 100%) / -2);
  background: white;
  z-index: -1;
}
@media screen and (max-width: 1300px) {
  .hz-bandeau-img-txt.couleur-Blanc .bandeau_image_txt::before {
    top: -25px;
    bottom: 25px;
    left: 25px;
  }
}
.hz-bandeau-img-txt.couleur-Beige {
  background-color: transparent !important;
}
.hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt::before {
  content: "";
  position: absolute;
  top: -40px;
  bottom: 40px;
  left: 40px;
  right: calc((100dvw - 100%) / -2);
  background: #F5F1EC;
  z-index: -1;
}
.hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt a.bouton-cta span {
  background-color: white;
}
.hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt a.bouton-cta:hover span {
  background-color: #D49A6A;
}
@media screen and (max-width: 1300px) and (min-width: 1025px) {
  .hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt .bloc_txt {
    width: 50%;
  }
}
@media screen and (max-width: 1024px) {
  .hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding-bottom: 40px;
  }
  .hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt .bloc_img {
    margin-left: auto;
  }
  .hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt .bloc_txt {
    margin-top: 2rem;
  }
  .hz-bandeau-img-txt.couleur-Beige .bandeau_image_txt::before {
    top: 40px;
    left: 0;
    bottom: 0;
  }
}
.hz-bandeau-img-txt.couleur-Vert {
  background-color: transparent !important;
}
.hz-bandeau-img-txt.couleur-Vert .bandeau_image_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.hz-bandeau-img-txt.couleur-Vert .bandeau_image_txt::before {
  content: "";
  position: absolute;
  top: -40px;
  bottom: 40px;
  left: 40px;
  right: calc((100dvw - 100%) / -2);
  background: #01746C;
  z-index: -1;
}
.hz-bandeau-img-txt.couleur-Vert .bandeau_image_txt a.bouton-cta span {
  background-color: white;
}
.hz-bandeau-img-txt.couleur-Vert .bandeau_image_txt a.bouton-cta:hover span {
  background-color: #D49A6A;
}
.hz-bandeau-img-txt.couleur-Bleu {
  background-color: transparent !important;
}
.hz-bandeau-img-txt.couleur-Bleu .bandeau_image_txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.hz-bandeau-img-txt.couleur-Bleu .bandeau_image_txt::before {
  content: "";
  position: absolute;
  top: -40px;
  bottom: 40px;
  left: 40px;
  right: calc((100dvw - 100%) / -2);
  background: #1C5D74;
  z-index: -1;
}
.hz-bandeau-img-txt.couleur-Bleu .bandeau_image_txt a.bouton-cta span {
  background-color: white;
}
.hz-bandeau-img-txt.couleur-Bleu .bandeau_image_txt a.bouton-cta:hover span {
  background-color: #D49A6A;
}

/* BLOC TEXTE S/ IMAGE */
.bloc_image-sur-txt {
  position: relative;
}
.bloc_image-sur-txt picture {
  display: block;
  overflow: hidden;
  height: 100vh;
  height: 100svh;
}
.bloc_image-sur-txt picture .parallax {
  width: 100%;
  height: 110%;
  -o-object-fit: cover;
     object-fit: cover;
  will-change: transform;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  -webkit-transition: -webkit-transform 0s;
  transition: -webkit-transform 0s;
  transition: transform 0s;
  transition: transform 0s, -webkit-transform 0s;
}
.bloc_image-sur-txt .bloc_txt {
  position: absolute;
  top: 50%;
  right: 20%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.85);
  padding: 6rem;
}
.bloc_image-sur-txt .bloc_txt .bouton-cta {
  margin-top: 2rem;
}
.bloc_image-sur-txt .bloc_txt .bouton-cta span {
  background-color: white;
}
.bloc_image-sur-txt .bloc_txt .bouton-cta span:hover {
  background-color: #D49A6A;
}
@media screen and (max-width: 1680px) {
  .bloc_image-sur-txt .bloc_txt {
    width: 40%;
  }
}
@media screen and (max-width: 1440px) {
  .bloc_image-sur-txt .bloc_txt {
    width: 70%;
    right: 4.5%;
  }
}
.bloc_image-sur-txt a.bouton-cta {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 1920px) {
  .bloc_image-sur-txt h2 {
    font-size: 1.9rem;
  }
}
@media screen and (max-width: 1680px) {
  .bloc_image-sur-txt h2 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .bloc_image-sur-txt picture {
    height: auto;
  }
  .bloc_image-sur-txt .bloc_txt {
    position: relative;
    width: 100%;
    right: initial;
    top: initial;
    bottom: initial;
    left: initial;
    -webkit-transform: none;
            transform: none;
    background: none;
    padding: 3rem 1.25rem;
  }
  .bloc_image-sur-txt h2 {
    font-size: 1.5rem;
  }
}

/* BLOC FULLPAGE */
#swiper-fullpage {
  width: 100%;
  height: 100vh;
  height: 100svh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  overflow: hidden;
}
#swiper-fullpage .swiper-slide {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
#swiper-fullpage picture {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}
#swiper-fullpage picture img {
  -o-object-fit: cover;
     object-fit: cover;
}
#swiper-fullpage .bloc_txt {
  position: absolute;
  top: 50%;
  right: 20%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.85);
  padding: 6rem;
}
#swiper-fullpage .bloc_txt .bouton-cta {
  margin-top: 2rem;
}
#swiper-fullpage .bloc_txt .bouton-cta span {
  background-color: white;
}
#swiper-fullpage .bloc_txt .bouton-cta:hover span {
  background-color: #D49A6A;
}
@media screen and (max-width: 1680px) {
  #swiper-fullpage .bloc_txt {
    width: 40%;
  }
}
@media screen and (max-width: 1440px) {
  #swiper-fullpage .bloc_txt {
    width: 70%;
    right: 4.5%;
  }
}
#swiper-fullpage a.bouton-cta {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 1920px) {
  #swiper-fullpage h2 {
    font-size: 1.9rem;
  }
}
@media screen and (max-width: 1680px) {
  #swiper-fullpage h2 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  #swiper-fullpage picture {
    height: auto;
  }
  #swiper-fullpage .bloc_txt {
    position: relative;
    width: 100%;
    right: initial;
    top: initial;
    bottom: initial;
    left: initial;
    -webkit-transform: none;
            transform: none;
    background: none;
    padding: 3rem 1.25rem;
  }
  #swiper-fullpage h2 {
    font-size: 1.5rem;
  }
}

@media (max-width: 767px) {
  #swiper-fullpage {
    height: auto !important;
    display: block !important;
    overflow: visible !important;
  }
  #swiper-fullpage .swiper-wrapper {
    display: block !important;
    -webkit-transform: none !important;
            transform: none !important;
  }
  #swiper-fullpage .swiper-slide {
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }
  #swiper-fullpage .swiper-pagination,
  #swiper-fullpage .swiper-button-prev,
  #swiper-fullpage .swiper-button-next {
    display: none !important;
  }
}
/* BLOC VIDEO */
.bloc_video {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.bloc_video .titre, .bloc_video p {
  text-align: center;
}
.bloc_video #video {
  width: 100%;
  margin-top: 6rem;
  display: block;
  position: relative;
}
.bloc_video #video .iframe-container {
  width: 100%;
  height: 45em;
  display: block;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 1214px) {
  .bloc_video #video .iframe-container {
    height: 42em;
  }
}
@media screen and (max-width: 1110px) {
  .bloc_video #video .iframe-container {
    height: 38em;
  }
}
@media screen and (max-width: 970px) {
  .bloc_video #video .iframe-container {
    height: 35em;
  }
}
@media screen and (max-width: 890px) {
  .bloc_video #video .iframe-container {
    height: 30em;
  }
}
@media screen and (max-width: 767px) {
  .bloc_video #video .iframe-container {
    height: 25em;
  }
}
@media screen and (max-width: 645px) {
  .bloc_video #video .iframe-container {
    height: 19em;
  }
}
@media screen and (max-width: 400px) {
  .bloc_video #video .iframe-container {
    height: 15em;
  }
}
@media screen and (max-width: 768px) {
  .bloc_video #video {
    margin-top: 2rem;
  }
}

/* BLOC SERVICES */
.bloc_services {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.bloc_services .bloc_txt {
  margin: 0 auto 10rem auto;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .bloc_services .bloc_txt {
    margin: 0 auto 5rem auto;
  }
}
.bloc_services .services {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  overflow: visible;
}
@media screen and (max-width: 1024px) {
  .bloc_services .services {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.bloc_services .services .bloc_images {
  display: -ms-grid !important;
  display: grid !important;
  -ms-grid-columns: minmax(0, 1fr) 2rem minmax(0, 1fr);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
  justify-items: stretch;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  overflow: visible;
}
.bloc_services .services .bloc_images > .columns {
  float: none;
  width: auto;
  padding: 0;
}
.bloc_services .services .bloc_images .bloc_img {
  position: relative;
  cursor: pointer;
  will-change: transform;
  --origin-x: left;
  --origin-y: center;
  -webkit-transform-origin: var(--origin-x) var(--origin-y);
          transform-origin: var(--origin-x) var(--origin-y);
  -webkit-transition: -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-filter 0.25s ease;
  transition: -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-filter 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease;
  transition: transform 0.25s ease, box-shadow 0.25s ease, filter 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease, -webkit-filter 0.25s ease;
  outline: 0;
  width: 100%;
}
.bloc_services .services .bloc_images .bloc_img .bloc_logo {
  width: 100%;
  aspect-ratio: 1/1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #fff;
  -webkit-box-shadow: rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px;
          box-shadow: rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px;
}
.bloc_services .services .bloc_images .bloc_img .bloc_logo img {
  max-width: 80%;
  max-height: 80%;
}
.bloc_services .services .bloc_images .bloc_img .bloc_logo img.logo-couleur {
  display: block;
}
.bloc_services .services .bloc_images .bloc_img .bloc_logo img.logo-blanc {
  display: none;
}
.bloc_services .services .bloc_images .bloc_img:focus-visible {
  -webkit-box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.15) inset;
          box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.15) inset;
}
.bloc_services .services .bloc_images .bloc_img.active {
  -webkit-transform: scale(1.08);
          transform: scale(1.08);
  z-index: 2;
  -webkit-filter: saturate(1.05);
          filter: saturate(1.05);
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo img.logo-couleur {
  display: none;
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo img.logo-blanc {
  display: block;
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo.couleur-Bleu {
  background-color: #0195CB;
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo.couleur-Rouge {
  background-color: #C85538;
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo.couleur-Vert {
  background-color: #01746C;
}
.bloc_services .services .bloc_images .bloc_img.active .bloc_logo.couleur-Marron {
  background-color: #A87B54;
}
.bloc_services .services .bloc_images .bloc_img:nth-child(1) {
  --origin-x: right;
  --origin-y: bottom;
}
.bloc_services .services .bloc_images .bloc_img:nth-child(2) {
  --origin-x: left;
  --origin-y: bottom;
}
.bloc_services .services .bloc_images .bloc_img:nth-child(3) {
  --origin-x: right;
  --origin-y: top;
}
.bloc_services .services .bloc_images .bloc_img:nth-child(4) {
  --origin-x: left;
  --origin-y: top;
}
.bloc_services .services .bloc_textes .bloc_texte {
  display: none;
}
.bloc_services .services .bloc_textes .bloc_texte .bloc_cta {
  margin-top: 2rem;
}
@media screen and (max-width: 1024px) {
  .bloc_services .services .bloc_textes {
    margin-top: 4rem;
  }
}

/* Motion réduite */
@media (prefers-reduced-motion: reduce) {
  .bloc_services .services .bloc_images .bloc_img {
    -webkit-transition: none;
    transition: none;
  }
}
/* Gallerie Services */
.hz-galerie-services .bloc_txt_logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 4rem;
}
.hz-galerie-services .bloc_txt_logo .logo {
  aspect-ratio: 1/1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.hz-galerie-services .bloc_txt_logo .logo img {
  width: 90%;
}
.hz-galerie-services .bloc_txt_droite p, .hz-galerie-services .bloc_txt_droite h2 {
  text-align: right;
}
.hz-galerie-services .bloc_galerie {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: 16px;
}
.hz-galerie-services .bloc_galerie .image_principale {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0px;
          flex: 1 1 0;
  min-width: 0;
}
.hz-galerie-services .bloc_galerie .image_principale img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}
.hz-galerie-services .bloc_galerie .autres_images {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0px;
          flex: 1 1 0;
  min-width: 0;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr) 16px minmax(0, 1fr);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.hz-galerie-services .bloc_galerie .autres_images .columns {
  width: auto !important;
  float: none !important;
  padding: 0;
}
.hz-galerie-services .bloc_galerie .autres_images img {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.hz-galerie-services .bloc_cta {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.hz-galerie-services .bloc_cta a.bouton-cta {
  -webkit-box-pack: right;
      -ms-flex-pack: right;
          justify-content: right;
  margin-left: 0;
}
@media screen and (max-width: 768px) {
  .hz-galerie-services.is-left .bloc_txt_logo {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .hz-galerie-services.is-left .bloc_galerie {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .hz-galerie-services.is-right .bloc_texte h2, .hz-galerie-services.is-right .bloc_texte h3, .hz-galerie-services.is-right .bloc_texte h4, .hz-galerie-services.is-right .bloc_texte p {
    text-align: left;
  }
  .hz-galerie-services.is-right .bloc_galerie {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .hz-galerie-services .bloc_cta {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .hz-galerie-services .bloc_cta .bouton-cta:not(:last-child) {
    margin-bottom: 1rem;
  }
  .hz-galerie-services .bloc_texte {
    margin-top: 3rem;
  }
}

/* BLOC PRODUITS */
.hz-produits .bloc_texte h2 {
  text-align: center;
}
.hz-produits .blocs_produits .bloc_produit .produit {
  background-color: #F5F1EC;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  aspect-ratio: 1/1;
  -webkit-transition: background-color 0.35s ease, color 0.35s ease;
  transition: background-color 0.35s ease, color 0.35s ease;
  cursor: pointer;
}
.hz-produits .blocs_produits .bloc_produit .produit p {
  color: #1C5D74;
  text-transform: uppercase;
  font-size: 1.5rem;
  margin-top: 2rem;
  -webkit-transition: color 0.35s ease;
  transition: color 0.35s ease;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .hz-produits .blocs_produits .bloc_produit .produit p {
    margin-top: 1rem;
  }
}
.hz-produits .blocs_produits .bloc_produit .produit svg {
  height: auto;
}
.hz-produits .blocs_produits .bloc_produit .produit svg path, .hz-produits .blocs_produits .bloc_produit .produit svg rect {
  fill: currentColor;
  -webkit-transition: fill 0.35s ease;
  transition: fill 0.35s ease;
}
.hz-produits .blocs_produits .bloc_produit .produit:hover svg path, .hz-produits .blocs_produits .bloc_produit .produit:hover svg rect {
  fill: white;
}
.hz-produits .blocs_produits .bloc_produit .produit:hover p {
  color: white;
}
.hz-produits .blocs_produits .bloc_produit .produit.couleur-violet:hover {
  background-color: #6883AC;
}
.hz-produits .blocs_produits .bloc_produit .produit.couleur-vert-eau:hover {
  background-color: #4AA39D;
}
.hz-produits .blocs_produits .bloc_produit .produit.couleur-vert-olive:hover {
  background-color: #7A9E73;
}
.hz-produits .blocs_produits .bloc_produit .produit.couleur-bleu:hover {
  background-color: #2A7289;
}
@media screen and (max-width: 1300px) {
  .hz-produits .blocs_produits .bloc_produit .produit svg {
    width: 50%;
  }
  .hz-produits .blocs_produits .bloc_produit .produit p {
    font-size: 1.1rem;
  }
}
@media screen and (max-width: 768px) {
  .hz-produits .blocs_produits .bloc_produit:nth-child(1), .hz-produits .blocs_produits .bloc_produit:nth-child(2) {
    margin-bottom: 2rem;
  }
  .hz-produits .blocs_produits .bloc_produit .produit svg {
    width: 40%;
  }
}

/* BLOC Accordeon */
.hz-block-accordeon .grid-accordeon-media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon:not(:last-child) {
  margin-bottom: 3rem;
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger {
  scroll-margin-top: calc(var(--header-h) + 20px);
  background-color: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  cursor: pointer;
  padding: 0 0 15px 0;
  width: 100%;
  text-align: left;
  border: none;
  border-bottom: 3px solid white;
  outline: none;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger .accordion-title {
  font-family: "Athachantr", sans-serif;
  font-size: 2.5rem;
  margin-bottom: 0;
  color: #1C5D74;
}
@media screen and (max-width: 1920px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger .accordion-title {
    font-size: 2rem;
  }
}
@media screen and (max-width: 1300px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger .accordion-title {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger .accordion-title {
    font-size: 1.5rem;
  }
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger:hover:after {
  color: #A87B54;
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger:after {
  content: "\f067";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 40px;
  color: #D49A6A;
  float: right;
  margin-left: 5px;
}
@media screen and (max-width: 767px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .accordion-trigger:after {
    font-size: 15px;
  }
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon.active .accordion-trigger:after {
  content: "\f068";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 40px;
  color: #D49A6A;
  float: right;
  margin-left: 5px;
}
@media screen and (max-width: 767px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon.active .accordion-trigger:after {
    font-size: 15px;
  }
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .panel {
  padding-top: 40px;
}
.hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h1, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h2, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h3, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h4 {
  font-family: Karla, sans-serif;
  font-size: 1.8rem;
  font-weight: bold;
  color: black;
}
@media screen and (max-width: 1920px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h1, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h2, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h3, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h4 {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 1300px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h1, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h2, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h3, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h4 {
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h1, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h2, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h3, .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel h4 {
    font-size: 1.15rem;
  }
}
@media screen and (max-width: 768px) {
  .hz-block-accordeon .grid-accordeon-media .bloc_media {
    margin-top: 2rem;
  }
  .hz-block-accordeon .grid-accordeon-media .bloc_media .media-offset {
    display: none;
  }
}
.hz-block-accordeon .bloc_cta_media .bouton-cta {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  margin-top: 3rem;
}
.hz-block-accordeon .bloc_cta_media .bouton-cta span {
  background-color: white;
}
.hz-block-accordeon .bloc_cta_media .bouton-cta span:hover {
  background-color: #D49A6A;
}

@media screen and (max-width: 768px) {
  .hz-block-accordeon .grid-accordeon-media .bloc_media {
    display: none;
  }
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel .media-item {
    margin-top: 1rem;
  }
  .hz-block-accordeon .grid-accordeon-media .single_accordeon .panel .slider-controls {
    margin-top: 0.5rem;
  }
}
/* Block Swiper Gallery */
.hz-slider-gallery {
  overflow: hidden;
  width: 100%;
}
.hz-slider-gallery .bloc-intro {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 4rem;
}
.hz-slider-gallery .bloc-intro .cta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 768px) {
  .hz-slider-gallery .bloc-intro .cta {
    margin-top: 2rem;
  }
}
.hz-slider-gallery .container > .Swiper2 {
  width: auto;
  max-width: none;
  margin-right: calc(50% - 50vw); /* ← étend à droite jusqu’au bord de l’écran */
}
.hz-slider-gallery .Swiper2 .swiper-wrapper {
  padding-bottom: 3rem;
  gap: 20px;
}
.hz-slider-gallery .Swiper2 .swiper-wrapper .swiper-slide img {
  width: 100%;
  max-width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}
.hz-slider-gallery .Swiper2 .slider-controls {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  bottom: 12px;
  left: 1.25rem;
  z-index: 10;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-pagination {
  position: static;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 2rem;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-pagination .swiper-pagination-bullet {
  background: #D49A6A;
  margin: 0;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-prev,
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-next {
  border: 0;
  background-color: inherit;
  color: #D49A6A;
  display: -ms-grid;
  display: grid;
  place-items: center;
  width: auto;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-prev {
  left: 0;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-prev::after {
  content: "\f060";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 1.2rem;
  display: inline-block;
  line-height: 1;
  speak: none;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-next {
  right: 0;
}
.hz-slider-gallery .Swiper2 .slider-controls .swiper-button-next::after {
  content: "\f061";
  font-family: "Line Awesome Free";
  font-weight: 900;
  font-size: 1.2rem;
  display: inline-block;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .hz-slider-gallery .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  .hz-slider-gallery .container .Swiper2 {
    margin-bottom: 2rem;
  }
  .hz-slider-gallery .bloc-intro {
    margin-bottom: 0;
  }
}

/* Texte Intro */
.hz-titre_intro {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

/* Block Avant Après */
.avant-apres {
  --pos: 50%;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media (max-width: 500px) {
  .avant-apres {
    width: 100%;
  }
}
.avant-apres .inner {
  width: 100%;
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.avant-apres .inner .img {
  width: 100%;
  display: block;
}
.avant-apres .inner .img img {
  width: 100%;
  max-width: none;
  height: auto;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}
.avant-apres .inner .background-img {
  position: relative;
  z-index: 1;
}
.avant-apres .inner .foreground-img {
  position: absolute;
  inset: 0;
  z-index: 2;
  -webkit-transition: none;
  transition: none;
  clip-path: polygon(var(--pos) 0%, 100% 0%, 100% 100%, var(--pos) 100%);
  -webkit-clip-path: polygon(var(--pos) 0%, 100% 0%, 100% 100%, var(--pos) 100%);
}
@supports not (clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%)) {
  .avant-apres .inner .foreground-img {
    width: calc(var(--pos));
    overflow: hidden;
  }
}
.avant-apres .inner .slider {
  position: absolute;
  inset: 0;
  z-index: 4;
  margin: 0;
  background: transparent;
  outline: none;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  cursor: ew-resize;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -ms-touch-action: none;
      touch-action: none;
}
.avant-apres .inner .slider::-webkit-slider-thumb {
  width: 2.2368em;
  height: 2.2368em;
  border-radius: 50%;
  background: transparent;
  cursor: ew-resize;
  appearance: none;
  -webkit-appearance: none;
}
.avant-apres .inner .slider::-moz-range-thumb {
  width: 2.2368em;
  height: 2.2368em;
  border-radius: 50%;
  background: transparent;
  cursor: ew-resize;
  border: 0;
}
.avant-apres .inner .slider::-ms-thumb {
  background: transparent;
}
.avant-apres .inner .slider::-webkit-slider-runnable-track {
  background: transparent;
}
.avant-apres .inner .slider::-moz-range-track {
  background: transparent;
}
.avant-apres .inner .slider::-ms-track {
  background: transparent;
  border-color: transparent;
  color: transparent;
}
.avant-apres .inner .button {
  position: absolute;
  top: 0;
  left: var(--pos);
  height: 100%;
  width: 3px;
  z-index: 3;
  background-color: white;
  pointer-events: none;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: none;
  transition: none;
  overflow: visible;
}
.avant-apres .inner .button:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2.2368em;
  height: 2.2368em;
  border-radius: 50%;
  background-image: url(../images/picto-avant-apres.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #fff;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}