html, body {
  color: #252525;
}

.maincolor {
  color: #000;
}

.sndcolor {
  color: #E8EBEE;
}

.dark {
  color: #747474;
}

.white {
  color: #FFFFFF;
}

.thirdcolor {
  color: #E4003A;
}

.corpo-color {
  color: #80217F;
}

.text75-color {
  color: #838383;
}

.bgmain {
  background: #000;
}

.bgwhite {
  background: #FFFFFF;
}

.bgsnd {
  background: #E8EBEE;
}

.bgdark {
  background: #747474;
}

.bgthird {
  background: #E4003A;
}

.container {
  --bs-gutter-x: 32px;
  --bs-gutter-y: 0px;
}

@media screen and (min-width: 1600px) {
  .container {
    max-width: 1520px;
  }
}
/* poppins-100 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 100;
  src: url("../fonts/poppins/poppins-normal-100.woff2") format("woff2");
}
/* poppins-100italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 100;
  src: url("../fonts/poppins/poppins-italic-100.woff2") format("woff2");
}
/* poppins-200 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/poppins/poppins-normal-200.woff2") format("woff2");
}
/* poppins-200italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 200;
  src: url("../fonts/poppins/poppins-italic-200.woff2") format("woff2");
}
/* poppins-300 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/poppins/poppins-normal-300.woff2") format("woff2");
}
/* poppins-300italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 300;
  src: url("../fonts/poppins/poppins-italic-300.woff2") format("woff2");
}
/* poppins-regular - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/poppins/poppins-normal-400.woff2") format("woff2");
}
/* poppins-italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/poppins/poppins-italic-400.woff2") format("woff2");
}
/* poppins-500 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/poppins/poppins-normal-500.woff2") format("woff2");
}
/* poppins-500italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 500;
  src: url("../fonts/poppins/poppins-italic-500.woff2") format("woff2");
}
/* poppins-600 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/poppins/poppins-normal-600.woff2") format("woff2");
}
/* poppins-600italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 600;
  src: url("../fonts/poppins/poppins-italic-600.woff2") format("woff2");
}
/* poppins-700 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/poppins/poppins-normal-700.woff2") format("woff2");
}
/* poppins-700italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 700;
  src: url("../fonts/poppins/poppins-italic-700.woff2") format("woff2");
}
/* poppins-800 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/poppins/poppins-normal-800.woff2") format("woff2");
}
/* poppins-800italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 800;
  src: url("../fonts/poppins/poppins-italic-800.woff2") format("woff2");
}
/* poppins-900 - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/poppins/poppins-normal-900.woff2") format("woff2");
}
/* poppins-900italic - latin */
@font-face {
  font-display: swap;
  font-family: "Poppins";
  font-style: italic;
  font-weight: 900;
  src: url("../fonts/poppins/poppins-italic-900.woff2") format("woff2");
}
* {
  font-family: "Poppins", sans-serif;
}

html, body {
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
}

.ttu {
  text-transform: uppercase;
}

.tac {
  text-align: center;
}

h1 {
  font-family: "Poppins", sans-serif;
  font-size: 35px;
  line-height: 54px;
  font-weight: 700;
  color: #000;
}

h2 {
  font-family: "Poppins", sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 40px;
}
h2 span.light {
  font-weight: 500;
  color: #747474;
  display: block;
  line-height: 38px;
  font-size: 25px;
}
@media only screen and (max-width: 550px) {
  h2 {
    font-size: 35px;
  }
}

h3 {
  font-size: 30px;
  line-height: 30px;
  font-family: "Poppins", sans-serif;
  color: #000;
  font-weight: 800;
}

h4 {
  font-size: 18px;
  font-weight: 800;
  line-height: 22px;
}

h3, h4, h5, h6 {
  font-family: "Poppins", sans-serif;
}

a {
  font-family: inherit;
  font-size: inherit;
  text-decoration: none;
  color: inherit;
}
a.none {
  text-decoration: none;
}
a.hover_snd:hover {
  color: #E8EBEE;
}
a.white_link:hover {
  color: #FFFFFF;
}

.content a {
  text-decoration: none;
  color: #000;
}
.content a:hover {
  color: #E4003A;
  text-decoration: underline;
}
.content p {
  margin: 25px 0;
}
.content p, .content li {
  text-align: inherit;
  color: inherit;
  font-size: 16px;
  line-height: 23px;
}
.content strong {
  font-weight: 700;
}
.content.last-center p {
  text-align-last: center;
}

small {
  font-size: 12px;
}

.medium {
  font-weight: 500;
}

.semibold {
  font-weight: 600;
}

.bold {
  font-weight: 700;
}

.extrabold {
  font-weight: 800;
}

.light {
  font-weight: 300;
}

.blackfont {
  font-weight: 900;
}

.mainfont {
  font-family: "Poppins", sans-serif;
}

.titrefont {
  font-family: "Poppins", sans-serif;
}

.thirdfont {
  font-family: "Poppins", sans-serif;
}

.underline {
  text-decoration: underline;
}

.nosouligne {
  text-decoration: none;
}

.letterspace {
  letter-spacing: 1.5px;
}

.letterspacebig {
  letter-spacing: 3px;
}

.italic {
  font-style: italic;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

em {
  font-family: inherit;
  font-style: italic;
  font-size: inherit;
}

strong {
  font-weight: 700;
  font-family: inherit;
  font-size: inherit;
}

span {
  font-family: inherit;
  font-weight: inherit;
  font-family: inherit;
}

.uppercase {
  text-transform: uppercase;
}

.normal {
  text-transform: initial;
}

.capitalize {
  text-transform: capitalize;
}

.smallLineheight {
  line-height: 20px;
}

ul:not([class]) {
  padding-left: 20px;
}
ul:not([class]) li {
  padding-left: 3px;
  list-style-type: disc;
  font-size: 16px;
  font-family: "Poppins", sans-serif;
  font-weight: inherit;
}
ul:not([class]).none {
  padding-left: 0;
}
ul:not([class]).none li {
  padding-left: 0;
  list-style-type: none;
  font-size: 16px;
  font-family: "Poppins", sans-serif;
}

ol {
  padding-left: 20px;
}
ol li {
  padding-left: 3px;
  font-size: 16px;
  font-family: "Poppins", sans-serif;
  font-weight: inherit;
}
ol.none {
  padding-left: 0;
}
ol.none li {
  padding-left: 0;
  list-style-type: none;
  font-size: 16px;
  font-family: "Poppins", sans-serif;
}

.border_text {
  color: transparent;
  -webkit-text-stroke: 1px #000;
  text-transform: uppercase;
  font-weight: 900;
  line-height: 60px;
}

.border_text.white_stroke {
  -webkit-text-stroke: 1px #FFFFFF;
}

hr {
  border: none;
  background: #000;
  height: 1px;
  margin-top: 15px;
  margin-bottom: 15px;
}
hr.white_hr {
  background: #FFFFFF;
  width: 100%;
}

.f11 {
  font-size: 11px;
}

.f12 {
  font-size: 12px;
}

.f13 {
  font-size: 13px;
}

.f14 {
  font-size: 14px;
}

.f15 {
  font-size: 15px;
}

.f16 {
  font-size: 16px;
}

.f18 {
  font-size: 18px;
}

.f20 {
  font-size: 20px;
}

.f22 {
  font-size: 22px;
}

.f25 {
  font-size: 25px;
}

.f30 {
  font-size: 30px;
}

.f32 {
  font-size: 32px;
}

.f35 {
  font-size: 35px;
}

.f40 {
  font-size: 40px;
}

.l43 {
  line-height: 43px;
}

.l35 {
  line-height: 35px;
}

.l30 {
  line-height: 30px;
}

.l25 {
  line-height: 25px;
}

.l22 {
  line-height: 22px;
}

.l18 {
  line-height: 19px;
}

.l18 {
  line-height: 18px;
}

.l16 {
  line-height: 16px;
}

.l20 {
  line-height: 20px;
}

.l15 {
  line-height: 15px;
}

.heading {
  font-family: "Poppins", sans-serif;
}
.heading--n1 {
  font-size: clamp(2.175rem, 2.008rem + 1.589vw, 3.438rem);
  letter-spacing: -0.02em;
  line-height: clamp(2.469rem, 1.874rem + 2.57vw, 4.188rem);
  font-weight: 700;
  margin-bottom: 0;
}
.heading--n2 {
  font-size: clamp(2rem, 1.697rem + 1.308vw, 2.875rem);
  letter-spacing: calc(clamp(2rem, 1.697rem + 1.308vw, 2.875rem) * -1 / 100);
  line-height: clamp(2.375rem, 1.964rem + 1.776vw, 3.563rem);
  font-weight: 500;
}
.heading--n3 {
  font-size: clamp(1.75rem, 1.447rem + 1.308vw, 2.625rem);
  letter-spacing: calc(clamp(1.75rem, 1.447rem + 1.308vw, 2.625rem) * -1 / 100);
  line-height: clamp(2.094rem, 1.694rem + 1.729vw, 3.25rem);
  font-weight: 200;
}
.heading--n4 {
  font-size: clamp(1.5rem, 1.414rem + 0.374vw, 1.75rem);
  letter-spacing: calc(clamp(1.5rem, 1.414rem + 0.374vw, 1.75rem) * -1 / 100);
  line-height: clamp(1.813rem, 1.726rem + 0.374vw, 2.063rem);
  font-weight: 700;
}
.heading--n5 {
  font-size: clamp(1.25rem, 1.207rem + 0.187vw, 1.375rem);
  letter-spacing: calc(clamp(1.25rem, 1.207rem + 0.187vw, 1.375rem) * -1 / 100);
  font-weight: 500;
}
.heading--special {
  font-size: clamp(1.875rem, 0.509rem + 5.988vw, 5rem);
  line-height: clamp(3.375rem, 1.9rem + 6.467vw, 6.75rem);
  letter-spacing: 0.02em;
  font-weight: 900;
  font-style: italic;
  color: #FFFFFF;
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: #E4003A;
  text-transform: uppercase;
  margin-block: 0;
}
@media screen and (min-width: 576px) {
  .heading--special {
    -webkit-text-stroke-width: 2px;
  }
}

.label {
  font-size: 18px;
  font-weight: 500;
}

hr {
  opacity: 1;
  background: #E4003A;
  width: 86px;
  height: 4px;
  margin: 0;
}

.btn {
  appearance: none;
  --webkit-appearance: none;
  --moz-webkit-appearance: none;
  border: none;
  background: unset;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  cursor: pointer;
  padding: 11px 20px;
  transition: 0.3s;
  border-radius: 50px;
  text-transform: uppercase;
  font-weight: 500;
  font-size: 16px;
  width: 100%;
  height: fit-content;
}
@media screen and (min-width: 768px) {
  .btn {
    width: fit-content;
    font-size: 18px;
  }
}
.btn:hover {
  text-decoration: none;
}
.btn.btn--main {
  background: #000;
  color: white;
  border: 1px solid #000;
}
.btn.btn--main svg {
  stroke: white;
}
.btn.btn--main:hover {
  background: transparent;
  color: #000;
  border: 1px solid #000;
}
.btn.btn--main:hover svg {
  stroke: #000;
}
.btn.btn--main.hoverFull {
  background: #000;
  color: white;
  border: none;
}
.btn.btn--main.hoverFull svg {
  stroke: white;
}
.btn.btn--main.hoverFull:hover {
  background: #E4003A;
  color: #000;
  border: none;
}
.btn.btn--main.hoverFull:hover svg {
  stroke: #000;
}
.btn.btn--white {
  background: #FFFFFF;
  color: #000;
  border: solid 1px rgba(0, 0, 0, 0.3);
}
.btn.btn--white:hover {
  background: #000;
  color: #FFFFFF;
}
.btn.btn--main-outline {
  background: #FFFFFF;
  color: #000;
  border: 1px solid #000;
}
.btn.btn--main-outline svg {
  stroke: #000;
}
.btn.btn--main-outline:hover {
  background: #000;
  color: #FFFFFF;
  border: 1px solid #000;
}
.btn.btn--main-outline:hover svg {
  stroke: #FFFFFF;
}
.btn.btn--white-outline {
  background: transparent;
  color: #FFFFFF;
  border: 1px solid #FFFFFF;
}
.btn.btn--white-outline svg {
  stroke: #000;
}
.btn.btn--white-outline:hover {
  background: #FFFFFF;
  color: #747474;
}
.btn.btn--white-outline:hover svg {
  stroke: #FFFFFF;
}
.btn.btn--dark-outline {
  background: #FFFFFF;
  color: #747474;
  border: 2px solid #747474;
}
.btn.btn--dark-outline svg {
  stroke: #747474;
  margin-left: 15px;
}
.btn.btn--dark-outline:hover {
  background: #747474;
  color: #FFFFFF;
  border: 2px solid #747474;
}
.btn.btn--dark-outline:hover svg {
  stroke: #FFFFFF;
}
.btn.btn--third {
  background: #E4003A;
  color: #FFFFFF;
}
.btn.btn--third svg {
  stroke: #FFFFFF;
  margin-left: 5px;
}
.btn.btn--third:hover {
  background: #747474;
  color: #FFFFFF;
}
.btn.btn--third:hover svg {
  stroke: #FFFFFF;
}
.btn.btn--dark {
  background: #747474;
  color: #FFFFFF;
}
.btn.btn--dark svg {
  stroke: #FFFFFF;
  margin-left: 5px;
}
.btn.btn--dark:hover {
  background: #E4003A;
  color: #FFFFFF;
}
.btn.btn--dark:hover svg {
  stroke: #FFFFFF;
}
.btn.btn--arrow {
  gap: 8px;
}
.btn.btn--arrow::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-size: contain;
}
.btn.btn--main.btn--arrow::after {
  background: url("../images/2025/arrow-right.svg") no-repeat center center;
}
.btn.btn--main.btn--arrow:hover::after, .btn.btn--main.btn--arrow:focus::after, .btn.btn--main.btn--arrow:active::after {
  background: url("../images/2025/arrow-right-black.svg") no-repeat center center;
}
.btn.btn--white.btn--arrow::after {
  background: url("../images/2025/arrow-right-black.svg") no-repeat center center;
}
.btn.btn--white.btn--arrow:hover::after, .btn.btn--white.btn--arrow:focus::after, .btn.btn--white.btn--arrow:active::after {
  background: url("../images/2025/arrow-right.svg") no-repeat center center;
}
.btn.btn--rounded {
  padding: 14px;
}

