/* --- bloc-accordeon.css --- */


.container-bloc-accordeon .accordeon-section { border-bottom: .1rem solid rgba(112, 112, 112, .27); }
.container-bloc-accordeon .accordeon-section:first-of-type {border-top: .1rem solid rgba(112, 112, 112, .27);}
.container-bloc-accordeon .accordeon-toggle {font-weight: 600;padding-left: 0;}
.container-bloc-accordeon .accordeon-content {padding: 0 1.5rem 2rem; font-size: 1.4rem;}
.container-bloc-accordeon .accordeon-content p {font-size: 1.4rem;}
.container-bloc-accordeon .accordeon-content p:first-of-type {margin-top: 0;}

.container-bloc-accordeon .accordeon-toggle:after {content: "\f053"; font-weight: 900; font-family: "Font Awesome 6 free";}
.container-bloc-accordeon .accordeon-toggle.open:after {content: "\f078";}


@media (min-width: 768px) {
    .container-bloc-accordeon {margin-top: 4rem;}
} 


@media (min-width: 1100px) {
    .container-bloc-accordeon {margin-top: 5rem; width: 90rem; margin-left: auto; margin-right: auto;}
    
} 

/* --- bloc-carrousel-actualites.css --- */
.container-bloc-carrousel-actualites {position: relative; overflow: visible; width: 100%;}

.container-bloc-carrousel-actualites .bloc-carrousel-actualites-wrapper {position: relative; overflow: visible; width: 100%;}

.container-bloc-carrousel-actualites .bloc-carrousel-actualites-slider {margin: 0;}

.container-bloc-carrousel-actualites .actualite-slide {margin: 2rem 1rem; display: flex !important; flex-direction: column; height: inherit; text-decoration: none; background-color: #fff; border-radius: var(--border-radius); overflow: hidden; box-shadow: var(--box-shadow);}
.container-bloc-carrousel-actualites .actualite-slide .actualite-content {padding: 2rem 3rem;}
.container-bloc-carrousel-actualites .actualite-slide h3 {font-weight: 600; margin-top: 0; margin-bottom: 0;}


.container-bloc-carrousel-actualites .actualite-slide .actualite-image-wrapper {margin-top: auto; height: 19rem;}

.container-bloc-carrousel-actualites .actualite-image {width: 100%; height: 100%; object-fit: cover; display: block;}

.container-bloc-carrousel-actualites .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important;}

.container-bloc-carrousel-actualites .slick-track {display: flex; align-items: stretch;}

.container-bloc-carrousel-actualites .slick-slide:last-child {margin-right: 0;}

.container-bloc-carrousel-actualites.main-container {overflow: visible; padding-right: 0; max-width: 100%;}

.container-bloc-carrousel-actualites.main-container .bloc-carrousel-actualites-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-actualites:not(.main-container) {overflow: visible;}

.container-bloc-carrousel-actualites:not(.main-container) .bloc-carrousel-actualites-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}


.container-bloc-carrousel-actualites .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-actualites .actualite-slide:hover {transform: translateY(-0.5rem); box-shadow: var(--box-shadow-hover);}
}

@media (min-width: 768px) {
  .container-bloc-carrousel-actualites .actualite-slide {margin: 2rem 1.5rem;}
  .container-bloc-carrousel-actualites .actualite-slide .actualite-image-wrapper {height: 25rem;}
  .container-bloc-carrousel-actualites .actualite-slide .actualite-content {padding: 3rem 3rem 2rem;}
}

@media (max-width: 767px) {
  .bloc-carrousel-actualites-slider.native-scroll > * { flex-basis: 80%; margin-left: 0.6rem; margin-right: 0.6rem; }
}


/* --- bloc-carrousel-equipes.css --- */
.container-bloc-carrousel-equipes .equipe-slide {border-radius: var(--border-radius); padding: 2rem 2rem 0; background-color: #fff; box-shadow: var(--box-shadow); margin: 2rem 1rem; display: flex !important; flex-direction: column; height: inherit; transition: all 230ms ease-in-out;}
.container-bloc-carrousel-equipes .equipe-taxonomies {flex-wrap: wrap; gap: .7rem; }
.container-bloc-carrousel-equipes .equipe-taxonomie {display: inline-flex; align-items: center; color: #fff; font-size: 1.2rem; padding: .3rem .5rem; border-radius: 2.5rem; transition: all 230ms ease-in-out;}
.container-bloc-carrousel-equipes .equipe-taxonomie.transverse-gradient {background: linear-gradient(to bottom right, #25a596, #49569e);}
.container-bloc-carrousel-equipes .equipe-thumbnail {padding: 2.5rem 0;}
.container-bloc-carrousel-equipes .equipe-thumbnail img {max-height: 12rem; margin: auto;}


.container-bloc-carrousel-equipes .equipe-title {font-size: 1.5rem; font-weight: 600; margin-bottom: 1rem; display: inline-block;}
.container-bloc-carrousel-equipes .equipe-fonction {font-size: 1.4rem; margin-bottom: 1rem;}
.container-bloc-carrousel-equipes .decouvrir {font-size: 1.4rem; margin-top: auto;}
.container-bloc-carrousel-equipes .decouvrir span {color: var(--couleur-principale);}


.container-bloc-carrousel-equipes .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important}

.container-bloc-carrousel-equipes .slick-track {display: flex; align-items: stretch}

.container-bloc-carrousel-equipes .slick-slide:last-child {margin-right: 0}

.container-bloc-carrousel-equipes.main-container {overflow: visible; padding-right: 0; max-width: 100%}

.container-bloc-carrousel-equipes.main-container .bloc-carrousel-equipes-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%)}

.container-bloc-carrousel-equipes:not(.main-container) {overflow: visible}

.container-bloc-carrousel-equipes:not(.main-container) .bloc-carrousel-equipes-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%)}
/*
@media (max-width: 768px) {
  .container-bloc-carrousel-equipes.main-container .bloc-carrousel-equipes-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none}
  .container-bloc-carrousel-equipes:not(.main-container) .bloc-carrousel-equipes-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none}
}
*/



