.header *, .footer * {
  position: unset;
}

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;
}

/* 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;
}

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;
}

.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;
}

.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;
  }
}

#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;
  }
}

/*# sourceMappingURL=header-footer.css.map */
