@import url('https://fonts.googleapis.com/css2?family=Aleo:wght@300;400;700&family=Roboto:wght@300;400;500&display=swap');

*{
padding:0px;
border:0px;
margin:0px;
}

html{
width:100%;
scroll-behavior: smooth;
}

.main_width{
width:95%;
margin:auto;
}


body{
font-family: 'Roboto', sans-serif;
font-weight:400;
width:100%;
color: #5e5e5e;
}


/* *********************** COMMON *********************** */

p{
line-height: 28px;
font-size: 18px;
margin-bottom: 10px;
}

h1{
color:#3c3c3b;
font-size: 32px;
font-weight: 700;
line-height: 42px;
font-family: 'Aleo', serif;
}

h2{
color:#3c3c3b;
font-size: 27px;
font-weight: 700;
line-height: 35px;
font-family: 'Aleo', serif;
}

h3{
color: #3c3c3b;
font-size: 24px;
font-weight: 700;
line-height: 32px;
font-family: 'Aleo', serif;
}

.line{
padding-left: 60px;
position: relative;
}

.line:after{
content:"";
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
height: 3px;
width: 40px;
background-color: #a4863f;
}


a.button{
display: inline-block;
color: #a4863f;
padding-right: 30px;
background-image: url(images/arrow-right-gold.svg);
background-position:right 5px center;
background-repeat: no-repeat;
background-size: 15px;
transition: all 0.4s;
font-size: 21px;
font-family: 'Aleo', serif;
text-decoration: none;
}

a.button:hover{
background-position: right center;
text-decoration: underline;
}

a{
color:inherit;
text-decoration:underline;
}


/* *********************** HEADING MSG*********************** */
#heading{
width: 100%;
padding: 10px 0;
text-align: center;
background-color: #a4863f;
display: inline-block;
}

#heading p{
color: white;
font-size: 18px;
margin: 0;
padding: 0 20px;
}

/* *********************** BANNER / MENU *********************** */
#banner{
margin: 30px 0 50px 30px;
}

@media screen and (max-width: 400px) {
	#banner{
	margin: 30px 0 50px 0;
	}
}

#banner .main_width{
position: relative;
}

#banner .logo{
display: inline-block;
width: 185px;
left: 0;
top: 0;
}

#banner .logo.home-page-logo{
}

#cssmenu{
grid-column: 3/4;
grid-row: 1/2;
text-align: right;
}

#cssmenu .menu-links{
cursor: pointer;
}

#cssmenu .menu-links.open{
text-transform: uppercase;
font-size: 20px;
position: absolute;
top: -65px;
right: 0;
transform: translateY(-50%);
margin-top: 13px;
}

#cssmenu .menu-links.open img{
transform: translate(-4px, 3px);
}

#cssmenu .menu-links.close{
display: inline-block;
margin-left: 35px;
margin-top: 35px;
}

#banner>.main_width>div>.banner_links{
cursor: pointer;
}

#banner .burger{
position: fixed;
top: 0;
right: -400px;
width: 350px;
height: 100vh;
margin: 0;
-webkit-box-shadow: 0px 2px 8px 0px #7e7e7e;
box-shadow: 0px 2px 8px 0px #7e7e7e;
transition: all 0.6s;
overflow: hidden;
box-sizing: border-box;
z-index: 10;
overflow-y: auto;
background-color: #3c3c3b;
text-align: left;
}

#banner .burger.open{
right: 0;
}

#banner .burger ul{
list-style: none;
display: flex;
flex-direction: column;
position: absolute;
top: 50%;
transform: translateY(calc(-50% - 20px));
}

@media screen and (max-height: 500px) {
	#banner .burger ul{
	position: static;
	margin: 70px 0 100px;
	transform: none;
	}
}

#banner .burger ul li{
display: block;
width: 100%;
padding: 20px 0;
transition: all 0.4s;
}

#banner .burger ul li a{
line-height: 30px;
padding: 10px 35px;
font-weight: 400;
font-size: 23px;
color: white;
text-decoration: none;
transition: all 0.4s;
}

#banner .burger ul li a.selected{
color: #a4863f;
}

#banner .burger ul li:hover a{
color: #a4863f;
}

#banner .banner_links a{
display: block;
text-decoration: none;
font-size: 15px;
padding-left: 25px;
background-repeat: no-repeat;
}

#banner .banner_links a:hover{
text-decoration: underline;
}

#banner .banner_links a{
background-image: url(images/icon-phone-blue.svg);
margin-bottom: 10px;
background-size: 12px;
background-position: 2px center;
}

