@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed&family=Source+Code+Pro:wght@800&display=swap');

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

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

.main_width{
width:1000px;
margin:auto;
}


body{
font-family: "Roboto Condensed", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
font-style: normal;
width:100%;
}


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

p{
color:#000;
line-height:28px;
font-size:18px;
margin-bottom:14px;
}

h1{
font-family: "Source Code Pro", monospace;
font-optical-sizing: auto;
font-weight: 800;
font-style: normal;	
color:#0C4FB3;
text-transform: uppercase;
font-size: 26px;
letter-spacing:-1px;
font-weight: 400;
line-height: 34px;
}


h2{
font-family: "Source Code Pro", monospace;
font-optical-sizing: auto;
font-weight: 800;
font-style: normal;	
color:#0C4FB3;
text-transform: uppercase;
font-size: 25px;
letter-spacing:-1px;
font-weight: 400;
line-height: 34px;
margin-bottom:20px;
}

h3{
font-family: "Source Code Pro", monospace;
font-optical-sizing: auto;
font-weight: 800;
font-style: normal;	
color:#0C4FB3;
text-transform: uppercase;
font-size: 22px;
letter-spacing:-1px;
font-weight: 400;
line-height: 26px;
margin-bottom:20px;
}

h4{
font-family: "Source Code Pro", monospace;
font-optical-sizing: auto;
font-weight: 800;
font-style: normal;	
color:#bababa;
text-transform: uppercase;
font-size: 18px;
letter-spacing:-1px;
font-weight: 400;
line-height: 26px;
margin-bottom:20px;
}





a.button{
display: inline-block;
text-transform: uppercase;
color: 000;
padding: 7px 39px;
margin:0px 10px;
transition: all 0.5s ease-in-out;
font-size: 20px;
text-decoration:none;
transition:all 0.3s;
border:2px solid #e1e1e1;
background-image:url('images/icon_button.png');
background-repeat:no-repeat;
background-position:right 20px top 13px;
transition: all 0.4s;
}

a.button:hover{
background-position:right 10px top 13px;
}

a{
color:inherit;
text-decoration:underline;
transition: all 0.2s ease-in-out;
}

p a:hover{
}


.clear{
width:100%;
clear:both;
}



/* *********************** HEADING MSG*********************** */
#heading{
width:100%;
text-align:center;
background-color:#42A86A;
z-index: 99;
}

#heading p{
color: white;
margin: 0;
padding: 0 70px;
box-sizing: border-box;
}



/* *********************** BANNER / MENU *********************** */
#banner{
width:100%;
padding-bottom:100px;
padding: 15px 0 100px;
}


#banner .logo{
width:250px;
display:inline-block;
vertical-align:top;

opacity: 1;
transform: scale(0.5);
animation: bounceIn 1s ease forwards;
}


@keyframes bounceIn {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  60% {
    opacity: 1;
    transform: scale(1.1);
  }
  80% {
    transform: scale(0.95);
  }
  100% {
    transform: scale(1);
  }
}


#banner .infos {
display:inline-block;
vertical-align:top;
float:right;
text-align:right;

}

#banner .infos .contact{
display:inline-block;
vertical-align:top;
margin-top:17px;
text-align:right;
}

#banner .infos .contact .button{
font-size: 14px;
padding: 5px 28px 5px 20px;
background-size: 8px;
background-position: right 13px center;
vertical-align: middle;
margin-right: 10px;
}

#banner .infos .contact .button:hover{
background-position: right 8px center;
}

#banner .infos .contact p{
display:inline-block;
vertical-align: middle;
font-size:17px;
padding-top:10px;
color:#717171;
}

#banner .infos .contact p a{
text-decoration:none;
padding:0px 7px;
}

#banner .infos .contact p a:hover{
text-decoration:underline;
background:none;
}

#banner .infos .social{
display:inline-block;
vertical-align:top;
padding-right:10px;
}

#banner .infos .social a{
display: inline-block;
transition: transform 0.3s;
width:30px;
height:30px;
padding: 25px 5px;
}

#banner .infos .social a:hover{
animation: spinShrinkBounce 0.6s ease-in-out;	
}