.container-bloc-carrousel-equipes .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-equipes .equipe-slide:hover {transform: translateY(-0.5rem); box-shadow: var(--box-shadow-hover); color: #fff;}
  .container-bloc-carrousel-equipes .equipe-slide[style*="--couleur-hover"]:hover {background-color: var(--couleur-hover);}
  .container-bloc-carrousel-equipes .equipe-slide:not([style*="--couleur-hover"]):not(.slide-transverse):hover {background-color: var(--couleur-principale);}
  .container-bloc-carrousel-equipes .equipe-slide.slide-transverse:hover {background: linear-gradient(to bottom right, #25a596, #49569e);}
  .container-bloc-carrousel-equipes .equipe-slide:hover .equipe-thumbnail {background-image: url(https://iwego.iwegodev.fr/wp-content/uploads/2025/11/motif-iwego-alpha.svg); background-repeat: no-repeat; background-size: contain; background-position: center;}

  .container-bloc-carrousel-equipes .equipe-slide:hover .equipe-taxonomie {background-color: #fff !important;}
  .container-bloc-carrousel-equipes .equipe-slide:hover .equipe-taxonomie.transverse-gradient {background: #fff !important; color: #25a596;}
  .container-bloc-carrousel-equipes .equipe-slide[style*="--couleur-hover"]:hover .equipe-taxonomie {color: var(--couleur-hover);}
  .container-bloc-carrousel-equipes .equipe-slide:not([style*="--couleur-hover"]):not(.slide-transverse):hover .equipe-taxonomie {color: var(--couleur-principale);}
  .container-bloc-carrousel-equipes .equipe-slide.slide-transverse:hover .equipe-taxonomie:not(.transverse-gradient) {color: #25a596;}
  .container-bloc-carrousel-equipes .equipe-slide:hover p, .container-bloc-carrousel-equipes .equipe-slide:hover p span {color: #fff;}
}

@media (min-width: 768px) {
  .container-bloc-carrousel-equipes .equipe-slide { margin: 2rem 1.5rem; padding: 2rem 3rem 1rem;}
  .container-bloc-carrousel-equipes .equipe-thumbnail img {max-height: 18rem;}
}

@media (max-width: 767px) {
  .bloc-carrousel-equipes-slider.native-scroll > * { flex-basis: 70%; margin-left: 0.6rem; margin-right: 0.6rem; }
}


/* --- bloc-carrousel-mots-cles.css --- */

.container-bloc-carrousel-mots-cles .mot-cle-slide {box-shadow: var(--box-shadow); background-color: #fff; border-radius: var(--border-radius); overflow: hidden; padding: 4rem 2rem; margin: 2rem 1rem; min-width: max-content;}
.container-bloc-carrousel-mots-cles .mot-cle-titre {margin: 0; font-weight: 600; text-align: center; font-size: 2rem; }

.container-bloc-carrousel-mots-cles .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important}

.container-bloc-carrousel-mots-cles .slick-track {display: flex; align-items: stretch}

.container-bloc-carrousel-mots-cles .slick-slide:last-child {margin-right: 0}

.container-bloc-carrousel-mots-cles.main-container {overflow: visible; padding-right: 0; max-width: 100%}

.container-bloc-carrousel-mots-cles.main-container .bloc-carrousel-mots-cles-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%)}

.container-bloc-carrousel-mots-cles:not(.main-container) {overflow: visible}

.container-bloc-carrousel-mots-cles:not(.main-container) .bloc-carrousel-mots-cles-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%)}

/*@media (max-width: 768px) {
  .container-bloc-carrousel-mots-cles.main-container .bloc-carrousel-mots-cles-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none}
  .container-bloc-carrousel-mots-cles:not(.main-container) .bloc-carrousel-mots-cles-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none}
}
*/





.container-bloc-carrousel-mots-cles .slick-arrow.slick-disabled {display: none !important;}

@media (min-width: 1400px) {
  .container-bloc-carrousel-mots-cles .mot-cle-slide {padding: 7rem 5rem;  margin: 2rem 1.5rem;}
  .container-bloc-carrousel-mots-cles .mot-cle-titre {font-size: 4rem; }


}
@media (max-width: 767px) {
  .bloc-carrousel-mots-cles-slider.native-scroll > * { flex-basis: 46%; margin-left: 0.6rem; margin-right: 0.6rem; }
}


/* --- bloc-carrousel-poles.css --- */
.container-bloc-carrousel-poles {position: relative; overflow: visible; width: 100%;}

.container-bloc-carrousel-poles .bloc-carrousel-poles-wrapper {position: relative; overflow: visible; width: 100%;}

.container-bloc-carrousel-poles .bloc-carrousel-poles-slider {margin: 0;}

.container-bloc-carrousel-poles .pole-slide.slick-slide {margin: 1rem; text-decoration: none; color: inherit; display: block; height: 30rem; min-width: calc(100vw - 10rem);}
.container-bloc-carrousel-poles .pole-slide .pole-vignette {position: relative; overflow: hidden; border-radius: var(--border-radius); flex-direction: column; justify-content: center; padding: 3rem 2rem;  box-shadow: var(--box-shadow); transition: inherit;}
.container-bloc-carrousel-poles .pole-slide .pole-vignette::before {content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to right, rgba(0,0,0,1) 0%, rgba(0,0,0,0.5) 40%, rgba(0,0,0,0.1) 60%, transparent 100%); z-index: 2; pointer-events: none; border-radius: 20px;}

.container-bloc-carrousel-poles .pole-image-wrapper {position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; overflow: hidden;}

.container-bloc-carrousel-poles .pole-image {width: 100%; height: 100%; object-fit: cover;}
.container-bloc-carrousel-poles .pole-content {position: relative; z-index: 3;}

.container-bloc-carrousel-poles .pole-title {margin: 0 0 2rem 0; line-height: 1; font-size: 3rem; font-weight: 400; color: #fff; font-family: "Abril Fatface", serif; text-shadow: -1px -1px 1px rgba(255, 255, 255, .1), 1px 1px 1px rgba(0, 0, 0, .8);}
.container-bloc-carrousel-poles .pole-title .pole-prefix {font-family: "Inter", sans-serif;font-weight: 300;}
.container-bloc-carrousel-poles .pole-description {color: #fff; margin-bottom: 0; text-shadow: -1px -1px 1px rgba(255, 255, 255, .1), 1px 1px 1px rgba(0, 0, 0, .8); font-size: 1.8rem;}

.container-bloc-carrousel-poles .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important;}

.container-bloc-carrousel-poles .slick-track {display: flex; align-items: stretch;}

.container-bloc-carrousel-poles .slick-slide:last-child {margin-right: 0;}

.container-bloc-carrousel-poles .pole-vignette {height: 100%;}

.container-bloc-carrousel-poles.main-container {overflow: visible; padding-right: 0; max-width: 100%;}

.container-bloc-carrousel-poles.main-container .bloc-carrousel-poles-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-poles:not(.main-container) {overflow: visible;}

.container-bloc-carrousel-poles:not(.main-container) .bloc-carrousel-poles-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-poles .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-poles .pole-slide:hover {transform: scale3d(1.01, 1.01, 1.01);}
  .container-bloc-carrousel-poles .pole-slide:hover .pole-vignette {box-shadow: var(--box-shadow-hover);}
}

@media (min-width: 768px) {
  .container-bloc-carrousel-poles .pole-slide.slick-slide {min-width: 35rem;}
}

@media (min-width: 1000px) {
  .container-bloc-carrousel-poles .pole-slide {margin: 2rem;}
  .container-bloc-carrousel-poles .pole-title {font-size: 4rem;}
  .container-bloc-carrousel-poles .pole-slide .pole-vignette {padding: 0 5rem;}
}

@media (min-width: 1400px) {
  .container-bloc-carrousel-poles .pole-slide .pole-vignette {padding: 0 7rem;}
  .container-bloc-carrousel-poles .pole-description {width: 85%;}
}

@media (min-width: 1800px) {
  .container-bloc-carrousel-poles .pole-description {width: 70%;}
}

@media (max-width: 767px) {
  .bloc-carrousel-poles-slider.native-scroll > * { flex-basis: 85%; margin-left: 0.6rem; margin-right: 0.6rem; }
}


/* --- bloc-carrousel-prestations.css --- */


.container-bloc-carrousel-prestations .bloc-carrousel-prestations-wrapper {position: relative; overflow: visible; width: 100%;}

.container-bloc-carrousel-prestations .bloc-carrousel-prestations-slider {margin: 0;}
.bloc-prestations-slider .slick-track {display: flex !important;}
.container-bloc-carrousel-prestations .prestation-slide {text-decoration: none; height: inherit; background-color: #fff; box-shadow: var(--box-shadow);  overflow: hidden; border-radius: var(--border-radius);}
.container-bloc-carrousel-prestations .prestation-image-wrapper {width: 40%; background-position: center; background-size: cover; background-repeat: repeat;}
.container-bloc-carrousel-prestations .prestation-vignette {height: 100%;}
.container-bloc-carrousel-prestations .prestation-image {width: 100%; height: 100%; object-fit: cover;}
.container-bloc-carrousel-prestations .prestation-content {width: 60%; padding: 2rem;}
.container-bloc-carrousel-prestations .prestation-content .prestation-description {font-size: 1.4rem; margin-bottom: 0;}

.container-bloc-carrousel-prestations .prestation-title {font-weight: 600; color: var(--couleur-principale); margin-top: 0; font-size: 1.5rem;}
.container-bloc-carrousel-prestations .prestation-title::after {content: ''; display: block; height: .1rem; width: 80%; margin-top: 1rem; background-color: var(--couleur-texte);}


.container-bloc-carrousel-prestations .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important;}

.container-bloc-carrousel-prestations .slick-track {display: flex; align-items: stretch;}

.container-bloc-carrousel-prestations .slick-slide:last-child {margin-right: 0;}


.container-bloc-carrousel-prestations.main-container {overflow: visible; padding-right: 0; max-width: 100%;}

.container-bloc-carrousel-prestations.main-container .bloc-carrousel-prestations-wrapper { padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-prestations:not(.main-container) {overflow: visible;}
.container-bloc-carrousel-prestations:not(.main-container) .bloc-carrousel-prestations-wrapper { padding-right: 0; margin-right: calc(-50vw + 50%);}





.container-bloc-carrousel-prestations .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-prestations .prestation-slide:hover {transform: translateY(-0.5rem); box-shadow: var(--box-shadow-hover);}

}

@media (min-width: 768px) {
  .container-bloc-carrousel-prestations .prestation-content {width: 50%; padding: 3rem;}
  .container-bloc-carrousel-prestations .prestation-image-wrapper {width: 50%;}

}


@media (min-width: 1200px) {
  .container-bloc-carrousel-prestations .prestation-image-wrapper {height: inherit;}

}

@media (min-width: 1900px) {
  .container-bloc-carrousel-prestations .prestation-content {padding: 3rem 5rem; width: 60%;}
  .container-bloc-carrousel-prestations .prestation-image-wrapper {width: 40%;}
  
}

/*@media (max-width: 768px) {
  .container-bloc-carrousel-prestations.main-container .bloc-carrousel-prestations-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none;}
  .container-bloc-carrousel-prestations:not(.main-container) .bloc-carrousel-prestations-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none;}
}*/


@media (max-width: 767px) {
  .bloc-carrousel-prestations-slider.native-scroll > * { flex-basis: 82%; margin-left: 0.6rem; margin-right: 0.6rem; }
  .bloc-prestations-slider.native-scroll > * { flex-basis: 82%; margin: 2rem 0.6rem; }
  .bloc-prestations-slider.native-scroll > *:first-child { margin-left: 1.5rem; }
  .bloc-prestations-slider.native-scroll > *:last-child { margin-right: 1.5rem; }
}


/* --- bloc-carrousel-projets.css --- */
.container-bloc-carrousel-projets {position: relative;}

.container-bloc-carrousel-projets .bloc-carrousel-projets-wrapper {position: relative; overflow: visible; width: 100%}

.container-bloc-carrousel-projets .bloc-carrousel-projets-slider {flex: 1 1 auto; width: 100%;}


.container-bloc-carrousel-projets .projet-link {display: flex !important; flex-direction: column; height: inherit; background-color: #fff; box-shadow: var(--box-shadow); margin: 2rem 1rem; border-radius: var(--border-radius); overflow: hidden; text-decoration: none;}
.container-bloc-carrousel-projets .projet-content {padding: 2rem;}
.container-bloc-carrousel-projets .projet-title {font-weight: 600; font-size: 2rem; margin-bottom: 1.2rem; margin-top: 0;}
.container-bloc-carrousel-projets .projet-taxonomies {column-gap: .6rem; row-gap: .6rem; display: none;}
.container-bloc-carrousel-projets .projet-taxonomie {display: inline-flex; align-items: center; background-color: var(--couleur-principale); color: #fff; font-size: 1.2rem; padding: .3rem .8rem; border-radius: 2.5rem;}
.container-bloc-carrousel-projets .projet-description {font-size: 1.4rem; margin-bottom: 0;}
.container-bloc-carrousel-projets .projet-thumbnail {width: 100%; height: 15rem; margin-top: auto;}
.container-bloc-carrousel-projets .projet-thumbnail img {width: 100%; height: 100%; object-fit: cover; transition: all 230ms ease-in-out;}


.container-bloc-carrousel-projets .slick-track {display: flex;}

.container-bloc-carrousel-projets .slick-slide:last-child {margin-right: 0;}

.container-bloc-carrousel-projets.main-container {overflow: visible; padding-right: 0; max-width: 100%;}

.container-bloc-carrousel-projets.main-container .bloc-carrousel-projets-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-projets:not(.main-container) {overflow: visible;}

.container-bloc-carrousel-projets .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-projets .projet-link:hover {transform: translateY(-0.5rem); box-shadow: var(--box-shadow-hover);}
}

/* Native scroll mobile - styles génériques (s'applique à tous les carrousels) */
@media (max-width: 767px) {
  .native-scroll {
    display: flex;
    overflow-x: scroll;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    overscroll-behavior-x: contain;
    will-change: scroll-position;
    transform: translateZ(0);
    touch-action: pan-x;
  }
  .native-scroll::-webkit-scrollbar { display: none; }
  .native-scroll > * {
    flex-shrink: 0;
    scroll-snap-align: start;
    margin-top: 2rem;
    margin-bottom: 2rem;
  }
  .native-scroll > *:first-child { margin-left: 1.5rem; }
  .native-scroll > *:last-child { margin-right: 1.5rem !important; }
}

@media (min-width: 1025px) {
.container-bloc-carrousel-projets .projet-thumbnail {height: 22rem; margin-top: auto;}
}


/* Carrousel projets - sizing carte mobile */
@media (max-width: 767px) {
  .bloc-carrousel-projets-slider.native-scroll > * {
    flex-basis: 82%;
    margin: 2rem 0.6rem;
  }
  .bloc-carrousel-projets-slider.native-scroll > *:first-child { margin-left: 1.5rem; }
  .bloc-carrousel-projets-slider.native-scroll > *:last-child { margin-right: 1.5rem !important; }
}

/* Legacy carousels - sizing carte mobile */
@media (max-width: 767px) {
  .bloc-projets-slider.native-scroll > * { flex-basis: 82%; margin: 2rem 0.6rem; }
  .bloc-projets-slider.native-scroll > *:first-child { margin-left: 1.5rem; }
  .bloc-projets-slider.native-scroll > *:last-child { margin-right: 1.5rem !important; }
  .bloc-methodo-slider.native-scroll > * { flex-basis: 88%; margin: 2rem 0.6rem; }
  .bloc-methodo-slider.native-scroll > *:first-child { margin-left: 1.5rem; }
  .bloc-methodo-slider.native-scroll > *:last-child { margin-right: 1.5rem !important; }
}

@media (min-width: 768px) {
  .container-bloc-carrousel-projets .projet-link {margin: 2rem 1.5rem;}
  .container-bloc-carrousel-projets .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important}
  .container-bloc-carrousel-projets .slick-track {align-items: stretch;}
  .container-bloc-carrousel-projets .projet-title {font-size: 2.5rem;}
  .container-bloc-carrousel-projets .projet-taxonomies {flex-wrap: wrap; display: flex;}
}



@media (min-width: 1800px) {
  .container-bloc-carrousel-projets .projet-content {padding: 2rem 3rem;}
}

/* --- bloc-carrousel-temoignages.css --- */
.container-bloc-carrousel-temoignages {position: relative;}

.container-bloc-carrousel-temoignages .bloc-carrousel-temoignages-wrapper {position: relative; overflow: visible; width: 100%;}


.container-bloc-carrousel-temoignages .temoignage-link {background-color: #fff; border-radius: var(--border-radius); overflow: hidden; box-shadow: var(--box-shadow); margin: 1.5rem 1rem; text-decoration: none; height: inherit; display: flex !important; flex-direction: column;}

.container-bloc-carrousel-temoignages .temoignage-link .temoignage-content {padding: 2rem 3rem;}
.container-bloc-carrousel-temoignages .temoignage-link .temoignage-content .temoignage-header {font-size: 1.5rem;}
.container-bloc-carrousel-temoignages .temoignage-link .temoignage-content .temoignage-header::after {content: ''; display: block; height: .1rem; width: 20rem; margin-top: 1rem; background-color: var(--couleur-texte); }
.container-bloc-carrousel-temoignages .temoignage-link .temoignage-content p {font-size: 1.4rem; margin-bottom: 0;}

.container-bloc-carrousel-temoignages .temoignage-slide {padding: 0 4%;}






.container-bloc-carrousel-temoignages .temoignage-title {font-weight: 700; color: var(--couleur-principale); text-transform: uppercase;}

.container-bloc-carrousel-temoignages .temoignage-author-separator {font-weight: 300;}

.container-bloc-carrousel-temoignages .temoignage-author-name {font-weight: 700; }

.container-bloc-carrousel-temoignages .temoignage-thumbnail {width: 100%; height: 15rem; margin-top: auto;}
.container-bloc-carrousel-temoignages .temoignage-thumbnail img {width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%); transition: all 230ms ease-in-out;}

.container-bloc-carrousel-temoignages .slick-list {overflow: hidden !important; padding-right: 0 !important; margin-right: 0 !important;}

.container-bloc-carrousel-temoignages .slick-track {display: flex; align-items: stretch;}

.container-bloc-carrousel-temoignages .slick-slide:last-child {margin-right: 0;}

.container-bloc-carrousel-temoignages .temoignage-slide {height: auto;}

.container-bloc-carrousel-temoignages.main-container {overflow: visible; padding-right: 0; max-width: 100%;}

.container-bloc-carrousel-temoignages.main-container .bloc-carrousel-temoignages-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}

.container-bloc-carrousel-temoignages:not(.main-container) {overflow: visible;}

.container-bloc-carrousel-temoignages:not(.main-container) .bloc-carrousel-temoignages-wrapper {padding-right: 0; margin-right: calc(-50vw + 50%);}



.container-bloc-carrousel-temoignages .slick-arrow.slick-disabled {display: none !important;}

@media (hover: hover) {
  .container-bloc-carrousel-temoignages .temoignage-link:hover {box-shadow: var(--box-shadow-hover); transform: translateY(-0.5rem);}
  .container-bloc-carrousel-temoignages .temoignage-link:hover img {filter: grayscale(0%);}

}

@media (min-width: 768px) {
  .container-bloc-carrousel-temoignages .temoignage-link {margin: 1.5rem;}

}
@media (min-width: 1025px) {
    .container-bloc-carrousel-temoignages .temoignage-thumbnail {height: 20rem;}
}

/*
@media (max-width: 768px) {
  .container-bloc-carrousel-temoignages.main-container .bloc-carrousel-temoignages-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none;}
  .container-bloc-carrousel-temoignages:not(.main-container) .bloc-carrousel-temoignages-wrapper {padding-left: 0; margin-right: 0; width: 100%; left: 0; transform: none;}
}*/


@media (max-width: 767px) {
  .bloc-carrousel-temoignages-slider.native-scroll > * { flex-basis: 82%; margin-left: 0.6rem; margin-right: 0.6rem; }
}


/* --- bloc-carte-entreprise.css --- */
/* =====================================================
   BLOC CARTE ENTREPRISE
   Conçu pour une colonne ~50% de largeur écran
   ===================================================== */

.container-bloc-carte-entreprise {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.container-bloc-carte-entreprise .carte-entreprise-titre {
    font-size: inherit;
    font-weight: inherit;
    font-family: inherit;
    color: inherit;
    margin-bottom: 2rem;
}

/* ---- ÉTABLISSEMENTS WRAPPER ---- */

.container-bloc-carte-entreprise .carte-etablissements-wrapper {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 3rem;
    align-items: stretch;
}

/* ---- ÉTABLISSEMENT ---- */

.container-bloc-carte-entreprise .carte-etablissement {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-radius: var(--border-radius);
    overflow: hidden;
    background: #fff;
    flex: 1 1 0;
    min-width: 0;
}

/* ---- CARTE MAP ---- */

.container-bloc-carte-entreprise .carte-map-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 7;
}

.container-bloc-carte-entreprise .carte-map-wrapper iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

/* ---- CORPS DU BLOC (sous la carte) ---- */

.container-bloc-carte-entreprise .carte-etablissement-infos {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border-top: .1rem solid rgba(0,0,0,.07);
}

.container-bloc-carte-entreprise .carte-coordonnees {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    padding: 2rem;
    border-right: .1rem solid rgba(0,0,0,.07);
}

.container-bloc-carte-entreprise .carte-horaires {
    padding: 2rem;
}

/* ---- LABEL ---- */

.container-bloc-carte-entreprise .carte-etab-label {
    font-weight: 700;
    font-size: 1.5rem;
    color: var(--couleur-principale);
    margin: 0;
    padding: 0;
    display: block;
}

/* ---- COORD ITEMS ---- */

.container-bloc-carte-entreprise .carte-coord-item {
    display: flex;
    align-items: flex-start;
    gap: .8rem;
    font-size: 1.35rem;
    line-height: 1.5;
    color: var(--couleur-texte);
}

.container-bloc-carte-entreprise .carte-coord-item i {
    color: var(--couleur-principale);
    font-size: 1.4rem;
    margin-top: .2rem;
    flex-shrink: 0;
    width: 1.4rem;
    text-align: center;
}

.container-bloc-carte-entreprise .carte-coord-item a {
    color: var(--couleur-texte);
    text-decoration: none;
}

.container-bloc-carte-entreprise .carte-coord-item a:hover {
    color: var(--couleur-principale);
}

/* ---- NOTE GLOBALE ---- */

.container-bloc-carte-entreprise .carte-note-globale {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
    padding-top: .4rem;
    border-top: .1rem solid rgba(0,0,0,.07);
    margin-top: .4rem;
}

.container-bloc-carte-entreprise .carte-etoiles {
    color: #f5a623;
    font-size: 1.3rem;
    letter-spacing: .05rem;
}

.container-bloc-carte-entreprise .carte-note-chiffre {
    font-weight: 700;
    font-size: 1.35rem;
}

.container-bloc-carte-entreprise .carte-nb-avis {
    font-size: 1.2rem;
    color: var(--muted, #888);
}

/* ---- BOUTON ITINÉRAIRE ---- */

.container-bloc-carte-entreprise .carte-itineraire {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-size: 1.3rem;
    margin-top: .4rem;
    align-self: flex-start;
}

/* ---- HORAIRES ---- */

.container-bloc-carte-entreprise .carte-horaires-titre {
    display: flex;
    align-items: center;
    gap: .7rem;
    font-weight: 600;
    font-size: 1.4rem;
    margin-bottom: 1rem;
    color: var(--couleur-texte);
}

.container-bloc-carte-entreprise .carte-horaires-titre i {
    color: var(--couleur-principale);
    width: 1.4rem;
    text-align: center;
}

.container-bloc-carte-entreprise .carte-horaires-liste {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

.container-bloc-carte-entreprise .carte-horaires-liste li {
    font-size: 1.25rem;
    color: var(--couleur-texte);
    line-height: 1.4;
}

/* ---- AVIS ---- */

.container-bloc-carte-entreprise .carte-avis {
    border-top: .1rem solid rgba(0,0,0,.07);
    padding: 2rem;
}

.container-bloc-carte-entreprise .carte-avis-titre {
    display: flex;
    align-items: center;
    gap: .7rem;
    font-size: 1.6rem;
    margin: 0 0 1.5rem;
}

.container-bloc-carte-entreprise .carte-avis-titre i {
    color: #f5a623;
}

.container-bloc-carte-entreprise .carte-avis-liste {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.container-bloc-carte-entreprise .carte-avis-item {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto auto;
    column-gap: 1rem;
    row-gap: .3rem;
    align-items: start;
    background-color: #f9f9f9;
    border-radius: var(--border-radius);
    padding: 1.4rem;
    box-shadow: var(--box-shadow);
}

.container-bloc-carte-entreprise .carte-avis-photo {
    grid-row: 1 / 3;
    width: 3.6rem;
    height: 3.6rem;
    border-radius: 50%;
    object-fit: cover;
}

.container-bloc-carte-entreprise .carte-avis-auteur {
    font-weight: 700;
    font-size: 1.35rem;
    margin: 0;
    align-self: end;
}

.container-bloc-carte-entreprise .carte-avis-etoiles {
    color: #f5a623;
    font-size: 1.2rem;
    margin: 0;
    letter-spacing: .05rem;
    align-self: start;
}

.container-bloc-carte-entreprise .carte-avis-texte {
    grid-column: 1 / -1;
    font-size: 1.3rem;
    line-height: 1.6;
    color: var(--couleur-texte);
    margin: .5rem 0 0;
}

/* ---- ÉTABLISSEMENTS LISTE ---- */

.container-bloc-carte-entreprise .carte-etablissements-liste {
    border-top: .1rem solid rgba(0,0,0,.07);
    padding: 1.6rem 2rem;
}

.container-bloc-carte-entreprise .carte-etab-liste-titre {
    display: flex;
    align-items: center;
    gap: .7rem;
    font-weight: 600;
    font-size: 1.4rem;
    margin-bottom: 1rem;
    color: var(--couleur-texte);
}

.container-bloc-carte-entreprise .carte-etab-liste-titre i {
    color: var(--couleur-principale);
    width: 1.4rem;
    text-align: center;
}

.container-bloc-carte-entreprise .carte-etab-liste-items {
    display: flex;
    flex-direction: column;
    gap: .6rem;
}

.container-bloc-carte-entreprise .carte-etab-item {
    display: flex;
    flex-wrap: wrap;
    gap: .2rem .8rem;
    font-size: 1.3rem;
    color: var(--couleur-texte);
}

/* ---- NO CACHE (admin only) ---- */

.container-bloc-carte-entreprise .carte-no-cache {
    background: #fff3cd;
    border: .1rem solid #ffc107;
    border-radius: var(--border-radius);
    padding: 1rem 1.5rem;
    font-size: 1.3rem;
    margin: 1.5rem 2rem;
}


/* --- bloc-entete-contact.css --- */
.container-bloc-entete-contact { display: none; flex-direction: column; gap: 2rem;}

.container-bloc-entete-contact p {margin: 0;}
.container-bloc-entete-contact .entete-contact {align-items: center;}


.container-bloc-entete-contact .entete-img {width: 4.5rem; max-height: 100%;}
.container-bloc-entete-contact .entete-img.entete-img-equipe {border-radius: 50%; overflow: hidden;}
.container-bloc-entete-contact .entete-list {list-style: none;}
.container-bloc-entete-contact .entete-list li:first-of-type {font-weight: 600;  font-size: 1.5rem;}
.container-bloc-entete-contact .entete-list li.list-before a {color: var(--couleur-principale); font-size: 1.4rem; text-decoration: none; padding: .2rem 0;}
.container-bloc-entete-contact .entete-list li.list-before::before {content: '->'; margin-right: .5rem; color: var(--couleur-texte); transition: all 230ms ease-in-out;}



@media (hover: hover) {
    
  .container-bloc-entete-contact .entete-list li.list-before:hover::before {margin-left: .3rem; margin-right: .8rem;}
}

@media (min-width: 1900px) {
    .container-bloc-entete-contact .entete-img {width: 6rem;}
    
  }


/*

.container-bloc-entete-contact .div-contact,
.container-bloc-entete-contact .div-retrouvez-nous
{
    display: flex;
    gap: 2rem;
}

.container-bloc-entete-contact .zone-contact-droite,
.container-bloc-entete-contact .zone-retrouve-droite
{
    align-items: flex-start;
}

.container-bloc-entete-contact .sous-zone-contact-droite,
.container-bloc-entete-contact .sous-zone-1-retrouve-droite,
.container-bloc-entete-contact .sous-zone-2-retrouve-droite
{
    display: flex; 
    align-items: stretch;
    gap: 8px;
}
*/


@media (min-width: 1025px) {
  .container-bloc-entete-contact {display: flex;}
}

/* --- bloc-liste-metiers.css --- */
.container-bloc-liste-metiers {column-gap: 1.5rem; row-gap: 1.5rem;}
.container-bloc-liste-metiers .bloc-liste-metiers-liste {width: 100vw;}
.bloc-liste-metiers-texte p {font-size: 1.4rem; margin-top: .5rem; margin-bottom: .5rem;}
.container-bloc-liste-metiers .metier-item {text-align: center; flex-direction: column; justify-content: center;}
.container-bloc-liste-metiers .metier-link {text-decoration: none; color: inherit; margin: 1rem 2rem; align-items: center; flex-direction: column;}
.container-bloc-liste-metiers .metier-thumbnail {width: 10rem; height: 10rem; border-radius: 50%; overflow: hidden; position: relative; transition: inherit;}
.container-bloc-liste-metiers .metier-thumbnail img {width: 100%; height: 100%; object-fit: cover; filter: grayscale(100%); transition: filter 0.3s ease;}
.container-bloc-liste-metiers .metier-autre-thumbnail {background-color: #fff; align-items: center; justify-content: center; font-size: 4rem; font-weight: 800; color: var(--couleur-principale); transition: inherit;}
.container-bloc-liste-metiers .metier-autre-thumbnail span {margin-bottom: 1.5rem;}
.container-bloc-liste-metiers .metier-title {margin-top: .8rem; font-size: 1.3rem; margin-bottom: 0; margin-left: auto; margin-right: auto; max-width: 14rem;}

.container-bloc-liste-metiers .bloc-liste-metiers-liste .metier-item {min-width: max-content; margin: 1rem 1.5rem;}


@media (hover: hover) {
  .container-bloc-liste-metiers .metier-link:hover .metier-thumbnail {box-shadow: var(--box-shadow);}
  .container-bloc-liste-metiers .metier-link:hover img {filter: grayscale(0%);}
  .container-bloc-liste-metiers .metier-autre-thumbnail:hover {background-color: var(--couleur-principale); color: #fff;}

}


@media (min-width: 768px) {
  .container-bloc-liste-metiers {align-items: center;}
  .container-bloc-liste-metiers .metier-link {margin: 0 1.7rem;}
  .bloc-liste-metiers-texte p {font-size: 1.5rem;}
  .container-bloc-liste-metiers .metier-thumbnail {width: 12rem; height: 12rem;}
  .container-bloc-liste-metiers .metier-title {max-width: 12rem;}
}

@media (min-width: 1400px) {
  .container-bloc-liste-metiers {column-gap: 5rem;}
  .slider-rtl .slick-slide.metier-item {margin: 1rem 2.3rem;}
  .container-bloc-liste-metiers .metier-thumbnail {width: 14rem; height: 14rem;}
  .container-bloc-liste-metiers .metier-link {margin: 0; max-width: 100%;}
  .container-bloc-liste-metiers .bloc-liste-metiers-liste {flex-wrap: wrap; column-gap: 3.5rem; flex: 1; width: auto;}
  .container-bloc-liste-metiers .metier-title {max-width: 14rem;}
}


@media (min-width: 1800px) {
  .container-bloc-liste-metiers .bloc-liste-metiers-liste {column-gap: 5rem;}
  .container-bloc-liste-metiers .metier-thumbnail {width: 16rem; height: 16rem;}
  .slider-rtl .slick-slide.metier-item {margin: 1rem 2.5rem;}
  .container-bloc-liste-metiers .metier-autre-thumbnail span {margin-bottom: 2rem;}
  .container-bloc-liste-metiers .metier-autre-thumbnail {font-size: 5.5rem;}
    
}
@media (max-width: 767px) {
  .bloc-liste-metiers-liste.native-scroll > * { flex-basis: auto; margin-left: 0.4rem; margin-right: 0.4rem; }
}


/* --- bloc-presentation-conflr.css --- */
.container-bloc-presentation-conflr {background: #fff; width: 100%; column-gap: 4rem; box-shadow: var(--box-shadow); border-radius: var(--border-radius);}
.container-bloc-presentation-conflr .presentation-conflr-content-inner {align-items: center; column-gap: 4rem; row-gap: 2rem; flex-wrap: wrap; padding: 2rem 3rem; width: 100%;}
.container-bloc-presentation-conflr .presentation-conflr-content-inner h2 {font-size: 2rem;}

.container-bloc-presentation-conflr .presentation-conflr-content-inner-title {width: 100%;}
.container-bloc-presentation-conflr .presentation-conflr-content-inner-title .btn-border {margin-top: 1rem;}
.container-bloc-presentation-conflr .background-conflr {height: inherit; position: relative;}

.container-bloc-presentation-conflr .background-conflr img {border-top-left-radius: var(--border-radius);}


@media (min-width: 768px) {
  .container-bloc-presentation-conflr .presentation-conflr-content-inner {flex: 1; }
  .container-bloc-presentation-conflr .presentation-conflr-content-inner-title {width: auto; flex: 1;}
  .container-bloc-presentation-conflr .presentation-conflr-content-inner-image {max-width: 35%; display: none;}
  .container-bloc-presentation-conflr .background-conflr img {border-bottom-left-radius: var(--border-radius); border-top-left-radius: var(--border-radius);}
}

@media (min-width: 1200px) {
    .container-bloc-presentation-conflr {column-gap: 6rem;}
    .container-bloc-presentation-conflr .presentation-conflr-content-inner {padding: 0; padding-right: 4rem;}
    .container-bloc-presentation-conflr .presentation-conflr-content-inner-image {display: block;}
    
  }


@media (min-width: 1900px) {
    .container-bloc-presentation-conflr { column-gap: 12rem; }
    .container-bloc-presentation-conflr .presentation-conflr-content-inner {column-gap: 12rem; padding-right: 6rem;}
    
  }

/* --- bloc-projet-citation.css --- */
/* =====================================================
   BLOC PROJET CITATION
   ===================================================== */


.container-bloc-projet-citation .projet-citation-inner p {font-size: 2.2rem; font-style: italic; text-align: center; line-height: 1.4;  margin: 0; }

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {

    .container-bloc-projet-citation .projet-citation-inner p {
        font-size: 3.2rem;
    }
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {

    .container-bloc-projet-citation .projet-citation-inner p {
        font-size: 3.6rem;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-citation .projet-citation-inner p {
        font-size: 4rem;
    }
}


/* --- bloc-projet-complement.css --- */
/* =====================================================
   BLOC PROJET COMPLEMENT
   ===================================================== */

.container-bloc-projet-complement .projet-complement-item {
    row-gap: 2rem;
    column-gap: 4rem;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.container-bloc-projet-complement .projet-complement-item .complement-visuel {
    border-radius: var(--border-radius);
    overflow: hidden;
    max-width: 80rem;
    margin-left: auto;
    margin-right: auto;
    max-height: 40rem;
    width: 100%;
}

.container-bloc-projet-complement .projet-complement-item .complement-text,
.container-bloc-projet-complement .projet-complement-item .visuel {
    width: 100%;
}

.container-bloc-projet-complement .projet-complement-item .complement-visuel img,
.container-bloc-projet-complement .projet-complement-item .complement-visuel video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Bouton son */
.complement-video-wrapper {
    position: relative;
    width: 100%;
    height: 40rem;
}

.complement-video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (min-width: 768px) {
    .complement-video-wrapper { height: 50rem; }
}

@media (min-width: 1100px) {
    .complement-video-wrapper { height: 60rem; }
}

.video-sound-btn {
    position: absolute;
    bottom: 1.2rem;
    right: 1.2rem;
    background-color: rgba(17, 24, 28, .55);
    border: none;
    border-radius: 50%;
    width: 3.8rem;
    height: 3.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #fff;
    font-size: 1.5rem;
    transition: background-color 230ms ease-in-out;
    backdrop-filter: blur(4px);
    z-index: 2;
}

.video-sound-btn:hover {
    background-color: rgba(17, 24, 28, .85);
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-complement .projet-complement-item {
        flex-wrap: nowrap;
        column-gap: 5rem;
    }

    .container-bloc-projet-complement .projet-complement-item .complement-text {
        width: calc(45% - 2.5rem);
        flex-shrink: 0;
    }

    .container-bloc-projet-complement .projet-complement-item .complement-visuel {
        flex: 1;
        max-width: none;
        max-height: 50rem;
        margin-left: 0;
        margin-right: 0;
    }
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-complement .projet-complement-item {
        column-gap: 6rem;
    }

    .container-bloc-projet-complement .projet-complement-item .complement-text {
        width: calc(55% - 3rem);
    }

    .container-bloc-projet-complement .projet-complement-item .complement-visuel {
        max-height: 60rem;
    }

    /* Alternance : les items impairs inversent l'ordre */
    .container-bloc-projet-complement .projet-complement-item:nth-child(odd) {
        flex-direction: row-reverse;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-complement .projet-complement-item {
        column-gap: 8rem;
    }
}


/* --- bloc-projet-entete.css --- */
/* =====================================================
   BLOC PROJET ENTETE
   ===================================================== */

.container-bloc-projet-entete {
    position: relative;
}

.container-bloc-projet-entete .projet-entete-inner {
    position: relative;
}

/* THUMBNAIL (image ou vidéo) */
.container-bloc-projet-entete .projet-entete-thumbnail {
    border-radius: var(--border-radius);
    overflow: hidden;
    margin-top: 2.8rem;
    max-height: 40rem;
    width: 100%;
}

.container-bloc-projet-entete .projet-entete-thumbnail img,
.container-bloc-projet-entete .projet-entete-thumbnail video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* LOGO */
.container-bloc-projet-entete .projet-entete-logo {
    margin-top: 2rem;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.container-bloc-projet-entete .projet-entete-logo img {
    max-width: 12rem;
    max-height: 8rem;
    object-fit: contain;
    display: block;
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-entete .projet-entete-thumbnail {
        margin-top: 4rem;
    }

    .container-bloc-projet-entete .projet-entete-logo {
        position: absolute;
        bottom: 2rem;
        right: 2rem;
        margin-top: 0;
        background: rgba(255, 255, 255, 0.9);
        padding: 1rem 1.5rem;
        border-radius: var(--border-radius);
        box-shadow: var(--box-shadow);
    }

    .container-bloc-projet-entete .projet-entete-logo img {
        max-width: 14rem;
        max-height: 10rem;
    }
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-entete .projet-entete-thumbnail {
        margin-top: 5rem;
        height: 85vh;
        max-height: 85vh;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-entete .projet-entete-logo img {
        max-width: 18rem;
        max-height: 12rem;
    }
}


/* --- bloc-projet-galerie.css --- */
/* =====================================================
   BLOC PROJET GALERIE
   ===================================================== */

.container-bloc-projet-galerie .projet-galerie-inner {
    overflow: hidden;
}

.container-bloc-projet-galerie .projet-galerie-inner .galerie-container {
    position: relative;
    width: 105%;
    left: -2.5%;
    column-gap: 1rem;
    row-gap: 1rem;
    flex-wrap: wrap;
    padding: 1rem 0;
    align-items: stretch;
}

.container-bloc-projet-galerie .projet-galerie-inner .galerie-img {
    border-radius: var(--border-radius);
    overflow: hidden;
    height: 20rem;
    box-shadow: var(--box-shadow);
    min-width: 33%;
    flex: 1;
}

.container-bloc-projet-galerie .projet-galerie-inner .galerie-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.container-bloc-projet-galerie .projet-galerie-inner .galerie-img:hover img {
    transform: scale(1.04);
    box-shadow: var(--box-shadow-hover);
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-galerie .projet-galerie-inner .galerie-img {
        height: 26rem;
    }

    .container-bloc-projet-galerie .projet-galerie-inner .galerie-container {
        column-gap: 2rem;
        row-gap: 2rem;
    }
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-galerie .projet-galerie-inner .galerie-img {
        height: 32rem;
        min-width: auto;
    }

    .container-bloc-projet-galerie .projet-galerie-inner .galerie-container {
        column-gap: 3rem;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-galerie .projet-galerie-inner .galerie-img {
        height: 40rem;
    }
}


/* --- bloc-projet-grille.css --- */
/* =====================================================
   BLOC PROJET GRILLE
   ===================================================== */

.container-bloc-projet-grille .projet-grille-intro {margin-bottom: 3rem;}

.container-bloc-projet-grille .projet-grid-img {
    gap: 2rem;
    flex-wrap: wrap;
}

.container-bloc-projet-grille .projet-grid-img .grid-left,
.container-bloc-projet-grille .projet-grid-img .grid-slider {
    width: 100%;
}

.container-bloc-projet-grille .projet-grid-img .grid-left img {border-radius: var(--border-radius);  overflow: hidden;  height: 20rem; width: 100%; display: block;}

.container-bloc-projet-grille .projet-grid-img .grid-left {
    gap: 2rem;
    flex-direction: row;
    flex-wrap: wrap;
}

.container-bloc-projet-grille .projet-grid-img .grid-slider {
    max-height: 30rem;
    border-radius: var(--border-radius);
    overflow: hidden;
}

.container-bloc-projet-grille .projet-grid-img .grid-slider-slick,
.container-bloc-projet-grille .projet-grid-img .grid-slider-slick .slick-list,
.container-bloc-projet-grille .projet-grid-img .grid-slider-slick .slick-track {
    height: 100% !important;
}

.container-bloc-projet-grille .projet-grid-img .grid-slider-slick .slick-slide > div,
.container-bloc-projet-grille .projet-grid-img .grid-slider-slick .grid-slider-slick__slide {
    height: 100%;
}

.container-bloc-projet-grille .projet-grid-img .grid-slider-slick .grid-slider-slick__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Slick arrows */
.container-bloc-projet-grille .grid-slider-slick .slick-arrow {
    bottom: 0;
    top: auto;
}

.container-bloc-projet-grille .grid-slider-slick .slick-next {
    right: 2rem;
    left: auto;
}

.container-bloc-projet-grille .grid-slider-slick .slick-prev {
    right: 10rem;
    left: auto;
}

.container-bloc-projet-grille .grid-slider-slick .slick-arrow:hover {
    background-color: #fff;
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-grille .projet-grid-img {
        flex-wrap: nowrap;
        align-items: stretch;
    }

    .container-bloc-projet-grille .projet-grid-img .grid-left img { height: 25rem; }

    .container-bloc-projet-grille .projet-grid-img .grid-slider {
        max-height: 50rem;
    }
    .container-bloc-projet-grille .projet-grille-intro {margin-left: auto; margin-right: auto;}
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-grille .projet-grid-img .grid-slider {width: 60%; height: 62rem; max-height: 100%;  flex-shrink: 0;}

    .container-bloc-projet-grille .projet-grid-img .grid-left {
        flex: 1;
        flex-direction: column;
        flex-wrap: nowrap;
    }

    .container-bloc-projet-grille .projet-grid-img .grid-left img {height: 30rem; }
    .container-bloc-projet-grille .projet-grille-intro {margin-bottom: 5rem; max-width: 80rem;}
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-grille .projet-grid-img .grid-slider {height: 78rem; }

    .container-bloc-projet-grille .projet-grid-img .grid-left img {height: 38rem; }
}


/* --- bloc-projet-intro.css --- */
/* =====================================================
   BLOC PROJET INTRO
   ===================================================== */

.container-bloc-projet-intro .projet-intro-inner {max-width: 80rem; gap: 3rem 6rem;  flex-direction: column;}
.container-bloc-projet-intro .projet-intro-left { width: 100%; gap: 1.5rem;  flex-wrap: wrap;}

.container-bloc-projet-intro .projet-intro-left .accompagnement {
    font-weight: 600;
    font-size: 1.8rem;
    margin: 0;
    width: 100%;
}

.container-bloc-projet-intro .projet-intro-left a {
    text-align: center;
}

.container-bloc-projet-intro .btn-site {
    max-width: max-content;
}

.container-bloc-projet-intro .projet-intro-liens {gap: 1.5rem;}
.container-bloc-projet-intro .projet-intro-liens a::after {transform: none;}
.container-bloc-projet-intro .projet-intro-liens a[href*='play.google']::after {content: "\f3ab"; font-weight: 900; font-family: "Font Awesome 6 brands";}
.container-bloc-projet-intro .projet-intro-liens a[href*='apps.apple']::after {content:"\f179"; font-weight: 900; font-family: "Font Awesome 6 brands";}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-intro .projet-intro-inner { align-items: flex-start; }

}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-intro .projet-intro-right {
        flex: 1;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-intro .projet-intro-inner {
        max-width: 100rem;
    }
}


/* --- bloc-projet-slider-sync.css --- */
/* =====================================================
   BLOC PROJET SLIDER SYNC
   ===================================================== */

.container-bloc-projet-slider-sync .projet-slider-intro { margin-bottom: 3rem;}

.container-bloc-projet-slider-sync .slider-syncing-wrapper { gap: 2rem; }

/* Navigation miniatures : masquée sur mobile */
.container-bloc-projet-slider-sync .slider-nav-col {
    width: 20%;
    flex-shrink: 0;
    display: none;
}

.container-bloc-projet-slider-sync .slider-projet-nav .slick-slide {
    padding: 0 0 2rem;
    cursor: pointer;
    opacity: 0.5;
    transition: opacity 0.3s;
}

.container-bloc-projet-slider-sync .slider-projet-nav .slick-slide.slick-current {
    opacity: 1;
}

.container-bloc-projet-slider-sync .slider-nav__item img {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: var(--border-radius);
    object-fit: cover;
    display: block;
}

/* Slider principal */
.container-bloc-projet-slider-sync .slider-projet-col {
    width: 100%;
    height: 35rem;
}

.container-bloc-projet-slider-sync .slider-projet-col .slider-projet {height: calc(100% - 2rem);}
.container-bloc-projet-slider-sync .slider-projet-col .slider-projet .slick-list, .container-bloc-projet-slider-sync .slider-projet-col .slider-projet .slick-track {height: 100%;}

.container-bloc-projet-slider-sync .slider-main__slide img {
    aspect-ratio: 16 / 9;
    border-radius: var(--border-radius);
    width: 100%;
    object-fit: cover;
    display: block;
}

/* Slick arrows */
.container-bloc-projet-slider-sync .slider-projet .slick-arrow {
    bottom: 0;
    top: auto;
}

.container-bloc-projet-slider-sync .slider-projet .slick-next {
    right: 2rem;
    left: auto;
}

.container-bloc-projet-slider-sync .slider-projet .slick-prev {
    right: 10rem;
    left: auto;
}

.container-bloc-projet-slider-sync .slider-projet .slick-arrow:hover {
    background-color: #fff;
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-slider-sync .slider-nav-col { display: block; }
    .container-bloc-projet-slider-sync .slider-projet-col { height: 45rem;}
    .container-bloc-projet-slider-sync .projet-slider-intro { margin-bottom: 5rem; max-width: 80rem;}
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-projet-slider-sync .slider-nav-col {
        display: block;
    }

    .container-bloc-projet-slider-sync .slider-projet-col {width: calc(80% - 2rem);  height: inherit;}

    .container-bloc-projet-slider-sync .slider-main__slide img {
        aspect-ratio: 16 / 9;
    }
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-slider-sync .slider-syncing-wrapper {
        gap: 3rem;
    }
}


/* --- bloc-projet-sliders-multiples.css --- */
/* =====================================================
   BLOC MULTI SLIDERS
   ===================================================== */

.container-bloc-multi-sliders .multi-sliders-inner {overflow: hidden;}
.container-bloc-multi-sliders .multi-sliders-intro {max-width: 80rem; margin-bottom: 3rem;}
.container-bloc-multi-sliders .sliders-row {flex-direction: column; gap: 2rem; padding: 1rem .3rem;}


.container-bloc-multi-sliders .slider-col {flex: 1;  min-width: 0; max-width: 45rem;}
.container-bloc-multi-sliders .slider-track {
    border-radius: var(--border-radius);
    overflow: hidden;
    box-shadow: var(--box-shadow);
}

.container-bloc-multi-sliders .slider-slide { overflow: hidden;
    outline: none;
}

.container-bloc-multi-sliders .slider-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.container-bloc-multi-sliders .sliders-row .slick-prev, .container-bloc-multi-sliders .sliders-row .slick-next {z-index: 10; width: 4rem;  height: 4rem;}
.container-bloc-multi-sliders .sliders-row .slick-prev { left: 0.75rem; }
.container-bloc-multi-sliders .sliders-row .slick-next { right: 0.75rem; }
.container-bloc-multi-sliders .sliders-row .slick-prev::before, .container-bloc-multi-sliders .sliders-row .slick-next::before {font-size: 2.5rem; opacity: 0.85;}


/* =====================================================
   DESKTOP 768px — disposition en ligne
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-multi-sliders .sliders-row {flex-direction: row; gap: 2rem; align-items: stretch; width: 100%; left: auto; justify-content: center; padding: 1rem;}
    .container-bloc-multi-sliders .slider-slide {aspect-ratio: 4 / 5;}
    
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    .container-bloc-multi-sliders .sliders-row {gap: 3rem; }
    .container-bloc-multi-sliders .multi-sliders-intro { margin-bottom: 5rem;}

}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
}

/* --- bloc-projet-visuel-central.css --- */
/* =====================================================
   BLOC PROJET VISUEL CENTRAL
   ===================================================== */

.container-bloc-projet-visuel-central {width: 100%; margin-top: 6rem; margin-bottom: 6rem;}

.container-bloc-projet-visuel-central .visuel-sticky {position: sticky;  top: 0; height: 60vh;  overflow: hidden;}

.container-bloc-projet-visuel-central .visuel-clip-wrap {
    width: 100%;
    height: 100%;
    clip-path: inset(0% 0% round 0px);
    will-change: clip-path;
    overflow: hidden;
}

.container-bloc-projet-visuel-central .visuel-clip-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* =====================================================
   DESKTOP 768px
   ===================================================== */
@media (min-width: 768px) {
    .container-bloc-projet-visuel-central {
        margin-top: 8rem;
        margin-bottom: 8rem;
    }
}

/* =====================================================
   DESKTOP 1100px
   ===================================================== */
@media (min-width: 1100px) {
    
    .container-bloc-projet-visuel-central { height: 200vh; margin-top: 10rem; margin-bottom: 10rem; }
    .container-bloc-projet-visuel-central .visuel-sticky {height: 100vh;}
}

/* =====================================================
   LARGE 1800px
   ===================================================== */
@media (min-width: 1800px) {
    .container-bloc-projet-visuel-central {
        margin-top: 12rem;
        margin-bottom: 12rem;
    }
}


/* --- bloc-raccourcis.css --- */
.container-bloc-raccourcis {column-gap: 2rem; row-gap: 1.5rem;}
.container-bloc-raccourcis .raccourci-bouton {border: .1rem solid var(--couleur-texte); padding: .5rem 2rem; text-decoration: none; border-radius: var(--border-radius); font-size: 1.5rem;}


@media (hover: hover) {

}



/* --- bloc-texte-defilant.css --- */
.bloc-texte-defilant {position: relative;width: 100%;overflow: hidden;white-space: nowrap;box-sizing: border-box; display: flex;align-items: center; height: 180px;}
.bloc-texte-defilant::before, .bloc-texte-defilant::after { content: "";position: absolute; top: 0;bottom: 0;  width: 10%;pointer-events: none;z-index: 1;}
.bloc-texte-defilant .texte-defilant { display: inline-block; font-size: 4rem; color: var(--couleur-texte);white-space: nowrap;padding-right: 80px; animation: marquee 20s linear infinite; animation-delay: 0s;}


@media (min-width: 768px) {
    .bloc-texte-defilant .texte-defilant {font-size: 8rem; animation: marquee 40s linear infinite;}
}

@media (min-width: 1200px) {
    .bloc-texte-defilant .texte-defilant {font-size: 10rem;}
}

@keyframes marquee{
    0% {
        transform: translateX(0px);
    }
    100% {
        transform: translateX(-100%);
    }
    }
    

/* --- bloc-visionneuse-pdf.css --- */
/* --- bloc-visionneuse-pdf.css --- */

.container-bloc-visionneuse-pdf {
    width: 100%;
    padding: 40px 0;
}

/* En-tête */
.visionneuse-pdf-header {
    text-align: center;
    margin-bottom: 32px;
}

.visionneuse-pdf-titre {
    margin-bottom: 8px;
}

.visionneuse-pdf-sous-titre {
    margin-bottom: 16px;
    opacity: 0.7;
}

.visionneuse-pdf-texte {
    max-width: 720px;
    margin: 0 auto;
}

/* Wrapper — s'adapte à son contenu */
.visionneuse-pdf-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Loading */
.visionneuse-pdf-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    font-style: italic;
    opacity: 0.6;
}

/* Flipbook outer — largeur appliquée dynamiquement par JS */
.flipbook-outer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    /* width injectée par JS */
}

/* Container du stage — dimensions exactes injectées par JS */
.flipbook-container {
    overflow: hidden;
    /* width et height injectées par JS */
}

.flipbook-stage {
    display: block;
    cursor: grab;
    /* width et height injectées par JS */
}

.flipbook-stage:active {
    cursor: grabbing;
}

/* Contrôles navigation */
.visionneuse-pdf-controls {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: center;
}

.flipbook-btn {
    background: none;
    border: 2px solid currentColor;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s, color 0.2s;
    padding: 0;
    flex-shrink: 0;
}

.flipbook-btn:hover {
    background: currentColor;
    color: #fff;
}

.flipbook-page-info {
    font-size: 14px;
    min-width: 60px;
    text-align: center;
}

/* Vide / erreur */
.visionneuse-pdf-empty {
    text-align: center;
    opacity: 0.5;
    font-style: italic;
    padding: 40px;
}

/* Responsive */
@media (max-width: 768px) {
    .flipbook-stage {
        touch-action: pan-y;
    }

    .flipbook-btn {
        width: 36px;
        height: 36px;
        font-size: 18px;
    }
}