section, .google_reviews {
  position: relative;
}

strong, .mejs-inner, .mejs-layers {
  position: initial;
}

.tac {
  text-align: center;
}

.ttu {
  text-transform: uppercase;
}

@media (min-width: 992px) {
  .ta-lg-l {
    text-align: left;
  }
}

a.rsx {
  transition: 0.3s;
}
a.rsx:hover {
  transform: scale(1.15);
}

.stroke {
  -webkit-text-stroke: 2px #e4003a;
  color: rgba(255, 255, 255, 0);
}

.titre_0 {
  font-style: italic;
  font-weight: 900;
  text-transform: uppercase;
  font-size: 40px;
  line-height: 46px;
}
@media (min-width: 992px) {
  .titre_0 {
    font-size: 75px;
    line-height: 70px;
  }
}
@media (min-width: 1200px) {
  .titre_0 {
    font-size: 95px;
    line-height: 89px;
  }
}

.titre_1 {
  font-style: italic;
  font-weight: 900;
  font-size: 34px;
  line-height: 42px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
@media (min-width: 992px) {
  .titre_1 {
    font-size: 71px;
    line-height: 78px;
  }
}

.titre_2 {
  font-style: italic;
  font-weight: 900;
  font-size: 27px;
  line-height: 30px;
  text-align: center;
}
@media (min-width: 992px) {
  .titre_2 {
    text-align: left;
    font-size: 40px;
    line-height: 45px;
  }
}

.titre_3 {
  font-weight: 400;
  font-size: 25px;
  line-height: 28px;
}
@media (min-width: 992px) {
  .titre_3 {
    font-size: 35px;
    line-height: 38px;
  }
}

.titre_4 {
  font-weight: 400;
  font-size: 25px;
  line-height: 28px;
}
@media (min-width: 992px) {
  .titre_4 {
    font-size: 35px;
    line-height: 38px;
  }
}

.surtitre_1 {
  font-weight: 400;
  font-size: 18px;
  line-height: 27px;
  text-transform: uppercase;
}

.degrade_texte {
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

.degrade_2 {
  background: linear-gradient(19.88deg, #80217F 6.55%, #DB0A3C 78.95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: 0.3s;
  text-fill-color: transparent;
}

.title_bg {
  background: url(../images/fond_texte.jpg);
  background-clip: border-box;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  font-style: italic;
  font-size: 31px;
  line-height: 38px;
  text-transform: uppercase;
  letter-spacing: 2px;
  background-position: -312px 450px;
  background-size: 890px;
  padding-right: 20px;
  padding-top: 20px;
  display: block;
  margin-bottom: 12px;
}
@media (min-width: 992px) {
  .title_bg {
    font-size: 80px;
    line-height: 83px;
  }
}

.sepa {
  width: 114px;
  height: 1px;
  background: #E4003A;
  margin: 0 auto 38px auto;
}
@media (min-width: 992px) {
  .sepa {
    margin-left: 0;
  }
}

.chapo * {
  font-weight: 700;
  font-size: 17px;
  line-height: 27px;
  text-align: center;
}
@media (min-width: 992px) {
  .chapo * {
    font-size: 21px;
    line-height: 32px;
    text-align: left;
  }
}

a.url {
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
}
a.url img {
  margin-left: 11px;
  transition: 0.3s;
}
a.url:hover img {
  transform: translateX(15px);
}
a.url.white {
  color: #FFFFFF;
}

.relative {
  position: relative;
}

#floating_rsx {
  position: fixed;
  display: none;
}
#floating_rsx .svg {
  height: 172px;
  width: 1px;
  background: #E4003A;
  margin: auto;
}
#floating_rsx a img {
  margin-top: 22px;
  margin-left: 2px;
}
#floating_rsx a:hover img {
  filter: grayscale(1) brightness(3.3);
}
@media (min-width: 1060px) {
  #floating_rsx {
    display: block;
    left: 13px;
    z-index: 10;
  }
}
@media (min-width: 1100px) {
  #floating_rsx {
    left: 20px;
  }
}
@media (min-width: 1200px) {
  #floating_rsx {
    left: 5px;
  }
}
@media (min-width: 1280px) {
  #floating_rsx {
    left: 26px;
  }
}
@media (min-width: 1300px) {
  #floating_rsx {
    left: 3.5vw;
  }
}
@media (min-width: 1440px) {
  #floating_rsx {
    left: 68px;
  }
}
@media (min-width: 1540px) {
  #floating_rsx {
    left: 118px;
  }
}

.swiper-pagination, .swiper-pagination_carou_article {
  bottom: -30px !important;
}
.swiper-pagination .swiper-pagination-bullet, .swiper-pagination_carou_article .swiper-pagination-bullet {
  width: 9px;
  background: unset;
  height: 9px;
  border: 1px solid #E4003A;
  margin-left: 7px;
  margin-right: 7px;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active, .swiper-pagination_carou_article .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #E4003A;
}

.breadcrumb p {
  display: flex;
  gap: 8px;
  align-items: center;
}
.breadcrumb a, .breadcrumb span {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  font-size: 12px;
  line-height: 21px;
  color: #BDBDBD;
  transition: 0.3s;
}
.breadcrumb a:hover {
  color: #939393;
}

.floating_share {
  display: none;
  position: fixed;
  background: white;
  padding-bottom: 25px;
  width: 82px;
  z-index: 1000;
  top: 0px;
  height: 556px;
  z-index: 1000000000000;
}
@media (min-width: 1310px) {
  .floating_share {
    display: block;
  }
}
.floating_share p {
  transform: rotate(-90deg) translate(0, -5px);
  display: block;
  margin: 60px 0 60px 0;
  color: #E4003A;
  width: max-content;
}
.floating_share .links {
  display: flex;
  flex-direction: column;
}
.floating_share .links a {
  margin: 10px auto;
}
.floating_share .links a:hover img {
  transform: scale(1.15);
}
.floating_share .retour {
  margin: auto;
  position: relative;
  width: 100%;
  display: block;
}
.floating_share .retour:hover span {
  color: #E4003A;
  transform: rotate(-90deg) translate(0, 5px);
}
.floating_share .retour img {
  margin-left: 20px;
}
.floating_share .retour span {
  transform: rotate(-90deg);
  position: absolute;
  display: block;
  text-transform: uppercase;
  color: #9F9F9F;
  font-size: 14px;
  top: 85px;
  transition: 0.3s;
  left: 25px;
}

#loader {
  display: none;
}

@media (min-width: 1310px) {
  .partage_projet {
    display: none;
  }
}

iframe {
  max-width: 100%;
  height: auto;
}
@media (min-width: 992px) {
  iframe {
    min-height: 600px;
  }
}

.wysiwyg h2 {
  line-height: 40px;
}

.yarpp-related {
  margin-bottom: 75px !important;
}

.wp-video video {
  height: auto;
}

.carou_yarp {
  overflow: visible !important;
  position: relative;
}
.carou_yarp::after {
  content: "";
  display: block;
  background: white;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 10;
  transform: translateX(-100%);
}

.google_reviews {
  padding-block: 50px;
  position: relative;
}
.google_reviews::before {
  content: "";
  display: block;
  width: 100%;
  height: 371px;
  background: linear-gradient(0deg, #E8EBEE -0.51%, rgba(232, 235, 238, 0) 99.94%);
  position: absolute;
  top: calc(50% - 120px);
  left: 0;
  transform: translateY(-50%);
  z-index: -1;
}
.google_reviews .title_reviews {
  position: relative;
  margin-bottom: 60px;
}
.google_reviews .title_reviews::before {
  display: none;
}
@media screen and (max-width: 992px) {
  .google_reviews .title_reviews {
    margin-bottom: 0px;
  }
}
.google_reviews .title_reviews h2, .google_reviews .title_reviews h2 .title_bg {
  font-style: italic;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 35px;
  line-height: 38px;
  padding-right: 10px;
  padding-top: 0;
  position: relative;
  width: max-content;
}
@media (min-width: 992px) {
  .google_reviews .title_reviews h2, .google_reviews .title_reviews h2 .title_bg {
    font-size: 60px;
    padding-top: 10px;
    line-height: 58px !important;
  }
}
.google_reviews .title_reviews h2 img, .google_reviews .title_reviews h2 .title_bg img {
  position: absolute;
  right: -30px;
  bottom: -30px;
}
@media screen and (min-width: 992px) {
  .google_reviews {
    padding-block: 110px;
  }
}

#carou_avis_foot .carou_avis {
  padding: 25px !important;
}
#carou_avis_foot .carou_avis .swiper-slide {
  height: auto;
}
#carou_avis_foot .carou_avis .single_avis {
  background: white;
  box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.08);
  padding: 24px;
  position: relative;
  height: 100%;
}
#carou_avis_foot .carou_avis .single_avis .avis_google-icon {
  position: absolute;
  top: 24px;
  right: 24px;
}
#carou_avis_foot .carou_avis .single_avis .stars {
  display: flex;
  margin-block: 16px;
}
#carou_avis_foot .carou_avis .single_avis .stars span {
  background: #FDD314;
  width: 24px;
  height: 24px;
  display: block;
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}
#carou_avis_foot .carou_avis .single_avis .head {
  display: flex;
}
#carou_avis_foot .carou_avis .single_avis .head img.profil_pic {
  width: 60px;
  height: 60px;
  display: block;
  margin-right: 10px;
}
#carou_avis_foot .carou_avis .single_avis .head .data {
  max-width: 66%;
}
#carou_avis_foot .carou_avis .single_avis .head .data p.name {
  color: #555555;
  margin-top: 5px;
  font-size: medium;
  margin-bottom: 0px;
  padding-right: 30px;
  font-weight: 700;
}
#carou_avis_foot .carou_avis .single_avis .head .data p.date {
  margin-top: 0;
}
#carou_avis_foot .carou_avis .single_avis .head a {
  display: block;
  min-width: 32px;
}
#carou_avis_foot .carou_avis .single_avis .head a img {
  width: 32px;
  display: block;
  height: 32px;
}
#carou_avis_foot .carou_avis + .swiper-pagination_avis {
  display: flex;
  justify-content: center;
  margin-top: 20px;
  margin-inline: auto;
}
#carou_avis_foot .carou_avis + .swiper-pagination_avis .swiper-pagination-bullet {
  background: #838383;
  width: 10px;
  height: 10px;
  border: none;
  flex-shrink: 0;
}
#carou_avis_foot .carou_avis + .swiper-pagination_avis .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #E4003A;
}
@media screen and (min-width: 576px) {
  #carou_avis_foot .carou_avis + .swiper-pagination_avis {
    width: 16px;
    height: 16px;
  }
}

