.flag {
  display: inline-block;
  background: url("../img/flags.png") no-repeat top left;
  width: 22px;
  height: 15px;
  vertical-align: middle;
}
.flag.ad {
  background-position: 0px -27px;
}
.flag.ae {
  background-position: 0px -62px;
}
.flag.af {
  background-position: 0px -93px;
}
.flag.ag {
  background-position: 0px -124px;
}
.flag.ai {
  background-position: 0px -154px;
}
.flag.al {
  background-position: 0px -185px;
}
.flag.am {
  background-position: 0px -216px;
}
.flag.an {
  background-position: 0px -247px;
}
.flag.ao {
  background-position: 0px -277px;
}
.flag.aq {
  background-position: 0px -308px;
}
.flag.ar {
  background-position: 0px -339px;
}
.flag.as {
  background-position: 0px -370px;
}
.flag.at {
  background-position: 0px -401px;
}
.flag.au {
  background-position: 0px -431px;
}
.flag.aw {
  background-position: 0px -462px;
}
.flag.ax {
  background-position: 0px -493px;
}
.flag.az {
  background-position: 0px -524px;
}
.flag.ba {
  background-position: 0px -555px;
}
.flag.bb {
  background-position: 0px -586px;
}
.flag.bd {
  background-position: 0px -616px;
}
.flag.be {
  background-position: 0px -647px;
}
.flag.bf {
  background-position: 0px -678px;
}
.flag.bg {
  background-position: 0px -709px;
}
.flag.bh {
  background-position: 0px -739px;
}
.flag.bi {
  background-position: 0px -770px;
}
.flag.bj {
  background-position: 0px -801px;
}
.flag.bl {
  background-position: 0px -832px;
}
.flag.bm {
  background-position: 0px -863px;
}
.flag.bn {
  background-position: 0px -894px;
}
.flag.bo {
  background-position: 0px -924px;
}
.flag.br {
  background-position: 0px -955px;
}
.flag.bs {
  background-position: 0px -986px;
}
.flag.bt {
  background-position: 0px -1017px;
}
.flag.bw {
  background-position: 0px -1047px;
}
.flag.by {
  background-position: 0px -1078px;
}
.flag.bz {
  background-position: 0px -1109px;
}
.flag.ca {
  background-position: 0px -1140px;
}
.flag.cc {
  background-position: 0px -1171px;
}
.flag.cd {
  background-position: 0px -1201px;
}
.flag.cf {
  background-position: 0px -1232px;
}
.flag.cg {
  background-position: 0px -1263px;
}
.flag.ch {
  background-position: 0px -1294px;
}
.flag.ci {
  background-position: 0px -1325px;
}
.flag.ck {
  background-position: 0px -1355px;
}
.flag.cl {
  background-position: 0px -1386px;
}
.flag.cm {
  background-position: 0px -1417px;
}
.flag.cn {
  background-position: 0px -1448px;
}
.flag.co {
  background-position: 0px -1479px;
}
.flag.cr {
  background-position: 0px -1510px;
}
.flag.cu {
  background-position: 0px -1540px;
}
.flag.cv {
  background-position: 0px -1571px;
}
.flag.cw {
  background-position: 0px -1602px;
}
.flag.cx {
  background-position: 0px -1633px;
}
.flag.cy {
  background-position: 0px -1664px;
}
.flag.cz {
  background-position: 0px -1694px;
}
.flag.de {
  background-position: 0px -1725px;
}
.flag.dj {
  background-position: 0px -1756px;
}
.flag.dk {
  background-position: 0px -1787px;
}
.flag.dm {
  background-position: 0px -1817px;
}
.flag.do {
  background-position: 0px -1848px;
}
.flag.dz {
  background-position: 0px -1879px;
}
.flag.ec {
  background-position: 0px -1910px;
}
.flag.ee {
  background-position: 0px -1941px;
}
.flag.eg {
  background-position: 0px -1971px;
}
.flag.eh {
  background-position: 0px -2002px;
}
.flag.er {
  background-position: 0px -2033px;
}
.flag.es {
  background-position: 0px -2064px;
}
.flag.et {
  background-position: 0px -2095px;
}
.flag.eu {
  background-position: 0px -2125px;
}
.flag.fi {
  background-position: 0px -2156px;
}
.flag.fj {
  background-position: 0px -2187px;
}
.flag.fk {
  background-position: 0px -2218px;
}
.flag.fm {
  background-position: 0px -2249px;
}
.flag.fo {
  background-position: 0px -2279px;
}
.flag.fr {
  background-position: 0px -2310px;
}
.flag.ga {
  background-position: 0px -2341px;
}
.flag.gb, .flag.en, .flag.uk {
  background-position: 0px -2372px;
}
.flag.gd {
  background-position: 0px -2403px;
}
.flag.ge {
  background-position: 0px -2433px;
}
.flag.gg {
  background-position: 0px -2464px;
}
.flag.gh {
  background-position: 0px -2495px;
}
.flag.gi {
  background-position: 0px -2526px;
}
.flag.gl {
  background-position: 0px -2557px;
}
.flag.gm {
  background-position: 0px -2587px;
}
.flag.gn {
  background-position: 0px -2618px;
}
.flag.gq {
  background-position: 0px -2649px;
}
.flag.gr {
  background-position: 0px -2680px;
}
.flag.gs {
  background-position: 0px -2711px;
}
.flag.gt {
  background-position: 0px -2741px;
}
.flag.gu {
  background-position: 0px -2772px;
}
.flag.gw {
  background-position: 0px -2803px;
}
.flag.gy {
  background-position: 0px -2834px;
}
.flag.hk {
  background-position: 0px -2865px;
}
.flag.hn {
  background-position: 0px -2896px;
}
.flag.hr {
  background-position: 0px -2926px;
}
.flag.ht {
  background-position: 0px -2957px;
}
.flag.hu {
  background-position: 0px -2988px;
}
.flag.ic {
  background-position: 0px -3019px;
}
.flag.id {
  background-position: 0px -3050px;
}
.flag.ie {
  background-position: 0px -3080px;
}
.flag.il {
  background-position: 0px -3111px;
}
.flag.im {
  background-position: 0px -3142px;
}
.flag.in {
  background-position: 0px -3173px;
}
.flag.iq {
  background-position: 0px -3204px;
}
.flag.ir {
  background-position: 0px -3235px;
}
.flag.is {
  background-position: 0px -3265px;
}
.flag.it {
  background-position: 0px -3296px;
}
.flag.je {
  background-position: 0px -3327px;
}
.flag.jm {
  background-position: 0px -3358px;
}
.flag.jo {
  background-position: 0px -3389px;
}
.flag.jp {
  background-position: 0px -3419px;
}
.flag.ke {
  background-position: 0px -3450px;
}
.flag.kg {
  background-position: 0px -3481px;
}
.flag.kh {
  background-position: 0px -3512px;
}
.flag.ki {
  background-position: 0px -3543px;
}
.flag.km {
  background-position: 0px -3573px;
}
.flag.kn {
  background-position: 0px -3604px;
}
.flag.kp {
  background-position: 0px -3635px;
}
.flag.kr {
  background-position: 0px -3666px;
}
.flag.kw {
  background-position: 0px -3696px;
}
.flag.ky {
  background-position: 0px -3727px;
}
.flag.kz {
  background-position: 0px -3758px;
}
.flag.la {
  background-position: 0px -3788px;
}
.flag.lb {
  background-position: 0px -3819px;
}
.flag.li {
  background-position: 0px -3850px;
}
.flag.lc {
  background-position: 0px -3881px;
}
.flag.lr {
  background-position: 0px -3912px;
}
.flag.lk {
  background-position: 0px -3943px;
}
.flag.ls {
  background-position: 0px -3973px;
}
.flag.lt {
  background-position: 0px -4004px;
}
.flag.lu {
  background-position: 0px -4035px;
}
.flag.lv {
  background-position: 0px -4066px;
}
.flag.ma {
  background-position: 0px -4096px;
}
.flag.ly {
  background-position: 0px -4127px;
}
.flag.md {
  background-position: 0px -4158px;
}
.flag.mc {
  background-position: 0px -4189px;
}
.flag.me {
  background-position: 0px -4220px;
}
.flag.mf {
  background-position: 0px -4251px;
}
.flag.mh {
  background-position: 0px -4281px;
}
.flag.mg {
  background-position: 0px -4312px;
}
.flag.mk {
  background-position: 0px -4343px;
}
.flag.ml {
  background-position: 0px -4374px;
}
.flag.mm {
  background-position: 0px -4404px;
}
.flag.mn {
  background-position: 0px -4435px;
}
.flag.mo {
  background-position: 0px -4466px;
}
.flag.mp {
  background-position: 0px -4497px;
}
.flag.mq {
  background-position: 0px -4528px;
}
.flag.mr {
  background-position: 0px -4559px;
}
.flag.ms {
  background-position: 0px -4589px;
}
.flag.mt {
  background-position: 0px -4620px;
}
.flag.mu {
  background-position: 0px -4651px;
}
.flag.mv {
  background-position: 0px -4682px;
}
.flag.mw {
  background-position: 0px -4713px;
}
.flag.mx {
  background-position: 0px -4743px;
}
.flag.my {
  background-position: 0px -4774px;
}
.flag.mz {
  background-position: 0px -4805px;
}
.flag.nc {
  background-position: 0px -4836px;
}
.flag.na {
  background-position: 0px -4867px;
}
.flag.ne {
  background-position: 0px -4897px;
}
.flag.nf {
  background-position: 0px -4928px;
}
.flag.ng {
  background-position: 0px -4959px;
}
.flag.ni {
  background-position: 0px -4990px;
}
.flag.nl {
  background-position: 0px -5020px;
}
.flag.no {
  background-position: 0px -5051px;
}
.flag.np {
  background-position: 0px -5080px;
  height: 19px;
}
.flag.nr {
  background-position: 0px -5113px;
}
.flag.nz {
  background-position: 0px -5144px;
}
.flag.nu {
  background-position: 0px -5175px;
}
.flag.om {
  background-position: 0px -5205px;
}
.flag.pa {
  background-position: 0px -5236px;
}
.flag.pf {
  background-position: 0px -5267px;
}
.flag.pe {
  background-position: 0px -5298px;
}
.flag.pg {
  background-position: 0px -5328px;
}
.flag.ph {
  background-position: 0px -5359px;
}
.flag.pk {
  background-position: 0px -5390px;
}
.flag.pl {
  background-position: 0px -5421px;
}
.flag.pn {
  background-position: 0px -5451px;
}
.flag.pr {
  background-position: 0px -5482px;
}
.flag.ps {
  background-position: 0px -5513px;
}
.flag.pt {
  background-position: 0px -5544px;
}
.flag.pw {
  background-position: 0px -5575px;
}
.flag.py {
  background-position: 0px -5606px;
}
.flag.ro {
  background-position: 0px -5637px;
}
.flag.qa {
  background-position: 0px -5667px;
}
.flag.ru {
  background-position: 0px -5698px;
}
.flag.rs {
  background-position: 0px -5729px;
}
.flag.sa {
  background-position: 0px -5760px;
}
.flag.rw {
  background-position: 0px -5791px;
}
.flag.sc {
  background-position: 0px -5821px;
}
.flag.sb {
  background-position: 0px -5852px;
}
.flag.sd {
  background-position: 0px -5883px;
}
.flag.se {
  background-position: 0px -5914px;
}
.flag.sg {
  background-position: 0px -5945px;
}
.flag.sh {
  background-position: 0px -5975px;
}
.flag.si {
  background-position: 0px -6006px;
}
.flag.sk {
  background-position: 0px -6037px;
}
.flag.sl {
  background-position: 0px -6068px;
}
.flag.sm {
  background-position: 0px -6098px;
}
.flag.sn {
  background-position: 0px -6129px;
}
.flag.so {
  background-position: 0px -6160px;
}
.flag.sr {
  background-position: 0px -6191px;
}
.flag.ss {
  background-position: 0px -6222px;
}
.flag.st {
  background-position: 0px -6252px;
}
.flag.sv {
  background-position: 0px -6283px;
}
.flag.sy {
  background-position: 0px -6314px;
}
.flag.sz {
  background-position: 0px -6345px;
}
.flag.tc {
  background-position: 0px -6376px;
}
.flag.td {
  background-position: 0px -6407px;
}
.flag.tf {
  background-position: 0px -6437px;
}
.flag.tg {
  background-position: 0px -6468px;
}
.flag.th {
  background-position: 0px -6499px;
}
.flag.tj {
  background-position: 0px -6530px;
}
.flag.tk {
  background-position: 0px -6560px;
}
.flag.tm {
  background-position: 0px -6591px;
}
.flag.tl {
  background-position: 0px -6622px;
}
.flag.tn {
  background-position: 0px -6653px;
}
.flag.to {
  background-position: 0px -6684px;
}
.flag.tr {
  background-position: 0px -6714px;
}
.flag.tt {
  background-position: 0px -6745px;
}
.flag.tw {
  background-position: 0px -6776px;
}
.flag.tv {
  background-position: 0px -6807px;
}
.flag.tz {
  background-position: 0px -6838px;
}
.flag.ua {
  background-position: 0px -6868px;
}
.flag.ug {
  background-position: 0px -6899px;
}
.flag.us {
  background-position: 0px -6930px;
}
.flag.uy {
  background-position: 0px -6961px;
}
.flag.uz {
  background-position: 0px -6992px;
}
.flag.va {
  background-position: 0px -7023px;
}
.flag.vc {
  background-position: 0px -7053px;
}
.flag.ve {
  background-position: 0px -7084px;
}
.flag.vg {
  background-position: 0px -7115px;
}
.flag.vi {
  background-position: 0px -7146px;
}
.flag.vn {
  background-position: 0px -7176px;
}
.flag.vu {
  background-position: 0px -7207px;
}
.flag.wf {
  background-position: 0px -7238px;
}
.flag.ye {
  background-position: 0px -7269px;
}
.flag.ws {
  background-position: 0px -7300px;
}
.flag.za {
  background-position: 0px -7330px;
}
.flag.yt {
  background-position: 0px -7361px;
}
.flag.zm {
  background-position: 0px -7392px;
}
.flag.zw {
  background-position: 0px -7423px;
}

.flagLang {
  display: inline-block;
  background: url("../img/flags_lang.png") no-repeat top left;
  width: 30px;
  height: 20px;
  vertical-align: middle;
}
.flagLang.fr {
  background-position: 0px -13px;
}
.flagLang.fr {
  background-position: 0px -10px;
}
.flagLang.en {
  background-position: 0px -51px;
}
.flagLang.ar {
  background-position: 0px -93px;
}
.flagLang.es {
  background-position: 0px -135px;
}