#banner .banner_links a:last-of-type{
background-image: url(images/icon-mail-blue.svg);
background-size: 15px;
margin-bottom: 0;
background-position: left center;
}


/* *********************** WRAPPER *********************** */
#wrapper .main_width{
}

/* *********************** PAGES *********************** */

/* ***** HOME ***** */
#home .c1{
position: relative;
padding-bottom: 120px;
overflow: hidden;
}

#home .c1 .content{
display: block;
width: 100%;
max-width: 550px;
margin: 25px auto 50px;
vertical-align: middle;
}

#home .c1 .content .logo{
display: none;
}

#home .c1 .content .logo img{
width: 100%;
height: auto;
}

#home .c1 .content h1{
margin-bottom: 20px;
}

#home .c1 .content h1+p{
max-width: 550px;
}

#home .c1 .content .button{
margin-top: 20px;
background-image: url(images/arrow-bottom-gold.svg);
background-size: 8px;
}

#home .c1 .content .button:hover{
background-position: right 5px bottom;
}

#home .c1 .image{
width: 100%;
max-width: 300px;
margin: 0 auto;
display: block;
height: 450px;
vertical-align: middle;
position: relative;
}

#home .c1 .image img{
width: 100%;
height: 100%;
object-fit: cover;
}

#home .c1 .image:after{
content: "";
position: absolute;
right: -55px;
bottom: -65px;
width: 250px;
height: 160px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
}

#home .c1:after{
content:"";
position: absolute;
left: 0;
bottom: 0;
height: 313px;
width: 100%;
background-color: #f7f7f9;
z-index: -1;
}

#home .c1:before{
content: "";
position: absolute;
left: 50%;
transform: translateX(-50%);
bottom: 0;
height: 48px;
width: 60px;
background-image: url(images/scroll.svg);
background-position: top center;
background-size: 100%;
background-repeat: no-repeat;
animation: scroll 2.5s ease-in 0s infinite;
}

@keyframes scroll {
  0%   {height: 48px;}
  20%   {height: 55px;}
  40%  {height: 48px;}
  100% {height: 48px;}
}

#home .c2{
text-align: center;
padding: 100px 0;
}

#home .c2 .content{
text-align: left;
max-width: 550px;
margin: 0 auto;
position: relative;
}

#home .c2 .content:before{
content:"";
position: absolute;
left: 20px;
top: -15px;
width: 100px;
height: 100px;
background-image: url(images/intro-background.svg);
background-size: 100%;
background-position: center;
background-repeat: no-repeat;
z-index: -1;
}

#home .c2 h2{
margin-bottom: 15px;
max-width: 450px;
}

#home .c3{
background-color: #f7f7f9;
padding: 75px 0 150px;
min-height: 300px;
box-sizing: border-box;
}

#home .c3 h2{
margin-bottom: 10px;
position: relative;
}

#home .c3 h2:before{
content: "";
position: absolute;
left: -125px;
bottom: -152px;
width: 350px;
height: 220px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
}

#home .c3 #slider{
position: relative;
max-width: 450px;
margin: 0 auto;
}

#home .c3 .item{
margin: 40px 25px;
position: relative;
padding: 30px 30px 80px;
background-color: white;
}

#home .c3 .item .image{
width: 100%;
height: 200px;
margin-bottom: 25px;
overflow: hidden;
position: relative;
}

#home .c3 .item .image img{
width: 100%;
height: 100%;
object-fit: cover;
transition: all 0.4s;
}

#home .c3 .item:hover .image img{
transform: scale(1.1);
}

#home .c3 .item .image .finished{
position: absolute;
top: 0;
right: 0;
color: white;
background-color: #a4863f;
display: block;
padding: 5px 10px;
}

#home .c3 .item a{
text-decoration: none;
}

#home .c3 .item p.date{
color: #a4863f;
font-size: 17px;
line-height: 19px;
margin-bottom: 7px;
}

#home .c3 h3{
margin-bottom: 15px;
}

#home .c3 h3+p{
line-height: 22px;
}


#home .c3 .button{
display: inline-block;
color: #a4863f;
padding-right: 30px;
background-image: url(images/arrow-right-gold.svg);
background-position:right 5px center;
background-repeat: no-repeat;
background-size: 15px;
transition: all 0.4s;
font-size: 21px;
font-family: 'Aleo', serif;
text-decoration: none;
position: absolute;
right: 45px;
bottom: 40px;
}

#home .c3 .item:hover .button{
background-position: right center;
text-decoration: underline;
}

#home .c3 .owl-nav{
display: block;
position: absolute;
right: 25px;
}