@keyframes spinShrinkBounce {
  0% {
    transform: rotate(0deg) scale(1);
  }
  30% {
    transform: rotate(360deg) scale(0.7);
  }
  60% {
    transform: rotate(360deg) scale(1.1);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}


/* *********************** MENU *********************** */
#menu{

}

#menu .open, #menu .close{
	display:none;
}

#menu li {
list-style-type:none;
display:inline-block;
vertical-align:top;
}

#menu a{
font-size: 17px;
color: #000;
padding: 6px 16px;
text-decoration: none;
text-transform: uppercase;
position: relative;
}

#menu a::after {
  content: "";
  position: absolute;
  width: 0%;
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: #000;
  transition: width 0.3s ease;
}

#menu a:hover::after {
  width: 100%;
}




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


/* ***** SLIDER -> HOME***** */
#slider{

}

/* ***** HOME ***** */
#home{
position: relative;	
}

#home .deco-mavic{
	background-image: url(images/mavic3procine.png);
    background-repeat: no-repeat;
    background-position: center right;
    background-size: contain;
    position: absolute;
    right: 0;
    top: -82px;
    z-index: -1;
    width: 840px;
	max-width: 45vw;
    height: 350px;
	transition: all 0.4s;
}

#home .c1{
width:50%;
}

#home #slider{
	margin: 0 auto 70px;
	width: 90vw;
	max-width: 2000px;
}

#home #slider .item{
	margin: 0 15px 10px;
	height: 220px;
}

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

#home #slider .slider-controls{
	margin-top: 20px;
	display: flex;
	justify-content: space-between;
}

#home #slider #prevBtn{
	background-color: transparent;
    color: #cacaca;
    text-transform: uppercase;
    font-size: 14px;
    padding-left: 44px;
    background-image: url(images/slider-icon-prec.svg);
    background-size: 35px;
    background-repeat: no-repeat;
    background-position: left center;
    line-height: 35px;
    display: inline-block;
	cursor: pointer;
}

#home #slider #nextBtn{
	background-color: transparent;
    color: #cacaca;
    text-transform: uppercase;
    font-size: 14px;
    padding-right: 44px;
    background-image: url(images/slider-icon-suiv.svg);
    background-size: 35px;
    background-repeat: no-repeat;
    background-position: right center;
    line-height: 35px;
    display: inline-block;
	cursor: pointer;
}

#home .video{
width:100%;	
text-align:center;
margin-bottom:80px;
}

#home .c2{
width:100%;
height:550px;
background-image:url('images/vue-aerienne-par-drone.jpg');
background-repeat:no-repeat;
background-position:center;
text-align:center;
position:relative;
}

#home .c2 .citation{
width:600px;
padding:44px 123px;
background: linear-gradient(to right, #004A9D, #004B70);
display:inline-block;
vertical-align:bottom;
position:absolute;
left:50%;
bottom:-100px;
transform:translate(-50%);
}

#home .c2 .citation p{
color:white;	
}

#home .c2 .citation p:after{
content: "";
display: block;
width: 150px;
height: 30px;
position: relative;
top: 20px;
background-image: url(images/signature.png);
background-size: contain;
background-position: center;
background-repeat: no-repeat;
margin: 0 auto;
}

#home .partenaires{
width:100%;
text-align:center;
padding-top:180px;
padding-bottom:85px;
}

#home .partenaires img{
padding: 0px 55px;
height: 70px;
width: auto;
}

#home .c3{
width: 100%;
max-width: 2000px;
min-height: 600px;
position: relative;
margin: 0 auto;
}


#home .c3 .left{
position:absolute;
width:100%;

}

#home .c3 .left .content{
display:inline-block;
vertical-align:top;
width:40%;
margin-right:10%;
}

#home .c3 .left .content p{
text-align:justify;
}

#home .c3 .right{
position:absolute;
width:100%;
display:inline-block;
vertical-align:top;
}

#home .c3 .right .background{
width:50%;
height:500px;
position:absolute;
right:0px;
background:#c0c0c0;
background-image:url('images/landscape-lontzen.png');
background-repeat:no-repeat;
background-size:cover;
}

