/*--------- [THEME WAKA PAR AGENCE WAKA Copyright 2020-2025 https://agence-waka.fr/] ---------*/
@font-face {    font-family: 'Futura PT';    src: url('../fonts/FuturaPT-Light.eot');    src: url('../fonts/FuturaPT-Light.eot?#iefix') format('embedded-opentype'),    url('../fonts/FuturaPT-Light.woff2') format('woff2'),    url('../fonts/FuturaPT-Light.woff') format('woff');    font-weight: 300;    font-style: normal;}
@font-face {    font-family: 'Futura PT';    src: url('../fonts/FuturaPT-Book.eot');    src: url('../fonts/FuturaPT-Book.eot?#iefix') format('embedded-opentype'),    url('../fonts/FuturaPT-Book.woff2') format('woff2'),    url('../fonts/FuturaPT-Book.woff') format('woff');    font-weight: 400;    font-style: normal;}
@font-face {    font-family: 'Futura PT';    src:    url('../fonts/FuturaPT-Medium.woff2') format('woff2'),    url('../fonts/FuturaPT-Medium.woff') format('woff');    font-weight: 500;    font-style: normal;}

:root {
    --couleur_01 : #343434;
    --wysiwyg-margin-elts: 2.5rem;
    --margin-gouttiere:10px;
    --margin-gouttiere-neg:-10px
}

/*--------- [ STYLAGE DE BASE : boutons, wysiwyg, blocs, modules... ] ---------*/
.hide_scrollbar {    -ms-overflow-style: none;    scrollbar-width: none; }
.hide_scrollbar::-webkit-scrollbar {     display: none;   }
.paddSection {  padding: 100px 0;}