.list--unstyled {
  list-style: none;
  padding: 0;
  margin: 0;
}
.list--unstyled li {
  list-style-type: none;
}

/* box sizing */
/* no wrap */
/* img autoheight */
/* img autowidth */
/* img fit */
/* clip path */
/* padding row */
/* columns */
/* videos */
/* 16/9 : 56.25% //// 4/3  : 75% */
/* svg icons */
/* calc */
/* transition */
/* multiple transitions */
/* box shadow */
/* text shadow */
/* blur */
/* appearance */
/* transform */
/* transform origin */
/* animation declaration */
/* animation doing */
.m100 {
  max-width: 100%;
}

.m90 {
  max-width: 90%;
}

.m75 {
  max-width: 75%;
}

.m50 {
  max-width: 50%;
}

.absolute {
  position: absolute;
}

.fixed {
  position: fixed;
}

.index-999 {
  z-index: 999;
}

.vmiddle {
  vertical-align: middle;
}

@media screen and (min-width: 1440px) {
  .container_large {
    min-width: 1324px;
    padding-left: 70px;
    padding-right: 70px;
  }
}

.animation.module {
  opacity: 0;
  transition: all 0.8s;
}
.animation.from_bottom.module {
  margin-top: 30px;
}
.animation.from_bottom.module.module-1 {
  margin-top: 50px;
}
.animation.from_bottom.module.module-2 {
  margin-top: 70px;
}
.animation.from_bottom.module.module-3 {
  margin-top: 90px;
}
.animation.from_bottom.module.module-4 {
  margin-top: 110px;
}
.animation.from_bottom.module.module-5 {
  margin-top: 130px;
}
.animation.from_bottom.module.module-6 {
  margin-top: 150px;
}
.animation.from_bottom.module.animate {
  margin-top: inherit;
  opacity: 1;
}
.animation.from_left.module {
  margin-left: 150px;
}
.animation.from_left.module.animate {
  margin-left: 0;
  opacity: 1;
}
.animation.from_right.module {
  margin-right: 150px;
}
.animation.from_right.module.animate {
  margin-right: 0;
  opacity: 1;
}

.ariane {
  display: flex;
  padding: 0;
}
@media screen and (max-width: 992px) {
  .ariane {
    display: none;
  }
}
.ariane li {
  list-style-type: none;
  font-size: 12px;
  font-family: "Poppins", sans-serif;
  line-height: 17px;
  color: #E8EBEE;
}
.ariane li::after {
  content: " > ";
  position: relative;
}
.ariane li:last-child::after {
  content: none;
}
.ariane li a {
  color: #000;
  font-size: 12px;
  text-decoration: none;
}

.footer {
  background: #E4003A;
  color: #FFFFFF;
  padding-block: 68px 40px;
  height: auto !important;
}

.footer-content {
  margin-block: 45px 20px;
}
@media screen and (min-width: 992px) {
  .footer-content {
    margin-block: 90px 77px;
  }
}

@media screen and (min-width: 992px) {
  .footer-newsletter {
    margin-right: 86px;
  }
}

.footer-newsletter__form {
  margin-top: 24px;
}
.footer-newsletter__form button {
  flex-shrink: 0;
}

.footer-social img {
  filter: brightness(0) invert(1);
}
@media screen and (min-width: 992px) {
  .footer-social {
    position: absolute;
    top: 0;
    right: 0;
  }
}

label {
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  color: black;
  display: block;
  margin-bottom: 6px;
}
label#msg_check {
  font-size: 12px;
  line-height: 18px;
  color: rgba(0, 0, 0, 0.6862745098);
}

input, textarea {
  background: #F4F4F4;
  border-radius: 5px;
  border: unset;
  height: 39px;
  width: 100%;
  margin-bottom: 30px;
  font-family: "Poppins", sans-serif;
  padding: 15px;
}

textarea {
  height: 165px;
}

.service_form {
  display: flex;
  justify-content: space-around;
  margin-bottom: 30px;
}
.service_form .sepa {
  height: 100px;
  width: 1px;
  background: #BDBDBD;
  margin: 0 !important;
}
.service_form .single_service {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
.service_form .single_service label {
  cursor: pointer;
  text-transform: uppercase;
}
.service_form .single_service label.autre {
  text-align: right;
}
.service_form .single_service label img {
  filter: grayscale(1) brightness(2);
  margin-bottom: 17px;
}
.service_form .single_service label img.autre {
  margin-bottom: 28px;
  margin-top: 11px;
}
.service_form .single_service label:hover img {
  filter: unset;
}
.service_form .single_service input {
  display: none;
}
.service_form .single_service input:checked + label img {
  filter: unset;
}

.acceptance {
  display: flex;
  flex-direction: row;
  cursor: pointer;
}
.acceptance label {
  cursor: pointer;
}
.acceptance input {
  display: none;
}
.acceptance input + label {
  display: flex;
  flex-direction: row;
  position: relative;
}
.acceptance input + label::before {
  content: "";
  border: 2px solid #E4003A;
  border-radius: 50px;
  height: 17px;
  min-width: 17px;
  display: block;
  margin: 0px 6px -4px 2px;
}
.acceptance input:checked + label::after {
  content: "";
  background: #E4003A;
  border-radius: 50px;
  height: 7px;
  min-width: 7px;
  display: block;
  position: absolute;
  left: 7px;
  top: 5px;
}

p.required {
  font-size: 12px;
  line-height: 18px;
  color: rgba(0, 0, 0, 0.6862745098);
}

.form_done, .form_fail, .remplis_captcha {
  display: none;
}

@media (min-width: 992px) {
  #form_done div {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
#form_done .red {
  color: #E4003A;
}

#submit {
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  background: linear-gradient(49.04deg, #80217F 22.76%, #DB0A3C 94.49%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  border: unset;
  cursor: pointer;
  display: flex;
  align-items: center;
  margin-bottom: 50px;
}
#submit img {
  margin-left: 11px;
}
#submit:hover img {
  transform: translateX(15px);
}

.leaflet-control-container {
  display: block !important;
}

#fonction_form {
  display: none;
}

#burger {
  background-color: transparent;
  border: none;
  height: 50px;
  cursor: pointer;
  display: flex;
  padding: 0;
}
#burger.opened {
  z-index: 100000000000;
}
#burger .line {
  fill: none;
  stroke: #000;
  stroke-width: 4;
  transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1), stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
}
#burger .line1 {
  stroke-dasharray: 60 207;
  stroke-width: 4;
}
#burger .line2 {
  stroke-dasharray: 60 60;
  stroke-width: 4;
}
#burger .line3 {
  stroke-dasharray: 60 207;
  stroke-width: 4;
}
#burger.opened .line1 {
  stroke-dasharray: 90 207;
  stroke-dashoffset: -134;
  stroke-width: 4;
}
#burger.opened .line2 {
  stroke-dasharray: 1 60;
  stroke-dashoffset: -30;
  stroke-width: 4;
}
#burger.opened .line3 {
  stroke-dasharray: 90 207;
  stroke-dashoffset: -134;
  stroke-width: 4;
}

.header {
  padding-block: 12px 22px;
  position: fixed;
  width: 100%;
  left: 0;
  top: 0;
  background: #FFFFFF;
  z-index: 20;
}
@media screen and (min-width: 992px) {
  .header.scrolled .header__logo {
    transform: scale(0.7);
  }
}

.header__logo img {
  width: auto;
  height: 50px;
}
@media screen and (min-width: 992px) {
  .header__logo img {
    width: auto;
    height: 66px;
  }
}

.header__top, .header__bottom {
  display: none;
}
@media screen and (min-width: 992px) {
  .header__top, .header__bottom {
    display: block;
  }
}

.header__bottom {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 100%);
  width: 100%;
  height: calc(100vh - 84px);
  background: #FFFFFF;
  padding-inline: 20px;
  overflow: scroll;
  padding-bottom: 30px;
}
@media screen and (min-width: 992px) {
  .header__bottom {
    position: static;
    transform: none;
    height: auto;
    min-height: auto;
    background: none;
    width: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    overflow: visible;
    padding-bottom: 0;
  }
}

.header__list--top {
  gap: 64px;
}

@media screen and (min-width: 992px) {
  .header__list--bottom {
    margin-top: 10px;
    gap: 10px;
  }
}
@media screen and (min-width: 1200px) {
  .header__list--bottom {
    gap: 20px;
  }
}

.header__link {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 18px;
  font-weight: 500;
  padding: 20px;
  border: none;
  border-bottom: solid 1px #E8EBEE;
  background: none;
  cursor: pointer;
  transition: color 0.2s ease;
  text-decoration: none;
  width: 100%;
  justify-content: space-between;
  color: #000;
  height: 71px;
}
.header__link:hover, .header__link:active, .header__link:focus {
  color: #E4003A;
}
@media screen and (min-width: 992px) {
  .header__link {
    width: fit-content;
    padding: 10px 20px;
    border-bottom: none;
    height: auto;
  }
}

li:has(.header__link) {
  width: 100%;
}
@media screen and (min-width: 992px) {
  li:has(.header__link) {
    width: auto;
  }
}

.header__link[aria-haspopup=true]::after {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background-image: url("../images/2025/arrow-down.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  transition: transform 0.3s ease;
  transform: rotate(-90deg);
}
.header__link[aria-haspopup=true]:hover::after, .header__link[aria-haspopup=true]:active::after, .header__link[aria-haspopup=true]:focus::after {
  background-image: url("../images/2025/arrow-down-red.svg");
}
.header__link[aria-haspopup=true][aria-expanded=true]::after {
  transform: rotate(180deg);
}
@media screen and (min-width: 992px) {
  .header__link[aria-haspopup=true]::after {
    width: 20px;
    height: 20px;
    transform: none;
  }
}

.header__submenu-panel {
  background: #FFFFFF;
  display: none;
  height: calc(100% + 84px);
  position: absolute;
  top: -84px;
  left: 0;
  padding-inline: 30px;
  padding-top: 44px;
  z-index: 8;
  opacity: 0;
}
@media screen and (min-width: 992px) {
  .header__submenu-panel {
    width: 100vw;
    box-shadow: 0 31px 35px 0 rgba(15, 58, 123, 0.05);
    position: absolute;
    top: unset;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 100%);
    z-index: 10;
    padding-inline: 0;
    padding-top: 0;
    height: unset;
    opacity: 1;
  }
}

.submenu-panel-menuback {
  position: absolute;
  top: 0;
  left: 16px;
}

.header__submenu-list {
  max-width: 1520px;
  padding-inline: 30px;
  margin-inline: auto;
  padding-block: 0px 16px;
}
@media screen and (min-width: 992px) {
  .header__submenu-list {
    padding-block: 32px 55px;
    display: flex;
    gap: 30px;
  }
}

.header__submenu-item {
  width: 100%;
}