#home .c3 .right .background .content{
width:400px;
padding:20px 30px;
position:absolute;
bottom:-30px;
left:-30px;
background: linear-gradient(to right, #004A9D, #004B70);
}

#home .c3 .right .background .content h3{
color:white;	
}

#home .c3 .right .background .content p{
color:white;
font-size:16px;	
padding-left:30px;
}

#home .c3 .right .background .content p.point1{
background-image:url('images/icon1.png');
background-repeat:no-repeat;
background-position:0px 4px;
}

#home .c3 .right .background .content p.point2{
background-image:url('images/icon2.png');
background-repeat:no-repeat;
background-position:0px 4px;
}

#home .c3 .right .background .content p.point3{
background-image:url('images/icon2.png');
background-repeat:no-repeat;
background-position:0px 4px;
}


#home .c4{
text-align:center;
margin-top: 20px;
}

#home .c4 .left, #home .c4 .right{
display:inline-block;
vertical-align:top;
padding:20px;
}


#home .c4 .content{
display:block;
vertical-align:top;
border:1px solid #004A9D;
padding:20px 30px;
background-color:white;
margin-bottom:30px;
break-inside: avoid;
width:300px;
text-align:left;
}

#home .c4 .content h2{
margin-bottom:0px;
line-height: 45px;
}

#home .c4 .content p.baseline{
display:inline-block;
vertical-align:top;
background-color: #004A9D;
padding:1px 9px;
color:white;
font-family: "Source Code Pro", monospace;
font-optical-sizing: auto;
font-weight: 800;
font-style: normal;	
font-size:20px;
text-transform:uppercase;
margin-bottom:20px;
position:relative;
top:-6px;

}

#home .c4 .content p.point1{

background-image: url('images/icon_photo.png');
  background-repeat: no-repeat;
  background-position: 0px 5px;
  font-size: 16px;
  padding-left: 30px;
  line-height: 21px;
  padding-top: 5px;
}

#home .c4 .content p.point2{
background-image:url('images/icon_euro.png');

  background-repeat: no-repeat;
  background-position: 0px 5px;
  font-size: 16px;
  padding-left: 30px;
  line-height: 21px;
  padding-top: 5px;
}

#home .c4 .content p.point3{
background-image:url('images/icon_ask.png');
background-repeat: no-repeat;
background-position: 0px 5px;
font-size: 16px;
padding-left: 30px;
line-height: 21px;
padding-top: 5px;
}

#home .c4 .content p.important{
font-size: 17px;
font-weight: 600;	
}

#home .c5{
text-align:center;
padding:50px 0px;	
}

#home .c6{
text-align:center;
padding:50px 0px;
}

#home .c6 p{
	max-width: 600px;
	margin: 0 auto;
}

#home .c6 .demo-gallery{
display: flex;
justify-content: center;
flex-wrap: wrap;
align-items: flex-start;
margin-top: 50px;
}

#home .c6 .item {
    position: relative;
	width: 250px;
	margin: 0 15px 50px;
	height: 250px;
	overflow: hidden;
}

#home .c6 .item:after{
    content: '';
	width: 50px;
	height: 50px;
	background-image:url(images/icon-voir.svg);
	background-size: contain;
	background-repeat: no-repeat;
	backgroun-position: center;
	opacity: 0;
	transition: all 0.4s;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

#home .c6 .item:hover:after{
	opacity: 1;
}

#home .c6 .item .img{
	width: 100%;
	height: 100%;
}

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

#home .c6 .item .description{
	position: absolute;
    left: 0;
    bottom: -100%;
    background-color: #0C4FB3;
    width: 100%;
    padding: 12px 20px 12px 40px;
    box-sizing: border-box;
    transition: all 0.4s;
    text-align: left;
    color: #fff;
    font-size: 13px;
    line-height: 22px;
	z-index: 2;
}

#home .c6 .item .description:after{
	content: '';
	background-image: url(images/icon-infos.svg);
	background-size: 18px;
	background-repeat: no-repeat;
	background-position: center;
	width: 18px;
	height: 18px;
	position: absolute;
	left: 13px;
    top: 14px;
}