#home .c3 .owl-nav button{
display: inline-block;
width: 50px;
height: 50px;
background-color: #c1ae80;
color: #c1ae80;
position: relative;
}

#home .c3 .owl-nav button:after{
content:"";
width: 20px;
height: 20px;
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
background-size: 11px;
background-position: center;
background-repeat: no-repeat;
}

#home .c3 .owl-nav button:nth-of-type(1):after{
background-image: url(images/before.svg);
}

#home .c3 .owl-nav button:nth-of-type(1){
margin-right: 10px;
}

#home .c3 .owl-nav button:nth-of-type(2):after{
background-image: url(images/after.svg);
}

/* ***** MISES EN VENTE ***** */

#news{
margin-top: 75px;
}

#news h1{
text-align: center;
margin-bottom: 65px;
}

#news .c1{
display: flex;
flex-wrap: wrap;
justify-content: space-around;
position: relative;
}

#news .c1:before{
content: "";
position: absolute;
left: -125px;
top: -70px;
width: 350px;
height: 220px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
}

#news .c1 .item{
position: relative;
padding: 30px 30px 80px;
background-color: #f7f7f9;
width: 100%;
max-width: 450px;
box-sizing: border-box;
margin: 0 0 35px;
}

#news .c1 .item .image{
width: 100%;
height: 200px;
margin-bottom: 25px;
overflow: hidden;
position: relative;
}

#news .c1 .item .image img{
width: 100%;
height: 100%;
object-fit: cover;
transition: all 0.4s;
}

#news .c1 .item:hover .image img{
transform: scale(1.1);
}

#news .c1 .item .image .finished{
position: absolute;
top: 0;
right: 0;
color: white;
background-color: #a4863f;
display: block;
padding: 5px 10px;
}

#news .c1 .item a{
text-decoration: none;
}

#news .c1 .item p.date{
color: #a4863f;
font-size: 17px;
line-height: 19px;
margin-bottom: 7px;
}

#news .c1 h3{
margin-bottom: 15px;
}

#news .c1 h3+p{
line-height: 22px;
}


#news .c1 .button{
display: inline-block;
color: #a4863f;
padding-right: 30px;
background-image: url(images/arrow-right-gold.svg);
background-position:right 5px center;
background-repeat: no-repeat;
background-size: 15px;
transition: all 0.4s;
font-size: 21px;
font-family: 'Aleo', serif;
text-decoration: none;
position: absolute;
right: 45px;
bottom: 40px;
}

#news .c1 .item:hover .button{
background-position: right center;
text-decoration: underline;
}

#news .c2{
margin-bottom: 50px;
overflow: hidden;
}

#news .microdata{
display: none;
}

#news .c2 .photos{
display: block;
width: 100%;
margin: 0 auto 100px;
max-width: 550px;
vertical-align: top;
text-align: left;
position: relative;
}

#news .c2 .photos:before{
content: "";
position: absolute;
right: -115px;
bottom: -50px;
width: 350px;
height: 220px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
z-index: -1;
}

#news .c2 .photos .photo_principale{
width: 100%;
height: 350px;
display: block;
overflow: hidden;
}

#news .c2 .photos a:not(.photo_principale){
display: inline-block;
width: 24%;
height: 120px;
overflow: hidden;
}

#news .c2 .photos img{
width: 100%;
height: 100%;
object-fit: cover;
transition: all 0.4s;
}

#news .c2 .photos a:hover img{
transform: scale(1.1);
}

#news .c2 .content{
vertical-align: top;
text-align: left;
display: block;
width: 100%;
max-width: 550px;
margin: 0 auto;
}

#news .c2 .content .finished{
display: inline-block;
text-transform: uppercase;
font-size: 16px;
margin-bottom: 13px;
color: #a4863f;
}

#news .c2 .content h1{
text-align: left;
margin-bottom: 15px;
}

#news .c2 .content h1+.date{
color: #a4863f;
font-size: 19px;
line-height: 23px;
margin-bottom: 20px;
}

#news .c2 .content .button{
margin-top: 30px;
}

#news .c2 .pdfs{
margin-top:50px;	
}

#news .c2 .pdfs a.item{
width: 130px;
display: inline-block;
vertical-align: top;
margin: 5px 10px;
transition: all 0.3s;
text-decoration: none;
}

#news .c2 .pdfs a.item .image{
position: relative;
width: 100%;
height: 110px;
overflow: hidden;
}

#news .c2 .pdfs a.item .image img{
width: 220px;
position: absolute;
top: -10px;
left: -10px;
transition: all 0.3s;
z-index: 30;
}