.header__submenu-item--card {
  background: linear-gradient(39deg, #F5B5D2 -4.1%, #FCF4F8 66.93%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 40px;
  margin-top: 20px;
  position: relative;
}
.header__submenu-item--card .heading {
  max-width: 50%;
}
.header__submenu-item--card > * {
  position: relative;
  z-index: 3;
}
.header__submenu-item--card::before {
  content: "";
  display: block;
  width: 225px;
  height: 272px;
  background-image: url("../images/2025/deco-statue.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media screen and (min-width: 992px) {
  .header__submenu-item--card {
    margin-top: 0;
  }
}

.header__submenu-link {
  color: #838383;
  letter-spacing: 0.32px;
  display: block;
  margin-block: 24px;
}

.header__submenu-sublink {
  font-size: 18px;
  letter-spacing: 0;
  font-weight: 400;
  display: flex;
  gap: 16px;
  padding-block: 14px;
  padding-inline: 10px;
  border-bottom: solid 1px #E8EBEE;
  position: relative;
  border-radius: 4px;
}
.header__submenu-sublink a::before {
  content: "";
  inset: 0;
  position: absolute;
  z-index: 1;
}
.header__submenu-sublink-picto {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
  width: 44px;
  height: 44px;
  background: linear-gradient(39deg, rgba(245, 181, 210, 0.6) -4.1%, rgba(252, 244, 248, 0.6) 66.93%);
  border-radius: 100%;
  flex-shrink: 0;
}
.header__submenu-sublink:hover, .header__submenu-sublink:focus-within, .header__submenu-sublink:active {
  background: #E8EBEE;
}
.header__submenu-sublink:hover a, .header__submenu-sublink:focus-within a, .header__submenu-sublink:active a {
  color: #000;
}

.header__submenu-sublink-details {
  font-size: 14px;
  color: #838383;
}

.header__list > li:has(.btn) {
  width: 100%;
  margin-top: 16px;
}
@media screen and (min-width: 992px) {
  .header__list > li:has(.btn) {
    margin-top: 0;
    width: fit-content;
  }
}

.my-marker-inner {
  background: url("../images/marker.svg") no-repeat;
  background-size: contain;
  width: 50px;
  height: 50px;
  z-index: 99999;
}

/*.leaflet-tile-container
 * position: relative
 * &::after
 * content: ""
 * position: absolute
 * top: -600px
 * background: rgba($maincolor, .8)
 * height: 2500px
 * left: -1200px
 * mix-blend-mode: multiply
 * width: 2500px
 * @media screen and ( max-width: $extrasmall )
 * left: -600px*/
.leaflet-control-container {
  display: none;
}

@media screen and (max-width: 768px) {
  .leaflet-map {
    max-height: 250px;
  }
}

header .tooltip {
  /* Red */
}
header .tooltip .arrow::before {
  border-bottom-color: #E8EBEE;
}
header .tooltip .tooltip-inner {
  background: #e8ebee;
  border-radius: 50px;
  color: #FFFFFF;
  opacity: 1;
  font-size: 13px;
}

.choiceNombre .tooltip {
  max-width: 250px;
  position: absolute;
  font-size: 12px;
}

.single-post .flexible h1 {
  font-size: 30px;
  line-height: 35px;
}
.single-post .flexible a:not(.article) {
  text-decoration: underline;
}
.single-post .flexible h2:not(.titre_1) {
  font-style: italic;
  font-weight: 900;
  font-size: 27px;
  line-height: 30px;
  text-align: center;
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-top: 50px;
  text-fill-color: transparent;
  width: max-content;
  padding-right: 10px;
  max-width: 100%;
}
@media (min-width: 992px) {
  .single-post .flexible h2:not(.titre_1) {
    text-align: left;
    font-size: 40px;
    line-height: 45px;
  }
}
.single-post .flexible h2:not(.titre_1)::after {
  width: 114px;
  height: 1px;
  background: #e4003a;
  margin: 30px auto 38px auto;
  content: "";
  display: block;
}
@media (min-width: 992px) {
  .single-post .flexible h2:not(.titre_1)::after {
    margin-left: 0;
  }
}
.single-post .flexible h3 {
  font-weight: 700;
  margin: 40px 0 30px 0;
}
.single-post .flexible ul {
  padding-left: 0;
}
.single-post .flexible ul li {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 15px;
}
.single-post .flexible ul li::before {
  content: ">";
  margin-right: 3px;
}
.single-post .flexible .carou_article_container {
  margin-top: 0px;
}
@media (min-width: 992px) {
  .single-post .flexible h1 {
    font-size: 40px;
    line-height: 46px;
  }
  .single-post .flexible h2 {
    margin-top: 105px;
  }
  .single-post .flexible .deco_col::after {
    content: url(../images/deco.svg);
    position: absolute;
    left: 10px;
    bottom: 20px;
  }
}
@media (min-width: 1200px) {
  .single-post .titre_0 {
    font-size: 65px;
    line-height: 69px;
  }
}

.hero {
  position: relative;
}
.hero .container {
  position: relative;
}
.hero .rsx_nav {
  display: none;
}
@media screen and (min-width: 1020px) {
  .hero .rsx_nav {
    display: block;
    position: fixed;
    left: 16px;
    z-index: 10;
    top: 150px;
  }
  .hero .rsx_nav #line {
    margin: 0 auto 20px auto;
    height: 277px;
    width: 1px;
    background: #E4003A;
  }
  .hero .rsx_nav a {
    margin-bottom: 12px;
    display: block;
  }
  .hero .container {
    position: static;
  }
}
@media (min-width: 1200px) {
  .hero .rsx_nav {
    left: 20px;
  }
}
@media (min-width: 1900px) {
  .hero .rsx_nav {
    left: calc(50% - 892px);
  }
}

.hero__video {
  max-width: 100%;
  clip-path: polygon(0 0, 100% 0%, 100% calc(100% - 5px), 0% calc(100% - 5px));
  height: 390px;
  margin-top: -100px;
}
.hero__video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .hero__video {
    position: absolute;
    bottom: 3px;
    left: 0;
    z-index: -1;
    height: 100%;
    max-width: 62%;
    width: 100%;
    margin-top: 0;
  }
  .hero__video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media screen and (min-width: 992px) {
  .hero__video {
    left: 0;
    height: calc(100% - 121px);
    max-width: 58%;
  }
}
@media screen and (min-width: 1600px) {
  .hero__video {
    max-width: 62%;
  }
}

.hero__content {
  padding-block: 0 50px;
}
@media screen and (min-width: 768px) {
  .hero__content {
    padding-block: 100px 90px;
    margin-right: 35px;
  }
}
@media screen and (min-width: 1400px) {
  .hero__content {
    margin-right: 130px;
  }
}

.hero__intro {
  margin-top: 78px;
}

.competences {
  padding-block: 53px 110px;
  position: relative;
}
.competences::before {
  content: "";
  display: block;
  width: 321px;
  height: 321px;
  background-image: url("../images/2025/deco-statue-461x461.png");
  background-size: contain;
  background-position: bottom right;
  background-repeat: no-repeat;
  position: absolute;
  bottom: 0;
  right: -120px;
  z-index: -1;
}
.competences::after {
  content: "";
  display: block;
  width: 533px;
  height: 461px;
  background: linear-gradient(319deg, #F5B5D2 0%, #FFF 49.52%);
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -2;
}
@media screen and (min-width: 576px) {
  .competences {
    padding-block: 53px 61px;
  }
}
@media screen and (min-width: 768px) {
  .competences::after {
    width: 361px;
    height: 361px;
  }
}
@media screen and (min-width: 992px) {
  .competences::before {
    width: 461px;
    height: 461px;
  }
}
@media screen and (min-width: 1400px) {
  .competences::before {
    right: 69px;
  }
}

.competence__item {
  margin-top: 63px;
}
.competence__item img {
  max-width: 28px;
}
.competence__item .heading {
  transition: 0.3s;
  font-size: 20px;
}
.competence__item:hover .heading, .competence__item:active .heading, .competence__item:focus .heading {
  color: #E4003A;
  transition: 0.3s;
}
.competence__item:hover .competence__item-btn, .competence__item:active .competence__item-btn, .competence__item:focus .competence__item-btn {
  transition: 0.3s;
  width: 130px;
}
@media screen and (min-width: 576px) {
  .competence__item img {
    max-width: unset;
  }
  .competence__item .heading {
    font-size: clamp(1.5rem, 1.414rem + 0.374vw, 1.75rem);
  }
}
@media screen and (min-width: 992px) {
  .competence__item {
    height: calc(100% - 43px);
    margin-top: 43px;
    padding-right: 20px;
  }
}
@media screen and (min-width: 1200px) {
  .competence__item {
    padding-right: 80px;
  }
}

.competence__item-btn {
  transition: 0.3s;
  width: 105px;
}

.words {
  margin-top: 110px;
  overflow: hidden;
}

.words__container {
  gap: 20px;
  display: flex;
  flex-wrap: nowrap;
  width: fit-content;
  white-space: nowrap;
}
.words__container:not(:first-of-type) {
  margin-top: -28px;
}
@media screen and (min-width: 768px) {
  .words__container {
    gap: 40px;
  }
}

.projets {
  padding-block: 30px 50px;
}
@media screen and (min-width: 992px) {
  .projets {
    padding-block: 99px 135px;
    position: relative;
  }
  .projets::before {
    content: "";
    display: block;
    width: 597px;
    height: 401px;
    background-image: url("../images/2025/monogram.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    top: 50%;
    left: calc(50% - 960px);
    transform: translateY(-50%);
    z-index: -1;
  }
}

.projets__header {
  margin-bottom: 35px;
}
@media screen and (min-width: 992px) {
  .projets__header {
    margin-bottom: 85px;
  }
}

.projet-card {
  margin-bottom: 30px;
}
.projet-card .projet-card-image {
  height: 210px;
}
.projet-card:hover .projet-card-image img, .projet-card:focus .projet-card-image img, .projet-card:active .projet-card-image img {
  transform: scale(1.05);
  transition: transform 0.3s ease-in-out;
}
@media screen and (min-width: 768px) {
  .projet-card .projet-card-image {
    height: 230px;
  }
}
@media screen and (min-width: 992px) {
  .projet-card {
    margin-bottom: 69px;
  }
  .projet-card:not(.projet-card-large) .projet-card-image {
    height: 365px;
  }
  .projet-card.projet-card-large .projet-card-image {
    max-height: 751px;
    height: 100%;
  }
}

.projet-card-image {
  overflow: hidden;
}
.projet-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}

.projet-card-badges {
  margin-block: 24px;
  display: flex;
  gap: 8px;
}

.projet-card-badge {
  background: #F7F7F7;
  display: block;
  padding: 3px 12px;
  border-radius: 100px;
  width: fit-content;
  color: #252525;
}

.touche-a-tout .container {
  padding-block: 50px;
}
.touche-a-tout .container::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  background: linear-gradient(266deg, #F5B5D2 -30.97%, #FCF4F8 57.37%);
  z-index: -1;
}
.touche-a-tout .container .titre_1 img {
  display: none;
}
@media screen and (min-width: 992px) {
  .touche-a-tout .container {
    position: relative;
    padding-block: 110px 70px;
  }
  .touche-a-tout .titre_1 {
    position: relative;
  }
  .touche-a-tout .titre_1 img {
    position: absolute;
    display: block;
    bottom: 0;
    transform: translate(-80%, 90%);
  }
}
@media screen and (min-width: 1200px) {
  .touche-a-tout .container::before {
    width: 82%;
  }
}

.touche-a-tout__img {
  margin-top: -45px;
}
@media screen and (min-width: 992px) {
  .touche-a-tout__img {
    margin-top: -75px;
  }
}

.touche-a-tout__texte ul {
  padding: 0;
  margin: 0;
}
.touche-a-tout__texte ul li {
  list-style: none;
  margin-bottom: 16px;
}
.touche-a-tout__texte a {
  appearance: none;
  --webkit-appearance: none;
  --moz-webkit-appearance: none;
  border: none;
  background: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-decoration: none;
  cursor: pointer;
  padding: 11px 20px;
  transition: 0.3s;
  border-radius: 50px;
  text-transform: uppercase;
  font-weight: 500;
  font-size: 16px;
  gap: 8px;
  width: 100%;
}
.touche-a-tout__texte a::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url("../images/2025/arrow-right-black.svg") no-repeat center center;
  background-size: contain;
}
.touche-a-tout__texte a:hover, .touche-a-tout__texte a:focus, .touche-a-tout__texte a:active {
  background: #000;
  color: #FFFFFF;
}
.touche-a-tout__texte a:hover::after, .touche-a-tout__texte a:focus::after, .touche-a-tout__texte a:active::after {
  background: url("../images/2025/arrow-right.svg") no-repeat center center;
}
@media screen and (min-width: 992px) {
  .touche-a-tout__texte {
    width: fit-content;
    font-size: 18px;
  }
}

.team-home {
  padding-block: 32px 0;
}
@media screen and (min-width: 992px) {
  .team-home {
    padding-block: 142px 0;
    min-height: 1000px;
  }
}
@media screen and (min-width: 1100px) {
  .team-home {
    min-height: 1050px;
  }
}
@media screen and (min-width: 1400px) {
  .team-home {
    min-height: 1152px;
  }
}
@media screen and (min-width: 1600px) {
  .team-home {
    min-height: 1000px;
  }
}

.team-home__titre {
  padding: 40px 0;
  position: relative;
}
.team-home__titre::before {
  content: "";
  display: block;
  width: 20vw;
  height: 100%;
  position: absolute;
  top: 0;
  left: 2px;
  background: #FFFFFF;
  transform: translateX(-100%);
}
.team-home__titre .titre_1 {
  position: relative;
  font-weight: 800;
  font-style: italic;
  line-height: 0.9;
  margin-bottom: 80px;
  font-size: 28px;
  letter-spacing: 0;
  max-width: calc(100% - 130px);
}
.team-home__titre .titre_1::before {
  content: "";
  display: block;
  width: 113px;
  height: 39px;
  background: url("../images/vague.svg") no-repeat center;
  background-size: contain;
  position: absolute;
  bottom: 0;
  left: calc(50% - 86px);
  transform: translateY(100%) rotate(10deg);
}
.team-home__titre .esper {
  position: absolute;
  left: 3px;
  top: -11px;
  transform: translateX(-100%);
  font-size: 74px;
  line-height: 1.1;
  font-weight: 800;
  font-style: italic;
  color: #FFFFFF;
  -webkit-text-stroke-width: 2px;
  -webkit-text-stroke-color: #E4003A;
}
@media screen and (min-width: 576px) {
  .team-home__titre {
    max-width: unset;
  }
  .team-home__titre .titre_1 {
    font-size: 34px;
  }
}
@media screen and (min-width: 992px) {
  .team-home__titre {
    padding: 0 6px 20px 80px;
  }
  .team-home__titre .titre_1 {
    font-size: 56px;
  }
  .team-home__titre .esper {
    font-size: 145px;
    left: 9px;
  }
}
@media screen and (min-width: 1200px) {
  .team-home__titre {
    padding: 0 6px 64px 80px;
  }
}
@media screen and (min-width: 1400px) {
  .team-home__titre {
    padding: 0 77px 88px 107px;
  }
  .team-home__titre .titre_1 {
    font-size: 71px;
  }
}

@media screen and (min-width: 992px) {
  .team-home__img {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
  }
}

#popup_video {
  display: none;
  background: rgba(0, 0, 0, 0.8509803922);
  position: fixed;
  width: 100vw;
  height: 100vh;
  z-index: 1000000000;
  top: 0;
}
#popup_video #quit_popup_video {
  margin: 25px 35px auto auto;
  width: 33px;
  cursor: pointer;
  height: 33px;
}
#popup_video #quit_popup_video span {
  position: absolute;
  display: block;
  width: 100%;
  height: 3px;
  background-color: red;
  border-radius: 1px;
  transform: rotate(45deg);
  top: 16px;
}
#popup_video #quit_popup_video span:last-of-type {
  transform: rotate(-45deg);
  bottom: 5px;
}
#popup_video .flex_container {
  display: flex;
  height: 100%;
  width: 80vw;
  margin: auto;
  justify-content: center;
}
#popup_video #content_popup {
  width: 100%;
  display: flex;
}
#popup_video #content_popup iframe {
  margin: auto;
  display: block;
  width: 100%;
}
#popup_video #loader_popup {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.projets-hero {
  padding-bottom: 49px;
}
.projets-hero .container {
  position: relative;
}
.projets-hero .container::before {
  content: "";
  display: block;
  width: 227px;
  height: 153px;
  background-image: url("../images/2025/monogram.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: -45px;
  right: 0;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .projets-hero {
    margin-top: 58px;
    padding-bottom: 54px;
  }
  .projets-hero .container::before {
    width: 487px;
    height: 327px;
    bottom: unset;
    top: -25px;
  }
  .projets-hero .container::after {
    content: "";
    display: block;
    width: 27px;
    height: 47px;
    background-image: url("../images/2025/deco-vague.png");
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    bottom: 0px;
    right: 0;
  }
}

.projet-card-proposition {
  background: linear-gradient(135deg, #E4003A 12.53%, #80217F 75.77%);
  padding: 24px;
  height: 230px;
  position: relative;
  margin-bottom: 30px;
}
.projet-card-proposition::before {
  content: "";
  display: block;
  width: 130px;
  height: 196px;
  position: absolute;
  bottom: 0;
  right: 0;
  background-image: url("../images/2025/deco-statue.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom right;
}
.projet-card-proposition .btn--arrow {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-block: 10px;
}
.projet-card-proposition .btn--arrow::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-size: contain;
  background: url("../images/2025/arrow-right.svg") no-repeat center center;
}
@media screen and (min-width: 576px) {
  .projet-card-proposition {
    padding: 30px;
  }
}
@media screen and (min-width: 992px) {
  .projet-card-proposition {
    margin-bottom: 69px;
    height: 365px;
    padding: 40px;
  }
  .projet-card-proposition::before {
    width: 225px;
    height: 272px;
  }
}

.projet-card-proposition--white {
  background: #FFFFFF;
  box-shadow: 0 0 35px 0 rgba(0, 0, 0, 0.1);
}
.projet-card-proposition--white .btn--arrow::after {
  background: url("../images/2025/arrow-right-black.svg") no-repeat center center;
}

.projets-terms {
  margin-block: 49px 0;
}

.projets-term {
  border: none;
  appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  padding: 4px 12px;
  border-radius: 14px;
  transition: 0.3s;
  font-weight: 500;
}
.projets-term:hover, .projets-term:active, .projets-term:focus {
  background: #EAEAEA;
  transition: 0.3s;
}
.projets-term.is-active {
  background: #EAEAEA;
}

#loader_projets {
  display: none;
}

#contact .title_img {
  margin-top: 50px;
  max-width: 80%;
}
#contact #form {
  margin-top: 74px;
}
#contact .links {
  position: absolute;
  top: 630px;
  right: 50%;
}
#contact .links a {
  margin-bottom: 20px;
  display: block;
}
#contact .links a:hover img {
  transform: scale(1.15);
}
#contact .carte {
  height: 500px;
}
#contact .carte iframe {
  height: 500px;
}
@media (min-width: 992px) {
  #contact .carte {
    margin-top: 182px;
    height: 800px;
  }
  #contact .carte iframe {
    height: 800px;
  }
  #contact .links {
    top: 950px;
  }
}
@media (min-width: 1200px) {
  #contact .carte {
    width: calc(50vw - 105px);
    margin-top: 30px;
  }
  #contact .carte .deco {
    position: absolute;
    right: 0;
    bottom: -268px;
  }
  #contact .carte img {
    max-width: unset;
  }
}