.tablist { display: flex; justify-content: center; margin-bottom: 55px; flex-wrap: wrap}
.tablist button { margin:5px 30px; background: none; position: relative; transition:all 0.3s ease; font-size: 2.2rem}
.tablist button .rond { transition:all 0.3s ease; opacity: 0; visibility: hidden; content:""; width: 10px; height: 10px; border-radius: 10px; background: #A35B43; position: absolute; left:50%; bottom:-19px; margin-left: -5px;}
.tablist button.actif { text-shadow: 0.5px 0 0 var(--couleur_01); }
.tablist button.actif .rond { opacity: 1; visibility: visible}
#panel-tab-0, #panel-tab-av0  { display: block}
.tab-content { display: none; position: relative}
@media all and (max-width:1400px) {
    .tablist button { margin: 3px 12px;  letter-spacing: -0.3px}
    .tablist button.actif  { color:#A35B43  !important;}
    .tablist { margin-bottom: 35px}
}

@media all and (max-width:1023px) {
    .tablist button:after {        display: none    }
}
@media all and (max-width:767px) {
    .tablist { margin-left: -15px; margin-right: -15px}
    .tablist button { font-size: 2.3rem; letter-spacing: -1px}
    .paddSection { padding: 70px 0}
}

.logo_main {  position: absolute; top:0; left:0; z-index: 100; background: url(../images/trace-logo.svg) no-repeat; width: 610px; background-size: 100% auto; height: 100%; padding: 5rem 0 0 6rem }
.logo_main.int {  width: 400px; padding: 3rem 0 0 4rem;}
.logo_main.int  img { width: 144px }
.h-banner { background-repeat: no-repeat; background-size: cover; background-position: center; color:#fff; overflow: hidden; position: sticky;   top: 0;  z-index: 0 }
.h-banner  video {    position: absolute;    top: 0;    left: 0;  right: 0;    bottom:0;    object-fit: cover;    z-index: -1; height: 100vh}
.h-banner.int:before { content:""; position: absolute; top:0; left:0; right: 0; bottom:0; background: rgba(0, 0,0,0.45);}
.h-banner .c_center {  position: relative; z-index: 10; height: 100vh; display: flex; align-items: center; margin: 0 auto; max-width: 800px;  padding: 30px;}
.h-banner .content { max-width: 600px}
.h-banner .wysiwyg p { font-size: 2.4rem}
.h-banner .wysiwyg a { margin-top: 1.5rem}
.h-banner.int .c_center { height: 550px}
.h-banner.int h1 { margin-bottom: 0}
.h-citation { font-weight: 400; position: relative;   font-family: 'Larken', sans-serif; background-color:#fff;   font-size: 4rem; line-height: 5rem; padding: 0 30px; text-align: center; height: 480px; display: flex; align-items: center; justify-content: center; background-position: center; background-repeat: no-repeat}
@media all and (max-width:1600px) {
    .logo_main  { width: 260px !important;; padding:18px 0 0 25px !important;}
    .logo_main  img { width: 90px!important;}
}

@media all and (max-width:1200px) {
    .h-citation { font-size: 3rem; line-height: 4.3rem; height: 400px; background-size: auto 90% }
}
@media all and (max-width:990px) {
    .logo_main { display: none}
    .h-banner .c_center, .h-banner.int .c_center { height: auto; padding: 100px  30px }
}

@media all and (max-width:767px) {
    .h-banner h1 br { display: none}
    .h-citation {  height: 330px;  }
    .h-citation br { display: none }
}

.h-lieux { position: relative; background: #fff   }
.h-lieux:before { content:""; background: #EAE4DC; position: absolute; left:0; right: 0; top:0; height: 700px;  }
.h-lieux .content {  position: absolute; bottom: -75px; right: -50px; opacity: 0;  width: 470px; color:#fff; height: 700px; padding: 100px 60px 0 130px; z-index: 4;  transition: all 0.6s ease;}
.h-lieux .logo {  background: #EAE4DC; display: flex; align-items: center; justify-content: center; position: absolute; right: 390px; bottom:75px; width: 250px; height: 370px; z-index: 5 }
.h-lieux .visuel { line-height: 0; max-width: 1100px; height: 700px; background-size: cover; background-position: center; position: relative;  }
.h-lieux .content .bouton { padding-top: 4rem;}
.h-lieux .tab-content.anim .content { right:0; opacity: 1 }
.h-lieux h3 em { font-style: normal; font-size: 2rem}
.h-lieux.equipe .content { padding-left: 70px; padding-right: 70px}
.h-lieux.equipe .content .wysiwyg a { color:#fff; }

.espace { padding: 50px 0; position: relative; background: #fff  }
.un_espace { padding: 50px 0; overflow: hidden}
.un_espace .container  { position: relative;  }
.un_espace .bg { position: absolute; top:0; left:130px; right: 30px; bottom:45px; }
.un_espace .deco { position: absolute; right: 95%; top:-120px; text-align: right; left:-100vh; z-index: -1}
.un_espace h3 em { font-style: normal; font-size: 2rem}
.un_espace .slogan {  text-align: center; font-size: 4rem; line-height: 4.2rem; padding-bottom: 1.5rem; padding-left: 20px; padding-right: 20px }
.un_espace  .wysiwyg {  width: 460px; margin: 0 auto; max-width: 100%}
.un_espace .content { padding: 100px 30px ; color:#fff;}
.un_espace .content .bouton { padding-top: 2rem;}
.un_espace .content .bouton a { min-width: 220px}
.un_espace .logo {  background: #EAE4DC; display: flex; align-items: center; justify-content: center; position: absolute; right: 50%; margin-right: -40px; bottom:0; width: 200px; height: 296px; z-index: 5 }
.un_espace .logo img { max-width: 100px}
.un_espace .visuel {  height: 600px; position: absolute; left:0; right: 50%; bottom:0; background-size: cover; background-position: center; }
.espace .un_espace:nth-child(even) .bg { right: 100px; left:30px;}
.espace .un_espace:nth-child(even) .deco { right:-100vh; left:80%; text-align: left }
.espace .un_espace:nth-child(even) .row .col-50:nth-child(1) { order: 2}
.espace .un_espace:nth-child(even) .row .col-50:nth-child(2) { order: 1}
.espace .un_espace:nth-child(even) .visuel { left:50%; right: 0}
.espace .un_espace:nth-child(even) .logo { left:50%; right: 0;  margin-right: 0; margin-left: -40px;}
@media all and (max-width:1320px) {
    .un_espace .logo { margin-right: 0}
    .espace .un_espace:nth-child(even) .logo { margin-left: 0}
}
@media all and (max-width:1180px) {
    .h-lieux { padding-bottom: 0}
    .h-lieux .logo, .un_espace .logo {  display: none }
    .h-lieux .visuel, .un_espace .visuel { height: 480px;}
    .h-lieux .content,  .un_espace .content { height: auto; position: inherit; width: auto; padding: 40px; bottom: inherit;  margin:-70px 30px 0}
    .h-lieux .wysiwyg p { margin-bottom: 1.2rem}
    .h-lieux .bouton { padding-top: 2.5rem !important;}
    .un_espace .visuel { position: inherit; left:inherit; right: inherit; bottom: inherit}
    .un_espace .row { display: block}
    .un_espace .row .col-50 { max-width: 100%; padding: 0; margin: 0 !important;}
    .un_espace .bg { display: none}
    .un_espace .wysiwyg { width: 100%}
    .un_espace .slogan { padding-bottom: 0}
    .un_espace .deco { display: none}
}
@media all and (max-width:650px) {
    .h-lieux .content, .un_espace .content { margin: 0; right: 0}
    .h-lieux .visuel, .un_espace .visuel { height: 250px}
}

.h-instagram { position: relative;  background: #fff}

.h-team { background: #5E5940;  color:#fff; position: relative;  }
.team-list { display: flex; margin: 0 -12.5px; padding: 15px 0 0; flex-wrap: wrap}
.team-list > div { padding: 0 12.5px; text-align: center; flex: 0 0 20%; min-width: 1px  }
.team-list a, .team-list a:hover {color:#fff;}
.team-list a:hover .nom { text-decoration: underline}
.team-list .nom { font-size: 2.5rem; white-space: nowrap; text-overflow: ellipsis; overflow: hidden}
.team-list .job { font-size: 2.2rem; font-weight: 300; white-space: nowrap; text-overflow: ellipsis; overflow: hidden}
.team-list .visuel { margin: 20px 0 0; position: relative; text-align: center}
.team-list .contact {  background: #CBBEA9; position: absolute; top:0; left:0; right: 0; bottom:0; display: flex; align-items: center; padding:15px;}
.team-list .contact .txt {   font-family: Larken; font-size:3.6rem; line-height: 4.1rem; color:#443A36;}
.team-list .contact .picto { padding: 25px 0  }
.team-list .contact .btn-primary { width: 80%; justify-content: center}
@media all and (max-width:1300px) {
    .team-list .contact .txt { font-size: 3rem; line-height: 3.5rem}
    .team-list .contact .picto { padding: 15px 0}
}
@media all and (max-width:1100px) {
    .team-list { flex-wrap: nowrap; overflow: auto; padding-bottom: 10px}
    .team-list > div { flex:0 0 250px}
}


.h-chiffres { height: 640px; background-repeat: no-repeat;  background-position: center; background-size: auto 90%; padding: 100px 0; position: relative; background-color: #fff  }
.list_chiffres { display: flex; flex-wrap: wrap; justify-content: space-between; text-align: center; padding-top: 50px}
.list_chiffres > div { padding: 15px 10px}
.list_chiffres .anim {  font-family: Larken; font-size: 10rem; line-height: 0.9}
.list_chiffres .txt { font-size: 2rem; line-height: 2.4rem}
@media all and (max-width:1200px) {
    .h-chiffres { height: auto}
    .list_chiffres { justify-content: center; margin: 0 -20px}
    .list_chiffres > div { padding: 15px 20px;}
    .list_chiffres .anim { font-size: 7rem;}
}

@media all and (max-width:767px) {
    .list_chiffres { padding-top: 0}
    .list_chiffres .anim { font-size: 5rem;}
}

.h-avantages {  background: #EAE4DC; position: relative;  }
.page-template-page-avantages .h-avantages {  background: #fff}
.h-avantages h2 { margin-bottom: 0}
.h-avantages .subhead { padding-bottom: 5rem}
.h-avantages .flex { display: flex; align-items: center;}
.h-avantages .flex .visuel {  flex:0 0 56.3%  }
.h-avantages .flex .visuel img { border:3px solid #fff;}
.h-avantages .flex .content { padding-left: 120px}
.h-avantages .content .bouton { padding-top: 4rem;}


@media all and (max-width:1200px) {
    .h-avantages .flex .content { padding-left: 60px}
}


@media all and (max-width:1023px) {
    .h-avantages .flex { display: block}
    .h-avantages .flex .content { padding: 30px 0 0}
}

.h-events { overflow: hidden; position: relative; background: #fff  }
.h-events h2 { margin-bottom: 0}
.h-events .swiper { margin: 50px 0 0; overflow: inherit}
.h-events .swiper-slide { width: 450px; height: auto}
.h-events .event {  height: 100%; border: 1px solid #707070; display: block}
.h-events .visuel { height: 250px; background-size: cover; background-position: center }
.h-events .content { padding: 40px 30px}
.h-events h3 { margin-bottom: 0}
.h-events .excerpt { font-weight: 300; margin-top: 2rem}
.h-events .date { min-height: 24px }
.h-events .bouton { padding-top: 3rem;}
.h-events .bouton a { width: 220px}
.h-events .swiper-scrollbar { max-width: 770px; margin:30px auto 0; position: inherit !important;}
.h-events .swiper-scrollbar-drag { background: var(--couleur_01) !important;}
.h-events .all { text-align: center; padding-top: 50px}
@media all and (max-width:550px) {
    .h-events .swiper { margin-top: 30px}
    .h-events .swiper-slide { width: 330px  }
    .h-events .visuel { height: 170px}
}

.banniere_avantages { background-position: center; background-repeat: no-repeat; background-color:#eae4dc; margin-bottom: -3rem; position: relative}
.banniere_avantages .flex { padding: 30px 0; min-height: 350px;  display: flex; align-items: center; justify-content: center }
.banniere_avantages .wysiwyg { width: 100%;}
.banniere_avantages .wysiwyg h2 { margin-bottom: 2rem}
.banniere_avantages .wysiwyg strong { font-weight: 500}

@media all and (max-width:767px) {
    .banniere_avantages .wysiwyg h2 br { display: none}
}

.p_contact { padding: 100px 0; background: #fff; position: relative}
.p_contact h2 { margin-bottom: 0}
.form_contact { width: 1070px; max-width:100%;  margin: 0 auto; padding: 7rem 0 3rem  }
.form_contact .flex {  display: flex; align-items: center; margin: 0 -3rem }
.form_contact  .flex> div { flex:0 0 50%; padding: 0 3rem}
.form_contact img { max-width: 100%  }
.form_contact label { padding-bottom: 5px;display: block; }
.form_contact textarea { height: 120px}
.form_contact .bouton { text-align: right; padding-top: 1rem}
.c_social { display: flex; justify-content: center; align-items: center}
.c_social > div { padding: 5px 20px;}
.c_social > div img { height: 50px}

@media all and (max-width:767px) {
    .form_contact { padding: 3rem 0}
    .form_contact .flex { display: block}
    .form_contact .flex > div:nth-child(1) { text-align: center}
    .form_contact .flex > div:nth-child(1) img { max-width: 200px;}
    .form_contact .bouton { text-align: center}
    .c_social > div img { height: 40px;}
    .c_social > div { padding: 5px 15px}
    .p_contact { padding: 40px 0 30px}
}










    /*--------- [ STYLAGE DE BASE ] ---------*/

/* Texte + Wysiwyg */
a {  color:var(--couleur_01);}
a:hover { color:var(--couleur_01); }
h1, h2, h3, h4, h5  { font-weight: 300;  font-family: 'Larken', sans-serif;  }
h1 {     font-size: 4rem;    line-height: 5rem; margin-bottom:2rem;  }
h2 { font-size:5rem; line-height:5.5rem; margin-bottom:5.5rem; text-align: center; font-weight: 400}
h3 { font-size: 3.1rem; line-height:3.5rem; margin-bottom:2.2rem;}
h4 { font-size:1.7rem; line-height:2.2rem; margin-bottom:1rem; }
h5 { font-size:1.5rem; line-height:1.5rem; margin-bottom:0.8rem; }
.subhead { text-align: center; font-size: 2.5rem; font-weight: 300}
.wysiwyg { overflow-wrap: break-word; font-weight: 300 }
.wysiwyg ul li { list-style: disc}
.wysiwyg ol li {list-style-type:decimal}
.wysiwyg hr {   clear: both;}
.wysiwyg strong { font-weight: 400}
.wysiwyg img { display: block; max-width: 100%; height: auto}
.wysiwyg figcaption { padding-top:0.5rem; font-style: italic}
.wysiwyg blockquote{ font-style: italic  }
.aligncenter, div.aligncenter, a img.aligncenter{    display: block;    margin-left:auto; margin-right: auto}
.alignright, a img.alignright, .wp-caption.alignright   {    float:right;    }
.alignleft, a img.alignleft, .wp-caption.alignleft {    float: left;    }
.wysiwyg p, .wysiwyg ul, .wysiwyg ol   {  margin-bottom:var(--wysiwyg-margin-elts);}
.wysiwyg p:last-child { margin-bottom: 0}
.wysiwyg ul, .wysiwyg ol  {  margin-left:var(--wysiwyg-margin-elts);}
.wysiwyg a { font-size: 1.8rem }


.alignright, a img.alignright, .wp-caption.alignright { margin-left:calc(var(--wysiwyg-margin-elts) + 0.5rem);}
.alignleft, a img.alignleft, .wp-caption.alignleft {    margin-right:calc(var(--wysiwyg-margin-elts) + 0.5rem);}
img { max-width: 100%; height: auto;}
.txt_center { text-align: center}

@media all and (max-width:1200px) {
    h1 { font-size:3.5rem; line-height:4.5rem; }
    h2 { font-size:4.2rem; line-height:4.5rem; margin-bottom:4.5rem; }
    h3 { font-size: 2.6rem; line-height: 3rem; margin-bottom: 1.8rem }
}
@media all and (max-width:767px) {
    h2 { font-size: 3.6rem; line-height: 4.3rem}
    .subhead br { display: none}
}






/* Boutons */
[class^="btn-"], [class*="wpcf7-btn-"] button {background: transparent; border-top:2px solid #443A36; justify-content: center; position: relative; border-bottom:2px solid #443A36; font-weight: 500; text-decoration: none !important; padding:0 2.5rem; height: 45px; line-height: 1.9rem; display:inline-flex; align-items: center; max-width: 100%; text-align: center; transition: all  0.3s ease;  }
[class^="btn-"]:before, [class^="btn-"]:after { content:""; width: 2px; background:#443A36; height: 50%; position: absolute; transition: all 0.3s ease;}
[class^="btn-"]:before { left:0; ; top:0;}
[class^="btn-"]:after { right:0;  bottom:0;}
[class^="btn-"]:hover:before, [class^="btn-"]:hover:after, .h-events .event:hover [class^="btn-"]:before, .h-events .event:hover [class^="btn-"]:after { height: 100%  }
[class^="btn-"].white {  border-color:#fff; color:#fff}
[class^="btn-"].white:before, [class^="btn-"].white:after { background: #fff}
[class^="btn-"] img { margin-right: 10px}
@media all and (max-width:1200px) {
    [class^="btn-"] { font-size: 1.6rem;}
    [class^="btn-"] img { display: none}
}





/* Carousel */
.owl-carousel .owl-item { padding: 0 !important;}
.owl-carousel .owl-dots .owl-dot { margin: 0 3px}
.owl-carousel .owl-dots .owl-dot span { display: block; border: 1px solid blue !important;  width: 15px; height: 15px; border-radius: 15px; position: relative; background: transparent; transition: all 0.3s ease; }
.owl-carousel .owl-dots .owl-dot span:before { content:""; width: 12px; height: 12px;   position: absolute; top:1px; left:1px; border-radius: 12px; background: transparent; transition: all 0.3s ease;}
.owl-carousel .owl-dots .owl-dot.active span, .owl-dots .owl-dot:hover span { background:blue; }
.owl-carousel .owl-dots .owl-dot.active span:before, .owl-dots .owl-dot:hover span:before {  background:blue;}
.owl-carousel .owl-nav button  { position:absolute; top:0;   text-decoration: none;   }
.owl-carousel .owl-nav button span { line-height: 0; display: block }
.owl-carousel .owl-nav button:hover {            }
.owl-carousel .owl-prev { left:-1.5rem;  }
.owl-carousel .owl-next { right:-1.5rem; }

/* Formulaires */
label, input[type=submit], button { cursor:pointer; -webkit-appearance:none; }
input:not([type="hidden"]):not([type="checkbox"]):not([type="radio"]):not([type="submit"]), textarea, select  { vertical-align:middle;  background:#F4F4F4;  width: 100%; padding:1.5rem 1.8rem; margin-bottom: 1.5rem; }
input[type="file"] { border:0 !important;}
textarea {  resize:none;}
input[type="checkbox"], input[type="radio"] { margin-right: 0.6rem; position: relative; top:2px;}
input[type="file"] { border:0 !important;}
textarea {  resize:none;}
::placeholder { color:#928f8f; transition: all 0.3s ease;}
:focus::placeholder {  opacity:0.2; }
.wpcf7 form .wpcf7-response-output { margin-top: 0}
/* Custom Radio / Checkbox */
.custom_radio_checkbox {  display: inline-block; vertical-align: top; margin-right: 3rem }
.custom_radio_checkbox input{    display: none}
.custom_radio_checkbox label {  display: flex; align-items: center; position: relative}
.custom_radio_checkbox label:before {  width:20px; height: 20px; border: 1px solid #ccc; background: #fff;  content: ''; margin-right:0.5rem    }
.custom_radio_checkbox [type="radio"] + label:before{  border-radius: 100%    }
.custom_radio_checkbox [type="radio"]:checked + label:after, .custom_radio_checkbox [type="radio"]:not(:checked) + label:after {   content:"";    width: 12px;    height: 12px;    background:#000;    position: absolute;    top: 5px;    left: 5px;    border-radius: 100%;     transition: all 0.2s ease;}
.custom_radio_checkbox [type="checkbox"]:checked + label:after, .custom_radio_checkbox [type="checkbox"]:not(:checked) + label:after  {  content: '\2713\0020';   position: absolute;  top:4px; left:6px;      line-height:1;    color: #616161;    transition: all 0.2s ease;  }
.custom_radio_checkbox input:not(:checked) + label:after {    opacity: 0;    transform: scale(0);}
.custom_radio_checkbox input:checked + label:after {    opacity: 1;    transform: scale(1);}
/* Custom Select */
.custom_select { /* Chercher 000000 pour changer couleur */ background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23000000%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E');    background-repeat: no-repeat, repeat;    background-position: right 10px top 50%, 0 0;    background-size: .65em auto, 100%;    -moz-appearance: none;    -webkit-appearance: none;    appearance: none;  padding-right: 25px;   }
.custom_select::-ms-expand {    display: none;}



@media all and (max-width:767px) {
    .alignright, a img.alignright, .wp-caption.alignright, .alignleft, a img.alignleft, .wp-caption.alignleft {        float: none;        margin: 0 auto 2rem;        display: block    }

}

/* popin */
.mf_popin {  background: #FFF; max-width:1000px; padding: 25px; position: relative; width:auto;  margin: 0 auto; display:none; border-radius: 10px}
.mfp-close {  width:43px;  height: 43px; background:url(../images/popin-close.svg) no-repeat;  position: absolute;  right: 20px;  top: 30px;    font-size: 28px; text-indent: -9999px; }
.mfp-arrow {  position: absolute;  top: 50%;  margin-top:-0px;  width:10px; height:10px;  background:red; }
.mfp-arrow-left { left:10px; background-position:0 0; }
.mfp-arrow-right { right:10px;  background-position:0 0;}
.mfp-bg, .mfp-wrap .mfp-content {   opacity: 0;    -webkit-transition: all 0.5s ease;  transition: all 0.5s ease;}
.mfp-bg.mfp-ready {  opacity: 0.8; }
.mfp-bg.mfp-removing {    opacity: 0;}
.mfp-wrap.mfp-ready .mfp-content {    opacity: 1;}
.mfp-wrap.mfp-removing .mfp-content {    opacity: 0;}
.mfp-ready .mf_popin { display:block; }
.mfp-bg {background-color: rgba(11, 11, 11, 0.98);  top: 0;  left: 0;  width: 100%;  height: 100%;  z-index: 1042;  overflow: hidden;  position: fixed;}
.mfp-wrap {  top: 0;  left: 0;  width: 100%;  height: 100%;  z-index: 1043;  position: fixed;  outline: none !important;  -webkit-backface-visibility: hidden; }
.mfp-container {padding:10px;  text-align: center;  position: absolute;  width: 100%;  height: 100%;  left: 0; top: 0;  box-sizing: border-box; }
.mfp-container:before {  content: '';  display: inline-block;  height: 100%;  vertical-align: middle; }
.mfp-align-top .mfp-container:before {  display: none; }
.mfp-content {  position: relative;  display: inline-block;  vertical-align: middle;  margin: 0 auto;  text-align: left;  z-index: 1045; }
.mfp-inline-holder .mfp-content,.mfp-ajax-holder .mfp-content {  width: 100%;  cursor: auto; }
.mfp-ajax-cur {  cursor: progress; }
.mfp-loading.mfp-figure {  display: none; }
.mfp-hide {  display: none !important; }
.mfp-s-ready .mfp-preloader {  display: none; }
.mfp-s-error .mfp-content {  display: none; }
.mfp-counter { display:none;   }
.mfp-title { display:none;}
button.mfp-close, button.mfp-arrow {  overflow: visible;  cursor: pointer;  -webkit-appearance: none;  display: block;  z-index: 1046; touch-action: manipulation; }
img.mfp-img {  width: auto;  max-width:100%;  }
.mfp-figure {  line-height: 0; }

.mf_popin .conteneur {  max-width: 840px; margin: 0 auto; padding-top: 55px }
.mf_popin .titre {  text-align: center; font-size: 2.5rem; line-height: 2.8rem; font-family: 'Larken', sans-serif }
.mf_popin .txt { text-align: center; font-size: 1.8rem; line-height: 2.1rem; font-weight: 300 }
.mf_popin .form { padding: 50px 0; display: flex; margin: 0 -20px; flex-wrap: wrap }
.mf_popin .form > div { flex:0 0 50%; padding: 0 20px; }
.mf_popin label { padding-bottom: 10px; display: block}
.mf_popin textarea { height: 150px}
.mf_popin .bouton { text-align: center; padding-top: 20px !important;flex:0 0 100% !important;}


@media all and (max-width:767px) {
    .mf_popin .form { display: block}
}

.cms { padding: 50px 0 100px; background: #fff; position: relative; z-index: 2}
.cms h2 { text-align: left; font-size: 4rem; line-height: 4.5rem; padding-top: 4rem; margin-bottom: 0.5rem}


    /*--------- [ LAYOUT ] ---------*/
.container { max-width: 1460px;  margin:0 auto;  padding: 0 30px }
.row [class^="col"], .owl-carousel .owl-item { padding:0 var(--margin-gouttiere); }
#main {  min-height:90vh; padding-bottom: 3rem}
body, input, textarea,  button { font-family: 'Futura PT', Arial, Verdana, sans-serif; font-size:1.8rem; line-height: 1.3; color: var(--couleur_01) !important;   }

/* Header */
#header { z-index: 5; background: transparent; position: absolute; top:20px; left:0; right: 0  }
#header.scrolled { z-index: 500}
#header .hlogo img { max-width: 100%;  height: 52px; }
.wk_sticky .sticky_onscroll.fixed { background: #fff; box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;  transition: all 0.3s ease;}
.wk_sticky .sticky_onscroll.fixed { z-index: 500}
.wk_sticky .sticky_onscroll.fixed #hmenu  a { color:var(--couleur_01)}
.wk_sticky .sticky_onscroll.fixed .hlogo img { height: 42px; }
.wk_sticky .sticky_onscroll.fixed #header_middle .logo_min {  opacity: 1; visibility: visible; transition: all 0.3s ease;}
.wk_sticky .sticky_onscroll.fixed #header_middle .conteneur { justify-content: center}
#header_middle .conteneur { display: flex; align-items: center; justify-content: flex-end; height: 70px; }
#header_middle .logo_min { position: absolute; top:5px; left:15px; opacity: 0; visibility: hidden; z-index: 10 }
#header_middle .logo_min img { height: 60px}
#hmenu > ul { display: flex; align-items: center;   }
#hmenu > ul > li {  position:relative; display: flex; justify-content: space-between; align-items: center; padding: 0 3rem; text-align: center; font-size: 2rem; line-height: 1.3}
#hmenu  a { color:#fff; text-transform: uppercase; transition: all 0s ease; padding: 7px 5px;}
#hmenu  a:hover{ text-decoration: underline}
#hmenu > ul > li.menu-item-has-children:hover > a { text-decoration: none}
#hmenu > ul > li:hover .sub-menu { display: block}
#hmenu .sub-menu { position: absolute; top:100%; left:0; padding:10px 12px; box-shadow: 5px 5px 7px -2px rgba(0,0,0,0.14); display: none; background: #fff; text-align: left; font-size: 17px; border-radius: 7px;}
#hmenu .sub-menu li { white-space: nowrap; padding: 2px 0}
#hmenu .sub-menu a { color:var(--couleur_01);     text-transform: inherit;}
.hamburger {  /* width: 3.0rem;    height: 2.3rem; */ top:25px; right: 30px;  display: none;} /* Burger Menu anim-slider   anim-slider   anim-squeeze   anim-spin */
.hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {  /*background-color:#000;  height: 3px;    border-radius: 4px;*/}
.hamburger-inner {   /*margin-top: -1.5px;*/ }
.hamburger-inner::before {   /* top: -10px; */}
.hamburger-inner::after {   /* bottom: -10px;*/ }

/* Footer */
.pre_footer { position: relative; height: 480px }
.pre_footer .ctmap { height: auto !important; position: absolute !important; top:0; left:0; right: 0; bottom:0; z-index: 100}
.pre_footer .container {}
.pre_footer .coordonnees { font-size: 2rem;  z-index: 110; position: relative; background: #fff url(../images/bg-coordonnees.jpg) no-repeat 35px; display: flex; align-items: center; padding: 15px 15px 15px 150px;  width: 400px; min-height: 220px;  margin: -32px 0 0 70px; box-shadow: 0 0 5px rgb(237 237 237)}
.pre_footer strong { font-weight: 500}
.leaflet-popup-content { min-width: 160px !important;}
.leaflet-popup-content h4 {  margin-bottom: 0; font-weight: 500}
.leaflet-popup-content p  { margin-top: 0 !important;}
#footer {  background: #443A36; color:#fff; font-weight: 300; padding: 80px 0}
#footer a { color:#fff;}
#footer a:hover { text-decoration: underline}
#footer .titre {  font-size: 2rem; font-weight: 500; padding-bottom: 2rem}
#footer ul li { padding-bottom: 1.5rem}
#footer ul li:last-child { padding-bottom: 0}
#form_newsletter .form { display: flex;  border-bottom: 1px solid #665d58; padding-bottom: 10px; width: 360px; max-width: 100%  }
#form_newsletter input { background: none; padding: 0; border: 0; margin: 0; color: #fff!important  }
#form_newsletter input::placeholder { color:#fff; transition: all 0.3s ease;}
#form_newsletter input:focus::placeholder {  opacity:0.2; }
#form_newsletter button { background: none; color:#fff !important;}
#form_newsletter .cgv { font-size: 15px; padding-top: 10px}
.footer_top { display: flex; justify-content: space-between; max-width: 1200px; margin: 0 auto}
.footer_top > div { padding: 0 20px;}
.footer_bottom {  border-top: 1px solid #665d58; margin-top: 40px; padding-top: 25px; text-align: center}
.footer_bottom ul li { display: inline-block}
.footer_bottom ul li:after { content:" -"; padding:0  10px} 
.footer_bottom ul li:last-child:after { display: none}
.footer_bottom .copy { font-size: 14px;}
.fsocial ul { display: flex; margin: 20px -8px 0}
.fsocial ul li { padding: 0 8px;}

#moove_gdpr_cookie_info_bar .moove-gdpr-cookie-notice button.change-settings-button { color:#fff !important;}

@media all and (max-width:1300px) {
    #hmenu > ul > li { padding: 0 2.5rem}

}

@media all and (max-width:1200px) {
    .footer_top { margin: 0 -20px}
}
@media all and (max-width:1100px) {
    #hmenu > ul > li { padding: 0 2rem; font-size: 1.8rem}
}

@media all and (max-width:1024px) {
    #form_newsletter .form { min-width: auto}
    .pre_footer { height: 320px}
    .pre_footer .coordonnees { margin-left: 0; min-height:0; font-size: 1.7rem; padding: 10px 15px; width: 160px; background-image: none;/*background-size: auto 90px; background-position:15px center;  padding-left: 90px; width: 260px;*/}
    #form_newsletter .form { width: 320px}

}
@media all and (max-width:990px) {
    #wrapper { padding-top: 70px}
    #header { top:0;}
    #header br { display: none}
    .wk_sticky .sticky_onscroll { background: #fff;        box-shadow: rgba(100, 100, 111, 0.2) 0px 7px 29px 0px;        transition: all 0.3s ease; }
    .wk_sticky .sticky_onscroll #header_middle .logo_min {  opacity: 1;        visibility: visible;}
    html.menu-open { overflow: hidden;}
    #header_middle .container { padding: 0 !important;}
    #hmobile { opacity: 0; visibility: hidden; position:absolute; top:70px; left:0; right: 0; width:100%; z-index: 9998; height:calc(100vh - 0rem);  overflow: auto;  transition: all 0.3s ease; }
    #hmobile.open { opacity:1 ; visibility: visible }
    #hmobile {background:#fff; }
    #hmenu { padding-top: 3rem; }
    #hmenu > ul { line-height: 1.3; display: flex;     flex-direction: column;}
    #hmenu > ul > li {  position: relative;  padding: 0.5rem 1.5rem 0.5rem; font-size: 2rem; line-height: 1.4; display: block}
    #hmenu > ul > li a { display: block;  padding-top: 0.5rem; padding-bottom:  0.5rem;}
    #hmenu > ul > li svg { position: absolute; top:1.5rem; right: 1.5rem; }
    #hmenu > ul ul { display: none; /* padding: 0 1.5rem 1.5rem 1.5rem;*/}
    #hmenu .sub-menu { display: block; text-align: center; position: inherit; top:inherit; right: inherit; box-shadow: 0 0 0 #fff; font-size: 16px; padding: 0 0 10px;}
    #hmenu > ul ul li a {  padding: 0rem 0 }
    #hmenu > ul ul li a:before,
    #hmenu > ul ul li a:after { content:" - "}
    #hmenu > ul > li.open_accordeon {  background-color: #f5f6f8;  }
    #hmenu > ul > li.open_accordeon ul { display: block;}
    #hmenu .arrow { width: 20px; height: 20px;}


    .hamburger { display: block;}
    #footer { padding: 40px 0}
    .footer_top { display: block}
    .flogo img { height: 150px; display: none  }
    .footer_top { margin: 0}
    .footer_top > div { padding: 5px 0}
    #footer .titre { padding-bottom: 1rem}
    #footer ul { display: flex; flex-wrap: wrap; line-height: 0.8; padding: 1rem 0 1.5rem}
    #footer ul li:before{ content:"-"; padding: 0 10px}
    .fsocial ul { padding: 0 !important; margin: 1rem 0 2rem}
    #footer ul li:first-child:before,  .footer_bottom li:before, .fsocial li:before  { display: none}
    .footer_bottom ul { justify-content: center}
}



@media all and (max-width:767px) {
    html { font-size: 58%; }
    .container { padding: 0 30px !important;}
    .row { flex-direction: column}
    .row [class^="col"] { max-width: 100%; flex: 0 0 100%;margin-bottom:2rem !important; padding: 0  !important;  }
    .row [class^="col"] .col { padding: 0}
    .row [class^="col"]:last-child { margin-bottom: 0 !important;}
    .pre_footer { height: 230px}


}