#news .c2 .pdfs a.item:hover .image img{
width:200px;
top:0px;
left:0px;
filter: grayscale(0.20);
}

#news .c2 .pdfs a.item span.description{
line-height: 19px;
padding: 13px 8px;
display: block;
overflow: hidden;
font-size: 16px;
letter-spacing: 0px;
width: 100%;
box-sizing: border-box;
text-align: center;
color: #a4863f;
background-color: #f7f7f9;
}

#news .c2 .pdfs a.item:hover span.description{
text-decoration: underline;
}


/* ***** MATIÈRES PRÉFÉRENTIELLES ***** */
.single-page .c1{
position: relative;
padding: 30px 0 80px;
overflow: hidden;
}

.single-page .c1 .content{
display: block;
width: 100%;
max-width: 550px;
margin: 0 auto;
vertical-align: middle;
}

.single-page .c1 .content .logo{
width: 350px;
margin: 60px 0 120px 30px;
}

.single-page .c1 .content .logo img{
width: 100%;
height: auto;
}

.single-page .c1 .content h1{
margin-bottom: 20px;
}

.single-page .c1 .content h1+p{
max-width: 550px;
}

.single-page .c1 ul{
list-style: none;
margin-top: 20px;
}

.single-page .c1 ul li{
padding: 0 0 15px 25px;
background-image: url(images/icon-list.svg);
background-position: left 6px;
background-repeat: no-repeat;
background-size: 9px;
font-size: 16px;
line-height: 21px;
}

.single-page .c1 .content .button{
margin-top: 30px;
}

.single-page .c1 .image{
display: block;
width: 100%;
max-width: 550px;
margin: 0 auto 100px;
height: 350px;
vertical-align: middle;
position: relative;
}

.single-page .c1 .content+.image{
margin-left: 11%;
margin-right: 0;
}

.single-page .c1 .image img{
width: 100%;
height: 100%;
object-fit: cover;
}

.single-page .c1 .image:after{
content: "";
position: absolute;
right: -245px;
bottom: -60px;
width: 350px;
height: 250px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
z-index: -1;
}

.single-page .c1 .content+.image:after{
right: auto;
left: -245px;
}

.single-page .c1:after{
content:"";
position: absolute;
left: 0;
bottom: 0;
height: 335px;
width: 100%;
background-color: #f7f7f9;
z-index: -2;
}



/* ***** CONTACT ***** */

#contact{
text-align:center;
padding-bottom:30px;
margin-top: 100px;
}

#contact .main_width{
}


#contact .c1{
display: block;
width: 100%;
max-width: 400px;
margin: 0 auto 50px;
vertical-align:middle;
text-align:left;
}

#contact h1{
margin-bottom: 30px;
}

#contact .c1 .title{
font-size: 26px;
text-transform: uppercase;
font-family: 'Aleo', serif;
font-weight: 300;
letter-spacing: 2px;
margin-bottom: 20px;
}

#contact .c1 a{
max-width: 200px;
padding-left: 30px;
background-size: 15px;
background-position: left 3px;
background-repeat: no-repeat;
display: block;
text-decoration: none;
margin-bottom: 12px;
line-height: 23px;
transition: all 0.4s;
}

#contact .c1 a:hover{
padding-left: 40px;
}

#contact .c1 a:hover span{
border-bottom: 1px solid #a4863f;
}

#contact .c1 a.address{
background-image: url(images/icon-address.svg);
}

#contact .c1 a.phone{
background-image: url(images/icon-phone.svg);
}

#contact .c1 a.mail{
background-image: url(images/icon-mail.svg);
background-position: left 4px !important;
}

#contact .c1 .tva{
font-size: 16px;
color:  #a4863f;
}

#contact .c1 .microdata{
display:none;
}


#contact .c2{
display:block;
width: 100%;
vertical-align:middle;
text-align:left;
position: relative;
}

#contact .c2 .streetview{
width:100%;
height:350px;
}

#contact .c2:after{
content: "";
position: absolute;
left: -200px;
bottom: -60px;
width: 350px;
height: 250px;
background-image: url(images/mh-background.svg);
background-position: center;
background-size: 100%;
background-repeat: no-repeat;
z-index: -1;
}




/* ***** Mentions légales ***** */


#legal{
text-align:center;
}

#legal .main_width{
}


#legal h1{
text-align:center;
background-position:bottom center;
margin-bottom:73px;
}

#legal h2{
background-position: 0px 7px;
position: relative;
bottom: 0px;
margin-top: 14px;
margin-bottom: 14px;
font-size:28px;
line-height:30px;
background-position: bottom left;
padding-bottom: 7px;
}