.deco_titre_one {
  text-align: center;
  margin: 25px 0;
}
@media (min-width: 992px) {
  .deco_titre_one {
    text-align: left;
    margin-bottom: 90px;
  }
  .deco_titre_one::after {
    content: url(../images/deco.svg);
    position: absolute;
    right: calc(50% - 430px);
    bottom: -70px;
  }
}

.intro_vignette .img img {
  display: block;
}
.intro_vignette .resume {
  box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.08);
  padding: 20px;
  margin-bottom: 25px;
}
.intro_vignette .resume p, .intro_vignette .resume a {
  text-align: center;
}
.intro_vignette .resume p .strong, .intro_vignette .resume a .strong {
  font-weight: 600;
}
.intro_vignette .resume a {
  width: 100%;
  background: linear-gradient(19.88deg, #80217F 6.55%, #DB0A3C 78.95%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: 0.3s;
  text-fill-color: transparent;
  display: flex;
  margin: auto;
  width: max-content;
  max-width: 100%;
}
.intro_vignette .resume a img {
  padding-left: 5px;
}
.intro_vignette .resume a:hover img {
  transform: translateX(10px);
}
@media (min-width: 992px) {
  .intro_vignette .img {
    height: 756px;
  }
  .intro_vignette .img img {
    max-width: unset;
    position: absolute;
    right: 0;
    transform: translateX(0);
    height: 100%;
    width: auto;
  }
  .intro_vignette .resume {
    padding: 40px 45px 30px 45px;
  }
  .intro_vignette .resume::after {
    content: url(../images/deco_client2.svg);
    position: absolute;
    bottom: -254px;
    left: 297px;
  }
  .intro_vignette .resume::before {
    content: url(../images/square.svg);
    position: absolute;
    bottom: 54px;
    right: -193px;
  }
  .intro_vignette .resume p, .intro_vignette .resume a {
    text-align: left;
  }
  .intro_vignette .resume p .strong, .intro_vignette .resume a .strong {
    display: block;
  }
  .intro_vignette .resume a {
    margin-left: 0;
  }
  .intro_vignette .chapo {
    margin-bottom: 0px;
    padding-left: 20px;
  }
  .intro_vignette .chapo p, .intro_vignette .chapo strong, .intro_vignette .chapo sup, .intro_vignette .chapo sub, .intro_vignette .chapo a {
    font-size: 16px;
    line-height: 25px;
  }
  .intro_vignette .chapo p a, .intro_vignette .chapo strong a, .intro_vignette .chapo sup a, .intro_vignette .chapo sub a, .intro_vignette .chapo a a {
    font-size: 16px;
    line-height: 25px;
  }
}
@media (min-width: 1200px) {
  .intro_vignette .img {
    height: 856px;
  }
  .intro_vignette .resume {
    max-width: 90%;
  }
  .intro_vignette .resume::after {
    left: 320px;
  }
  .intro_vignette .chapo {
    padding-left: 45px;
    padding-right: 45px;
  }
}
@media (min-width: 1500px) {
  .intro_vignette .img img {
    max-width: unset;
    position: absolute;
    right: 0;
    transform: translateX(0);
  }
}

.texte_photo h2 {
  margin-top: 0;
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  font-style: italic;
  font-weight: 900;
  font-size: 27px;
  line-height: 30px;
  text-align: center;
}
.texte_photo h2::after {
  width: 114px;
  height: 1px;
  background: #e4003a;
  margin: 40px auto 38px auto;
  content: "";
  display: block;
}
.texte_photo h3 {
  font-weight: 700;
  margin: 40px 0 30px 0;
  text-transform: uppercase;
}
.texte_photo ul {
  padding-left: 0;
}
.texte_photo ul li {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 15px;
}
.texte_photo ul li::before {
  content: ">";
  margin-right: 3px;
}
.texte_photo a.lightbox {
  overflow: hidden;
  display: block;
}
.texte_photo a.lightbox:hover img {
  transform: scale(1.05);
}
@media (min-width: 992px) {
  .texte_photo {
    margin-top: 160px;
  }
  .texte_photo h2 {
    text-align: left;
    font-size: 40px;
    line-height: 45px;
  }
  .texte_photo h2::after {
    margin-left: 0;
  }
  .texte_photo div.deco::after {
    content: url(../images/group_logos.svg);
    position: absolute;
    top: 410px;
    left: -3px;
  }
  .texte_photo div.deco::before {
    content: url(../images/deco_text_photo_alt.svg);
    position: absolute;
    left: -374px;
  }
  .texte_photo .sepa {
    margin-left: 0;
  }
  .texte_photo.deco_h3 h3::after {
    content: url(../images/deco.svg);
    position: absolute;
    right: -10px;
    bottom: -10px;
  }
}
@media (min-width: 1200px) {
  .texte_photo h3.deco::after {
    right: -100px;
  }
}

.mosaique_triptique {
  margin-top: 105px;
}
.mosaique_triptique a {
  display: block;
  margin-bottom: 20px;
  overflow: hidden;
}
.mosaique_triptique a.zoom {
  cursor: -moz-zoom-in;
  cursor: -webkit-zoom-in;
  cursor: zoom-in;
}
.mosaique_triptique a:hover img {
  transform: scale(1.05);
}
.mosaique_triptique a .title {
  position: absolute;
  bottom: 0;
  width: 100%;
  display: flex;
  background: rgb(0, 0, 0);
  background: rgba(0, 0, 0, 0.6) 100%;
}
.mosaique_triptique a .title p {
  color: white;
  margin: 35px;
}

.titre_texte_colonnes a {
  text-decoration: underline;
}
.titre_texte_colonnes h2:not(.titre_2) {
  font-style: italic;
  text-shadow: 0px 0px rgba(0, 0, 0, 0);
  font-weight: 900;
  font-size: 27px;
  line-height: 30px;
  text-align: center;
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-top: 30px;
  text-fill-color: transparent;
  padding-right: 10px;
}
@media (min-width: 992px) {
  .titre_texte_colonnes h2:not(.titre_2) {
    text-align: left;
    font-size: 40px;
    line-height: 45px;
  }
}
.titre_texte_colonnes h2:not(.titre_2)::after {
  width: 114px;
  height: 1px;
  background: #e4003a;
  margin: 30px auto 38px auto;
  content: "";
  display: block;
}
@media (min-width: 992px) {
  .titre_texte_colonnes h2:not(.titre_2)::after {
    margin-left: 0;
  }
}
.titre_texte_colonnes h3 {
  font-weight: 700;
  margin: 40px 0 30px 0;
}
.titre_texte_colonnes ul {
  padding-left: 0;
  width: 100%;
}
.titre_texte_colonnes ul li {
  list-style-type: none;
  padding-left: 0;
  margin-bottom: 15px;
}
.titre_texte_colonnes ul li::before {
  content: ">";
  margin-right: 3px;
}
@media (min-width: 992px) {
  .titre_texte_colonnes h2 {
    margin-top: 105px;
  }
  .titre_texte_colonnes .deco_col::after {
    content: url(../images/deco.svg);
    position: absolute;
    left: 10px;
    bottom: 20px;
  }
}

.partage {
  margin-bottom: 75px;
}
.partage .sepa {
  margin: 17px auto 25px 0;
}
.partage a {
  margin-right: 15px;
}
.partage a:hover img {
  transform: scale(1.15);
}

.carousel_projet {
  margin-top: 50px;
  padding-bottom: 75px;
}
.carousel_projet::before {
  content: "";
  width: 1441px;
  height: 425px;
  max-width: 100%;
  background: linear-gradient(89.95deg, #EDEDED -24.82%, rgba(237, 237, 237, 0) 156.19%);
  position: absolute;
  top: 75px;
  left: 0;
}
.carousel_projet h2, .carousel_projet h2 .title_bg {
  font-style: italic;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: 40px;
  line-height: 48px;
  text-align: center;
  padding-right: 10px;
  padding-top: 0;
}
@media (min-width: 992px) {
  .carousel_projet h2, .carousel_projet h2 .title_bg {
    font-size: 60px;
    padding-top: 20px;
    line-height: 58px !important;
  }
}
.carousel_projet a.ref {
  display: block;
}
.carousel_projet a.ref .text {
  color: black;
  font-weight: 700;
  font-size: 20px;
  line-height: 25px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  width: max-content;
  max-width: 100%;
  z-index: 100;
}
.carousel_projet a.ref .text .surtitre {
  font-size: 10px;
  line-height: 20px;
}
.carousel_projet a.ref .text .intitule {
  display: flex;
  align-items: center;
}
.carousel_projet a.ref .text .intitule img {
  margin-left: 36px;
  transition: 0.3s;
}
.carousel_projet a.ref .img {
  overflow: hidden;
  margin-bottom: 26px;
}
.carousel_projet a.ref .img img {
  transition: 0.3s;
}
.carousel_projet a.ref:hover img.fleche {
  transform: translateX(-15px);
}
.carousel_projet a.ref:hover .img img {
  transform: scale(1.05);
}
.carousel_projet .swiper-pagination {
  margin-top: 20px;
}
.carousel_projet .carou_autre_projet {
  padding-right: 30px;
  overflow: visible;
}
@media (min-width: 992px) {
  .carousel_projet::after {
    content: url(../images/deco_autres_projets.svg);
    position: absolute;
    top: 263px;
    left: calc(50% - 990px);
    z-index: 10;
  }
  .carousel_projet h2, .carousel_projet h2 .title_bg {
    font-size: 71px;
    text-align: left;
    line-height: 78px;
    margin-bottom: 90px;
  }
  .carousel_projet .swiper-pagination {
    display: none;
  }
  .carousel_projet .carou_autre_projet {
    overflow: visible;
  }
  .carousel_projet .carou_autre_projet::after {
    content: "";
    background: rgb(237, 237, 237);
    background: linear-gradient(180deg, #f0f0f0 0%, #f0f0f0 292px, #ffffff 292px, #ffffff 100%);
    width: 33vw;
    height: 100%;
    display: block;
    z-index: 10;
    top: 0;
    left: 0;
    position: absolute;
    transform: translateX(-100%);
  }
  .carousel_projet a.ref .text {
    font-size: 30px;
    line-height: 39px;
  }
}

.carou_article_container::after {
  content: url(../images/double_vague_reverse.svg);
  position: absolute;
  left: calc(50% - 696px);
  top: 400px;
  z-index: 100;
}
.carou_article_container h2 {
  color: #E4003A;
  text-align: center;
  font-size: 47px;
  line-height: 53px;
  text-align: center;
}
.carou_article_container h2 span {
  display: block;
}
.carou_article_container h2 img {
  position: absolute;
  left: calc(50% + 86px);
  bottom: -25px;
}
.carou_article_container .carou_article {
  margin-bottom: 50px;
}
.carou_article_container .carou_article a.article {
  max-width: 318px;
  display: block;
  margin: auto;
}
.carou_article_container .carou_article a.article .img {
  overflow: hidden;
}
.carou_article_container .carou_article a.article .text p {
  font-weight: 700;
  font-size: 22px;
  line-height: 28px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  margin-top: 26px;
}
.carou_article_container .carou_article a.article:hover .img img {
  transform: scale(1.05);
}
.carou_article_container .carou_article a.article:hover .fleche {
  transform: translateX(10px);
}
.carou_article_container .all_posts {
  display: flex;
  flex-direction: row;
  align-items: center;
  margin: auto auto 50px auto;
}
.carou_article_container .all_posts img {
  margin-left: 11px;
}
@media (min-width: 992px) {
  .carou_article_container {
    margin-top: 200px;
  }
  .carou_article_container .all_posts {
    margin-right: 0;
  }
  .carou_article_container .svg_container {
    transform: rotate(180deg);
    position: absolute;
    right: calc(50% + 670px);
    top: 66%;
    z-index: 10;
  }
  .carou_article_container .svg_container .svg_animate {
    stroke-dashoffset: 500;
    stroke-dasharray: 500;
    transition: 3s;
  }
  .carou_article_container h2 {
    text-align: left;
  }
  .carou_article_container h2 img {
    left: 278px;
  }
  .carou_article_container .col-lg-strange {
    max-width: 890px;
  }
  .carou_article_container .col-lg-strange .carou_article {
    overflow: visible;
  }
  .carou_article_container .col-lg-strange .carou_article::after {
    content: "";
    background: white;
    width: 33vw;
    height: 100%;
    display: block;
    z-index: 10;
    top: 0;
    left: 0;
    position: absolute;
    transform: translateX(-100%);
  }
  .carou_article_container .col-lg-strange .carou_article::before {
    content: url(../images/deco_actu_2.svg);
    position: absolute;
    right: calc(50% - 606px);
    top: -72px;
    z-index: 100;
  }
}
@media (min-width: 1200px) {
  .carou_article_container {
    overflow: visible;
  }
  .carou_article_container .col-lg-strange {
    max-width: 982px;
  }
}

.titre_img::after {
  position: absolute;
  top: -29px;
  right: -29px;
  display: block;
  z-index: -1;
  transform: scale(0.5);
}
@media (min-width: 992px) {
  .titre_img::after {
    top: 29px;
    transform: scale(1);
    right: 0;
  }
}
.titre_img.creation::after {
  content: url(../images/crea_big.svg);
}
.titre_img.web::after {
  content: url(../images/web_big.svg);
}
.titre_img.conseil::after {
  content: url(../images/conseil_big.svg);
}
.titre_img .stroke {
  font-size: 31px;
  line-height: 38px;
  font-style: italic;
  display: block;
  text-transform: uppercase;
}
@media (min-width: 992px) {
  .titre_img .stroke {
    font-size: 80px;
    line-height: 83px;
    margin-top: -15px;
  }
}

.intitule_logo {
  margin: 50px 0;
}
.intitule_logo p {
  text-align: center;
}
.intitule_logo .svg_line {
  margin: auto;
  width: 172px;
  height: 1px;
  background: #E4003A;
}
@media (min-width: 992px) {
  .intitule_logo p {
    text-align: left;
  }
}
@media (min-width: 1200px) {
  .intitule_logo .svg_line {
    margin-left: 0;
  }
}

.container_illu_texte::before {
  content: url(../images/deco_illu.svg);
  position: absolute;
  top: -100px;
  left: -300px;
  z-index: -1;
  transform: scale(0.5);
}
.container_illu_texte .illu_texte .svg_absolute {
  position: absolute;
  right: calc(50% - 630px);
  top: 230px;
}
.container_illu_texte .illu_texte h3 {
  font-weight: 400;
  font-size: 27px;
  line-height: 29px;
}
.container_illu_texte .illu_texte .sepa {
  margin-top: 30px;
}
.container_illu_texte .illu_texte .wysiwyg * {
  text-align: center;
}
@media (min-width: 992px) {
  .container_illu_texte::before {
    top: 90px;
    left: 0px;
    transform: scale(1);
  }
  .container_illu_texte p.offset {
    margin-left: 20%;
    margin-right: 20%;
    font-size: 18px;
    line-height: 27px;
  }
  .container_illu_texte .wysiwyg * {
    text-align: left;
  }
  .container_illu_texte .wysiwyg h2 {
    font-weight: 400;
    font-size: 35px;
    line-height: 38px;
  }
  .container_illu_texte h3 {
    font-size: 35px;
    line-height: 38px;
  }
}
@media (min-width: 1200px) {
  .container_illu_texte p.offset {
    margin-left: 25%;
    margin-right: 25%;
  }
}

.carou_presta {
  margin-top: 50px;
  margin-bottom: 25px;
}
.carou_presta .degrade_texte.titre_2 {
  padding-right: 5px;
}
.carou_presta .presta_swiper {
  padding: 1rem;
}
.carou_presta .presta_swiper .presta {
  box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.08);
  display: block;
  padding: 38px 39px 30px 39px;
  height: 346px;
  display: flex;
  flex-direction: column;
  background: white;
}
.carou_presta .presta_swiper .presta p.titre {
  color: #E4003A;
  font-weight: 700;
  font-size: 20px;
  line-height: 24px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 22px;
}
.carou_presta .presta_swiper .presta .link {
  margin-top: auto;
  display: flex;
  background: linear-gradient(49.04deg, #80217F 22.76%, #DB0A3C 94.49%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}
.carou_presta .presta_swiper .presta .link img {
  margin-left: 11px;
}
.carou_presta .presta_swiper .presta:hover .link img {
  transform: translateX(10px);
}
@media (min-width: 992px) {
  .carou_presta {
    margin-top: 150px;
  }
  .carou_presta::before {
    content: url(../images/bg_carou_presta_tiny.jpg);
    position: absolute;
    left: calc(50% - 140px);
    top: -100px;
  }
  .carou_presta .col-lg-strange {
    max-width: 980px;
  }
  .carou_presta .presta_swiper {
    overflow: visible;
  }
  .carou_presta .presta_swiper::before {
    content: "";
    background: white;
    display: block;
    height: 130%;
    width: 30vw;
    position: absolute;
    top: 0;
    left: -10px;
    z-index: 10;
    transform: translate(-100%, -30px);
  }
  .carou_presta .presta_swiper::after {
    content: url(../images/deco_carou_presta.svg);
    position: absolute;
    left: 0;
    top: 7px;
    z-index: 20;
    transform: translate(-100%, -100%);
  }
  .carou_presta .titre_2 {
    margin-bottom: 110px;
  }
  .carou_presta .titre_2::after {
    content: url(../images/deco.svg);
    position: absolute;
    left: 210%;
    top: -4px;
  }
}

.page-template-template-equipe .deco_1 {
  position: absolute;
  left: calc(50% - 710px);
  top: 2481px;
}
.page-template-template-equipe .deco_2 {
  top: 1621px;
  position: absolute;
  right: calc(50% - 806px);
}

#equipe_page .title_img {
  margin-top: 75px;
}
#equipe_page .intro {
  margin-top: 73px;
  margin-bottom: 120px;
}
@media (min-width: 992px) {
  #equipe_page .deco_container::after {
    content: url(../images/deco_title_team.svg);
    position: absolute;
    right: -15px;
    bottom: 0;
    transform: translateX(100%);
  }
}
@media (min-width: 1200px) {
  #equipe_page .img_team img:not(.deco_3) {
    max-width: unset;
    margin-left: -395px;
  }
  #equipe_page .img_team .deco_3 {
    position: absolute;
    right: -261px;
    top: -247px;
  }
}