@font-face {
  font-family: "Light";
  src: url("../fonts/Inter-Light.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Regular";
  src: url("../fonts/Inter-Regular.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Bold";
  src: url("../fonts/Inter-Bold.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Titre";
  src: url("../fonts/DMSans-Black.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
:root {
  --font-light: Light;
  --font-regular: Regular;
  --font-bold: Bold;
  --font-titre: Titre;
}

html, body {
  min-height: 100%;
  font-size: 10px;
  font-family: var(--real-font-regular);
  line-height: normal;
}
@media print {
  html, body {
    background: #ffffff;
  }
}

body.page-homepage {
  width: 100%;
  height: 100%;
}
body.page-homepage.body-theme-insitu {
  background: #000 url("../img/bg-homepage.png") center top no-repeat;
}
body.page-homepage.body-theme-insitunet {
  background: #000 url("../img/bg-homepage-net.png") center top no-repeat;
}
body.page-homepage.body-theme-insitulab {
  background: #000 url("../img/bg-homepage-lab.png") center top no-repeat;
}
@media only screen and (max-width : 660px) {
  body.page-homepage {
    background-position: center -150px;
  }
}
body.page-homepage .container-page {
  margin: 525px auto 0;
}
@media only screen and (max-width : 660px) {
  body.page-homepage .container-page {
    margin-top: 400px;
  }
}
body.page-homepage .index-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 0;
  margin: 0;
}
@media only screen and (max-width : 660px) {
  body.page-homepage .index-nav {
    flex-direction: column;
    align-items: center;
  }
}
body.page-homepage .index-nav li {
  list-style: none;
  margin-bottom: 1rem;
}
body.page-homepage .index-nav li a {
  padding: 0 13px;
  display: inline-block;
  font-size: 1.6rem;
  text-transform: uppercase;
  color: #ffffff;
  -webkit-transition: color 0.5s ease 0s;
  -o-transition: color 0.5s ease 0s;
  transition: color 0.5s ease 0s;
}
body.page-homepage .index-nav li a:hover {
  color: var(--color-secondaire);
  text-decoration: none;
}
body.page-homepage .index-nav li:before {
  display: inline-block;
  content: "";
  width: 10px;
  height: 10px;
  background: var(--color-secondaire);
}
@media only screen and (max-width : 660px) {
  body.page-homepage .index-nav li:before {
    display: block;
    margin: 0 auto 1rem;
  }
}
body.page-homepage .index-nav li:first-child:before {
  display: none;
}
body.page-homepage .langues {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 0;
  margin: 0;
  margin-top: 3rem;
}
body.page-homepage .langues a {
  padding: 0 5px;
  display: inline-block;
  font-size: 1.4rem;
  text-transform: uppercase;
  color: #ffffff;
}
body.page-homepage .langues a:hover {
  text-decoration: none;
  color: var(--color-secondaire);
}

.container {
  padding: 0;
  width: 95%;
  max-width: 1040px;
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
}
@media only screen and (max-width: 1040px) {
  .container {
    max-width: 90%;
  }
}

.css_mce figure figcaption {
  display: block;
  margin: 1rem 0 0 0;
  font-size: 1.2rem;
  font-style: italic;
}
.css_mce .btn-cta {
  display: inline-block;
  padding: 1rem 2rem;
  border-radius: 50px;
  color: #fff !important;
  font-size: 1.8rem;
  border: none;
  font-weight: 700;
  background: linear-gradient(0deg, var(--color-primaire-dark), var(--color-primaire));
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.css_mce .btn-cta:hover {
  border-radius: 20px 0 20px 0;
  text-decoration: none;
}
@media only screen and (max-width: 1024px), only screen and (max-width : 660px) {
  .css_mce .btn-cta {
    font-size: 1.6rem;
    padding: 8px 15px;
  }
}
.css_mce .btn-cta:focus {
  outline: none;
}
.css_mce .btn-cta.btn-small {
  font-size: 1.2rem;
  padding: 0.5rem 1rem;
}
.css_mce .btn-cta-bordered {
  display: inline-block;
  padding: 1rem 2rem;
  border-radius: 50px;
  color: var(--color-primaire-dark);
  font-size: 1.8rem;
  transition: all 0.3s;
  font-weight: 700;
  border: 1px solid transparent;
  background: linear-gradient(white, white) padding-box, linear-gradient(180deg, var(--color-primaire), var(--color-primaire-dark)) border-box;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
@media only screen and (max-width: 1024px), only screen and (max-width : 660px) {
  .css_mce .btn-cta-bordered {
    font-size: 1.6rem;
    padding: 8px 15px;
  }
}
.css_mce .btn-cta-bordered:focus {
  outline: none;
}
.css_mce .btn-cta-bordered:hover {
  text-decoration: none;
  color: var(--color-primaire);
  border-radius: 20px 0 20px 0;
}
.css_mce .btn-cta-bordered.btn-small {
  font-size: 1.2rem;
  padding: 0.5rem 1rem;
}
.css_mce .btn-cta.btn-mail:before, .css_mce .btn-cta-bordered.btn-mail:before {
  display: inline-block;
  content: "\f0e0";
  font-family: "Font Awesome 6 Pro";
  margin-right: 1rem;
}
.css_mce .btn-cta.btn-phone:before, .css_mce .btn-cta-bordered.btn-phone:before {
  display: inline-block;
  content: "\f095";
  font-family: "Font Awesome 6 Pro";
  margin-right: 1rem;
}
.css_mce blockquote {
  font-size: 2rem;
  font-family: var(--real-font-titre);
  text-align: center;
  color: var(--color-text);
}
@media only screen and (max-width : 660px) {
  .css_mce blockquote {
    font-size: 2rem;
  }
}
.css_mce blockquote p {
  font-size: inherit;
  text-align: center;
  font-family: inherit;
  color: inherit;
  margin: 0;
}
.css_mce em {
  font-size: inherit;
  font-style: italic;
}
.css_mce img {
  border: 0;
}
.css_mce .youtube_player {
  text-align: center;
}
.css_mce iframe {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  border: 0;
}
.css_mce ol > li, .css_mce ul > li, .css_mce p, .css_mce td, .css_mce th, .css_mce pre {
  font-size: 1.8rem;
}
.css_mce h1, .css_mce h2, .css_mce h3, .css_mce h4, .css_mce h5, .css_mce h6, .css_mce p {
  padding: 0;
}
.css_mce h1, .css_mce h2, .css_mce h3, .css_mce h4, .css_mce h5, .css_mce h6, .css_mce p, .css_mce ul {
  font-family: var(--real-font-regular), "Arial";
  color: var(--color-text);
  font-size: 1.8rem;
}
.css_mce h1 img, .css_mce h2 img, .css_mce h3 img, .css_mce h4 img, .css_mce h5 img, .css_mce h6 img, .css_mce p img, .css_mce ul img {
  max-width: 100%;
  height: auto;
}
.css_mce h1.center, .css_mce h2.center, .css_mce h3.center, .css_mce h4.center, .css_mce h5.center, .css_mce h6.center, .css_mce p.center, .css_mce ul.center {
  text-align: center;
}
.css_mce h1 .emphasize, .css_mce h2 .emphasize, .css_mce h3 .emphasize, .css_mce h4 .emphasize, .css_mce h5 .emphasize, .css_mce h6 .emphasize, .css_mce p .emphasize, .css_mce ul .emphasize {
  color: var(--color-text);
}
.css_mce h1 a, .css_mce h2 a, .css_mce h3 a, .css_mce h4 a, .css_mce h5 a, .css_mce h6 a, .css_mce p a, .css_mce ul a {
  color: inherit;
  font-family: inherit;
  -webkit-transition: color 0.25s ease 0s;
  -o-transition: color 0.25s ease 0s;
  transition: color 0.25s ease 0s;
  font-weight: inherit;
  text-decoration: none;
  color: var(--color-primaire);
}
.css_mce h1 a:hover, .css_mce h1 a:hover strong, .css_mce h2 a:hover, .css_mce h2 a:hover strong, .css_mce h3 a:hover, .css_mce h3 a:hover strong, .css_mce h4 a:hover, .css_mce h4 a:hover strong, .css_mce h5 a:hover, .css_mce h5 a:hover strong, .css_mce h6 a:hover, .css_mce h6 a:hover strong, .css_mce p a:hover, .css_mce p a:hover strong, .css_mce ul a:hover, .css_mce ul a:hover strong {
  color: var(--color-primaire-dark);
}
.css_mce h1 a img, .css_mce h1 a:hover, .css_mce h2 a img, .css_mce h2 a:hover, .css_mce h3 a img, .css_mce h3 a:hover, .css_mce h4 a img, .css_mce h4 a:hover, .css_mce h5 a img, .css_mce h5 a:hover, .css_mce h6 a img, .css_mce h6 a:hover, .css_mce p a img, .css_mce p a:hover, .css_mce ul a img, .css_mce ul a:hover {
  text-decoration: none;
}
.css_mce h1 strong, .css_mce h2 strong, .css_mce h3 strong, .css_mce h4 strong, .css_mce h5 strong, .css_mce h6 strong, .css_mce p strong, .css_mce ul strong {
  font-family: var(--real-font-regular);
  font-weight: 700;
  font-weight: normal;
}
.css_mce p {
  margin: 0 0 1rem 0;
  text-align: inherit;
  color: var(--color-text-dark);
  line-height: 1.8rem;
}
@media only screen and (max-width : 660px) {
  .css_mce p {
    margin-bottom: 10px;
  }
}
.css_mce p img {
  max-width: 100%;
  height: auto;
}
.css_mce p.signature img {
  max-width: 400px;
}
.css_mce ul > li strong {
  font-family: var(--real-font-bold);
  font-weight: normal;
  color: inherit;
}
.css_mce ol > li, .css_mce ul > li, .css_mce p, .css_mce td {
  font-size: 1.4rem;
  font-family: var(--real-font-regular);
  font-weight: normal;
}
.css_mce ol > li img, .css_mce ul > li img, .css_mce p img, .css_mce td img {
  max-width: 100%;
  height: auto;
}
@media only screen and (max-width: 1024px) {
  .css_mce ol > li, .css_mce ul > li, .css_mce p, .css_mce td {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width : 660px) {
  .css_mce ol > li, .css_mce ul > li, .css_mce p, .css_mce td {
    font-size: 1.4rem;
  }
}
.css_mce ol > li strong, .css_mce ul > li strong, .css_mce p strong, .css_mce td strong {
  font-weight: 800;
}
.css_mce ol > li a, .css_mce ul > li a, .css_mce p a, .css_mce td a {
  color: var(--color-primaire);
  -webkit-transition: color 0.25s ease 0s;
  -o-transition: color 0.25s ease 0s;
  transition: color 0.25s ease 0s;
  font-weight: 600;
  font-family: inherit;
}
.css_mce ol > li a img, .css_mce ol > li a:hover, .css_mce ul > li a img, .css_mce ul > li a:hover, .css_mce p a img, .css_mce p a:hover, .css_mce td a img, .css_mce td a:hover {
  color: var(--color-secondaire);
  text-decoration: none;
}
.css_mce h6, .css_mce h5, .css_mce h4, .css_mce h3, .css_mce .h3, .css_mce h2, .css_mce h1, .css_mce .h1 {
  display: block;
  font-family: var(--real-font-regular), "Arial";
  font-weight: 700;
  font-size: 2.8em;
  color: var(--real-color-primaire);
  padding: 0;
  margin: 0 0 1rem 0;
  text-align: inherit;
}
@media only screen and (max-width : 660px) {
  .css_mce h6, .css_mce h5, .css_mce h4, .css_mce h3, .css_mce .h3, .css_mce h2, .css_mce h1, .css_mce .h1 {
    margin-bottom: 10px;
  }
}
.css_mce h1, .css_mce .h1 {
  font-size: 5rem;
}
.css_mce h2, .css_mce .h2 {
  font-size: 2.5rem;
  text-transform: uppercase;
  font-family: var(--real-font-regular), "Arial";
  font-weight: 700;
  position: relative;
  color: var(--color-text-dark);
}
.css_mce h2 a, .css_mce .h2 a {
  font-family: inherit;
  text-decoration: underline;
  color: inherit;
}
.css_mce h2 a:hover, .css_mce .h2 a:hover {
  text-decoration: none;
}
.css_mce h3, .css_mce .h3 {
  font-size: 2.5rem;
  text-transform: uppercase;
  font-family: var(--real-font-regular), "Arial";
  font-weight: 600;
  position: relative;
  color: var(--color-text-dark);
}
.css_mce h3 a, .css_mce .h3 a {
  font-family: inherit;
  text-decoration: underline;
  color: inherit;
}
.css_mce h3 a:hover, .css_mce .h3 a:hover {
  text-decoration: none;
}
.css_mce h4 {
  color: var(--color-text-dark);
  font-weight: normal;
  font-size: 1.4rem;
  margin: 0 0 1rem 0;
  text-transform: uppercase;
}
.css_mce h4 strong {
  font-weight: normal;
}
.css_mce h5, .css_mce h6 {
  color: var(--color-text);
  font-family: var(--real-font-bold);
  font-size: 1.4rem;
  margin: 0 0 1rem 0;
  text-transform: uppercase;
}
.css_mce h5 strong, .css_mce h6 strong {
  font-weight: normal;
}
.css_mce hr {
  border: 0;
  padding: 0;
  display: block;
  height: 1px;
  width: 100%;
  overflow: hidden;
  border-bottom: 1px dotted var(--color-text-dark);
  margin-bottom: 15px;
  margin-top: 15px;
}
.css_mce ul > li {
  list-style: none;
}
.css_mce ul > li:before {
  content: "\f111";
  font-family: "Font Awesome 6 Pro";
  position: absolute;
  top: 10px;
  left: -15px;
  font-size: 0.3rem;
  font-weight: bold;
  color: var(--color-text);
  padding-right: 5px;
  vertical-align: middle;
}
.css_mce ol > li,
.css_mce ul > li {
  font-family: var(--real-font-regular), "Arial";
  padding: 0;
  margin: 0;
  position: relative;
  color: var(--color-text);
  font-size: 1.8rem;
  padding-top: 10px;
  line-height: 2.6rem;
}
@media only screen and (max-width: 1024px) {
  .css_mce ol > li,
  .css_mce ul > li {
    font-size: 1.6rem;
  }
}
@media only screen and (max-width : 660px) {
  .css_mce ol > li,
  .css_mce ul > li {
    font-size: 1.4rem;
  }
}
.css_mce ol > li strong,
.css_mce ul > li strong {
  color: inherit;
  font-weight: 700;
}
.css_mce ol > li a,
.css_mce ul > li a {
  font-family: inherit;
  color: inherit;
  text-decoration: none;
  -webkit-transition: color 0.25s ease 0s;
  -o-transition: color 0.25s ease 0s;
  transition: color 0.25s ease 0s;
  font-weight: inherit;
  color: var(--color-primaire);
}
.css_mce ol > li a:hover,
.css_mce ul > li a:hover {
  color: var(--color-secondaire);
}
.css_mce ol > li strong,
.css_mce ul > li strong {
  font-weight: 700;
}
.css_mce ol > li ul,
.css_mce ul > li ul {
  margin-bottom: 0;
}
.css_mce .uppercase {
  text-transform: uppercase;
}
.css_mce table {
  border: 0;
  max-width: 100%;
  padding: 0;
  margin-bottom: 1rem;
  border-collapse: collapse;
  background: #fff;
  font-size: 1.6rem;
  font-family: var(--real-font-regular);
}
@media only screen and (max-width : 660px) {
  .css_mce table {
    font-size: 1.6rem;
  }
}
.css_mce table th,
.css_mce table td {
  border-collapse: collapse;
  padding: 1rem;
  font-size: 1em;
  font-family: var(--real-font-regular);
  color: var(--color-text);
  border: 1px solid #ccc;
}
.css_mce table th img,
.css_mce table td img {
  max-width: 100%;
  height: auto;
}
.css_mce table th p,
.css_mce table td p {
  font-size: 1em;
  margin: 0;
  padding: 0;
  font-family: inherit;
}
.css_mce .css_mce_small > ul > li, .css_mce .css_mce_small p {
  font-size: 1rem;
}
.css_mce .alert {
  font-size: 1.6rem;
}
.css_mce .alert p {
  margin: 0;
}
.css_mce .cta-primary,
.css_mce .cta-secondary,
.css_mce .cta-light,
.css_mce .cta-tertiary {
  background: var(--real-theme-color-1) !important;
  border-color: var(--real-theme-color-1) !important;
  font-size: 1.4rem;
  font-family: var(--real-font-regular);
  padding: 1rem 2rem;
  display: inline-block;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  text-decoration: none;
  color: #fff;
}
.css_mce .cta-primary.active, .css_mce .cta-primary:hover,
.css_mce .cta-secondary.active,
.css_mce .cta-secondary:hover,
.css_mce .cta-light.active,
.css_mce .cta-light:hover,
.css_mce .cta-tertiary.active,
.css_mce .cta-tertiary:hover {
  background: var(--color-primaire-dark) !important;
  border-color: var(--color-primaire-dark) !important;
  color: #fff;
  text-decoration: none;
}
.css_mce .cta-primary:focus,
.css_mce .cta-secondary:focus,
.css_mce .cta-light:focus,
.css_mce .cta-tertiary:focus {
  background-color: var(--color-primaire-dark) !important;
  box-shadow: none !important;
}
.css_mce .cta-primary:active,
.css_mce .cta-secondary:active,
.css_mce .cta-light:active,
.css_mce .cta-tertiary:active {
  box-shadow: none !important;
}
.css_mce .cta-primary:active:focus,
.css_mce .cta-secondary:active:focus,
.css_mce .cta-light:active:focus,
.css_mce .cta-tertiary:active:focus {
  box-shadow: none !important;
}
.css_mce .cta-secondary {
  background: var(--real-theme-color-2) !important;
  border-color: var(--real-theme-color-2) !important;
}
.css_mce .cta-secondary.active, .css_mce .cta-secondary:focus, .css_mce .cta-secondary:hover {
  background: var(--color-secondaire-dark) !important;
  border-color: var(--color-secondaire-dark) !important;
}
.css_mce .cta-tertiary {
  background: var(--real-theme-color-3) !important;
  border-color: var(--real-theme-color-3) !important;
}
.css_mce .cta-tertiary.active, .css_mce .cta-tertiary:focus, .css_mce .cta-tertiary:hover {
  background: var(--color-tertiaire-dark) !important;
  border-color: var(--color-tertiaire-dark) !important;
}
.css_mce .cta-light {
  background: #fff !important;
  border: 1px solid #eee !important;
  color: var(--color-text) !important;
}
.css_mce .cta-light.active, .css_mce .cta-light:focus, .css_mce .cta-light:hover {
  color: #fff !important;
  background: var(--real-theme-color-2) !important;
  border-color: var(--real-theme-color-2) !important;
}

body {
  background-color: #fff;
}

@keyframes rotating {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.page-projet {
  padding-left: 150px;
}
@media only screen and (max-width: 1040px) {
  .page-projet {
    padding: 0;
  }
}
.page-projet h1 {
  font-size: 2.5rem;
  text-transform: uppercase;
  font-weight: bold;
  margin: 0;
  padding: 0;
}
.page-projet .soustitre {
  font-size: 2.5rem;
  text-transform: uppercase;
  display: block;
}
.page-projet .content {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}
@media only screen and (max-width: 1040px) {
  .page-projet .content {
    flex-direction: column;
  }
}
.page-projet .content .left {
  padding-top: 2rem;
  flex: 1;
  font-size: 1.4rem;
}
.page-projet .content .left .images img {
  max-width: 100%;
  display: block;
}
.page-projet .content .left .content-html {
  margin-top: 1rem;
}
.page-projet .content .left .content-html:before {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--color-secondaire);
  display: block;
  margin-bottom: 1rem;
}
.page-projet .content .right {
  padding-top: 2rem;
  width: 160px;
  font-size: 1.4rem;
  position: sticky;
  top: 0;
}
.page-projet .content .right:before {
  content: "";
  width: 10px;
  height: 10px;
  background: var(--color-secondaire);
  display: block;
  margin-bottom: 1rem;
}

.page-catalogue {
  background: var(--color-primaire-transparent);
}
.page-catalogue .module-texte {
  background: transparent;
  margin: 0rem;
  padding: 10rem 0 2rem;
}
@media only screen and (max-width : 660px) {
  .page-catalogue .module-texte {
    padding: 4rem 0 2rem;
  }
}
.page-catalogue .module-texte .mod-titre-bloc {
  display: flex;
  gap: 5rem;
  align-items: center;
}
.page-catalogue .module-texte .mod-titre-bloc .mod-titre {
  flex: 1;
}
.page-catalogue .module-subpages {
  background: transparent;
  padding: 0;
  padding-bottom: 10rem;
}
.page-catalogue .module-subpages.sub-catalogues .blocs .bloc .contenu-visuel {
  height: 220px;
}
.page-catalogue .module-subpages.sub-catalogues .css_mce p {
  font-size: 1.6rem;
}
.page-catalogue .module-subpages .blocs {
  margin: 0;
}
.page-catalogue .module-subpages > .container {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
}
.page-catalogue .module-subpages .blocs {
  flex: 1;
}
.page-catalogue .module-prestation {
  padding-bottom: 10rem;
}
.page-catalogue .module-prestation > .container {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
  position: relative;
}
@media only screen and (max-width: 1040px) {
  .page-catalogue .module-prestation > .container {
    padding: 0;
  }
}
.page-catalogue .module-prestation .fiche-prestation {
  flex: 1;
  border-radius: 60px;
  background: #ffffff;
  padding: 1rem;
  position: relative;
}
.page-catalogue .module-prestation .fiche-prestation .module-texte {
  padding: 0;
  margin: 5rem 0;
}
@media only screen and (max-width : 660px) {
  .page-catalogue .module-prestation .fiche-prestation .module-texte {
    margin: 4rem 0;
  }
}
.page-catalogue .module-prestation .fiche-prestation .module-caracteristiques {
  margin: 5rem 0;
}
@media only screen and (max-width : 660px) {
  .page-catalogue .module-prestation .fiche-prestation .module-caracteristiques {
    margin: 4rem 0;
  }
}
.page-catalogue .menu-catalogue {
  width: 300px;
}
@media only screen and (max-width: 1040px) {
  .page-catalogue .menu-catalogue {
    display: none;
  }
}
.page-catalogue .menu-catalogue ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.page-catalogue .menu-catalogue ul li {
  padding: 0;
  order: 1;
}
.page-catalogue .menu-catalogue ul li a {
  display: block;
  border-radius: 10px 0 10px 0;
  background: #000000;
  color: #ffffff;
  font-size: 1.6rem;
  padding: 1rem 2rem;
  text-decoration: none;
  margin-bottom: 3px;
}
.page-catalogue .menu-catalogue ul li a:hover {
  background: var(--color-secondaire);
  text-decoration: none;
}
.page-catalogue .menu-catalogue ul li.active {
  order: 0;
}
.page-catalogue .menu-catalogue ul li ul li a {
  background: #ffffff;
  color: #000000;
}
.page-catalogue .menu-catalogue ul li ul li a:hover {
  color: #ffffff;
}
.page-catalogue .menu-catalogue ul li ul li.active a {
  background: var(--color-primaire);
  color: #ffffff;
}

.page-recherche .header-search {
  border-radius: 20px;
  font-size: 7rem;
  color: #ffffff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primaire);
  background: linear-gradient(90deg, var(--color-primaire-light) 0%, var(--color-primaire) 100%);
  height: 215px;
  margin-bottom: 1rem;
}
.page-recherche .module-recherche .container {
  border: 1px solid rgba(12, 4, 133, 0.3);
  border-radius: 20px;
  background: rgba(12, 4, 133, 0.02);
  padding: 4rem;
}
.page-recherche .list-page .list-page-item {
  border-bottom: 1px solid rgba(12, 4, 133, 0.3);
  padding: 2rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.page-recherche .list-page .list-page-item:last-child {
  border-bottom: none;
}
.page-recherche .list-page .list-page-item .list-page-item-title {
  font-size: 1.8rem;
  color: var(--color-primaire);
  font-weight: 800;
}

.formulaire .alert {
  border-radius: 50px;
  padding: 10px 25px;
  color: #ffffff;
}
.formulaire .alert-success {
  color: #ffffff;
  background: var(--color-primaire);
  border-color: var(--color-primaire-light);
}
.formulaire .alert-danger {
  color: #ffffff;
  background: var(--color-danger);
  border-color: var(--color-danger);
}
.formulaire ul.list-unstyled {
  margin: 0;
  padding: 0;
}
.formulaire ul.list-unstyled li {
  color: var(--color-danger);
  font-weight: 600;
  padding: 0;
}
.formulaire ul.list-unstyled li:before {
  display: none;
}
.formulaire ul.list-unstyled li span:before {
  content: "\f06a";
  font-weight: 600;
  font-family: "Font Awesome 6 Pro";
}
.formulaire form input[type=text],
.formulaire form input[type=email],
.formulaire form input[type=password],
.formulaire form input[type=tel] {
  background: rgba(249, 20, 146, 0.1);
  border: none;
  font-size: 1.6rem;
  color: var(--color-text-dark);
  padding: 1rem 2rem;
  height: auto;
  outline: none;
  border-radius: 20px;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.formulaire form input[type=text]::placeholder,
.formulaire form input[type=email]::placeholder,
.formulaire form input[type=password]::placeholder,
.formulaire form input[type=tel]::placeholder {
  color: var(--color-text-dark);
}
.formulaire form input[type=text]:focus,
.formulaire form input[type=email]:focus,
.formulaire form input[type=password]:focus,
.formulaire form input[type=tel]:focus {
  outline: 0;
  border-radius: 20px 0 20px 0;
}
.formulaire form select {
  width: 100%;
  background: rgba(249, 20, 146, 0.1);
  border: none;
  font-size: 1.6rem;
  color: var(--color-text-dark);
  padding: 1rem 1.5rem;
  height: auto;
  outline: none;
  border-radius: 20px;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.formulaire form select:focus {
  outline: 0;
  border-radius: 20px 0 20px 0;
}
.formulaire form label {
  font-size: 1.2rem;
  color: var(--color-text);
  padding: 0rem 0 1rem;
}
.formulaire form textarea {
  background: rgba(249, 20, 146, 0.1);
  border: none;
  height: 160px;
  border-radius: 20px;
  font-size: 1.6rem;
  color: var(--color-text-dark);
  padding: 1rem 2rem;
  outline: none;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.formulaire form textarea::placeholder {
  color: var(--color-text-dark);
}
.formulaire form textarea:focus {
  outline: 0;
  border-radius: 20px 0 20px 0;
}
.formulaire form .form-group {
  margin-bottom: 0.8rem;
}
.formulaire form .form-group .checkbox {
  display: flex;
  align-items: flex-start;
}
.formulaire form .form-group .checkbox label {
  flex: 1;
  font-size: 1.3rem;
  padding-left: 3px;
}
.formulaire form .form-group .form-captcha {
  display: flex;
  gap: 2rem;
}
.formulaire form .form-group .form-captcha > div {
  width: 320px;
}
.formulaire form .form-group .form-captcha .renew-captcha {
  border: none;
  background: transparent;
  font-size: 1.4rem;
  color: var(--color-primaire);
  font-family: var(--real-font-bold);
  padding: 0;
  margin-bottom: 5px;
  outline: none;
}
.formulaire form .form-group .form-captcha .renew-captcha:focus {
  outline: none;
}
.formulaire form .form-group .form-captcha .renew-captcha:before {
  margin-right: 5px;
  content: "\f2f9";
  font-weight: bold;
  font-family: "Font Awesome 6 Pro";
}
.formulaire form .form-group .alert {
  padding: 0;
  margin: 0;
  color: var(--color-primaire);
  font-size: 1.2rem;
  font-style: italic;
  font-family: var(--real-font-bold);
  padding-left: 1.5rem;
  margin-top: 0.5rem;
  display: none;
}
.formulaire .full-rgpd {
  margin: 2rem 0;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 20px;
  padding: 1rem;
  height: 160px;
  overflow: auto;
}
.formulaire .full-rgpd h1, .formulaire .full-rgpd h2, .formulaire .full-rgpd h3, .formulaire .full-rgpd h4, .formulaire .full-rgpd h5, .formulaire .full-rgpd h6 {
  font-size: 1.6rem;
  color: var(--color-text-dark);
  text-transform: uppercase;
  font-weight: 700;
}
.formulaire .full-rgpd p {
  font-size: 1.3rem;
  color: var(--color-text-dark);
}
.formulaire .full-rgpd p a {
  color: var(--color-text-dark);
}
.formulaire .ligne-submit {
  margin-top: 3rem;
}
.formulaire .ligne-submit span.required {
  font-size: 1.6rem;
  color: var(--color-primaire);
  display: block;
  margin-bottom: 2rem;
}
.formulaire .ligne-submit .message-confirm {
  font-size: 1.6rem;
  color: var(--color-secondaire);
  display: block;
  text-align: center;
  padding: 1rem 0;
}
.formulaire .ligne-submit .message-confirm.hidden {
  display: none;
}
.formulaire .ligne-submit button[type=submit] {
  border: none;
  display: inline-block;
  padding: 1rem 3rem;
  border-radius: 50px;
  color: #fff !important;
  font-size: 1.8rem;
  font-weight: 700;
  background: linear-gradient(0deg, var(--color-primaire-dark), var(--color-primaire));
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.formulaire .ligne-submit button[type=submit]:hover {
  border-radius: 20px 0 20px 0;
  text-decoration: none;
}
@media only screen and (max-width : 660px) {
  .formulaire .ligne-submit button[type=submit] {
    font-size: 1.6rem;
    padding: 8px 15px;
  }
}
.formulaire .ligne-submit button[type=submit]:focus {
  outline: none;
}
.formulaire .ligne-submit button[type=submit].send:before {
  content: "\f1d8";
  font-weight: normal;
  font-family: "Font Awesome 6 Pro";
  display: inline-block;
  margin-right: 10px;
}

#previsu {
  padding-top: 1rem;
  padding-bottom: 1rem;
  position: fixed;
  left: 50%;
  bottom: 0;
  width: 500px;
  margin-left: -250px;
  background-color: #fff;
  color: #000000;
  z-index: 1000;
  text-align: center;
  font-size: 12px;
}
#previsu a.btn {
  font-size: 12px;
}

.custom-file-label::after {
  content: "Parcourir" !important;
}

#is-desktop {
  display: block;
  position: fixed;
  left: 0;
  top: 0;
}
@media only screen and (max-width : 660px), only screen and (max-width: 1040px), only screen and (max-width : 1280px) {
  #is-desktop {
    display: none;
  }
}

#is-responsive-tablet {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
}
@media only screen and (max-width: 1040px) {
  #is-responsive-tablet {
    display: block;
  }
}

#is-responsive-phone {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
}
@media only screen and (max-width : 660px) {
  #is-responsive-phone {
    display: block;
  }
}

.btn-heur-white,
.btn-heur-secondary,
.btn-heur-primary {
  border: 0;
  display: inline-block;
  padding: 10px 2rem;
  color: #fff;
  background-color: var(--color-primaire);
  font-size: 1.5rem;
  font-family: var(--real-font-regular);
  outline: none;
  cursor: pointer;
  text-decoration: none;
  border-radius: 50px;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.btn-heur-white:hover,
.btn-heur-secondary:hover,
.btn-heur-primary:hover {
  background-color: #000;
  color: #fff;
  text-decoration: none;
}
.btn-heur-white.btn-heur-primary:hover,
.btn-heur-secondary.btn-heur-primary:hover,
.btn-heur-primary.btn-heur-primary:hover {
  background-color: var(--color-primaire-dark);
}
.btn-heur-white.btn-heur-white,
.btn-heur-secondary.btn-heur-white,
.btn-heur-primary.btn-heur-white {
  background-color: #fff;
  color: #000;
  border: 1px solid #000;
}
.btn-heur-white.btn-heur-white:hover,
.btn-heur-secondary.btn-heur-white:hover,
.btn-heur-primary.btn-heur-white:hover {
  background-color: #000;
  color: #fff !important;
  border-color: #fff;
}
.btn-heur-white.btn-heur-secondary,
.btn-heur-secondary.btn-heur-secondary,
.btn-heur-primary.btn-heur-secondary {
  background-color: var(--color-secondaire);
  color: #fff;
}
.btn-heur-white.btn-heur-secondary:hover,
.btn-heur-secondary.btn-heur-secondary:hover,
.btn-heur-primary.btn-heur-secondary:hover {
  background-color: var(--color-secondaire-dark);
}
.btn-heur-white.mid,
.btn-heur-secondary.mid,
.btn-heur-primary.mid {
  padding: 0.5rem 1.25rem;
  font-size: 1.5rem;
}

.center {
  text-align: center;
}

#ajaxLoader {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  background-color: rgba(255, 255, 255, 0.8);
  display: none;
  width: 100%;
  height: 100%;
  align-self: center;
  justify-content: center;
}
#ajaxLoader.visible {
  display: flex;
}
#ajaxLoader .flexme {
  display: flex;
  align-self: center;
  justify-content: center;
}
#ajaxLoader .flexme span {
  font-size: 4rem;
  color: var(--color-primaire);
}

.alert {
  font-size: 1.4rem;
}

.youtube_player {
  margin-left: auto;
  margin-right: auto;
}
.youtube_player .tac_activate {
  padding: 2rem;
  font-size: 1.4rem;
  min-height: 300px;
}

.popup-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 20;
}
.popup-modal .popup-content-flexme {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
}
.popup-modal .popup-content-flexme .small-content,
.popup-modal .popup-content-flexme .medium-content,
.popup-modal .popup-content-flexme .contrat-content {
  width: 95%;
  max-width: 1100px;
  background-color: #fff;
  padding: 20px;
  max-height: 100%;
  overflow: auto;
  box-sizing: border-box;
}
.popup-modal .popup-content-flexme .small-content.small-content,
.popup-modal .popup-content-flexme .medium-content.small-content,
.popup-modal .popup-content-flexme .contrat-content.small-content {
  max-width: 400px;
}
.popup-modal .popup-content-flexme .small-content.medium-content,
.popup-modal .popup-content-flexme .medium-content.medium-content,
.popup-modal .popup-content-flexme .contrat-content.medium-content {
  max-width: 600px;
}
.popup-modal .popup-content-flexme .small-content .popup-titre,
.popup-modal .popup-content-flexme .medium-content .popup-titre,
.popup-modal .popup-content-flexme .contrat-content .popup-titre {
  margin: 0 0 2rem;
  position: relative;
}
.popup-modal .popup-content-flexme .small-content .popup-titre:after,
.popup-modal .popup-content-flexme .medium-content .popup-titre:after,
.popup-modal .popup-content-flexme .contrat-content .popup-titre:after {
  content: "";
  display: block;
  height: 1px;
  background-color: #f1f1f1;
  margin-top: 5px;
  width: 100%;
}
.popup-modal .popup-content-flexme .small-content .popup-titre .css_mce,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce {
  flex: 1;
}
.popup-modal .popup-content-flexme .small-content .popup-titre .css_mce h1, .popup-modal .popup-content-flexme .small-content .popup-titre .css_mce h2, .popup-modal .popup-content-flexme .small-content .popup-titre .css_mce h3,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce h1,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce h2,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce h3,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce h1,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce h2,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce h3 {
  font-size: 1.6rem;
  margin-bottom: 1rem;
}
.popup-modal .popup-content-flexme .small-content .popup-titre .css_mce p, .popup-modal .popup-content-flexme .small-content .popup-titre .css_mce li,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce p,
.popup-modal .popup-content-flexme .medium-content .popup-titre .css_mce li,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce p,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .css_mce li {
  font-size: 1.4rem;
  margin-bottom: 1rem;
}
.popup-modal .popup-content-flexme .small-content .popup-titre .bt-close-popup,
.popup-modal .popup-content-flexme .medium-content .popup-titre .bt-close-popup,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .bt-close-popup {
  position: absolute;
  top: 0;
  right: 0;
  color: var(--color-gris);
  font-size: 2rem;
  border: 0;
  cursor: pointer;
  padding: 0;
  margin: 0;
  background: transparent;
}
.popup-modal .popup-content-flexme .small-content .popup-titre .bt-close-popup:hover,
.popup-modal .popup-content-flexme .medium-content .popup-titre .bt-close-popup:hover,
.popup-modal .popup-content-flexme .contrat-content .popup-titre .bt-close-popup:hover {
  color: var(--color-primaire);
}
.popup-modal .popup-content-flexme .small-content .popup-content form > .form-group,
.popup-modal .popup-content-flexme .medium-content .popup-content form > .form-group,
.popup-modal .popup-content-flexme .contrat-content .popup-content form > .form-group {
  display: flex;
  align-items: center;
  gap: 15px;
}
.popup-modal .popup-content-flexme .small-content .popup-content form > .form-group > .checkbox,
.popup-modal .popup-content-flexme .medium-content .popup-content form > .form-group > .checkbox,
.popup-modal .popup-content-flexme .contrat-content .popup-content form > .form-group > .checkbox {
  display: flex;
  align-items: flex-start;
}
.popup-modal .popup-content-flexme .small-content .popup-content form > .form-group > .checkbox input,
.popup-modal .popup-content-flexme .medium-content .popup-content form > .form-group > .checkbox input,
.popup-modal .popup-content-flexme .contrat-content .popup-content form > .form-group > .checkbox input {
  margin-top: 5px;
}