#legal h3{
line-height:23px!important;
padding-bottom: 6px!important;
}

#legal p{
margin-bottom:5px;
}

#legal p span{
display:inline-block;
vertical-align:top;
width:166px;
text-decoration:underline;
}

#legal .c0{
width:600px;
text-align:left;
display:inline-block;
vertical-align:top;
border:1px solid #c0c0c0;
text-align:left;
padding:1%;
margin-bottom:30px;
background-color:white;
border-radius:13px;
}

#legal .c1{
display:inline-block;
vertical-align:top;
width:90%;
padding:1%;
border:1px solid #c0c0c0;
text-align:left;
margin-bottom:30px;
min-height:262px;
background-color:white;
border-radius:13px;
}

#legal .c1.last{
margin-right:0px;
}

#legal .c1 p{
margin-bottom:8px;
font-size:13px;
line-height:22px;
}

#legal .c2{
width:90%;
padding:1%;
text-align:left;
display:inline-block;
vertical-align:top;
border:1px solid #c0c0c0;
margin-bottom:30px;
height:600px;
overflow:auto;
padding-bottom:30px;
background-color:white;
border-radius:13px;
}

#legal .c2 h3{

}

#legal .c2 h4{

}

#legal .c2 p{
margin-bottom:8px;
font-size:13px;
line-height:22px;
}

#legal .c2 ul li{
margin-bottom:5px;
font-size:13px;
line-height:22px;
padding-left:15px;
list-style-type:none;
}

#legal .c2 ul ul li{
padding-left:30px;
}

#legal .c2.last{
margin-right:0px;
}


/* ***** 404 ***** */

#e404{
text-align:center;
}

#e404 .main_width{
}

#e404 h1{
text-align:center;
background-position:bottom center;
margin-bottom:35px;
}


/* *********************** FOOTER *********************** */

#footer{
padding: 100px 0 30px;
}

#footer .logo{
display: block;
width: 100%;
max-width: 350px;
margin: 0 auto 50px;
vertical-align: top;
}

#footer .content{
display: block;
width: 100%;
margin: 0;
vertical-align: top;
padding-top: 35px;
border-top: 2px solid #a4863f;
}

#footer .content>div:first-of-type{
display: block;
width: 100%;
max-width: 360px;
margin: 0 auto 35px;
vertical-align: middle;
text-align: center;
}

#footer .content .title{
font-size: 26px;
text-transform: uppercase;
font-family: 'Aleo', serif;
font-weight: 300;
letter-spacing: 2px;
margin-bottom: 20px;
}

#footer .content>div:first-of-type a{
padding-left: 30px;
background-size: 15px;
background-position: left 3px;
background-repeat: no-repeat;
display: block;
text-decoration: none;
margin: 0 auto 12px;
line-height: 23px;
transition: all 0.4s;
width: fit-content;
}

#footer .content>div:first-of-type a:hover{
padding-left: 40px;
}

#footer .content>div:first-of-type a:hover span{
border-bottom: 1px solid #a4863f;
}

#footer a.address{
background-image: url(images/icon-address.svg);
}

#footer a.phone{
background-image: url(images/icon-phone.svg);
}

#footer a.mail{
background-image: url(images/icon-mail.svg);
background-position: left 4px !important;
}

#footer .content>div:last-of-type{
display: block;
width: 100%;
max-width: 285px;
margin: 0 auto;
text-align: center;
vertical-align: middle;
}

#footer .content>div:last-of-type ul{
list-style: none;
}

#footer .content>div:last-of-type a{
display: block;
text-decoration: none;
margin-bottom: 10px;
line-height: 23px;
transition: all 0.4s;
}

#footer .content>div:last-of-type a:hover{
transform: translateX(10px);
}

#footer .content>div:last-of-type a:hover span{
border-bottom: 1px solid #a4863f;
}

#footer p.copyright{
font-size: 14px;
margin: 0;
padding: 60px 0px 35px;
text-align: center;
position: relative;
}

#footer p.copyright a:last-of-type{
position: absolute;
left: 50%;
transform: translateX(-50%);
bottom: 0;
}

#footer .copyright a img{
display: inline-block;
width: 94px;
margin-left: 10px;
height: auto;
}



/* ***** CAPTCHA ***** */

.grecaptcha-badge { 
	visibility: hidden; 
}


/* ***** COOKIES ***** */

#cookieChoiceInfo{
	box-sizing: border-box;
}

/* ***** AOS ***** */

.fade_container {
    overflow-x: hidden;
}