#liste_team {
  margin-top: 171px;
}
#liste_team .single_team {
  display: block;
  margin-bottom: 120px;
}
#liste_team .single_team .img {
  overflow: hidden;
  width: 369px;
  max-width: 100%;
}
#liste_team .single_team .img img, #liste_team .single_team .img video {
  max-width: 100%;
}
#liste_team .single_team .text p {
  font-size: 16px;
  line-height: 24px;
}
#liste_team .single_team .text p.name {
  margin-top: 27px;
  margin-bottom: 0;
  font-weight: 700;
  font-size: 22px;
  line-height: 28px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  max-width: 100%;
  width: max-content;
}
#liste_team .single_team .text p.fonction {
  margin-bottom: 22px;
}

#single_member {
  max-width: 2000px;
  margin: auto;
}
#single_member h1 {
  font-style: italic;
  font-weight: 900;
  font-size: 51px;
  line-height: 56px;
  text-transform: uppercase;
  background-clip: text;
  text-fill-color: transparent;
  color: rgba(255, 255, 255, 0);
  background: unset;
  -webkit-text-stroke: 2px #e4003a;
  text-align: center;
}
#single_member h1 .bg {
  padding-right: 15px;
  background: linear-gradient(19.88deg, #80217F 6.55%, #DB0A3C 78.95%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 0px;
}
#single_member h2 {
  display: flex;
  align-items: center;
}
#single_member h2::before {
  width: 98px;
  display: block;
  content: "";
  background: #E4003A;
  margin-right: 25px;
  height: 1px;
}
#single_member p {
  text-align: center;
}
#single_member a {
  display: flex;
  align-items: center;
  width: max-content;
  margin: 50px auto;
}
#single_member a p {
  background: linear-gradient(49.04deg, #80217F 22.76%, #DB0A3C 94.49%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  text-transform: uppercase;
}
#single_member a .svg {
  margin-right: 11px;
  transition: 0.3s;
}
#single_member a .svg svg {
  margin-bottom: 2px;
}
#single_member a:hover .svg {
  transform: translateX(-10px);
}
#single_member .img {
  margin: 25px 0;
}
#single_member .img #video_single_membre {
  max-width: 100%;
  clip-path: polygon(1px 1px, calc(100% - 1px) 1px, calc(100% - 1px) calc(100% - 1px), 1px calc(100% - 1px));
}
@media (max-width: 992px) {
  #single_member .main_img {
    transition: clip-path 1s;
    animation-name: main_img;
    animation-duration: 10s;
    animation-iteration-count: 1000;
  }
  #single_member .main_img.hover {
    animation-name: hover_img;
    animation-duration: 10s;
    animation-iteration-count: 1000;
    position: absolute;
    top: 0;
  }
}
@media (min-width: 992px) {
  #single_member h1 {
    font-size: 80px;
    line-height: 75px;
    text-align: left;
    margin-top: 0;
  }
  #single_member p {
    text-align: left;
  }
  #single_member a {
    margin-left: 0;
  }
  #single_member .img {
    margin: 8px 0 0 0;
  }
  #single_member .img.bottom {
    position: absolute;
    bottom: -116px;
    width: 45vw;
    left: 0;
  }
  #single_member .img.bottom #video_single_membre, #single_member .img.bottom .main_img {
    position: relative;
    left: 1px;
    top: 0;
  }
  #single_member .img.bottom .hover {
    left: 1px;
    top: 0;
    position: absolute;
  }
  #single_member .img #video_single_membre, #single_member .img .main_img {
    position: fixed;
    left: 55%;
    width: 45vw;
    top: 108px;
    object-fit: cover;
    max-width: 810px;
    height: calc(100vh - 108px);
    min-height: 810px;
    max-height: 940px;
    transition: 0s !important;
    object-position: top;
  }
  #single_member .img .main_img {
    transition: clip-path 1s;
    animation-name: main_img;
    animation-duration: 10s;
    animation-iteration-count: 1000;
  }
  #single_member .img .main_img.hover {
    animation-name: hover_img;
    animation-duration: 10s;
    animation-iteration-count: 1000;
  }
}
@media (min-width: 1200px) {
  #single_member h1 {
    font-size: 90px;
    line-height: 89px;
  }
  #single_member .img #video_single_membre, #single_member .img .main_img {
    max-width: 870px;
  }
}
@media (min-width: 1920px) {
  #single_member .img .main_img, #single_member .img .hover {
    left: calc(50% + 95px);
  }
}

