/*
@font-face {
    font-family: "daily-spark-sans";
    src: url("http://mcc.local/wp-content/themes/idcomweb/fonts/daily-spark-sans.woff2") format("woff2");
}
*/
@media screen and (max-width: 991px) {
  header #menu-mobile {
    display: block;
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
    z-index: 100000;
  }
  header #menu-mobile .ouvrant {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  header #menu-mobile .ouvrant span {
    display: block;
    width: 25px;
    height: 3px;
    background-color: #3B3A3A;
    transition: all 0.3s ease;
  }
  header #menu-mobile .fermant {
    display: none;
  }
  header #menu-mobile .fermant svg {
    height: 35px;
    width: 35px;
    color: #3B3A3A;
  }
  header #menu-mobile.active .ouvrant {
    display: none;
  }
  header #menu-mobile.active .fermant {
    display: block;
  }
  header .menu-principal {
    position: fixed;
    top: -10px;
    left: -100%;
    width: 100%;
    height: 100vh;
    background-color: white;
    z-index: 99998;
    overflow-y: auto;
    transition: left 0.3s ease;
    padding: 70px 20px 30px 20px;
  }
  header .menu-principal.active {
    left: 0;
  }
  header .menu-principal nav ul.menu {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
  }
  header .menu-principal nav ul.menu > li {
    border: none;
    margin: 0;
    padding: 0;
    margin-bottom: 15px;
    list-style: none;
  }
  header .menu-principal nav ul.menu > li > a {
    display: block;
    padding: 15px 20px;
    border-bottom: 1px solid #E0E0E0;
    font-family: "Lato", sans-serif;
    font-size: 16px;
    font-weight: 500;
    color: #1a1a1a;
    text-transform: uppercase;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu {
    position: static;
    width: 100%;
    left: 0;
    transform: none;
    border: none;
    padding: 0;
    display: none;
    flex-direction: column;
    list-style: none;
    padding: 1rem 2rem;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu li {
    margin-bottom: 10px;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu li:last-child {
    margin-bottom: 0;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu li a {
    font-family: 'Inter', sans-serif;
    font-family: "Lato", sans-serif;
    font-size: 16px;
    font-weight: 500;
    color: #1a1a1a;
    text-transform: uppercase;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu.sub-menu-with-image {
    flex-direction: column;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-image-wrapper {
    width: 100%;
    max-width: 100%;
    padding: 20px;
    margin: 0;
    border: none;
    list-style: none;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-image-wrapper .menu-image img {
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: 8px;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-items-wrapper {
    width: 100%;
    max-width: 100%;
    padding: 0;
    border: none;
    list-style: none;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-items-wrapper .sub-menu-items {
    display: flex;
    flex-direction: column;
    padding: 0;
    border: none;
    position: static;
    list-style: none;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-items-wrapper .sub-menu-items li {
    border: none;
    border-bottom: 1px solid #E0E0E0;
    padding: 15px 20px;
    margin: 0;
    list-style: none;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-items-wrapper .sub-menu-items li:last-child {
    border-bottom: none;
  }
  header .menu-principal nav ul.menu > li ul.sub-menu .menu-items-wrapper .sub-menu-items li a {
    font-size: 14px;
    color: #3B3A3A;
    text-transform: uppercase;
  }
  header .menu-principal nav ul.menu > li.ouvert > ul.sub-menu {
    display: flex;
  }
}
@keyframes texte-defilant {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(-100%, 0);
  }
}
html {
  overflow-x: hidden;
}
body {
  color: #1a1a1a;
  background-color: #1a1a1a;
  overflow-x: hidden;
}
body .container {
  max-width: 1580px;
}
@media screen and (min-width: 1850px) {
  body .container {
    max-width: 1820px;
  }
}
@media screen and (max-width: 1850px) {
  body .container {
    max-width: 1500px;
  }
}
body a {
  transition: all 0.4s ease-in-out !important;
  -webkit-transition: all 0.4s ease-in-out !important;
  -moz-transition: all 0.4s ease-in-out !important;
  -o-transition: all 0.4s ease-in-out !important;
  text-decoration: none;
}
body a:hover,
body a:active,
body a:focus {
  outline: 0;
  text-decoration: none;
}
body div.bloc-texte ul {
  padding-left: 0;
}
body div.bloc-texte ul li:before {
  background-color: currentColor;
}
body header {
  display: none !important;
  background-color: white;
  position: fixed;
  width: 1512px;
  border-radius: 40px;
  height: 80px;
  top: 54px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}
@media screen and (max-width: 767.98px) {
  body header {
    height: 60px;
    transform: translateX(0%);
    top: 10px;
  }
}
@media screen and (min-width: 767.98px) and (max-width: 1850px) {
  body header {
    width: 1300px;
  }
}
body header .corps {
  width: 95%;
  margin: 0 auto;
}
body header .corps .logo img {
  width: 217px;
  height: auto;
  object-fit: contain;
}
@media screen and (max-width: 767.98px) {
  body header .corps .logo img {
    height: auto;
    width: 130px;
  }
}
body header .corps .menu-principal nav ul {
  display: flex;
  margin-bottom: 0;
}
body header .corps .menu-principal nav ul li {
  list-style: none;
  margin-right: 20px;
  border: 1px solid transparent;
  transition: all 0.4s ease-in-out !important;
  padding: 10px 20px;
}
@media screen and (min-width: 767.98px) and (max-width: 1850px) {
  body header .corps .menu-principal nav ul li {
    margin-right: 10px;
  }
}
body header .corps .menu-principal nav ul li:last-child {
  margin-right: 90px;
}
@media screen and (min-width: 767.98px) and (max-width: 1850px) {
  body header .corps .menu-principal nav ul li:last-child {
    margin-right: 30px;
  }
}
body header .corps .menu-principal nav ul li a {
  font-family: "Lato", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #1a1a1a;
}
@media screen and (max-width: 1850px) {
  body header .corps .menu-principal nav ul li a {
    font-size: 16px;
  }
}
body header .corps .menu-principal nav ul li a:hover {
  color: #4fa9b8;
}
body header .corps .menu-principal nav ul li ul {
  display: none;
  margin-bottom: 0;
  position: absolute;
  background-color: #4fa9b8;
  width: 245px;
  left: 0;
  top: 55px;
  border-radius: 22px;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 0;
  box-shadow: 0px 3px 6px #00000029;
}
body header .corps .menu-principal nav ul li ul li {
  padding-left: 30px;
  border: none !important;
  width: 245px;
  position: relative;
  padding: 15px 20px;
}
body header .corps .menu-principal nav ul li ul li:after {
  content: "";
  background-color: #1a1a1a;
  position: absolute;
  bottom: 0px;
  left: 50%;
  width: 80%;
  height: 1px;
  transform: translateX(-50%);
}
body header .corps .menu-principal nav ul li ul li:last-child {
  margin-right: 0;
}
body header .corps .menu-principal nav ul li ul li:last-child:after {
  display: none;
}
body header .corps .menu-principal nav ul li ul li:hover {
  border: none;
}
body header .corps .menu-principal nav ul li ul li a {
  color: #1a1a1a;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 600;
}
body header .corps .menu-principal nav ul li ul li a svg {
  margin-right: 6px;
}
@media screen and (max-width: 1550px) {
  body header .corps .menu-principal nav ul li ul li a {
    font-size: 16px;
  }
}
body header .corps .menu-principal nav ul li ul li a:hover {
  font-weight: bold;
  color: #1a1a1a;
}
body header .corps .menu-principal nav ul li ul:before {
  content: "";
  background-color: transparent;
  position: absolute;
  top: -20px;
  left: 0;
  height: 50px;
  width: 100%;
}
body header .corps .menu-principal nav ul li.menu-item-has-children {
  position: relative;
}
body header .corps .menu-principal nav ul li.menu-item-has-children:after {
  content: '';
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9.432' height='9.432' viewBox='0 0 9.432 9.432'%3E%3Cg id='Icon_feather-arrow-down-right' data-name='Icon feather-arrow-down-right' transform='translate(-9.793 -9.793)'%3E%3Cpath id='Tracé_96772' data-name='Tracé 96772' d='M10.5,10.5l8.017,8.017' fill='none' stroke='%23191919' stroke-linecap='round' stroke-linejoin='round' stroke-width='1'/%3E%3Cpath id='Tracé_96773' data-name='Tracé 96773' d='M18.517,10.5v8.017H10.5' fill='none' stroke='%23191919' stroke-linecap='round' stroke-linejoin='round' stroke-width='1'/%3E%3C/g%3E%3C/svg%3E%0A");
  background-repeat: no-repeat;
  background-size: 11px 11px;
  background-position: right center;
  padding-left: 25px;
}
body header .corps .bouton-header a {
  border-radius: 25px;
  padding: 8px 30px;
  background-color: #4fa9b8;
  color: white;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
}
body header .corps .bouton-header a:hover {
  background-color: #1b3b6f;
  color: white;
}
body header .corps .bouton-header a:hover svg g {
  stroke: white;
}
body header .corps .bouton-header a:hover svg g path {
  stroke: white;
}
body main {
  margin-top: 0 !important;
}
@media screen and (max-width: 768px) {
  body main .row-block {
    margin: auto;
  }
}
@media screen and (max-width: 768px) {
  body main .w-75 {
    width: 100% !important;
  }
}
@media screen and (max-width: 768px) {
  body main .w-25 {
    width: 100% !important;
  }
}
@media screen and (min-width: 768px) {
  body main .justify-items-end {
    justify-items: end;
  }
}
body main .justify-items-center {
  justify-items: center;
}
body main .titre-valeurs {
  margin-bottom: 46px;
}
@media screen and (min-width: 768px) {
  body main .px-md-180 {
    padding-left: 180px;
    padding-right: 180px;
  }
}
body main .container-bootstrap .container {
  max-width: 1300px;
}
body main .titre-before-form {
  margin-bottom: 10px;
}
body main .titre-before-form p {
  font-family: "Lato", sans-serif;
  font-size: 20px;
  line-height: 32px;
  font-weight: bold;
  letter-spacing: 0px;
  color: #FFFFFF;
  margin-bottom: 0;
}
body main .bloc-formulaire .nf-field {
  margin-bottom: 15px;
}
body main .bloc-formulaire .nf-field .nf-field-label label {
  text-align: left;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-field .nf-field-element input {
  width: 100%;
  background: #1a1a1a;
  border-radius: 4px;
  border: none;
  height: 44px;
  padding-left: 10px;
  color: white;
}
body main .bloc-formulaire .nf-field .nf-field-element select {
  width: 100%;
  background: #1a1a1a;
  border-radius: 4px;
  border: none;
  height: 44px;
  padding-left: 10px;
  color: white;
}
body main .bloc-formulaire .nf-field .nf-field-element textarea {
  width: 100%;
  background: #1a1a1a;
  border-radius: 4px;
  border: none;
  padding: 10px;
  min-height: 100px;
  color: white;
}
body main .bloc-formulaire .nf-field .nf-field-element .nf-fu-fileinput-button {
  background: transparent;
  border: 1px solid #FFFFFF;
  border-radius: 30px;
  padding: 14px 30px;
  font-size: 14px;
  font-family: "Lato", sans-serif;
  line-height: 20px;
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0px;
  color: white;
}
body main .bloc-formulaire .nf-field #nf-field-13-wrap .nf-field-label {
  display: none;
}
body main .bloc-formulaire .nf-field .file_upload-wrap {
  display: flex;
  gap: 20px;
}
body main .bloc-formulaire .nf-field .file_upload-wrap .nf-field-element {
  display: flex;
}
body main .bloc-formulaire .nf-field .file_upload-wrap .nf-field-element .files_uploaded p {
  font-family: "Lato", sans-serif;
  font-size: 14px;
  line-height: 24px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-field .html-wrap p {
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-field .checkbox-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-direction: row-reverse;
  justify-content: start;
}
body main .bloc-formulaire .nf-field .checkbox-wrap input {
  margin-top: 5px;
}
body main .bloc-formulaire .nf-field .checkbox-wrap label {
  text-align: left;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-field .checkbox-wrap label a {
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-field .submit-wrap .nf-field-element {
  text-align: center;
}
body main .bloc-formulaire .nf-field .submit-wrap .nf-field-element input {
  background: #4fa9b8;
  border-radius: 25px;
  width: fit-content;
  padding: 0px 25px;
  text-align: center;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
}
body main .bloc-formulaire .nf-error-msg {
  font-family: "Lato", sans-serif;
  font-size: 10px;
  color: red;
  margin-top: -10px;
}
body main .bloc-formulaire .nf-form-fields-required {
  text-align: left;
  font-family: "Lato", sans-serif;
  font-size: 16px;
  line-height: 28px;
  font-weight: 500;
  letter-spacing: 0px;
  color: #FFFFFF;
  margin-bottom: 30px;
}
body main .bloc-formulaire .nf-after-form-content {
  display: none;
}
body main .texte-descriptif .container {
  max-width: 1512px;
  padding-right: 300px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .texte-descriptif .container {
    max-width: 1200px;
    padding-right: 250px;
  }
}
@media screen and (max-width: 768px) {
  body main .texte-descriptif .container {
    padding-right: 20px;
  }
}
body main .texte-descriptif .container .bloc-texte .texte-court p,
body main .texte-descriptif .container .bloc-texte .texte-complet p {
  color: white;
}
body main .texte-descriptif .container .bloc-texte .texte-court p span,
body main .texte-descriptif .container .bloc-texte .texte-complet p span {
  color: white !important;
}
body main .texte-descriptif .container .bloc-texte button {
  color: white !important;
}
body main .lame-apercu-galerie .container {
  padding-left: 150px;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body main .lame-apercu-galerie .container {
    padding: 100px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-apercu-galerie .container {
    padding: 40px 30px 40px 30px;
    margin-bottom: 15px;
  }
}
body main .lame-apercu-galerie .container .bloc-titre {
  margin-bottom: 71px;
}
body main .lame-apercu-galerie .container .bloc-titre .titre {
  margin-bottom: 0;
}
body main .lame-valeurs .container {
  background-color: #1a1a1a;
  border-radius: 32px;
  padding: 100px 150px;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body main .lame-valeurs .container {
    padding: 100px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-valeurs .container {
    padding: 40px 20px;
    margin-bottom: 15px;
  }
}
body main .lame-valeurs .container .bloc-titre {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  body main .lame-valeurs .container .bloc-titre {
    margin-bottom: 30px;
  }
}
body main .lame-valeurs .container .bloc-titre .titre {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-valeurs .container .bloc-image {
    height: 100%;
  }
}
body main .lame-valeurs .container .bloc-image img {
  height: 732px;
  object-fit: cover;
  border-radius: 32px;
  width: 100%;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-valeurs .container .bloc-image img {
    height: 100%;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-valeurs .container .bloc-image img {
    height: auto;
  }
}
body main .lame-texte-image .colonne-texte {
  background-color: #d4af37;
  border-radius: 32px;
  padding: 100px 130px 50px 154px;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body main .lame-texte-image .colonne-texte {
    padding: 50px 100px 50px 100px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-texte-image .colonne-texte {
    padding: 20px 30px;
    margin-bottom: 15px;
  }
}
body main .lame-texte-image .colonne-image {
  position: relative;
}
@media screen and (max-width: 768px) {
  body main .lame-texte-image .colonne-image {
    padding: 0;
  }
}
body main .lame-texte-image .colonne-image:after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 168px;
  height: 190px;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg id='Groupe_162398' data-name='Groupe 162398' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='168.249' height='190.057' viewBox='0 0 168.249 190.057'%3E%3Cdefs%3E%3CclipPath id='clip-path'%3E%3Crect id='Rectangle_148042' data-name='Rectangle 148042' width='168.249' height='190.058' fill='%23191919'/%3E%3C/clipPath%3E%3C/defs%3E%3Cg id='Groupe_162397' data-name='Groupe 162397' transform='translate(0 0)' clip-path='url(%23clip-path)'%3E%3Cpath id='Tracé_30' data-name='Tracé 30' d='M137.366,124.275l-5.061,5.436a50.918,50.918,0,1,1-37.276-85.6,50.5,50.5,0,0,1,30.9,10.439L113.261,66.9A33.5,33.5,0,1,0,95.07,128.529V114.385a19.359,19.359,0,1,1,13.653-33.048l4.936,4.938L146.344,54.4l-5-5.064a65.086,65.086,0,1,0-4.042,95.151l11.059,11.356a80.112,80.112,0,0,1-53.337,20.067A80.885,80.885,0,1,1,157.5,43.7l10.216-9.9q-2.607-3.088-5.491-5.973a95.051,95.051,0,1,0-67.2,162.224A94.773,94.773,0,0,0,163.5,160.921l4.748-4.933Z' transform='translate(0 0.003)' fill='%23191919'/%3E%3C/g%3E%3C/svg%3E%0A");
}
@media screen and (max-width: 768px) {
  body main .lame-texte-image .colonne-image:after {
    width: 100px;
    height: 120px;
  }
}
body main .lame-texte-image .colonne-image .bloc-image {
  height: 100%;
}
body main .lame-texte-image .colonne-image .bloc-image img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  border-radius: 32px;
}
body main .lame-image-texte .colonne-texte {
  background-color: #4fa9b8;
  border-radius: 32px;
  padding: 108px 130px 50px 154px;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body main .lame-image-texte .colonne-texte {
    padding: 50px 100px 50px 100px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-image-texte .colonne-texte {
    padding: 20px 30px;
    margin-bottom: 15px;
  }
}
body main .lame-image-texte .colonne-image {
  position: relative;
}
@media screen and (max-width: 768px) {
  body main .lame-image-texte .colonne-image {
    padding: 0;
    margin-bottom: 10px;
  }
}
body main .lame-image-texte .colonne-image .bloc-image {
  height: 100%;
}
body main .lame-image-texte .colonne-image .bloc-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 32px;
}
body main .lame-card-offre .container {
  max-width: 1512px;
}
body main .lame-card-offre .bloc-titre {
  margin-bottom: 50px;
}
body main .lame-contact {
  padding: 70px 0;
}
body main .lame-tarifs .container {
  background-color: #1a1a1a;
  border-radius: 32px;
  padding: 100px 150px;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body main .lame-tarifs .container {
    padding: 100px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-tarifs .container {
    padding: 40px 20px;
    margin-bottom: 15px;
  }
}
body main .le-mot-du-fondateur .container {
  padding: 0 150px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .le-mot-du-fondateur .container {
    padding: 0px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .le-mot-du-fondateur .container {
    padding: 0px 20px;
  }
}
body main .le-mot-du-fondateur .container .bloc-texte p {
  color: white;
  text-align: center;
  font-family: "Lato", sans-serif;
  font-weight: 900;
  color: #d4af37;
  font-size: 35px;
  line-height: 50px;
}
@media screen and (max-width: 768px) {
  body main .le-mot-du-fondateur .container .bloc-texte p {
    font-size: 24px;
    line-height: 36px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .le-mot-du-fondateur .container .bloc-texte p {
    font-size: 25px;
  }
}
body main .le-mot-du-fondateur .container .align-content-center {
  position: relative;
}
body main .le-mot-du-fondateur .container .align-content-center:after {
  content: "";
  background-color: #95AAC7;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: 1px;
  height: 100%;
}
body main .le-mot-du-fondateur .container .bloc-titre {
  margin-bottom: 60px;
}
@media screen and (max-width: 768px) {
  body main .le-mot-du-fondateur .container .bloc-titre {
    margin-bottom: 20px;
  }
}
body main .le-mot-du-fondateur .container .bouton-container {
  text-align: center;
  justify-items: center;
}
@media screen and (max-width: 768px) {
  body main .le-mot-du-fondateur .container .bouton-container {
    margin-bottom: 20px;
  }
}
body main .long-section-texte .container {
  padding: 0 350px 0 150px;
}
@media screen and (max-width: 768px) {
  body main .long-section-texte .container {
    padding: 0 20px;
  }
}
body main .long-section-texte .bloc-titre {
  margin-bottom: 0;
}
body main .long-section-texte .bloc-titre h3 {
  font-size: 24px;
  line-height: 36px;
  font-family: "Playfair Display", serif;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  body main .long-section-texte .bloc-titre h3 {
    font-size: 20px;
    line-height: 30px;
  }
}
body main .long-section-texte .bloc-titre h2 {
  margin-bottom: 50px;
}
body main .long-section-texte .mt-50 {
  margin-top: 50px;
}
body main .long-section-texte .bloc-texte p {
  color: white;
}
body main .long-section-texte .bloc-texte ul {
  padding-left: 0rem;
}
body main .long-section-texte .bloc-texte ul li {
  color: white;
}
body main .lame-last-news .container {
  background-color: #d4af37;
  border-radius: 32px;
  padding: 100px 150px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-last-news .container {
    padding: 60px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-last-news .container {
    padding: 40px 20px;
    width: 96%;
  }
}
body main .lame-last-news .bloc-titre {
  margin-bottom: 60px;
}
body main .lame-chiffres .container {
  padding: 100px 50px 100px 150px;
  background-color: #4fa9b8;
  border-radius: 32px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-chiffres .container {
    padding: 60px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-chiffres .container {
    padding: 40px 20px;
    width: 96%;
  }
}
body main .lame-cta .container {
  background-color: #4fa9b8;
  border-radius: 32px;
  padding: 60px 280px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-cta .container {
    padding: 60px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-cta .container {
    padding: 40px 20px;
    width: 96%;
  }
}
body main .lame-cta .container .bloc-texte p {
  color: #1a1a1a;
}
body main .lame-cta .container .bloc-titre .titre {
  color: #1a1a1a;
}
body main .lame-cta .container .bouton-container {
  justify-items: end;
}
body main .lame-cta .container .bouton-container a {
  background-color: white;
  color: #4fa9b8;
}
body main .lame-cta .container .bouton-container a span {
  color: #4fa9b8;
}
body main .lame-cta .container .bouton-container a:hover {
  background-color: #1b3b6f;
  color: white;
}
body main .lame-cta .container .bouton-container a:hover span {
  color: white;
}
body main .lame-zone-intervention .container {
  padding: 100px 50px 50px 150px;
  background-color: #d4af37;
  border-radius: 32px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-zone-intervention .container {
    padding: 60px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-zone-intervention .container {
    padding: 40px 20px;
    width: 96%;
  }
}
body main .lame-zone-intervention .container .bloc-texte {
  margin-bottom: 30px;
}
body main .lame-zone-intervention .container .bloc-image img {
  height: 500px;
  object-fit: contain;
}
@media screen and (max-width: 768px) {
  body main .lame-zone-intervention .container .bloc-image img {
    height: auto;
  }
}
body main .lame-avis .container {
  padding: 0px 150px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-avis .container {
    padding: 60px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-avis .container {
    padding: 40px 20px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-avis {
    padding: 50px 0 40px 0;
  }
}
body main .lame-avis .bloc-titre {
  margin-bottom: 34px;
}
@media screen and (max-width: 768px) {
  body main .lame-avis .bloc-titre {
    margin-bottom: 0px;
  }
}
body main .lame-avis .bloc-texte {
  margin-bottom: 50px;
}
@media screen and (max-width: 768px) {
  body main .lame-avis .bloc-texte {
    margin-bottom: 0px;
  }
  body main .lame-avis .bloc-texte .ti-footer {
    margin-top: 30px !important;
  }
}
body main .lame-avis .bloc-texte .ti-widget .ti-rating {
  color: white;
}
body main .lame-avis .bloc-texte .ti-widget .ti-review-item .ti-inner {
  background-color: #1a1a1a !important;
}
body main .lame-avis .bloc-texte .ti-widget .ti-rating-text span {
  color: white;
}
body main .lame-avis .bloc-texte .ti-widget .ti-rating-text span strong {
  color: white;
}
body main .lame-certifications {
  padding: 120px 0 100px;
}
@media screen and (max-width: 768px) {
  body main .lame-certifications {
    padding: 60px 0;
  }
}
body main .lame-certifications .container {
  max-width: 1256px;
}
body main .lame-certifications .container .row {
  justify-content: center;
}
body main .lame-tabs .container {
  max-width: 1512px;
}
@media screen and (max-width: 768px) {
  body main .lame-tabs .container {
    padding: 0 20px;
  }
}
@media screen and (max-width: 1850px) {
  body main .lame-tabs .container {
    max-width: 1200px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-video-texte {
    margin-bottom: 0;
  }
}
body main .lame-timeline .container {
  background-color: #1a1a1a;
  border-radius: 32px;
  padding: 100px 150px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-timeline .container {
    padding: 100px 150px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-timeline .container {
    padding: 40px 20px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-video-offre {
    padding-top: 30px;
    padding-bottom: 50px;
  }
  body main .lame-video-offre .video {
    margin-right: 0 !important;
  }
}
body main .section-tableau .container {
  max-width: 1512px;
  background-color: #d4af37;
  border-radius: 32px;
  padding: 100px 125px;
}
body main .lame-faq {
  position: relative;
  margin-top: 0;
}
body main .lame-faq .container {
  position: relative;
  z-index: 1;
  max-width: 1820px;
  padding: 0 150px;
}
@media screen and (max-width: 768px) {
  body main .lame-faq .container {
    padding: 0 20px;
  }
}
body main .lame-faq .bloc-titre {
  padding-top: 0px;
}
@media screen and (max-width: 768px) {
  body main .lame-faq .bloc-titre {
    padding-top: 40px;
  }
}
body main .lame-faq .bloc-titre .titre {
  margin-bottom: 48px;
}
@media screen and (max-width: 768px) {
  body main .lame-faq .bloc-titre .titre {
    margin-bottom: 30px;
  }
}
body main .lame-faq .bloc-image {
  height: 100%;
}
body main .lame-faq .bloc-image img {
  height: 100%;
  object-fit: cover;
  border-radius: 32px;
}
body main .lame-equipe {
  padding: 60px 0;
}
@media screen and (min-width: 768px) {
  body main .lame-equipe {
    margin-bottom: 300px;
    margin-top: 115px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-equipe {
    padding: 40px 0;
  }
}
body main .lame-video-accueil .container {
  background-color: #1a1a1a;
  border-radius: 32px;
  padding: 100px 282px;
}
@media screen and (min-width: 768px) and (max-width: 1850px) {
  body main .lame-video-accueil .container {
    padding: 100px 200px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-video-accueil .container {
    padding: 40px 20px;
  }
}
body main .lame-video-accueil .container video {
  border-radius: 32px;
  height: 703px;
}
@media screen and (max-width: 1850px) and (min-width: 768px) {
  body main .lame-video-accueil .container video {
    height: 600px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-video-accueil .container video {
    height: 400px;
  }
}
@media screen and (max-width: 768px) {
  body main .lame-video-accueil .container .bloc-titre .titre {
    text-align: left;
  }
}
@media screen and (max-width: 768px) {
  body main .chiffres-container {
    margin-top: 30px;
  }
}
@media screen and (min-width: 768px) {
  body main .chiffres-container {
    position: relative;
    height: 300px;
  }
  body main .chiffres-container .chiffres {
    position: absolute;
    width: 100%;
    top: 100%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
body footer {
  display: none !important;
  background-color: #1a1a1a;
  position: relative;
}
@media screen and (min-width: 1850px) {
  body footer .container {
    max-width: 1256px;
  }
}
body footer .corps {
  width: 90%;
  margin: 0 auto;
  padding-top: 50px;
}
body footer .corps .logo {
  text-align: center;
}
body footer .corps .logo img {
  width: 666px;
  object-fit: contain;
}
@media screen and (max-width: 768px) {
  body footer .corps .logo img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  body footer .corps .menu-container-footer {
    column-count: 2;
    margin-bottom: 0rem;
  }
}
body footer .corps .titre-footer {
  font-family: "Playfair Display", serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: bold;
  letter-spacing: 0px;
  color: white;
  margin-bottom: 15px;
}
body footer .corps .coordonnees .adresse {
  margin-bottom: 15px;
}
body footer .corps .coordonnees .adresse a {
  font-family: "Lato", sans-serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: bold;
  color: white;
  letter-spacing: 0px;
}
body footer .corps .coordonnees .adresse a svg {
  margin-right: 6px;
}
body footer .corps .coordonnees .telephone {
  margin-bottom: 15px;
}
body footer .corps .coordonnees .telephone a {
  font-family: "Lato", sans-serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: bold;
  color: white;
  letter-spacing: 0px;
}
body footer .corps .coordonnees .telephone a svg {
  margin-right: 6px;
}
body footer .corps .coordonnees .email a {
  font-family: "Lato", sans-serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: bold;
  color: white;
  letter-spacing: 0px;
}
body footer .corps .coordonnees .email a svg {
  margin-right: 6px;
}
body footer .corps .reseaux-sociaux-footer {
  list-style: none;
  padding-left: 0;
  margin-bottom: 40px;
}
body footer .corps .reseaux-sociaux-footer li {
  margin-right: 18px;
}
body footer .corps .reseaux-sociaux {
  padding-left: 2rem;
  position: relative;
}
body footer .corps .reseaux-sociaux:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 1px;
  height: 100%;
  background-color: #3B3A3A;
  opacity: 0.3;
}
body footer .corps .reseaux-sociaux li {
  list-style: none;
  margin-bottom: .5rem;
}
body footer .corps .reseaux-sociaux li a {
  font-family: "Lato", sans-serif;
  color: #3B3A3A;
  font-size: 14px;
  font-weight: 500;
  text-decoration: underline;
}
body footer .corps .part-menu {
  position: relative;
}
@media screen and (max-width: 768px) {
  body footer .corps .part-menu {
    margin-left: 0;
  }
}
@media screen and (max-width: 768px) {
  body footer .corps .part-menu.column-footer-1 {
    padding-left: 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }
}
body footer .corps .part-menu.column-footer-2 {
  margin-left: 30px;
}
@media screen and (max-width: 768px) {
  body footer .corps .part-menu.column-footer-2 {
    margin-left: 0;
    padding-left: 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }
}
body footer .corps .part-menu li {
  list-style: none;
  margin-bottom: 20px;
}
body footer .corps .part-menu li a {
  font-family: "Lato", sans-serif;
  color: white;
  font-size: 18px;
  line-height: 26px;
  font-weight: bold;
  font-weight: 500;
}
body footer .corps .horaires ul {
  padding-left: 0rem;
  position: relative;
}
body footer .corps .horaires ul li {
  display: block;
  width: 100%;
  font-size: 18px;
  line-height: 30px;
  font-weight: 500;
  font-family: "Lato", sans-serif;
  letter-spacing: 0px;
  color: white;
}
@media screen and (min-width: 768px) and (max-width: 1550px) {
  body footer .corps .horaires ul li {
    gap: 0 80px;
  }
}
body footer .corps .horaires ul li .jour {
  width: 50px;
}
body footer .pied {
  font-size: 0.875rem;
  line-height: 1.188rem;
}
body footer .pied .container {
  margin-top: 20px;
  max-width: 1256px;
}
body footer .pied .container .row {
  text-align: center;
}
body footer .pied > .container {
  padding-top: 21px;
  padding-bottom: 21px;
  padding-left: 0;
  padding-right: 0;
  border-top: 1px solid #707070;
}
body footer .pied .pied-part-1 {
  display: flex;
  justify-content: space-between;
}
body footer .pied a {
  margin-right: 20px;
  text-align: left;
  font-size: 14px;
  line-height: 28px;
  font-family: "Lato", sans-serif;
  font-weight: 600;
  letter-spacing: 0px;
  color: white;
}
body footer .pied a:hover {
  color: #1b3b6f;
}
body footer .pied .desc {
  text-align: left;
  font-size: 14px;
  line-height: 28px;
  font-family: "Lato", sans-serif;
  font-weight: 600;
  letter-spacing: 0px;
  color: white;
}
body footer .pied .desc a {
  margin-right: 0;
  text-align: left;
  font-size: 14px;
  line-height: 28px;
  font-family: "Lato", sans-serif;
  font-weight: 600;
  letter-spacing: 0px;
  color: white;
}
body footer .pied .logo-idcom {
  display: inline-block;
  vertical-align: middle;
  margin-left: 10px;
}
body footer .pied .logo-idcom svg {
  width: 81px;
  margin-top: -10px;
}
body footer .pied .logo-idcom svg .st1 {
  fill: white;
}
@media screen and (max-width: 1199px) {
  body header .corps.menu-7 .champ-recherches .asl_w_container #ajaxsearchlite1 {
    width: 500px;
  }
  body footer .corps {
    padding: 30px 0;
  }
  body footer .corps .logo-footer {
    margin-bottom: 15px;
  }
  body footer .corps .part-identite .description {
    font-size: 0.875rem;
    line-height: 1.25rem;
    margin-bottom: 15px;
  }
  body footer .corps .part-identite .reseaux-sociaux .reseau {
    margin-right: 20px;
  }
  body footer .corps .part-identite .reseaux-sociaux .reseau a .icone {
    width: 24px;
    height: 24px;
  }
  body footer .corps .part-menu ul.menu li a {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  body footer .corps .part-annexes .zone-annexes .infos-contact {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  body footer .pied {
    font-size: 0.75rem;
    line-height: 1rem;
  }
  body footer .pied .logo-idcom svg {
    width: 70px;
  }
  body footer .pied.separateur-container > .container {
    padding-bottom: 15px;
  }
  body footer .pied.separateur-container > .container:before {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 991px) {
  body .container {
    padding: 0 30px;
  }
  body header .corps .menu-principal nav ul li {
    margin-right: 1.25rem;
  }
  body header .corps .bouton-mise-en-avant {
    padding-bottom: 22px;
  }
  body header .corps .bouton-mise-en-avant a {
    padding: 4px 15px;
  }
  body header .corps.menu-7 .champ-recherches .asl_w_container #ajaxsearchlite1 {
    width: 350px;
  }
}
@media screen and (max-width: 767.98px) {
  body .container {
    padding: 0 20px;
  }
  body header {
    position: fixed;
    left: 0;
    width: 100%;
    z-index: 100;
  }
  body header .entete {
    height: 20px;
  }
  body header .entete .accroche {
    white-space: nowrap;
    overflow: hidden;
  }
  body header .entete .accroche span {
    display: inline-block;
    padding-left: 100%;
    animation: texte-defilant 10s linear infinite;
  }
  body header .corps {
    height: 60px;
    position: relative;
    border-bottom: 1px solid var(--couleur);
  }
  body header .corps .logo a img {
    height: 50px;
  }
  body header .corps .menu-principal nav {
    position: fixed;
    top: 60px;
    left: 0;
    width: 350px;
    height: 100%;
    box-shadow: 10px 0px 10px 0px rgba(136, 136, 136, 0.1);
    -webkit-box-shadow: 10px 0px 10px 0px rgba(136, 136, 136, 0.1);
    -moz-box-shadow: 10px 0px 10px 0px rgba(136, 136, 136, 0.1);
    text-align: left;
    left: -800px;
    overflow-y: scroll;
    padding-bottom: 120px;
    background-color: var(--couleur-fond);
    width: 100%;
    box-shadow: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
  }
  body header .corps .menu-principal nav.header-avec-entete {
    top: 80px;
  }
  body header .corps .menu-principal nav ul.menu {
    padding-top: 30px;
  }
  body header .corps .menu-principal nav ul.menu li.menu-item-has-children > a:after {
    transition: all 0.4s ease-in-out !important;
    -webkit-transition: all 0.4s ease-in-out !important;
    -moz-transition: all 0.4s ease-in-out !important;
    -o-transition: all 0.4s ease-in-out !important;
  }
  body header .corps .menu-principal nav ul.menu li.menu-item-has-children > a:hover:after {
    transform: rotate(180deg);
  }
  body header .corps .menu-principal nav ul.menu > li {
    display: block;
    margin-left: 0;
    padding-bottom: 0;
    margin-bottom: 30px;
    margin-right: 0;
  }
  body header .corps .menu-principal nav ul.menu > li > a {
    display: block;
    padding: 0 15px;
  }
  body header .corps .menu-principal nav ul.menu > li ul.sub-menu {
    position: static;
    margin: 0px;
    width: 100%;
    transform: none;
    box-shadow: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    text-align: left;
    padding: 15px 30px;
  }
  body header .corps .menu-principal nav ul.menu > li ul.sub-menu > li > a {
    font-size: 14px;
    line-height: 18px;
  }
  body header #menu-mobile div {
    display: inline-block;
    vertical-align: middle;
    width: 15px;
    margin-left: 12px;
  }
  body header #menu-mobile div span {
    display: block;
    margin-bottom: 2px;
    height: 2px;
    background-color: var(--couleur-texte);
  }
  body header #menu-mobile div.fermant {
    display: none;
    vertical-align: top;
  }
  body header #menu-mobile.active {
    background-color: var(--couleur-fond-actif) !important;
  }
  body header #menu-mobile.active div.ouvrant {
    display: none;
  }
  body header #menu-mobile.active div.fermant {
    display: inline-block;
  }
  body header .bouton-recherche-etude {
    vertical-align: middle;
    margin-bottom: 0;
    margin-left: 30px;
  }
  body footer .corps {
    padding: 30px 0 0;
  }
  body footer .corps .part-annexes {
    text-align: left;
  }
  body footer .corps .part-annexes:before {
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    background-color: var(--couleur-separateur);
    opacity: .1;
    margin: 0 0 15px;
  }
  body footer .corps .part-annexes .zone-annexes .infos-contact {
    text-align: left;
  }
  body footer .corps .part-identite:after {
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    background-color: var(--couleur-separateur);
    opacity: .1;
    margin: 15px 0;
  }
  body footer .corps .part-identite .infos-contact {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  body footer .corps .part-menu {
    padding-bottom: 10px;
    padding-left: 0;
  }
  body footer .corps .infos-contact .bloc-contact {
    margin-bottom: 15px;
  }
  body footer .pied .pied-part-1 {
    margin-bottom: 5px;
  }
  body footer .pied .pied-part-1 .separateur {
    font-size: 0.875rem;
    margin-right: 0;
  }
  body footer .pied .pied-part-2 {
    text-align: left;
  }
  body footer .pied .logo-idcom svg {
    width: 50px;
  }
}
body#maintenance .page-content {
  background-image: url('/wp-content/themes/idcomweb/img/site-constrcution-img.jpeg');
  background-attachment: fixed;
  background-size: cover;
  background-position: center center;
}
body#maintenance .page-content > .bloc-image {
  display: flex;
  justify-content: center;
  align-items: center;
}
body#maintenance .page-content > .bloc-image img {
  width: 250px;
  border-radius: 5px;
}
body#maintenance .page-content .formulaire > .container {
  background: #fff;
  padding: 20px;
  border-radius: 10px;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
}
body#maintenance .page-content .formulaire .contenus-txt .bloc-image img {
  border-radius: 5px;
}
body#maintenance .nf-error-msg.nf-error-field-errors {
  text-align: center;
}