@font-face {
  font-family: "Light";
  src: url("../fonts/Inter-Light.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Regular";
  src: url("../fonts/Inter-Regular.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Bold";
  src: url("../fonts/Inter-Bold.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
@font-face {
  font-family: "Titre";
  src: url("../fonts/DMSans-Black.ttf?v=3.2.1") format("truetype");
  font-optical-sizing: auto;
  font-style: normal;
}
:root {
  --font-light: Light;
  --font-regular: Regular;
  --font-bold: Bold;
  --font-titre: Titre;
}

@keyframes animBotToTop {
  0% {
    transform: translateY(50px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes animTopToBot {
  0% {
    transform: translateY(-50px);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes animRightToLeft {
  0% {
    transform: translateX(50px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes animLeftToRight {
  0% {
    transform: translateX(-50px);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes animFadeIn {
  0% {
    opacity: 0;
    filter: blur(0.5rem) saturate(80%);
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    filter: blur(0) saturate(100%);
  }
}
.heurisko-module {
  -webkit-transition: box-shadow 0.25s ease 0s;
  -o-transition: box-shadow 0.25s ease 0s;
  transition: box-shadow 0.25s ease 0s;
  font-size: 1.4rem;
}
.heurisko-module > .container {
  padding-left: 150px;
}
@media only screen and (max-width: 1024px) {
  .heurisko-module > .container {
    padding: 0;
  }
}
.heurisko-module .heurisko-toolbar-add-after {
  opacity: 0;
  position: absolute;
  bottom: 10px;
  left: 0;
  z-index: 1049;
  width: 100%;
  -webkit-transition: opacity 1s ease 0s;
  -o-transition: opacity 1s ease 0s;
  transition: opacity 1s ease 0s;
}
.heurisko-module .heurisko-toolbar-add-after .cont-btn {
  display: block;
  text-align: center;
}
.heurisko-module .heurisko-toolbar-add-after .cont-btn button.btn-show-toolbar-add-after {
  display: inline-block;
  border-radius: 100px;
  background-color: #28a745;
  color: #fff;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.heurisko-module .heurisko-toolbar-add-after .cont-btn button.btn-show-toolbar-add-after:hover {
  -webkit-box-shadow: 0 0 3px 0 #fff;
  -o-box-shadow: 0 0 3px 0 #fff;
  box-shadow: 0 0 3px 0 #fff;
  background-color: #4de36f;
}
.heurisko-module .heurisko-toolbar-add-after .modules {
  opacity: 0;
  height: 0;
  overflow: hidden;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  width: 100%;
}
.heurisko-module .heurisko-toolbar-add-after .modules.showme {
  opacity: 1;
  height: auto;
  box-shadow: rgba(0, 0, 0, 0.15) 0px -10px 10px 0px;
  position: absolute;
  bottom: 0px;
  left: 0;
  background-color: #fff;
  width: 100%;
  padding: 15px;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2rem;
}
.heurisko-module .heurisko-toolbar-add-after .modules.showme ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.heurisko-module .heurisko-toolbar-add-after .modules .heurisko-toolbar-cont-btn-close {
  text-align: center;
  width: 100%;
}
.heurisko-module .heurisko-toolbar-add-after .modules .heurisko-toolbar-cont-btn-close button {
  display: inline-block;
  border-radius: 100px;
  background-color: #a72828;
  color: #fff;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.heurisko-module .heurisko-toolbar-add-after .modules .heurisko-toolbar-cont-btn-close button:hover {
  -webkit-box-shadow: 0 0 3px 0 #fff;
  -o-box-shadow: 0 0 3px 0 #fff;
  box-shadow: 0 0 3px 0 #fff;
  background-color: #e34d4d;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul, .heurisko-module .heurisko-toolbar-add-after .modules li {
  list-style: none;
  margin: 0;
  padding: 0;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul {
  text-align: center;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li {
  display: inline-block;
  text-align: center;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
  opacity: 0.8;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li button {
  background-color: transparent !important;
  border: none !important;
  text-align: center;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li button img {
  max-height: 35px;
  border-radius: 2px;
  -webkit-box-shadow: 0 0 3px 0 #999;
  -o-box-shadow: 0 0 3px 0 #999;
  box-shadow: 0 0 3px 0 #999;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li button i {
  text-align: center;
  display: inline-block;
  font-size: 2rem;
  color: #01bbaa;
  background-color: #fff;
  padding: 1rem;
  border-radius: 2px;
  -webkit-box-shadow: 0 0 3px 0 #999;
  -o-box-shadow: 0 0 3px 0 #999;
  box-shadow: 0 0 3px 0 #999;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li button span {
  display: block;
  text-align: center;
  background-color: #007bff;
  color: #fff;
  border-radius: 4px;
  padding: 3px 5px;
  margin-top: 5px;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li:hover {
  opacity: 1;
}
.heurisko-module .heurisko-toolbar-add-after .modules ul li:hover button i,
.heurisko-module .heurisko-toolbar-add-after .modules ul li:hover button img {
  -webkit-box-shadow: 0 0 5px 0 #999;
  -o-box-shadow: 0 0 5px 0 #999;
  box-shadow: 0 0 5px 0 #999;
}
.heurisko-module .heurisko-toolbar,
.heurisko-module .heurisko-toolbar-bloc {
  opacity: 0;
  display: block;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line {
  text-align: right;
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  padding: 5px 5px;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom {
  position: absolute;
  width: 200px;
  top: 100%;
  right: 0;
  left: auto;
  padding: 20px 10px 10px 20px;
  margin: 0;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form {
  padding: 0;
  margin: 0;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme {
  max-height: 300px;
  overflow: auto;
  padding-right: 10px;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group {
  margin: 0;
  padding: 0;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .custom-choice-group,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .custom-choice-group {
  font-weight: bold;
  cursor: pointer;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  background-color: #efefef;
  border-radius: 5px;
  display: block;
  padding: 5px 10px;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .custom-choice-group:hover,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .custom-choice-group:hover {
  opacity: 0.6;
  background-color: #fff;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices {
  display: none;
  border: 1px solid #eee;
  padding: 5px;
  margin-bottom: 10px;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices .cont-label label,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices .cont-label label {
  display: block;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices .cont-label label:hover,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .conteneur form .overflowme .form-group .choices .cont-label label:hover {
  opacity: 0.6;
  background-color: #fff;
}
.heurisko-module .heurisko-toolbar .heurisko-toolbar-line .dropdown-custom .btn-custom,
.heurisko-module .heurisko-toolbar-bloc .heurisko-toolbar-line .dropdown-custom .btn-custom {
  text-align: center;
}
.heurisko-module.heurisko-module-back:hover {
  position: relative;
  box-shadow: 0px 0px 0px 3px rgba(0, 158, 255, 0.4);
}
.heurisko-module.heurisko-module-back:hover .heurisko-toolbar-add-after {
  opacity: 1;
}
.heurisko-module.heurisko-module-back:hover .heurisko-toolbar {
  opacity: 1;
}
.heurisko-module.heurisko-module-back:hover .heurisko-toolbar .heurisko-toolbar-line {
  z-index: 99;
}
.heurisko-module.heurisko-module-back .bloc:hover {
  position: relative;
}
.heurisko-module.heurisko-module-back .bloc:hover .heurisko-toolbar-bloc {
  opacity: 1;
}
.heurisko-module.heurisko-module-back .bloc:hover .heurisko-toolbar-bloc .heurisko-toolbar-line {
  z-index: 99;
}
.heurisko-module.heurisko-module-back img.ajax-visuel {
  -webkit-transition: opacity 0.25s ease 0s;
  -o-transition: opacity 0.25s ease 0s;
  transition: opacity 0.25s ease 0s;
  cursor: revert;
}
.heurisko-module.heurisko-module-back img.ajax-visuel:hover {
  opacity: 0.5;
}
.heurisko-module .heurisko-bloc-add {
  padding-top: 15px !important;
  padding-bottom: 15px !important;
}
.heurisko-module.heurisko-module-back .blocs .bloc {
  -webkit-transition: box-shadow 0.25s ease 0s;
  -o-transition: box-shadow 0.25s ease 0s;
  transition: box-shadow 0.25s ease 0s;
  box-shadow: 0px 0px 0px 1px rgba(100, 100, 100, 0.1);
}
.heurisko-module.heurisko-module-back .blocs .bloc:hover {
  box-shadow: 0px 0px 0px 3px rgba(0, 158, 255, 0.4);
  position: relative;
}
.heurisko-module.heurisko-module-back .blocs .bloc:hover .heurisko-toolbar-bloc {
  display: block;
}

.button {
  display: inline-block;
  color: #fff;
  border-radius: 50px;
  font-size: 2.2rem;
  padding: 20px 50px;
  margin: 0;
  border: 0;
  background-color: var(--color-secondaire);
  font-family: var(--real-font-bold);
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  text-transform: uppercase;
}
@media only screen and (max-width : 660px) {
  .button {
    font-size: 1.6rem;
    width: 100%;
    padding: 20px 0;
  }
}
.button .button-flex {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
}
.button .icon-start {
  padding-right: 15px;
}
@media only screen and (max-width : 660px) {
  .button .icon-start {
    padding-right: 5px;
  }
}
.button .icon-end {
  padding-left: 15px;
}
@media only screen and (max-width : 660px) {
  .button .icon-end {
    padding-left: 5px;
  }
}
.button.mini {
  padding: 5px 15px;
  font-size: 1rem;
}
.button.mid {
  font-size: 1.6rem;
  padding: 10px 25px;
}
.button.new {
  padding: 3px 6px;
  font-size: 1.2rem;
}
.button.back {
  vertical-align: middle;
  padding: 3px 6px;
  font-size: 0.6rem;
  text-transform: none;
  background-color: var(--color-secondaire);
  color: #ffffff;
}
.buttonstrong {
  font-weight: normal;
}

a.button,
button.button {
  cursor: pointer;
}

a.button:hover,
button.button:hover {
  background-color: var(--color-primaire-light);
  text-decoration: none;
  color: #fff;
}

.slick-dotted.slick-slider {
  margin-bottom: 5rem;
}

.slick-dots {
  bottom: -25px;
  display: flex;
  justify-content: flex-start;
  gap: 0.5rem;
}
.slick-dots li {
  width: 15px;
  height: 15px;
  margin: 0;
  padding: 0;
}
.slick-dots li button {
  width: 15px;
  padding: 0;
  height: 15px;
  background: transparent;
  color: var(--color-text);
  opacity: 0.5;
  font-size: 1.4rem;
  line-height: 1rem;
}
.slick-dots li button:before {
  display: none;
}
.slick-dots li.slick-active button {
  color: var(--color-secondaire);
  opacity: 1;
  font-weight: bold;
}

.slick-prev {
  left: 40px !important;
  z-index: 999;
}

.slick-next {
  right: 40px !important;
  z-index: 999;
}

.slick-prev:before {
  content: "\f053";
}

.slick-next:before {
  content: "\f054";
}

.slick-prev:before, .slick-next:before {
  font-family: "Font Awesome 6 Pro";
  font-weight: 300;
  color: #ffffff;
  font-size: 4rem;
}

.module-blocs.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
@media only screen and (min-width: 1024px) {
  .module-blocs .blocs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: auto;
    gap: 2rem;
  }
}
@media only screen and (max-width: 1024px) {
  .module-blocs .blocs {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 2rem;
  }
}
.module-blocs .blocs .bloc .a {
  display: block;
  height: 270px;
  position: relative;
  overflow: hidden;
}
.module-blocs .blocs .bloc .contenu-visuel {
  width: 100%;
  height: 100%;
}
.module-blocs .blocs .bloc .contenu-visuel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.module-blocs .blocs .bloc .contenu-center {
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: var(--color-secondaire-transparent);
  -webkit-transition: left 0.5s ease 0s;
  -o-transition: left 0.5s ease 0s;
  transition: left 0.5s ease 0s;
}
.module-blocs .blocs .bloc .contenu-center h3 {
  text-transform: uppercase;
  color: var(--color-text-dark);
  font-size: 1.8rem;
  font-weight: 600;
  padding: 1rem;
}
.module-blocs .blocs .bloc .a:hover .contenu-center {
  left: 0;
}

.module-actualites.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-actualites .blocs .bloc {
  display: flex;
  gap: 1rem;
  padding-bottom: 2rem;
  border-bottom: 1px dotted var(--color-text-dark);
  margin-bottom: 2rem;
}
@media only screen and (max-width: 1024px) {
  .module-actualites .blocs .bloc {
    flex-direction: column;
  }
}
.module-actualites .blocs .bloc:last-child {
  padding-bottom: 0;
  border-bottom: none;
  margin-bottom: 0;
}
.module-actualites .blocs .bloc .contenu-visuel {
  width: 275px;
}
@media only screen and (max-width: 1024px) {
  .module-actualites .blocs .bloc .contenu-visuel {
    order: 3;
  }
}
.module-actualites .blocs .bloc .contenu-visuel img {
  max-width: 100%;
}
.module-actualites .blocs .bloc .contenu-center {
  width: 215px;
  padding-top: 1.5rem;
  position: relative;
}
.module-actualites .blocs .bloc .contenu-center:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  background: var(--color-secondaire);
  width: 10px;
  height: 10px;
}
.module-actualites .blocs .bloc .contenu-center h3 {
  text-transform: uppercase;
  color: var(--color-text-dark);
  font-size: 2rem;
  font-weight: 700;
  margin: 0;
}
.module-actualites .blocs .bloc .contenu-center span.soustitre {
  text-transform: uppercase;
  color: var(--color-text-dark);
  font-size: 1.8rem;
  font-weight: 500;
  display: block;
}
.module-actualites .blocs .bloc .contenu-html {
  flex: 1;
}
.module-actualites .blocs .bloc .a:hover .contenu-center {
  left: 0;
}

.module-texte {
  margin: 2rem 0;
  position: relative;
}
.module-texte.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
@media only screen and (max-width: 1024px) {
  .module-texte {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-texte {
    margin: 4rem 0;
  }
}
.module-texte.top_puce .css_mce {
  padding-top: 1.5rem;
  position: relative;
}
.module-texte.top_puce .css_mce:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  background: var(--color-secondaire);
  width: 10px;
  height: 10px;
}
.module-texte .container {
  position: relative;
}
.module-texte .container .mod-titre {
  display: block;
  font-size: 5rem;
  color: var(--color-primaire);
  font-weight: 700;
  margin-bottom: 2rem;
  text-transform: none;
}
@media only screen and (max-width: 1024px) {
  .module-texte .container .mod-titre {
    font-size: 3.5rem;
  }
}
.module-texte .container .mod-intro {
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 1024px) {
  .module-texte .container .mod-intro {
    font-size: 1.8rem;
  }
}
.module-texte .container .css_mce h2 {
  margin-bottom: 2rem;
}
.module-texte.blockquote {
  padding: 50px 0;
  margin: 0;
}
.module-texte.blockquote .container {
  max-width: 695px;
}
.module-texte.blockquote .css_mce blockquote {
  margin: 0;
}
.module-texte.etroit .container .css_mce {
  max-width: 500px;
  margin: 0 auto;
}

.module-image_texte, .module-texte_slider, .module-sommaire {
  margin: 2rem 0;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte, .module-texte_slider, .module-sommaire {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-image_texte, .module-texte_slider, .module-sommaire {
    margin: 4rem 0;
  }
}
.module-image_texte .box-pattern, .module-texte_slider .box-pattern, .module-sommaire .box-pattern {
  display: none;
}
.module-image_texte.heurisko-module-back, .module-texte_slider.heurisko-module-back, .module-sommaire.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-image_texte.no-margin, .module-texte_slider.no-margin, .module-sommaire.no-margin {
  margin: 0 !important;
}
.module-image_texte.separator-before:before, .module-texte_slider.separator-before:before, .module-sommaire.separator-before:before {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-before.png") top center no-repeat;
  margin-bottom: 7rem;
  margin-top: 3rem;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.module-image_texte.separator-after:after, .module-texte_slider.separator-after:after, .module-sommaire.separator-after:after {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-after.png") top center no-repeat;
  margin-top: 7rem;
}
.module-image_texte > .container, .module-texte_slider > .container, .module-sommaire > .container {
  display: flex;
  gap: 6rem;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte > .container, .module-texte_slider > .container, .module-sommaire > .container {
    flex-direction: column;
    gap: 4rem;
  }
}
.module-image_texte .visuel, .module-texte_slider .visuel, .module-sommaire .visuel {
  order: 2;
  width: 50%;
  text-align: center;
  border-radius: 6rem 0 6rem 0;
  overflow: hidden;
  min-height: 500px;
  margin: 0;
  position: relative;
  align-self: stretch;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .visuel, .module-texte_slider .visuel, .module-sommaire .visuel {
    width: 100% !important;
    text-align: center !important;
    padding: 0 !important;
  }
}
.module-image_texte .visuel .slick-list, .module-image_texte .visuel .slick-track, .module-texte_slider .visuel .slick-list, .module-texte_slider .visuel .slick-track, .module-sommaire .visuel .slick-list, .module-sommaire .visuel .slick-track {
  height: 100%;
  min-height: 500px;
}
.module-image_texte .visuel .bloc-picture, .module-image_texte .visuel .bloc-video, .module-texte_slider .visuel .bloc-picture, .module-texte_slider .visuel .bloc-video, .module-sommaire .visuel .bloc-picture, .module-sommaire .visuel .bloc-video {
  height: 100%;
  min-height: 500px;
}
.module-image_texte .visuel video, .module-texte_slider .visuel video, .module-sommaire .visuel video {
  max-width: 100%;
  display: block;
}
.module-image_texte .visuel picture, .module-texte_slider .visuel picture, .module-sommaire .visuel picture {
  height: 100%;
  min-height: 500px;
  display: block;
}
.module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 500px;
  object-fit: cover;
  object-position: center;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
    width: 100% !important;
    height: auto !important;
  }
}
@media only screen and (max-width : 1366px) {
  .module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
    max-width: 100% !important;
  }
}
@media only screen and (max-width: 1080px) {
  .module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
    max-width: 100% !important;
  }
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
    max-width: 100% !important;
  }
}
@media only screen and (max-width : 660px) {
  .module-image_texte .visuel img, .module-texte_slider .visuel img, .module-sommaire .visuel img {
    max-width: 100% !important;
  }
}
.module-image_texte.image_contain .visuel, .module-texte_slider.image_contain .visuel, .module-sommaire.image_contain .visuel {
  border-radius: 0;
  min-height: initial;
}
.module-image_texte.image_contain .visuel .bloc-picture, .module-image_texte.image_contain .visuel .bloc-video, .module-texte_slider.image_contain .visuel .bloc-picture, .module-texte_slider.image_contain .visuel .bloc-video, .module-sommaire.image_contain .visuel .bloc-picture, .module-sommaire.image_contain .visuel .bloc-video {
  height: auto;
  min-height: initial;
}
.module-image_texte.image_contain .visuel picture, .module-texte_slider.image_contain .visuel picture, .module-sommaire.image_contain .visuel picture {
  height: auto;
  min-height: initial;
  display: block;
}
.module-image_texte.image_contain .visuel img, .module-texte_slider.image_contain .visuel img, .module-sommaire.image_contain .visuel img {
  width: auto;
  height: auto;
  min-height: initial;
  object-fit: initial;
  object-position: top;
  max-width: 100%;
}
.module-image_texte .contenu, .module-texte_slider .contenu, .module-sommaire .contenu {
  order: 1;
  width: 50%;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .contenu, .module-texte_slider .contenu, .module-sommaire .contenu {
    width: 100% !important;
  }
}
.module-image_texte .contenu .published, .module-texte_slider .contenu .published, .module-sommaire .contenu .published {
  font-family: var(--real-font-regular);
  color: var(--color-text-dark);
  font-size: 5rem;
  text-transform: none;
  font-weight: 700;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .contenu .published, .module-texte_slider .contenu .published, .module-sommaire .contenu .published {
    font-size: 3.5rem;
  }
}
.module-image_texte .contenu .mod-titre, .module-texte_slider .contenu .mod-titre, .module-sommaire .contenu .mod-titre {
  font-family: var(--real-font-regular);
  color: var(--color-primaire);
  font-size: 5rem;
  text-transform: none;
  font-weight: 700;
  margin-bottom: 2rem;
}
.module-image_texte .contenu .mod-intro, .module-texte_slider .contenu .mod-intro, .module-sommaire .contenu .mod-intro {
  font-family: var(--real-font-regular);
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 2rem;
}
.module-image_texte .contenu .css_mce, .module-texte_slider .contenu .css_mce, .module-sommaire .contenu .css_mce {
  margin: 0 auto;
}
.module-image_texte .contenu .bouton, .module-texte_slider .contenu .bouton, .module-sommaire .contenu .bouton {
  padding-top: 2rem;
  text-align: center;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte .contenu .mod-titre, .module-texte_slider .contenu .mod-titre, .module-sommaire .contenu .mod-titre {
    font-size: 3.5rem;
  }
  .module-image_texte .contenu .mod-intro, .module-texte_slider .contenu .mod-intro, .module-sommaire .contenu .mod-intro {
    font-size: 1.8rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-image_texte .contenu .mod-titre, .module-texte_slider .contenu .mod-titre, .module-sommaire .contenu .mod-titre {
    font-size: 3.5rem;
  }
  .module-image_texte .contenu .mod-intro, .module-texte_slider .contenu .mod-intro, .module-sommaire .contenu .mod-intro {
    font-size: 1.8rem;
  }
}
.module-image_texte.gradient_background, .module-texte_slider.gradient_background, .module-sommaire.gradient_background {
  margin: 0;
  padding: 6rem 0;
  background: linear-gradient(0deg, var(--color-primaire-dark), var(--color-primaire));
}
.module-image_texte.gradient_background .contenu .mod-titre, .module-texte_slider.gradient_background .contenu .mod-titre, .module-sommaire.gradient_background .contenu .mod-titre {
  color: #FFFFFF;
}
.module-image_texte.gradient_background .contenu .mod-intro, .module-texte_slider.gradient_background .contenu .mod-intro, .module-sommaire.gradient_background .contenu .mod-intro {
  color: #FFFFFF;
}
.module-image_texte.gradient_background .contenu .css_mce *, .module-texte_slider.gradient_background .contenu .css_mce *, .module-sommaire.gradient_background .contenu .css_mce * {
  color: #ffffff;
}
.module-image_texte.align-items-center .container, .module-texte_slider.align-items-center .container, .module-sommaire.align-items-center .container {
  align-items: center;
}
.module-image_texte.imageGauche > .container > .visuel, .module-texte_slider.imageGauche > .container > .visuel, .module-sommaire.imageGauche > .container > .visuel {
  order: 1;
  text-align: right;
}
.module-image_texte.imageGauche > .container > .contenu, .module-texte_slider.imageGauche > .container > .contenu, .module-sommaire.imageGauche > .container > .contenu {
  order: 2;
}
.module-image_texte.grande_image > .container, .module-texte_slider.grande_image > .container, .module-sommaire.grande_image > .container {
  padding: 0;
  margin: 0;
  width: 100%;
  max-width: 100%;
}
@media only screen and (max-width: 1024px) {
  .module-image_texte.grande_image > .container, .module-texte_slider.grande_image > .container, .module-sommaire.grande_image > .container {
    gap: 0;
  }
}
.module-image_texte.grande_image > .container > .visuel img, .module-texte_slider.grande_image > .container > .visuel img, .module-sommaire.grande_image > .container > .visuel img {
  max-width: 100%;
}
@media only screen and (max-width : 660px) {
  .module-image_texte.grande_image > .container > .visuel, .module-texte_slider.grande_image > .container > .visuel, .module-sommaire.grande_image > .container > .visuel {
    width: 100%;
    height: auto;
  }
  .module-image_texte.grande_image > .container > .visuel img, .module-texte_slider.grande_image > .container > .visuel img, .module-sommaire.grande_image > .container > .visuel img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
}
@media only screen and (max-width: 1024px) {
  .module-image_texte.grande_image > .container > .contenu, .module-texte_slider.grande_image > .container > .contenu, .module-sommaire.grande_image > .container > .contenu {
    padding: 4rem 3rem !important;
  }
}
.module-image_texte.grande_image > .container > .contenu .css_mce, .module-texte_slider.grande_image > .container > .contenu .css_mce, .module-sommaire.grande_image > .container > .contenu .css_mce {
  padding: 0;
  max-width: 420px;
  margin: 0 auto;
}
.module-image_texte.primary, .module-texte_slider.primary, .module-sommaire.primary {
  background-color: var(--color-primaire);
}
.module-image_texte.primary .css_mce, .module-texte_slider.primary .css_mce, .module-sommaire.primary .css_mce {
  color: #ffffff;
}
.module-image_texte.primary .css_mce *, .module-texte_slider.primary .css_mce *, .module-sommaire.primary .css_mce * {
  color: inherit;
}
.module-image_texte.primary .css_mce p, .module-texte_slider.primary .css_mce p, .module-sommaire.primary .css_mce p {
  color: var(--color-primaire-light);
}
.module-image_texte.primary .btn-borderMove, .module-texte_slider.primary .btn-borderMove, .module-sommaire.primary .btn-borderMove {
  color: #ffffff;
  outline-color: rgba(255, 255, 255, 0.5);
}
.module-image_texte.primary .btn-borderMove:hover, .module-texte_slider.primary .btn-borderMove:hover, .module-sommaire.primary .btn-borderMove:hover {
  outline-color: rgba(255, 255, 255, 0);
}
.module-image_texte.primary .btn-bordered rect, .module-texte_slider.primary .btn-bordered rect, .module-sommaire.primary .btn-bordered rect {
  stroke: #ffffff;
}
.module-image_texte.secondary, .module-texte_slider.secondary, .module-sommaire.secondary {
  background-color: var(--color-secondaire);
}
.module-image_texte.secondary .css_mce, .module-texte_slider.secondary .css_mce, .module-sommaire.secondary .css_mce {
  color: #ffffff;
}
.module-image_texte.secondary .css_mce *, .module-texte_slider.secondary .css_mce *, .module-sommaire.secondary .css_mce * {
  color: inherit;
}
.module-image_texte.secondary .css_mce p, .module-texte_slider.secondary .css_mce p, .module-sommaire.secondary .css_mce p {
  color: var(--color-secondaire-light);
}
.module-image_texte.secondary .btn-borderMove, .module-texte_slider.secondary .btn-borderMove, .module-sommaire.secondary .btn-borderMove {
  color: #ffffff;
  outline-color: rgba(255, 255, 255, 0.5);
}
.module-image_texte.secondary .btn-borderMove:hover, .module-texte_slider.secondary .btn-borderMove:hover, .module-sommaire.secondary .btn-borderMove:hover {
  outline-color: rgba(255, 255, 255, 0);
}
.module-image_texte.secondary .btn-bordered rect, .module-texte_slider.secondary .btn-bordered rect, .module-sommaire.secondary .btn-bordered rect {
  stroke: #ffffff;
}

@keyframes fadeImg {
  to {
    transform: translateX(200px);
  }
}
.module-projets_diapo.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-projets_diapo .blocs {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.module-projets_diapo .blocs .bloc {
  width: 162px;
}
@media only screen and (max-width : 660px) {
  .module-projets_diapo .blocs .bloc {
    width: 100%;
  }
}
.module-projets_diapo .blocs .bloc:before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  background: var(--color-secondaire);
  margin-bottom: 1rem;
}
.module-projets_diapo .blocs .bloc .titre {
  font-size: 1.4rem;
  font-weight: bold;
  text-transform: uppercase;
  margin: 0;
  padding: 0;
}
.module-projets_diapo .blocs .bloc .soustitre {
  font-size: 1.4rem;
  display: block;
  text-transform: uppercase;
  margin: 0;
  padding: 0;
}
.module-projets_diapo .blocs .bloc .contenu-visuel {
  margin-top: 2rem;
  width: 160px;
  height: 100px;
}
@media only screen and (max-width : 660px) {
  .module-projets_diapo .blocs .bloc .contenu-visuel {
    width: 100%;
    height: 175px;
  }
}
.module-projets_diapo .blocs .bloc .contenu-visuel img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.module-projets_diapo .blocs .bloc a {
  text-decoration: none;
  color: var(--color-text-dark);
}
.module-projets_diapo .blocs .bloc a:hover {
  text-decoration: none;
}
.module-projets_diapo .blocs .bloc a:hover .titre {
  color: var(--color-secondaire);
}
.module-projets_diapo .blocs .bloc a:hover .soustitre {
  color: var(--color-secondaire);
}

.module-projets_list.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-projets_list .blocs .bloc {
  padding-bottom: 2rem;
  margin-bottom: 2rem;
  border-bottom: 1px dotted var(--color-text-dark);
}
.module-projets_list .blocs .bloc:last-child {
  border: none;
}
.module-projets_list .blocs .bloc .titre {
  font-size: 1.6rem;
  margin-bottom: 1rem;
  text-transform: uppercase;
  font-weight: normal;
  color: var(--color-text-dark);
}
.module-projets_list .blocs .bloc .slick-me {
  width: 700px;
}
@media only screen and (max-width: 1024px) {
  .module-projets_list .blocs .bloc .slick-me {
    width: 100%;
  }
}
.module-projets_list .blocs .bloc .slide {
  width: 100%;
  height: 440px;
}
@media only screen and (max-width : 660px) {
  .module-projets_list .blocs .bloc .slide {
    height: 225px;
  }
}
.module-projets_list .blocs .bloc .slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.module-projets_list .blocs .bloc .contenu-html {
  margin-top: 2.5rem;
}
.module-projets_list .blocs .bloc .contenu-html:before {
  display: block;
  margin-bottom: 1rem;
  content: "";
  width: 10px;
  height: 10px;
  background: var(--color-secondaire);
}

.module-separateur.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-separateur .container {
  height: 1px;
}
.module-separateur .container .borderme {
  border-bottom: 1px dotted #303030;
  margin: 25px 0;
}
.module-separateur.h1px .container .borderme {
  margin: 0;
}
.module-separateur.h10vh .container .borderme {
  margin: 5vh 0;
}
.module-separateur.h20vh .container .borderme {
  margin: 10vh 0;
}
.module-separateur.h30vh .container .borderme {
  margin: 15vh 0;
}
.module-separateur.h40vh .container .borderme {
  margin: 20vh 0;
}

.img-object-fit-cover {
  object-fit: cover;
}

.img-object-fit-contain {
  object-fit: contain;
}

.module-texte_blocs {
  margin: 2rem 0;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 1024px) {
  .module-texte_blocs {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-texte_blocs {
    margin: 4rem 0;
  }
}
.module-texte_blocs.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-texte_blocs.heurisko-module-back {
  padding-bottom: 50px;
}
.module-texte_blocs.heurisko-module-back > .container .blocs .bloc {
  padding-top: 40px;
  min-width: 20px;
}
.module-texte_blocs.justify-content-center > .container .blocs {
  justify-content: center;
}
.module-texte_blocs > .container {
  margin-top: 0;
  margin-bottom: 0;
}
.module-texte_blocs > .container .mod-header {
  margin-bottom: 1rem;
}
.module-texte_blocs > .container .mod-header .mod-titre {
  margin: 0;
  display: block;
  font-size: 2.5rem;
  text-transform: uppercase;
  font-family: var(--real-font-regular), "Arial";
  font-weight: 700;
  position: relative;
  color: var(--color-text-dark);
}
.module-texte_blocs > .container .mod-header .mod-soustitre {
  display: block;
  font-size: 2.5rem;
  text-transform: uppercase;
  font-family: var(--real-font-regular), "Arial";
  position: relative;
  color: var(--color-text-dark);
}
.module-texte_blocs > .container .blocs {
  display: flex;
  gap: 6rem;
}
@media only screen and (max-width: 1024px) {
  .module-texte_blocs > .container .blocs {
    flex-direction: column;
    gap: 1.5rem;
  }
}
.module-texte_blocs > .container .blocs .bloc {
  flex: 1;
  padding-top: 1.5rem;
  position: relative;
}
.module-texte_blocs > .container .blocs .bloc.top_puce:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  background: var(--color-secondaire);
  width: 10px;
  height: 10px;
}
.module-texte_blocs > .container .blocs .bloc .mod-titre {
  font-size: 5rem;
  font-weight: 700;
  color: var(--color-primaire);
  text-transform: none;
  margin-bottom: 2rem;
}
@media only screen and (max-width: 1024px) {
  .module-texte_blocs > .container .blocs .bloc .mod-titre {
    font-size: 3.5rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-texte_blocs > .container .blocs .bloc .mod-titre {
    font-size: 3.5rem;
  }
}
.module-texte_blocs > .container .blocs .bloc .contenu-visuel {
  height: 345px;
  margin-top: 3rem;
  border-radius: 3rem;
  overflow: hidden;
}
@media only screen and (max-width : 660px) {
  .module-texte_blocs > .container .blocs .bloc .contenu-visuel {
    height: 245px;
  }
}
.module-texte_blocs > .container .blocs .bloc .contenu-visuel img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.module-texte_blocs > .container .blocs .bloc .bouton {
  margin-top: 3rem;
}
.module-texte_blocs > .container .blocs .bloc.bloc-empty {
  padding: 0 !important;
}
.module-texte_blocs > .container .blocs .bloc.text_light h1, .module-texte_blocs > .container .blocs .bloc.text_light h2, .module-texte_blocs > .container .blocs .bloc.text_light h3, .module-texte_blocs > .container .blocs .bloc.text_light ul, .module-texte_blocs > .container .blocs .bloc.text_light li, .module-texte_blocs > .container .blocs .bloc.text_light p, .module-texte_blocs > .container .blocs .bloc.text_light td {
  color: #fff;
}
.module-texte_blocs > .container .blocs .bloc.text_light .cta-primary,
.module-texte_blocs > .container .blocs .bloc.text_light .cta-secondary,
.module-texte_blocs > .container .blocs .bloc.text_light .cta-tertiary {
  background-color: #fff !important;
  color: var(--color-text) !important;
}
.module-texte_blocs > .container .blocs .bloc.text_light .cta-primary:hover,
.module-texte_blocs > .container .blocs .bloc.text_light .cta-secondary:hover,
.module-texte_blocs > .container .blocs .bloc.text_light .cta-tertiary:hover {
  color: var(--real-theme-color-1) !important;
}
.module-texte_blocs.blocs-images {
  margin: 4rem 0;
}
@media only screen and (max-width: 1024px) {
  .module-texte_blocs.blocs-images {
    display: none;
  }
}
.module-texte_blocs.blocs-images > .container .blocs .bloc .contenu-visuel {
  margin-top: 0;
  height: 275px;
}

.module-faq {
  margin: 2rem 0;
  opacity: 0;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 1024px) {
  .module-faq {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-faq {
    margin: 4rem 0;
  }
}
.module-faq.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-faq.heurisko-module-back {
  padding-bottom: 50px;
}
.module-faq.heurisko-module-back > .container .blocs .bloc {
  padding-top: 40px;
  min-width: 20px;
}
.module-faq.heurisko-module-back > .container .blocs .bloc .bloc-contenu {
  display: block;
}
.module-faq.activeModule {
  animation: animFadeIn 1s ease-out 0s 1 normal forwards;
}
.module-faq > .container {
  margin-top: 0;
  margin-bottom: 0;
}
.module-faq > .container .mod-titre {
  display: block;
  font-weight: 700;
  color: var(--color-text-dark);
  font-size: 5rem;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 1024px) {
  .module-faq > .container .mod-titre {
    font-size: 3.5rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-faq > .container .mod-titre {
    font-size: 3.5rem;
  }
}
.module-faq > .container .blocs .bloc {
  background: rgba(249, 20, 146, 0.07);
  border-bottom: 1px solid #ffffff;
  padding: 2rem;
}
@media only screen and (max-width : 660px) {
  .module-faq > .container .blocs .bloc {
    padding: 1rem;
  }
}
.module-faq > .container .blocs .bloc .bloc-titre {
  cursor: pointer;
  display: block;
  font-size: 2.8rem;
  font-weight: 500;
  color: var(--color-primaire);
  text-transform: none;
  position: relative;
  padding-right: 5rem;
}
@media only screen and (max-width: 1024px) {
  .module-faq > .container .blocs .bloc .bloc-titre {
    font-size: 2rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-faq > .container .blocs .bloc .bloc-titre {
    font-size: 1.6rem;
  }
}
.module-faq > .container .blocs .bloc .bloc-titre:after {
  position: absolute;
  top: 0;
  right: 0;
  content: "+";
  font-family: "Font Awesome 6 Pro";
  color: var(--color-text-dark);
  font-weight: 700;
}
.module-faq > .container .blocs .bloc .bloc-titre.toggled:after {
  content: "\f068";
}
.module-faq > .container .blocs .bloc .bloc-contenu {
  margin-top: 2rem;
  display: none;
}
.module-faq > .container .blocs .bloc .bouton {
  margin-top: 2rem;
}
.module-widget_embed {
  margin: 2rem 0;
}
@media only screen and (max-width: 1024px) {
  .module-widget_embed {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-widget_embed {
    margin: 4rem 0;
  }
}
.module-widget_embed.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-widget_embed.separator-before:before {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-before.png") top center no-repeat;
  margin-bottom: 7rem;
  margin-top: 3rem;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.module-widget_embed.separator-after:after {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-after.png") top center no-repeat;
  margin-top: 7rem;
}
.module-widget_embed .container {
  position: relative;
}

.module-argument_blocs {
  margin: 2rem 0;
  transform: translateY(50px);
  opacity: 0;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs {
    margin: 4rem 0;
  }
}
.module-argument_blocs.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-argument_blocs.separator-before:before {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-before.png") top center no-repeat;
  margin-bottom: 7rem;
  margin-top: 3rem;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.module-argument_blocs.separator-after:after {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  background: url("../img/separator-after.png") top center no-repeat;
  margin-top: 7rem;
}
.module-argument_blocs > .container {
  width: 100%;
  max-width: 100%;
  border-radius: 6rem 0 6rem 0;
  background: var(--color-primaire);
  background: linear-gradient(0deg, var(--color-primaire-dark) 0%, var(--color-primaire) 100%);
  padding: 8rem 0 8rem 0;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs > .container {
    padding: 5rem 0;
  }
}
.module-argument_blocs .mod-titre {
  display: block;
  text-align: center;
  font-family: var(--real-font-regular);
  font-weight: 700;
  color: #ffffff;
  font-size: 3.6rem;
  text-transform: none;
  margin: 0;
  padding: 0;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs .mod-titre {
    max-width: 80%;
    margin: 0 auto;
    font-size: 3.2rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs .mod-titre {
    font-size: 2.6rem;
  }
}
.module-argument_blocs .blocs {
  margin-top: 6rem;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs .blocs {
    margin-top: 0rem;
    gap: 0;
  }
}
.module-argument_blocs .blocs .bloc {
  position: relative;
  width: 33.333%;
  display: flex;
  flex-direction: column;
  align-items: center;
  opacity: 0;
  transform: translateY(50px);
}
.module-argument_blocs .blocs .bloc.visibleBloc {
  animation: animBotToTop 0.5s ease-out 0s 1 normal forwards, animFadeIn 0.5s ease-out 0s 1 normal forwards;
}
.module-argument_blocs .blocs .bloc.visibleBloc .bloc-titre, .module-argument_blocs .blocs .bloc.visibleBloc .bloc-content {
  animation: animBotToTop 0.5s ease-out 0.5s 1 normal forwards, animFadeIn 0.5s ease-out 0.5s 1 normal forwards;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs .blocs .bloc {
    width: 50%;
    padding: 3rem 2rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs .blocs .bloc {
    width: 100%;
    padding: 3rem;
  }
}
.module-argument_blocs .blocs .bloc.heurisko-bloc-add {
  display: flex;
  align-items: center;
  justify-content: center;
}
.module-argument_blocs .blocs .bloc .contenu-center {
  flex-direction: column;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.module-argument_blocs .blocs .bloc .bloc-titre {
  margin: 0.5rem 0;
  display: block;
  font-weight: 500;
  font-size: 2.8rem;
  color: #ffffff;
  opacity: 0;
  transform: translateY(50px);
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs .blocs .bloc .bloc-titre {
    font-size: 2.4rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs .blocs .bloc .bloc-titre {
    font-size: 2rem;
  }
}
.module-argument_blocs .blocs .bloc .bloc-soustitre {
  margin: 0.5rem 0;
  font-weight: 700;
  font-size: 5rem;
  color: #ffffff;
  display: block;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs .blocs .bloc .bloc-soustitre {
    font-size: 3.5rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-argument_blocs .blocs .bloc .bloc-soustitre {
    font-size: 3.5rem;
  }
}
.module-argument_blocs .blocs .bloc.invert .bloc-soustitre {
  order: 2;
}
.module-argument_blocs .blocs .bloc.invert .bloc-titre {
  order: 1;
}
.module-argument_blocs.checkboxes .container {
  width: 95%;
}
.module-argument_blocs.checkboxes .mod-titre {
  text-transform: uppercase;
}
.module-argument_blocs.checkboxes .blocs .bloc .bloc-content {
  opacity: 0;
  transform: translateY(50px);
}
.module-argument_blocs.checkboxes .blocs .bloc .bloc-content p {
  font-size: 1.6rem;
  color: #ffffff;
  text-align: left;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs.checkboxes .blocs .bloc .bloc-content p {
    text-align: center;
  }
}
.module-argument_blocs.checkboxes .blocs .bloc .contenu-center {
  align-items: flex-start;
  padding-left: 100px;
  padding-right: 65px;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs.checkboxes .blocs .bloc .contenu-center {
    padding: 0;
    align-items: center;
  }
}
.module-argument_blocs.checkboxes .blocs .bloc .bloc-soustitre {
  position: relative;
  text-align: left;
}
.module-argument_blocs.checkboxes .blocs .bloc .bloc-soustitre:before {
  position: absolute;
  top: 8px;
  left: -65px;
  display: inline-block;
  content: "\f058";
  font-weight: 700;
  font-family: "Font Awesome 6 Pro";
  margin-right: 1rem;
  font-size: 5rem;
  color: #ffffff;
}
@media only screen and (max-width: 1024px) {
  .module-argument_blocs.checkboxes .blocs .bloc .bloc-soustitre {
    text-align: center;
  }
  .module-argument_blocs.checkboxes .blocs .bloc .bloc-soustitre:before {
    position: static;
    top: initial;
    left: initial;
    display: block;
    text-align: center;
  }
}
.module-argument_blocs.pictured .container {
  width: 95%;
}
.module-argument_blocs.pictured .blocs .bloc .bloc-visuel {
  width: 240px;
  height: 240px;
  border-radius: 50%;
  overflow: hidden;
  margin-bottom: 2rem;
}
.module-argument_blocs.pictured .blocs .bloc .bloc-visuel img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}
.module-argument_blocs.pictured .blocs .bloc .bloc-content {
  opacity: 0;
  transform: translateY(50px);
  padding: 0 20%;
}
.module-argument_blocs.pictured .blocs .bloc .bloc-content p {
  text-align: center;
  font-size: 1.6rem;
  color: #ffffff;
}

.module-onglets {
  margin: 4rem 0;
}
.module-onglets.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-onglets ul {
  display: flex;
  gap: 1rem;
  padding: 0;
  margin: 0;
}
.module-onglets ul li {
  list-style: none;
  padding: 0;
  margin: 0;
  position: relative;
}
.module-onglets ul li .btn-cta {
  display: inline-block;
  padding: 1rem 2rem;
  border-radius: 50px;
  color: #fff !important;
  font-size: 1.8rem;
  border: none;
  font-weight: 700;
  background: linear-gradient(0deg, var(--color-primaire-dark), var(--color-primaire));
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
.module-onglets ul li .btn-cta:hover {
  border-radius: 20px 0 20px 0;
  text-decoration: none;
}
@media only screen and (max-width: 1024px), only screen and (max-width : 660px) {
  .module-onglets ul li .btn-cta {
    font-size: 1.6rem;
    padding: 8px 15px;
  }
}
.module-onglets ul li .btn-cta:focus {
  outline: none;
}
.module-onglets ul li .btn-cta-bordered {
  display: inline-block;
  padding: 1rem 2rem;
  border-radius: 50px;
  color: var(--color-primaire-dark);
  font-size: 1.8rem;
  transition: all 0.3s;
  font-weight: 700;
  border: 1px solid transparent;
  background: linear-gradient(white, white) padding-box, linear-gradient(180deg, var(--color-primaire), var(--color-primaire-dark)) border-box;
  -webkit-transition: all 0.5s ease 0s;
  -o-transition: all 0.5s ease 0s;
  transition: all 0.5s ease 0s;
}
@media only screen and (max-width: 1024px), only screen and (max-width : 660px) {
  .module-onglets ul li .btn-cta-bordered {
    font-size: 1.6rem;
    padding: 8px 15px;
  }
}
.module-onglets ul li .btn-cta-bordered:focus {
  outline: none;
}
.module-onglets ul li .btn-cta-bordered:hover {
  text-decoration: none;
  color: var(--color-primaire);
  border-radius: 20px 0 20px 0;
}
.module-onglets ul li .heurisko-toolbar-bloc .heurisko-toolbar-line {
  top: -35px;
}
.module-onglets ul li .heurisko-bloc-add {
  padding: 0 !important;
}
.module-onglets ul li .heurisko-bloc-add button {
  display: inline-block;
  background: var(--color-primaire);
  color: #ffffff;
  font-weight: 600;
  border-radius: 50px;
  padding: 1rem 2rem;
  text-transform: uppercase;
  font-size: 1.2rem;
}

.module-partenaires {
  margin: 2rem 0;
}
@media only screen and (max-width: 1024px) {
  .module-partenaires {
    margin: 6rem 0;
  }
}
@media only screen and (max-width : 660px) {
  .module-partenaires {
    margin: 4rem 0;
  }
}
.module-partenaires.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-partenaires .mod-titre {
  display: block;
  font-size: 5rem;
  font-weight: 700;
  color: var(--color-primaire);
  text-transform: none;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 1024px) {
  .module-partenaires .mod-titre {
    font-size: 3.5rem;
  }
}
@media only screen and (max-width : 660px) {
  .module-partenaires .mod-titre {
    font-size: 3.5rem;
  }
}
.module-partenaires .blocs {
  margin: 4rem 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-template-rows: repeat(1, 1fr);
  gap: 2rem;
}
@media only screen and (max-width: 1024px) {
  .module-partenaires .blocs {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media only screen and (max-width : 660px) {
  .module-partenaires .blocs {
    grid-template-columns: repeat(2, 1fr);
  }
}
.module-partenaires .blocs .bloc {
  height: 160px;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width : 660px) {
  .module-partenaires .blocs .bloc {
    height: 120px;
  }
}
.module-partenaires .blocs .bloc .contenu-visuel {
  padding: 1rem 3rem;
}
.module-partenaires .blocs .bloc .contenu-visuel img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}
.module-partenaires .bouton {
  text-align: center;
}

.module-gallery {
  margin: 4rem 0;
}
.module-gallery.heurisko-module-back {
  position: relative;
  padding-top: 60px;
  padding-bottom: 40px;
  background-image: url(../img/module-bg-spacer.png);
  background-position: center top;
  background-repeat: repeat-x;
}
.module-gallery .container {
  max-width: 1440px !important;
}
.module-gallery .mod-titre {
  display: block;
  margin-bottom: 2rem;
}
.module-gallery .module-onglets ul {
  flex-wrap: wrap;
  justify-content: center;
}
.module-gallery .blocs {
  display: none;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}
.module-gallery .blocs .bloc {
  width: 250px;
  height: 250px;
  position: relative;
}
.module-gallery .blocs .bloc a.btn-download {
  display: none;
  position: absolute;
  top: 10px;
  right: 10px;
  background: var(--color-primaire-light);
  color: #ffffff;
  font-size: 1.2rem;
  padding: 3px 10px;
  border-radius: 205px;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  z-index: 2;
}
.module-gallery .blocs .bloc a.btn-download:hover {
  text-decoration: none;
  background: var(--color-secondaire);
}
.module-gallery .blocs .bloc:hover a.btn-download {
  display: block;
}
.module-gallery .blocs .bloc .bloc-video, .module-gallery .blocs .bloc .bloc-visuel {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
}
.module-gallery .blocs .bloc .bloc-video a, .module-gallery .blocs .bloc .bloc-visuel a {
  display: block;
  width: 100%;
  height: 100%;
}
.module-gallery .blocs .bloc .bloc-video img, .module-gallery .blocs .bloc .bloc-video video, .module-gallery .blocs .bloc .bloc-visuel img, .module-gallery .blocs .bloc .bloc-visuel video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media only screen and (max-width : 660px) {
  .module-gallery .blocs {
    gap: initial;
  }
  .module-gallery .blocs .bloc {
    width: 50%;
    height: 125px;
    padding: 0.25rem;
  }
  .module-gallery .blocs .bloc .bloc-video, .module-gallery .blocs .bloc .bloc-visuel {
    border-radius: 10px;
  }
}
.module-gallery .blocs.selected {
  display: flex;
}
.module-gallery .blocs .bloc {
  opacity: 1;
  transform: none;
}

div.error {
  max-width: 560px;
  padding: 10px;
  background-color: #fff;
  margin-bottom: 2rem;
}
div.error h1 {
  color: var(--color-secondaire);
  font-size: 2em;
  margin: 0 0 20px;
  padding: 0;
  font-weight: normal;
}
div.error p {
  color: var(--color-secondaire);
  font-size: 1.4rem;
  margin: 0 0;
  padding: 0;
}
div.error a {
  text-decoration: underline;
  color: var(--color-secondaire);
}
div.error a:hover {
  color: var(--color-primaire);
}

.checkbox-switch {
  position: relative;
  display: inline-block;
  width: 31px;
  height: 15px;
  margin: 0;
}
.checkbox-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.checkbox-switch .checkbox-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--color-primary);
  -webkit-transition: 0.4s;
  transition: 0.4s;
}
.checkbox-switch .checkbox-slider:before {
  position: absolute;
  content: "";
  height: 11px;
  width: 11px;
  left: 3px;
  bottom: 2px;
  background-color: #fff;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.checkbox-switch input:checked + .checkbox-slider {
  background-color: var(--color-primaire-light);
}
.checkbox-switch input:focus + .checkbox-slider {
  box-shadow: 0 0 1px #ccc;
}
.checkbox-switch input:checked + .checkbox-slider:before {
  left: 17px;
}
.checkbox-switch .checkbox-slider.checkbox-round {
  border-radius: 100px;
}
.checkbox-switch .checkbox-slider.checkbox-round:before {
  border-radius: 50%;
}

.kpn_pagination .navigation nav > ul {
  gap: 1rem;
}
.kpn_pagination .navigation nav > ul > .page-item > .page-link {
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  border-radius: 10px;
  padding: 5px 10px;
  border: 1px solid transparent;
  color: var(--color-primaire);
  font-size: 1.4rem;
}
.kpn_pagination .navigation nav > ul > .page-item > a.page-link:hover {
  color: var(--color-text);
}
.kpn_pagination .navigation nav > ul > .page-item.disabled > .page-link {
  opacity: 0.3;
  color: var(--color-text);
}
.kpn_pagination .navigation nav > ul > .page-item.active > .page-link {
  background: none;
  color: var(--color-primaire);
  border: 1px solid var(--color-primaire);
}

.notifyjs-bootstrap-base {
  background-position: 5px center !important;
}

.heur-m-1 {
  margin: 1rem;
}

.heur-mt-1 {
  margin-top: 1rem;
}

.heur-ml-1 {
  margin-left: 1rem;
}

.heur-mr-1 {
  margin-right: 1rem;
}

.heur-mb-1 {
  margin-bottom: 1rem;
}

.heur-p-1 {
  padding: 1rem;
}

.heur-pt-1 {
  padding-top: 1rem;
}

.heur-pl-1 {
  padding-left: 1rem;
}

.heur-pr-1 {
  padding-right: 1rem;
}

.heur-pb-1 {
  padding-bottom: 1rem;
}

.heur-m-2 {
  margin: 2rem;
}

.heur-mt-2 {
  margin-top: 2rem;
}

.heur-ml-2 {
  margin-left: 2rem;
}

.heur-mr-2 {
  margin-right: 2rem;
}

.heur-mb-2 {
  margin-bottom: 2rem;
}

.heur-p-2 {
  padding: 2rem;
}

.heur-pt-2 {
  padding-top: 2rem;
}

.heur-pl-2 {
  padding-left: 2rem;
}

.heur-pr-2 {
  padding-right: 2rem;
}

.heur-pb-2 {
  padding-bottom: 2rem;
}

.heur-m-3 {
  margin: 3rem;
}

.heur-mt-3 {
  margin-top: 3rem;
}

.heur-ml-3 {
  margin-left: 3rem;
}

.heur-mr-3 {
  margin-right: 3rem;
}

.heur-mb-3 {
  margin-bottom: 3rem;
}

.heur-p-3 {
  padding: 3rem;
}

.heur-pt-3 {
  padding-top: 3rem;
}

.heur-pl-3 {
  padding-left: 3rem;
}

.heur-pr-3 {
  padding-right: 3rem;
}

.heur-pb-3 {
  padding-bottom: 3rem;
}

.heur-m-4 {
  margin: 4rem;
}

.heur-mt-4 {
  margin-top: 4rem;
}

.heur-ml-4 {
  margin-left: 4rem;
}

.heur-mr-4 {
  margin-right: 4rem;
}

.heur-mb-4 {
  margin-bottom: 4rem;
}

.heur-p-4 {
  padding: 4rem;
}

.heur-pt-4 {
  padding-top: 4rem;
}

.heur-pl-4 {
  padding-left: 4rem;
}

.heur-pr-4 {
  padding-right: 4rem;
}

.heur-pb-4 {
  padding-bottom: 4rem;
}

.heur-m-5 {
  margin: 5rem;
}

.heur-mt-5 {
  margin-top: 5rem;
}

.heur-ml-5 {
  margin-left: 5rem;
}

.heur-mr-5 {
  margin-right: 5rem;
}

.heur-mb-5 {
  margin-bottom: 5rem;
}

.heur-p-5 {
  padding: 5rem;
}

.heur-pt-5 {
  padding-top: 5rem;
}

.heur-pl-5 {
  padding-left: 5rem;
}

.heur-pr-5 {
  padding-right: 5rem;
}

.heur-pb-5 {
  padding-bottom: 5rem;
}

.heur-m-6 {
  margin: 6rem;
}

.heur-mt-6 {
  margin-top: 6rem;
}

.heur-ml-6 {
  margin-left: 6rem;
}

.heur-mr-6 {
  margin-right: 6rem;
}

.heur-mb-6 {
  margin-bottom: 6rem;
}

.heur-p-6 {
  padding: 6rem;
}

.heur-pt-6 {
  padding-top: 6rem;
}

.heur-pl-6 {
  padding-left: 6rem;
}

.heur-pr-6 {
  padding-right: 6rem;
}

.heur-pb-6 {
  padding-bottom: 6rem;
}

.heur-m-7 {
  margin: 7rem;
}

.heur-mt-7 {
  margin-top: 7rem;
}

.heur-ml-7 {
  margin-left: 7rem;
}

.heur-mr-7 {
  margin-right: 7rem;
}

.heur-mb-7 {
  margin-bottom: 7rem;
}

.heur-p-7 {
  padding: 7rem;
}

.heur-pt-7 {
  padding-top: 7rem;
}

.heur-pl-7 {
  padding-left: 7rem;
}

.heur-pr-7 {
  padding-right: 7rem;
}

.heur-pb-7 {
  padding-bottom: 7rem;
}

.heur-m-8 {
  margin: 8rem;
}

.heur-mt-8 {
  margin-top: 8rem;
}

.heur-ml-8 {
  margin-left: 8rem;
}

.heur-mr-8 {
  margin-right: 8rem;
}

.heur-mb-8 {
  margin-bottom: 8rem;
}

.heur-p-8 {
  padding: 8rem;
}

.heur-pt-8 {
  padding-top: 8rem;
}

.heur-pl-8 {
  padding-left: 8rem;
}

.heur-pr-8 {
  padding-right: 8rem;
}

.heur-pb-8 {
  padding-bottom: 8rem;
}

.heur-m-9 {
  margin: 9rem;
}

.heur-mt-9 {
  margin-top: 9rem;
}

.heur-ml-9 {
  margin-left: 9rem;
}

.heur-mr-9 {
  margin-right: 9rem;
}

.heur-mb-9 {
  margin-bottom: 9rem;
}

.heur-p-9 {
  padding: 9rem;
}

.heur-pt-9 {
  padding-top: 9rem;
}

.heur-pl-9 {
  padding-left: 9rem;
}

.heur-pr-9 {
  padding-right: 9rem;
}

.heur-pb-9 {
  padding-bottom: 9rem;
}

.heur-m-10 {
  margin: 10rem;
}

.heur-mt-10 {
  margin-top: 10rem;
}

.heur-ml-10 {
  margin-left: 10rem;
}

.heur-mr-10 {
  margin-right: 10rem;
}

.heur-mb-10 {
  margin-bottom: 10rem;
}

.heur-p-10 {
  padding: 10rem;
}

.heur-pt-10 {
  padding-top: 10rem;
}

.heur-pl-10 {
  padding-left: 10rem;
}

.heur-pr-10 {
  padding-right: 10rem;
}

.heur-pb-10 {
  padding-bottom: 10rem;
}

@keyframes loaderLogoScaleIn {
  from {
    transform: scale(0, 0);
    opacity: 0.75;
    background-color: #ffffff;
  }
  to {
    background-color: var(--color-primaire);
    transform: scale(2.5, 2.5);
    opacity: 0;
  }
}
#loaderLogo {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: flex;
  align-content: center;
  justify-content: center;
  align-items: center;
  z-index: 1001;
}
@media only screen and (max-width: 1024px) {
  #loaderLogo {
    display: none;
  }
}
#loaderLogo .container {
  width: 300px;
}
#loaderLogo .container .circle {
  border-radius: 50%;
  background-color: var(--color-primaire-bg-light);
  width: 150px;
  height: 150px;
  position: absolute;
  left: 75px;
  top: 75px;
  opacity: 0;
  -webkit-box-shadow: inset 0px 0px 50px 0 #ffffff;
  -o-box-shadow: inset 0px 0px 50px 0 #ffffff;
  box-shadow: inset 0px 0px 50px 0 #ffffff;
  animation: loaderLogoScaleIn 4s infinite cubic-bezier(0.36, 0.11, 0.89, 0.32);
  z-index: 1003;
}
#loaderLogo .container #loaderLogoImg {
  width: 100%;
  position: relative;
  z-index: 1004;
}

.ctn-disclaimer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.95);
  display: flex;
  align-content: center;
  justify-content: center;
  align-items: center;
  z-index: 1001;
}
.ctn-disclaimer .disclaimer {
  background: #ffffff;
  padding: 3rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
}
@media only screen and (max-width : 660px) {
  .ctn-disclaimer .disclaimer {
    max-width: 90%;
  }
}
.ctn-disclaimer .disclaimer img {
  width: 100%;
  max-width: 300px;
}
.ctn-disclaimer .disclaimer p {
  font-size: 1.3rem;
  color: var(--color-text);
  font-family: var(--real-font-light);
}
.ctn-disclaimer .disclaimer .langues, .ctn-disclaimer .disclaimer .langues li {
  list-style: none;
  display: block;
  margin: 0;
  padding: 0;
  text-align: center;
}
.ctn-disclaimer .disclaimer .langues {
  display: flex;
  gap: 1rem;
}
.ctn-disclaimer .disclaimer .langues li a {
  text-transform: uppercase;
  color: var(--color-text-light);
  text-decoration: none;
}
.ctn-disclaimer .disclaimer .langues li a.selected, .ctn-disclaimer .disclaimer .langues li a:hover {
  color: var(--color-text);
}
.ctn-disclaimer .disclaimer button[type=button] {
  border: 1px solid var(--real-theme-color-1);
  color: var(--real-theme-color-1);
  text-transform: uppercase;
  padding: 1rem 3rem;
  outline: none;
  text-align: center;
  background: #fff;
  cursor: pointer;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
}
.ctn-disclaimer .disclaimer button[type=button]:hover {
  color: white;
  background: var(--real-theme-color-1);
  border-color: var(--real-theme-color-1);
}
.ctn-disclaimer .disclaimer button[type=button]:after {
  content: attr(data-front);
}
.ctn-disclaimer .disclaimer button[type=button].validate {
  font-size: 13px;
  color: white;
  background: var(--color-secondaire-light);
}
.ctn-disclaimer .disclaimer button[type=button].validate:after {
  font-family: "Font Awesome 6 Pro";
  content: "\f00c";
}
.ctn-disclaimer .disclaimer button[type=button].unsuccess {
  font-size: 13px;
  color: white;
  background: var(--color-primaire);
  border-color: var(--color-primaire);
}
.ctn-disclaimer .disclaimer button[type=button].unsuccess:after {
  font-family: "Font Awesome 6 Pro";
  content: "\f00d";
}
.ctn-disclaimer .disclaimer button[type=button].onclic {
  width: 40px;
  height: 40px;
  padding: 0;
  border-color: var(--color-secondaire);
  border-width: 3px;
  font-size: 0;
  border-radius: 50%;
  border-left-color: var(--color-secondaire-light);
  animation: rotating 2s 0.25s linear infinite;
}
.ctn-disclaimer .disclaimer button[type=button].onclic:after {
  content: "";
}
.ctn-disclaimer .disclaimer button[type=button].onclic:hover {
  color: var(--color-secondaire-light);
  background: white;
}

body.page-education .css_mce h6, body.page-education .css_mce h5, body.page-education .css_mce h4, body.page-education .css_mce h3, body.page-education .css_mce .h3, body.page-education .css_mce h2, body.page-education .css_mce h1, body.page-education .css_mce .h1 {
  color: var(--color-education);
}
body.page-education .css_mce .btn-cta:after {
  background-color: var(--color-education);
}
body.page-education .css_mce .btn-cta:before {
  background-color: var(--color-education-dark);
}
body.page-education .css_mce .btn-cta.btn-bordered {
  border-color: var(--color-education);
  color: var(--color-education);
}
body.page-education .css_mce .btn-cta.btn-bordered:before {
  background: var(--color-education);
}
body.page-education .css_mce .btn-cta.btn-bordered:hover {
  color: #FFFFFF;
}
body.page-education .css_mce h2, body.page-education .css_mce .h2 {
  color: var(--color-education);
}
body.page-education .css_mce h2:before, body.page-education .css_mce .h2:before {
  background: var(--color-education);
}
body.page-education .css_mce ol > li a,
body.page-education .css_mce ul > li a {
  color: var(--color-education);
}
body.page-education .css_mce ol > li a:hover,
body.page-education .css_mce ul > li a:hover {
  color: var(--color-education-dark);
}
body.page-education .css_mce h1 a, body.page-education .css_mce h2 a, body.page-education .css_mce h3 a, body.page-education .css_mce h4 a, body.page-education .css_mce h5 a, body.page-education .css_mce h6 a, body.page-education .css_mce p a, body.page-education .css_mce ul a {
  color: var(--color-education);
}
body.page-education .css_mce h1 a:hover, body.page-education .css_mce h1 a:hover strong, body.page-education .css_mce h2 a:hover, body.page-education .css_mce h2 a:hover strong, body.page-education .css_mce h3 a:hover, body.page-education .css_mce h3 a:hover strong, body.page-education .css_mce h4 a:hover, body.page-education .css_mce h4 a:hover strong, body.page-education .css_mce h5 a:hover, body.page-education .css_mce h5 a:hover strong, body.page-education .css_mce h6 a:hover, body.page-education .css_mce h6 a:hover strong, body.page-education .css_mce p a:hover, body.page-education .css_mce p a:hover strong, body.page-education .css_mce ul a:hover, body.page-education .css_mce ul a:hover strong {
  color: var(--color-education-dark);
}

body.page-training .css_mce h6, body.page-training .css_mce h5, body.page-training .css_mce h4, body.page-training .css_mce h3, body.page-training .css_mce .h3, body.page-training .css_mce h2, body.page-training .css_mce h1, body.page-training .css_mce .h1 {
  color: var(--color-training);
}
body.page-training .css_mce .btn-cta:after {
  background-color: var(--color-training);
}
body.page-training .css_mce .btn-cta:before {
  background-color: var(--color-training-dark);
}
body.page-training .css_mce .btn-cta.btn-bordered {
  border-color: var(--color-training);
  color: var(--color-training);
}
body.page-training .css_mce .btn-cta.btn-bordered:before {
  background: var(--color-training);
}
body.page-training .css_mce .btn-cta.btn-bordered:hover {
  color: #FFFFFF;
}
body.page-training .css_mce h2, body.page-training .css_mce .h2 {
  color: var(--color-training);
}
body.page-training .css_mce h2:before, body.page-training .css_mce .h2:before {
  background: var(--color-training);
}
body.page-training .css_mce ol > li a,
body.page-training .css_mce ul > li a {
  color: var(--color-training);
}
body.page-training .css_mce ol > li a:hover,
body.page-training .css_mce ul > li a:hover {
  color: var(--color-training-dark);
}
body.page-training .css_mce h1 a, body.page-training .css_mce h2 a, body.page-training .css_mce h3 a, body.page-training .css_mce h4 a, body.page-training .css_mce h5 a, body.page-training .css_mce h6 a, body.page-training .css_mce p a, body.page-training .css_mce ul a {
  color: var(--color-training);
}
body.page-training .css_mce h1 a:hover, body.page-training .css_mce h1 a:hover strong, body.page-training .css_mce h2 a:hover, body.page-training .css_mce h2 a:hover strong, body.page-training .css_mce h3 a:hover, body.page-training .css_mce h3 a:hover strong, body.page-training .css_mce h4 a:hover, body.page-training .css_mce h4 a:hover strong, body.page-training .css_mce h5 a:hover, body.page-training .css_mce h5 a:hover strong, body.page-training .css_mce h6 a:hover, body.page-training .css_mce h6 a:hover strong, body.page-training .css_mce p a:hover, body.page-training .css_mce p a:hover strong, body.page-training .css_mce ul a:hover, body.page-training .css_mce ul a:hover strong {
  color: var(--color-training-dark);
}

body.page-junior .css_mce h6, body.page-junior .css_mce h5, body.page-junior .css_mce h4, body.page-junior .css_mce h3, body.page-junior .css_mce .h3, body.page-junior .css_mce h2, body.page-junior .css_mce h1, body.page-junior .css_mce .h1 {
  color: var(--color-junior);
}
body.page-junior .css_mce .btn-cta {
  text-decoration: none !important;
  color: #ffffff !important;
}
body.page-junior .css_mce .btn-cta:after {
  background-color: var(--color-junior);
}
body.page-junior .css_mce .btn-cta:before {
  background-color: var(--color-junior-dark);
}
body.page-junior .css_mce .btn-cta.btn-bordered {
  border-color: var(--color-junior);
  color: var(--color-junior) !important;
}
body.page-junior .css_mce .btn-cta.btn-bordered:before {
  background: var(--color-junior);
}
body.page-junior .css_mce .btn-cta.btn-bordered:hover {
  color: #FFFFFF !important;
}
body.page-junior .css_mce h2, body.page-junior .css_mce .h2 {
  color: var(--color-junior);
}
body.page-junior .css_mce h2:before, body.page-junior .css_mce .h2:before {
  background: var(--color-junior);
}
body.page-junior .css_mce ol > li a,
body.page-junior .css_mce ul > li a {
  color: var(--color-junior);
}
body.page-junior .css_mce ol > li a:hover,
body.page-junior .css_mce ul > li a:hover {
  color: var(--color-junior-dark);
}
body.page-junior .css_mce h1 a, body.page-junior .css_mce h2 a, body.page-junior .css_mce h3 a, body.page-junior .css_mce h4 a, body.page-junior .css_mce h5 a, body.page-junior .css_mce h6 a, body.page-junior .css_mce p a, body.page-junior .css_mce ul a {
  color: var(--color-junior);
}
body.page-junior .css_mce h1 a:hover, body.page-junior .css_mce h1 a:hover strong, body.page-junior .css_mce h2 a:hover, body.page-junior .css_mce h2 a:hover strong, body.page-junior .css_mce h3 a:hover, body.page-junior .css_mce h3 a:hover strong, body.page-junior .css_mce h4 a:hover, body.page-junior .css_mce h4 a:hover strong, body.page-junior .css_mce h5 a:hover, body.page-junior .css_mce h5 a:hover strong, body.page-junior .css_mce h6 a:hover, body.page-junior .css_mce h6 a:hover strong, body.page-junior .css_mce p a:hover, body.page-junior .css_mce p a:hover strong, body.page-junior .css_mce ul a:hover, body.page-junior .css_mce ul a:hover strong {
  color: var(--color-junior-dark);
}

body.page-event .css_mce h6, body.page-event .css_mce h5, body.page-event .css_mce h4, body.page-event .css_mce h3, body.page-event .css_mce .h3, body.page-event .css_mce h2, body.page-event .css_mce h1, body.page-event .css_mce .h1 {
  color: var(--color-event);
}
body.page-event .css_mce .btn-cta:after {
  background-color: var(--color-event);
}
body.page-event .css_mce .btn-cta:before {
  background-color: var(--color-event-dark);
}
body.page-event .css_mce .btn-cta.btn-bordered {
  border-color: var(--color-event);
  color: var(--color-event);
}
body.page-event .css_mce .btn-cta.btn-bordered:before {
  background: var(--color-event);
}
body.page-event .css_mce .btn-cta.btn-bordered:hover {
  color: #FFFFFF;
}
body.page-event .css_mce h2, body.page-event .css_mce .h2 {
  color: var(--color-event);
}
body.page-event .css_mce h2:before, body.page-event .css_mce .h2:before {
  background: var(--color-event);
}
body.page-event .css_mce ol > li a,
body.page-event .css_mce ul > li a {
  color: var(--color-event);
}
body.page-event .css_mce ol > li a:hover,
body.page-event .css_mce ul > li a:hover {
  color: var(--color-event-dark);
}
body.page-event .css_mce h1 a, body.page-event .css_mce h2 a, body.page-event .css_mce h3 a, body.page-event .css_mce h4 a, body.page-event .css_mce h5 a, body.page-event .css_mce h6 a, body.page-event .css_mce p a, body.page-event .css_mce ul a {
  color: var(--color-event);
}
body.page-event .css_mce h1 a:hover, body.page-event .css_mce h1 a:hover strong, body.page-event .css_mce h2 a:hover, body.page-event .css_mce h2 a:hover strong, body.page-event .css_mce h3 a:hover, body.page-event .css_mce h3 a:hover strong, body.page-event .css_mce h4 a:hover, body.page-event .css_mce h4 a:hover strong, body.page-event .css_mce h5 a:hover, body.page-event .css_mce h5 a:hover strong, body.page-event .css_mce h6 a:hover, body.page-event .css_mce h6 a:hover strong, body.page-event .css_mce p a:hover, body.page-event .css_mce p a:hover strong, body.page-event .css_mce ul a:hover, body.page-event .css_mce ul a:hover strong {
  color: var(--color-event-dark);
}

.cta-primary,
.cta-secondary,
.cta-light,
.cta-tertiary {
  background: var(--real-theme-color-1) !important;
  border-color: var(--real-theme-color-1) !important;
  font-size: 1.4rem;
  font-family: var(--real-font-regular);
  padding: 1rem 2rem;
  display: inline-block;
  -webkit-transition: all 0.25s ease 0s;
  -o-transition: all 0.25s ease 0s;
  transition: all 0.25s ease 0s;
  text-decoration: none;
  color: #fff;
}
.cta-primary.active, .cta-primary:hover,
.cta-secondary.active,
.cta-secondary:hover,
.cta-light.active,
.cta-light:hover,
.cta-tertiary.active,
.cta-tertiary:hover {
  background: var(--color-primaire-dark) !important;
  border-color: var(--color-primaire-dark) !important;
  color: #fff;
  text-decoration: none;
}
.cta-primary:focus,
.cta-secondary:focus,
.cta-light:focus,
.cta-tertiary:focus {
  background-color: var(--color-primaire-dark) !important;
  box-shadow: none !important;
}
.cta-primary:active,
.cta-secondary:active,
.cta-light:active,
.cta-tertiary:active {
  box-shadow: none !important;
}
.cta-primary:active:focus,
.cta-secondary:active:focus,
.cta-light:active:focus,
.cta-tertiary:active:focus {
  box-shadow: none !important;
}

.cta-secondary {
  background: var(--real-theme-color-2) !important;
  border-color: var(--real-theme-color-2) !important;
}
.cta-secondary.active, .cta-secondary:focus, .cta-secondary:hover {
  background: var(--color-secondaire-dark) !important;
  border-color: var(--color-secondaire-dark) !important;
}

.cta-tertiary {
  background: var(--real-theme-color-3) !important;
  border-color: var(--real-theme-color-3) !important;
}
.cta-tertiary.active, .cta-tertiary:focus, .cta-tertiary:hover {
  background: var(--color-tertiaire-dark) !important;
  border-color: var(--color-tertiaire-dark) !important;
}

.cta-light {
  background: #fff !important;
  border: 1px solid #eee !important;
  color: var(--color-text) !important;
}
.cta-light.active, .cta-light:focus, .cta-light:hover {
  color: #fff !important;
  background: var(--real-theme-color-2) !important;
  border-color: var(--real-theme-color-2) !important;
}

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