@keyframes main_img {
  0% {
    z-index: -1;
    clip-path: circle(100%);
  }
  30% {
    z-index: -1;
    clip-path: circle(100%);
  }
  31% {
    z-index: 1;
    clip-path: circle(1%);
  }
  70% {
    clip-path: circle(1%);
  }
  90% {
    clip-path: circle(100%);
    z-index: 1;
  }
  100% {
    z-index: -1;
  }
}
@keyframes hover_img {
  0% {
    z-index: 1;
    clip-path: circle(0%);
  }
  10% {
    clip-path: circle(0%);
  }
  30% {
    clip-path: circle(100%);
    z-index: 1;
  }
  80% {
    clip-path: circle(100%);
    z-index: -1;
  }
  81% {
    clip-path: circle(0%);
    z-index: -1;
  }
  100% {
    clip-path: circle(0%);
    z-index: -1;
  }
}
.single-projet .floating_share {
  display: none;
}
.single-projet h1, .single-projet .heading--n1 {
  font-size: clamp(2.175rem, 2.008rem + 1.589vw, 3.438rem);
  letter-spacing: -0.02em;
  line-height: clamp(2.469rem, 1.874rem + 2.57vw, 4.188rem);
  font-weight: 700;
  margin-bottom: 0;
}
.single-projet h2, .single-projet .heading--n2 {
  font-size: clamp(2rem, 1.697rem + 1.308vw, 2.875rem);
  letter-spacing: calc(clamp(2rem, 1.697rem + 1.308vw, 2.875rem) * -1 / 100);
  line-height: clamp(2.375rem, 1.964rem + 1.776vw, 3.563rem);
  font-weight: 500;
}
.single-projet h3, .single-projet .heading--n3 {
  font-size: clamp(1.75rem, 1.447rem + 1.308vw, 2.625rem);
  letter-spacing: calc(clamp(1.75rem, 1.447rem + 1.308vw, 2.625rem) * -1 / 100);
  line-height: clamp(2.094rem, 1.694rem + 1.729vw, 3.25rem);
  font-weight: 200;
}
.single-projet h4, .single-projet .heading--n4 {
  font-size: clamp(1.5rem, 1.414rem + 0.374vw, 1.75rem);
  letter-spacing: calc(clamp(1.5rem, 1.414rem + 0.374vw, 1.75rem) * -1 / 100);
  line-height: clamp(1.813rem, 1.726rem + 0.374vw, 2.063rem);
  font-weight: 700;
}
.single-projet h5, .single-projet .heading--n5 {
  font-size: clamp(1.25rem, 1.207rem + 0.187vw, 1.375rem);
  letter-spacing: calc(clamp(1.25rem, 1.207rem + 0.187vw, 1.375rem) * -1 / 100);
  line-height: normal;
  font-weight: 500;
}
.single-projet .header:not(.scrolled) {
  background: transparent;
  color: #FFFFFF;
  transition: 0.3s;
}
.single-projet .header:not(.scrolled) .header__link {
  color: #FFFFFF;
}
.single-projet .header:not(.scrolled) .header__link[aria-haspopup=true]::after, .single-projet .header:not(.scrolled) .btn.btn--main {
  filter: invert(1);
}

.projet-entete {
  position: relative;
  overflow: hidden;
  color: #FFFFFF;
}

.projet-entete__bkg {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  z-index: -1;
  object-fit: cover;
  display: flex;
  justify-content: center;
}
.projet-entete__bkg::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.6);
}
.projet-entete__bkg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.projet-entete__infos {
  padding-block: 86px 64px;
}
@media screen and (min-width: 992px) {
  .projet-entete__infos {
    padding-block: 286px 64px;
  }
}

@media screen and (min-width: 992px) {
  .projet-entete__date {
    position: absolute;
    bottom: 14px;
    left: 0;
  }
}

.projet-intro {
  padding-block: 40px 20px;
}
.projet-intro:has(.heading--n2) .projet-intro__text-wrapper {
  margin-top: 28px;
  padding-top: 32px;
  border-top: solid 4px #ABABAB;
}
@media screen and (min-width: 992px) {
  .projet-intro {
    padding-block: 80px 40px;
  }
  .projet-intro:has(.heading--n2) {
    padding-block: 50px 40px;
  }
}

.projet-intro__text-wrapper {
  margin-top: 28px;
}

.projet-intro__info-item {
  padding-bottom: 16px;
  border-bottom: solid 1px #ABABAB;
}
.projet-intro__info-item:not(:first-of-type) {
  padding-top: 16px;
}

.projet-intro__info-value {
  text-transform: capitalize;
  font-size: 12px;
  line-height: normal;
  letter-spacing: 0.02em;
  display: block;
  padding: 3px 12px;
  background: #F7F7F7;
  border-radius: 100px;
  width: fit-content;
  margin-top: 5px;
}

.zone-texte {
  padding-block: 40px;
}
@media screen and (min-width: 992px) {
  .zone-texte {
    padding-block: 80px;
  }
}

.zone-texte__content {
  gap: 24px;
}
.zone-texte__content * {
  margin-bottom: 0;
}

.zone-texte__images, .projet-galerie__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: auto;
  gap: 16px;
}
@media screen and (min-width: 992px) {
  .zone-texte__images, .projet-galerie__grid {
    gap: 30px;
    margin-top: 75px;
  }
}

.projet-galerie {
  position: relative;
  z-index: 3;
}