#home .c6 .item:hover .description{
    bottom: 0;
}

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

#home .c6 .item a:before {
    content: '';
    position: absolute;
    width: 40%;
    height: 300px;
    right: 0;
    bottom: 20px;
    background-image: url(images/photo-deco-yellow.png);
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size: contain;
    transition: all 0.6s;
	z-index: 1;
}

#home .c6 .item a:hover:before {
    opacity: 0;
}

#home .c7{
text-align:center;
padding:50px 0px;
}

#home .c7 .item{
display:block;
margin:auto;
max-width:800px;
padding:13px 30px;
border:2px solid #004A9D;
margin-bottom:20px;
text-align:left;
position:relative;
cursor: pointer;
}

#home .c7 .item .hide_content{
opacity: 0;
height: 0;
overflow: hidden;
transition: all 0.6s;
transform: translateY(-10px);
}

#home .c7 .item.open .hide_content{
opacity: 1;
height: auto;
transform: translateY(0);
margin-top: 20px;
}

#home .c7 .item .arrow{
position: absolute;
right: 34px;
top: 35px;
width: 20px;
height: 16px;
background-size: 100%;
background-repeat: no-repeat;
background-position: center;
background-image: url('images/icon_arrow.png');
transform: rotate(0);
transition: all 0.6s;
}

#home .c7 .item.open .arrow{
transform: rotate(180deg);
}

#home .c7 .item h3{
color:#bababa;
text-transform: uppercase;
font-size: 18px;
letter-spacing:-1px;
font-weight: 400;
line-height: 26px;
margin-bottom:20px;
background-image: url('images/icon_faq.png');
background-repeat: no-repeat;
background-position: 0px 5px;
padding: 17px 0px 17px 63px;
margin-bottom:0px;
}




/* ***** 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:36%;
margin-right:6%;
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:36%;
padding:1%;
margin-right:4%;
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:73px;
}


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


#footer{
background: linear-gradient(to right, #004A9D, #004B70);
text-align: center;
margin-top: 100px;
position: relative;
}

#footer .background{
position: absolute;
top: 0;
left: 0;
height: 100%;
width: 100%;
overflow: hidden;
z-index: 1;
}

#footer .background span{
font-size: 13px;
color: #fff;
opacity: 0.05;
text-transform: uppercase;
display: block;
text-align: justify;
width: 100%;
line-height: 19px;
}

#footer .content{
position: relative;
z-index: 2;
}

#footer .content .logo{
width: 250px;
height: auto;
margin: 50px auto 15px;
}

#footer .content .contact{
display:block;
margin-top:17px;
text-align:center;
}

#footer .content .contact p{
display:inline-block;
vertical-align:top;
font-size:17px;
padding-top:10px;
color:#fff;
}

#footer .content .contact p a{
text-decoration:none;
padding:0px 7px;
}

#footer .content .contact p a:hover{
text-decoration:underline;
background:none;
}

#footer .content .social{
display:block;
vertical-align:top;
}

#footer .content .social a{
display: inline-block;
transition: transform 0.3s;
width:30px;
height:30px;
padding: 0 5px;
}

#footer .content .social a:hover{
animation: spinShrinkBounce 0.6s ease-in-out;	
}

@keyframes spinShrinkBounce {
  0% {
    transform: rotate(0deg) scale(1);
  }
  30% {
    transform: rotate(360deg) scale(0.7);
  }
  60% {
    transform: rotate(360deg) scale(1.1);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}

#footer p.copyright.center{
margin: 90px auto 0;
max-width: 500px;
}

#footer p.copyright{
color:white;
text-align:center;
font-size:14px;
padding-bottom:15px;
}

#footer p.copyright a{
color:white;
text-decoration:underline;
}

#footer p.copyright+a{
width: 100px;
display: block;
margin: 0 auto;
padding-bottom: 30px;
}

#footer p.copyright+a img{
width: 100%;
height: auto;
opacity: 0.4;
}




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

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

#cookieChoiceInfo a{
	display: inline-block;
}

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

.fade_container {
    overflow-x: hidden;
}