.projet-galerie__grid {
  background: #FFFFFF;
}
.projet-galerie__grid::after, .projet-galerie__grid::before {
  content: "";
  display: block;
  width: 100%;
  height: 80px;
  position: absolute;
  left: 0;
}
.projet-galerie__grid::after {
  bottom: -80px;
  background: linear-gradient(180deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}
.projet-galerie__grid::before {
  top: -5px;
  background: linear-gradient(0deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}

.zone-texte__images {
  margin-top: 30px;
}

.zone-texte__image img, .projet-galerie__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.zone-texte__image:nth-child(3n), .projet-galerie__item:nth-child(3n) {
  grid-column: span 2;
}

.zone-texte__texte ul li {
  margin-bottom: 16px;
}

.projet-citation {
  background: #FFFFFF;
}

.projet-quatre_photos {
  padding-block: 20px;
  position: relative;
}
@media screen and (min-width: 992px) {
  .projet-quatre_photos {
    padding-block: 0 144px;
  }
  .projet-quatre_photos::after, .projet-quatre_photos::before {
    content: "";
    display: block;
    width: 100%;
    height: 80px;
    position: absolute;
    left: 0;
  }
  .projet-quatre_photos::after {
    bottom: 64px;
    background: linear-gradient(180deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
  }
  .projet-quatre_photos::before {
    top: -80px;
    background: linear-gradient(0deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
  }
}

.projet-quatre_photos__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: auto;
  gap: 30px;
  background: #FFFFFF;
}
.projet-quatre_photos__grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.projet-img_fullwidth__image::after, .projet-img_fullwidth__image::before {
  content: "";
  display: block;
  width: 100%;
  height: 80px;
  position: absolute;
  left: 0;
}
.projet-img_fullwidth__image::after {
  bottom: -80px;
  background: linear-gradient(180deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}
.projet-img_fullwidth__image::before {
  top: -80px;
  background: linear-gradient(0deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}

.projet-img_fullwidth__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.projet-expertise__list {
  padding-block: 30px;
  gap: 16px;
}
@media screen and (min-width: 992px) {
  .projet-expertise__list {
    padding-block: 64px;
  }
}
@media screen and (min-width: 1200px) {
  .projet-expertise__list {
    padding-block: 64px 84px;
  }
}

.projet-expertise__heading {
  padding-block: 64px 0;
}
@media screen and (min-width: 992px) {
  .projet-expertise__heading {
    padding-block: 64px;
  }
}
@media screen and (min-width: 1200px) {
  .projet-expertise__heading {
    padding-block: 64px 84px;
  }
}

.projet-expertise__decor {
  position: relative;
  z-index: 2;
}

.projet-expertise {
  padding-bottom: 64px;
  position: relative;
  z-index: 3;
}
.projet-expertise::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  background: linear-gradient(39deg, #F5B5D2 -4.1%, #FCF4F8 66.93%);
  z-index: -1;
  pointer-events: none;
}
.projet-expertise::after, .projet-expertise .container::before {
  content: "";
  display: block;
  width: 100%;
  height: 80px;
  position: absolute;
  left: 0;
  pointer-events: none;
}
.projet-expertise::after {
  bottom: -80px;
  background: linear-gradient(180deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
  pointer-events: none;
}
.projet-expertise .container::before {
  top: -80px;
  background: linear-gradient(0deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}
@media screen and (min-width: 992px) {
  .projet-expertise {
    padding-bottom: 0;
  }
}
@media screen and (min-width: 1200px) {
  .projet-expertise {
    margin-top: -80px;
  }
  .projet-expertise .container::before {
    top: -20px;
  }
  .projet-expertise::before {
    height: calc(100% - 60px);
  }
}
@media screen and (min-width: 1400px) {
  .projet-expertise {
    margin-top: -160px;
  }
  .projet-expertise .container::before {
    top: 100px;
  }
  .projet-expertise::before {
    height: calc(100% - 180px);
  }
}
@media screen and (min-width: 1600px) {
  .projet-expertise .container::before {
    top: 140px;
  }
  .projet-expertise::before {
    height: calc(100% - 220px);
  }
}

.projet-expertise__item {
  display: block;
  padding: 12px 24px;
  border-radius: 24px;
  background: transparent;
  border: 1px solid rgba(0, 0, 0, 0.3);
}

.projet-nav-wrapper {
  position: relative;
}

.projet-nav.is-fixed {
  position: fixed;
  z-index: 1;
}

.projet-nav__item {
  padding: 16px;
  border-left: solid 1px #D2D2D2;
  transition: 0.3s;
}
.projet-nav__item.is-active {
  border-left: 3px solid #E4003A;
}

.projet-card-proposition--degrade::after, .projet-card-proposition--degrade a::before {
  content: "";
  display: block;
  width: 100%;
  height: 80px;
  position: absolute;
  left: 0;
}
.projet-card-proposition--degrade::after {
  bottom: -80px;
  background: linear-gradient(180deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}
.projet-card-proposition--degrade a::before {
  top: -80px;
  background: linear-gradient(0deg, #FFF 0%, rgba(255, 255, 255, 0) 100%);
}

html {
  overflow-x: hidden;
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
  max-width: 100vw;
}

body {
  max-width: 100vw;
  margin: 0;
  overflow: hidden;
  padding: 0;
  word-wrap: break-word;
}

.page-template-template-agence .deco_titre_one::after {
  display: none;
}
@media (min-width: 992px) {
  .page-template-template-agence .intro_vignette .img::after {
    content: url(../images/deco_agence.svg);
    position: absolute;
    top: 662px;
    right: 0;
    z-index: 10;
    transform: translateX(100%);
  }
}
.page-template-template-agence .intro_vignette .chapo {
  margin-top: 10px;
  font-weight: 700;
  font-size: 21px;
  line-height: 32px;
}
.page-template-template-agence .titre_texte_colonnes {
  margin-top: 25px;
}
.page-template-template-agence .titre_illu h2 {
  color: #E4003A;
  margin-bottom: 60px;
}
.page-template-template-agence .titre_illu h2 span {
  display: block;
}
.page-template-template-agence .titre_illu h2 img {
  position: absolute;
  right: calc(50% - 160px);
  bottom: -47px;
}
.page-template-template-agence .titre_illu .img {
  margin-bottom: 150px;
}
.page-template-template-agence .titre_illu .img::before {
  background: linear-gradient(262.45deg, #F5B5D2 -39.39%, #FCF4F8 56.77%);
  position: absolute;
  display: block;
  width: 100%;
  content: "";
  z-index: -1;
  height: 100%;
}
.page-template-template-agence .titre_illu .img .deco {
  position: absolute;
  max-width: 118px;
  right: 0;
}
.page-template-template-agence .titre_illu .img img:not(:first-child) {
  position: absolute;
  bottom: 0;
  transform: translateY(100%);
}
.page-template-template-agence .titre_illu .texte_photo {
  margin-top: 0;
}
.page-template-template-agence .titre_illu .texte_photo h2.snd {
  font-weight: 700;
  font-size: 25px;
  line-height: 31px;
  letter-spacing: 0.06em;
  color: black !important;
  background: unset !important;
  text-transform: uppercase;
  -webkit-text-fill-color: unset;
}
.page-template-template-agence .titre_illu.snd .img {
  padding-top: 150px;
  margin-bottom: 50px;
}
@media (min-width: 992px) {
  .page-template-template-agence .titre_illu.snd .img {
    margin-bottom: 150px;
    padding-top: 0;
  }
}
.page-template-template-agence .titre_illu.snd .img::before {
  transform: matrix(-1, 0, 0, 1, 0, 0);
  top: 0;
}
.page-template-template-agence .titre_illu.snd .img img {
  top: 0;
  transform: unset;
}
.page-template-template-agence .titre_illu.snd .img img:last-child {
  bottom: 0;
  top: unset;
}
.page-template-template-agence .texte_photo {
  margin-bottom: 75px;
}
.page-template-template-agence .texte_photo h3 {
  font-weight: 700;
  font-size: 25px;
  line-height: 31px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.page-template-template-agence .texte_photo a:not(.lightbox) {
  transition: 0.3s;
  display: block;
  text-transform: uppercase;
  font-size: 14px;
  line-height: 18px;
}
.page-template-template-agence .texte_photo a:not(.lightbox) + br {
  margin-top: 3px;
  display: block;
}
.page-template-template-agence .texte_photo a:not(.lightbox)::after {
  content: url(../images/arrow_red_small.svg);
  filter: saturate(0%) brightness(70%) contrast(1000%);
  transition: 0.3s;
  margin-left: 11px;
}
.page-template-template-agence .texte_photo a:not(.lightbox):hover {
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  transition: 0s;
}
.page-template-template-agence .texte_photo a:not(.lightbox):hover::after {
  filter: unset;
  margin-left: 25px;
}
.page-template-template-agence .competence_container .illu {
  margin-top: -60px;
  z-index: -1;
  margin-bottom: 25px;
  margin-left: auto;
  margin-right: auto;
}
.page-template-template-agence .competence_container .button {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: auto;
  font-weight: 400;
  font-size: 16px;
  line-height: 24px;
  text-transform: uppercase;
  background: linear-gradient(49.04deg, #80217F 22.76%, #DB0A3C 94.49%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  margin-bottom: 25px;
}
.page-template-template-agence .competence_container .button img {
  margin: auto 15px;
}
.page-template-template-agence .competence_container a:hover .button img {
  transform: translateX(10px);
}
.page-template-template-agence .carou_article_container {
  margin-top: 80px;
}
@media (min-width: 992px) {
  .page-template-template-agence h1 {
    margin-top: 50px;
  }
  .page-template-template-agence .titre_illu {
    margin-top: 150px;
  }
  .page-template-template-agence .titre_illu .titre_1 img {
    bottom: -40px;
    right: unset;
    left: 50px;
  }
  .page-template-template-agence .titre_illu .img {
    margin-right: -160px;
    margin-top: -750px;
  }
  .page-template-template-agence .titre_illu .img::before {
    width: 902px;
  }
  .page-template-template-agence .titre_illu .img img {
    max-width: unset;
  }
  .page-template-template-agence .titre_illu .img .deco {
    right: unset;
    left: 0;
    max-width: unset;
  }
  .page-template-template-agence .titre_illu h2 img {
    bottom: -40px;
    right: unset;
    left: 50px;
  }
  .page-template-template-agence .titre_illu.snd h2 img {
    right: 120px;
    bottom: -47px;
    left: unset;
  }
  .page-template-template-agence .titre_illu.snd .img {
    height: 726px;
    margin-top: 0px;
  }
  .page-template-template-agence .titre_illu.snd .img::before {
    height: 602px;
    width: 877px;
    bottom: 0;
    right: 0;
  }
  .page-template-template-agence .titre_illu.snd .img img:not(.deco) {
    position: absolute;
    right: 0;
  }
  .page-template-template-agence .titre_illu.snd .img .deco {
    left: unset;
    right: 0;
    bottom: 0;
    transform: translate(100%, 100%);
  }
  .page-template-template-agence .titre_texte_colonnes {
    margin-bottom: 200px;
  }
  .page-template-template-agence .titre_texte_colonnes::after {
    content: url(../images/double_vague_reverse.svg);
    position: absolute;
    right: calc(50% - 646px);
    bottom: -40px;
  }
  .page-template-template-agence .texte_photo {
    margin-top: 290px;
  }
  .page-template-template-agence .competence_container {
    margin-top: 125px;
  }
  .page-template-template-agence .competence_container::after {
    content: url(../images/deco_competence_agence.svg);
    position: absolute;
    z-index: -1;
    right: 0%;
    transform: translateX(100%);
  }
  .page-template-template-agence .competence_container::before {
    content: url(../images/deco.svg);
    position: absolute;
    left: -264px;
    bottom: 120px;
  }
  .page-template-template-agence .competence_container .sepa {
    height: 827px;
    width: 1px;
    margin: auto -0.5px 0 -0.5px;
    background: #EDEDED;
    padding: 0;
  }
  .page-template-template-agence .competence_container a:not(.lightbox) {
    font-size: 16px;
    line-height: 24px;
  }
  .page-template-template-agence .competence_container h2 {
    text-align: center;
  }
  .page-template-template-agence .competence_container .competence {
    display: flex;
    flex-direction: column;
  }
  .page-template-template-agence .competence_container .competence.first .illu {
    margin-top: 18px;
    margin-bottom: 7px;
  }
  .page-template-template-agence .competence_container .competence .illu {
    margin-top: 0;
  }
  .page-template-template-agence .competence_container .competence p {
    max-width: 275px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 992px) {
  .flexible h1 {
    margin-top: 50px;
  }
}

#liste_team .single_team img {
  position: absolute;
  z-index: 10;
}
#liste_team .single_team video {
  max-width: 100%;
}
#liste_team .single_team:hover img, #liste_team .single_team:focus img {
  transform: scale(1) !important;
  opacity: 1;
}
#liste_team .single_team img.main_vignette {
  position: relative;
}
#liste_team .single_team img.hover_vignette {
  position: absolute;
  top: 0;
  clip-path: circle(0%);
  z-index: 10;
  transition: clip-path 0.9s;
}
#liste_team .single_team:hover img.hover_vignette {
  clip-path: circle(100%);
}

@media (min-width: 1200px) {
  .single-projet h1.titre_0 {
    font-size: 75px;
    line-height: 77px;
  }
}
.single-projet .titre_texte_colonnes {
  margin-top: 50px;
}
.single-projet .titre_texte_colonnes h2 {
  margin-bottom: 10px;
  width: max-content;
}
@media (min-width: 992px) {
  .single-projet .titre_texte_colonnes h2 {
    margin-bottom: -10px;
  }
}

.gutenberg_content h2:not(.titre_1) {
  font-style: italic;
  font-weight: 900;
  font-size: 27px;
  line-height: 30px;
  text-align: center;
  background: linear-gradient(19.88deg, #80217F 6.55%, #DB0A3C 78.95%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: 0.3s;
  text-fill-color: transparent;
  margin-top: 50px;
  width: max-content;
  max-width: 100%;
  padding-right: 15px;
}
@media (min-width: 992px) {
  .gutenberg_content h2:not(.titre_1) {
    font-size: 40px;
    margin-top: 80px;
    line-height: 45px;
    text-align: left;
  }
}

#loadMore_actu {
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  background-clip: border-box;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  font-weight: 400;
}
#loadMore_actu::after {
  content: "";
  background: linear-gradient(52.27deg, #80217F 38.13%, #DB0A3C 87.32%);
  width: 0;
  transition: 0.5s;
  position: absolute;
  bottom: 0;
  height: 1px;
  display: block;
}
#loadMore_actu:hover::after {
  width: 100%;
}

/*# sourceMappingURL=main.css.map */
