*{
	margin: 0;
	padding: 0;
	box-sizing:border-box;
}

a img{border:none;}

body{
	font-family: 'Roboto Condensed', sans-serif;
	font-size: 16px;
}

.wrap{
	width: 1080px;
	max-width: 98%;
	margin: 0 auto;
}

header{
	background: #fff;
	padding: 9px 0;
	border-bottom:3px solid #2b3742;
}

a.logo{
	text-decoration: none;
	text-indent: -9999px;
	background: url(../images/logo-gervaisdube.png);
	background-size: cover;
	width: 205px;
	height: 110px;
	display: inline-block;
	vertical-align: top;
}

.cdf a.logo{
	background: url(../images/cdf-logo-blue.png);
	background-size: cover;
	width: 185px;
}

.nav-container{
	display: inline-block;
	vertical-align: top;
	width: calc(100% - 205px);
	text-align: right;
}

.cdf .nav-container{width: calc(100% - 185px);}

.top-nav{
	display: inline-block;
	text-align: left;
	padding-top: 15px;
}

.top-nav li{
	display: inline-block;
	vertical-align: middle;
	height: 30px;
	line-height: 30px;
	margin-left: 60px;
}

.top-nav li:not(:first-of-type):before, .hnav a:not(:first-of-type):before, nav.main a:not(:first-of-type):before{
	content:"";
	display: block;
	width: 1px;
	height: 30px;
	position: absolute;
	top: 0;
	left: -30px;
	background: #c9c9c9;
}

.top-nav li:first-child{
	color: #c5c5c5;
	font-size:14px;
	font-weight: 300;
}

.top-nav li:nth-child(2){
	position: relative;
	padding-left: 96px;
	font-size:14px;
	font-family: 'Rajdhani', sans-serif;
	font-weight: 600;
	text-transform: uppercase;
}

.cdf .top-nav li:nth-child(2){padding-left: 37px;}

.top-nav li:nth-child(2) a{
	color: #7f7f7f;
	text-decoration: none;
	transition: all .4s;
}

.top-nav li:nth-child(2) a:hover{
	color: #394754;
}

.top-nav li:nth-child(2) img{
	display: block;
	height: 30px;
	position: absolute;
	top: 0;
	left: 0;
	transition: all .4s;
}

.top-nav li:last-child{
	position: relative;
	width: 26px;
}

.top-nav li:last-child img{
	display: block;
	width: 26px;
	height: 26px;
	position: absolute;
	top: 2px;
	left: 0;
	transition: all .4s;
}

.top-nav li img+img{opacity: 0;}
.top-nav li a:hover img+img{opacity: 1;}

p.sloganheader{
	font-family: 'Rajdhani', sans-serif;
	text-transform: uppercase;
	font-size: 22px;
	font-weight: 600;
	margin-top: 25px;
	color: #394754;
}
.hnav{
	font-family: 'Rajdhani', sans-serif;
	text-transform: uppercase;
	font-size: 18px;
	font-weight: 600;
	margin-top: 25px;
}

.hnav a{
	text-decoration: none;
	color: #7f7f7f;
	display: inline-block;
	vertical-align: middle;
	height: 30px;
	line-height: 30px;
	margin-left: 60px;
	position: relative;
	transition: all .4s;
}

.hnav a:hover{
	color: #394754;
}

.slider{
	display: block;
	width: 100%;
	position: relative;
}

.slider:before{
	content:"";
	display: block;
	width: 100%;
	height: 120px;
	position: absolute;
	z-index: 5;
	top: 0;
	left: 0;
	background: rgba(57,71,84,1);
	background: -moz-linear-gradient(top, rgba(57,71,84,1) 0%, rgba(57,71,84,1) 1%, rgba(57,71,84,0.9) 19%, rgba(57,71,84,0) 100%);
	background: -webkit-gradient(left top, left bottom, color-stop(0%, rgba(57,71,84,1)), color-stop(1%, rgba(57,71,84,1)), color-stop(19%, rgba(57,71,84,0.9)), color-stop(100%, rgba(57,71,84,0)));
	background: -webkit-linear-gradient(top, rgba(57,71,84,1) 0%, rgba(57,71,84,1) 1%, rgba(57,71,84,0.9) 19%, rgba(57,71,84,0) 100%);
	background: -o-linear-gradient(top, rgba(57,71,84,1) 0%, rgba(57,71,84,1) 1%, rgba(57,71,84,0.9) 19%, rgba(57,71,84,0) 100%);
	background: -ms-linear-gradient(top, rgba(57,71,84,1) 0%, rgba(57,71,84,1) 1%, rgba(57,71,84,0.9) 19%, rgba(57,71,84,0) 100%);
	background: linear-gradient(to bottom, rgba(57,71,84,1) 0%, rgba(57,71,84,1) 1%, rgba(57,71,84,0.9) 19%, rgba(57,71,84,0) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#394754', endColorstr='#394754', GradientType=0 );
}

.slider .slide{
	height: 760px;
	background-size: cover;
	background-position: center;
	position: relative;
	overflow: hidden;
}

header+.slider .slide:not(:first-child){display: none;}

.captions{
	width: 400px;
	position: absolute;
	top: 0;
	right: calc(50% - 540px);
	background: #394754;
	color: #fff;
	text-align: center;
	font-weight: 400;
	font-family: 'Rajdhani', sans-serif;
	padding: 20px 0;
	font-size: 22px;
	z-index: 10;
	opacity: 0;
	transform: translateY(-100%);
	transition:all .4s;
}

.realslider .captions{
	width: 540px;
}

.active-slide .captions{
	opacity: 1;
	transform: translateY(0%);
}

.captions .title{
	text-transform: uppercase;
	font-weight: 600;
	margin-bottom: 10px;
}

.bx-next, .bx-prev{
	display: block;
	width: 46px;
	height: 46px;
	font-size:0;
	background: url(../images/slider-arrow.png);
	background-size: cover;
	position: absolute;
	left: 5%;
}

.bx-next{
	transform: rotate(180deg);
	right: 5%;
	left: auto;
}

.bx-controls{
	width: 100%;
	position: absolute;
	top:50%;
	transform: translateY(-50%);
}

nav.main{
	text-align: center;
	text-transform: uppercase;
	padding: 20px 0;
	background: #394754;
}

nav.main a{
	display: inline-block;
	text-decoration: none;
	color: #fff;
	font-weight: 300;
	font-size:20px;
	font-family: 'Rajdhani', sans-serif;
	height: 30px;
	line-height: 30px;
	position: relative;
}

nav.main a:not(:first-of-type){margin-left: 60px;}

nav.main a:hover{
	text-shadow: 1px 0px 0px rgba(255, 255, 255, 1);
}

section.content .wrap{
	padding: 105px 45px;
	
}

h1{
	font-family: 'Rajdhani', sans-serif;
	font-size:28px;
	font-weight: 700;
	margin-bottom: 40px;
}

section.content h2{
	font-family: 'Rajdhani', sans-serif;
	font-size:22px;
	font-weight: 700;
}

section.content div+h2{
	margin: 20px 0 40px;
}

section.content p{
	margin-bottom: 30px;
	line-height: 26px;
}

img.gal4{
	display: inline-block;
	vertical-align: top;
	width: calc(25% - 15px);
}

.gal5{text-align: center;}

img.gal5{
	display: inline-block;
	vertical-align: top;
	width: calc(100% / 3 - 30px);
	margin-left: 15px;
	margin-right: 15px;
	margin-bottom: 30px;
}

img.gal4:not(:last-of-type){
	margin-right: 20px;
}

img.gal2{
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 30px);
	margin-left: 15px;
	margin-right: 15px;
	margin-bottom: 30px;
}

#map{
	height: 400px;
	width: 100%;
}

.contact-img{
	display: inline-block;
	vertical-align: middle;
	height: 160px;
	margin-bottom: 40px;
}

.contact-div{
	display: inline-block;
	vertical-align: middle;
	margin-left: 30px;
	margin-bottom: 40px;
}

section.content .contact-div p{margin-bottom: 0;}

section.content a{
	font-weight: 700;
	text-decoration: none;
	color: #000;
	transition: all .4s;
}

section.content a:hover{
	color: #394653;
}

section.content ul{
	margin-bottom: 30px;
}

section.content li{
	list-style-type: none;
	position: relative;
	padding-left: 50px;
	margin-bottom: 10px;
}

section.content ul.double li{
	display: inline-block;
	width: 45%;
}

section.content li:before{
	content:"";
	display: block;
	position: absolute;
	top: 50%;
	transform:translateY(-50%);
	left: 25px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #394653;
}

.half{
	display: inline-block;
	vertical-align: top;
	width: 50%;
}

p.half{
	padding-right: 30px;
}

.prefoot{
	background: #394754;
	color: #fff;
	padding: 40px 0;
}

.prefoot p{
	display: inline-block;
	vertical-align: middle;
	width: calc(100% / 3);
	text-align: center;
	height: 60px;
	line-height: 60px;
	padding-left: 55px;
	font-size:18px;
	font-family: 'Rajdhani', sans-serif;
	position: relative;
	border-left: 1px solid #fff;
}

.prefoot p:first-child{
	text-align: left;
	padding-left: 100px;
	border-left: 0px;
	line-height: 26px;
}

.prefoot a{
	text-decoration: none;
	color: #fff;
}

.prefoot p:nth-child(1):before{
	content:"";
	display: block;
	width: 24px;
	height: 30px;
	position: absolute;
	top: 16px;
	left: 45px;
	background:url(../images/marker-icon.png);
	background-size: cover;	
}.prefoot p:nth-child(2):before{
	content:"";
	display: block;
	width: 30px;
	height: 30px;
	position: absolute;
	top: 14px;
	left: 100px;
	background:url(../images/phone-icon.png);
	background-size: cover;	
}.prefoot p:nth-child(3):before{
	content:"";
	display: block;
	width: 30px;
	height: 23px;
	position: absolute;
	top: 17px;
	left: 70px;
	background:url(../images/mail-icon.png);
	background-size: cover;	
}

footer{
	background: #fff;
	padding: 25px 0;
}

footer nav{
	display: inline-block;
	vertical-align: middle;
	width: 40%;
}

footer nav a{
	display: inline-block;
	vertical-align: middle;
	font-size:14px;
	color: #bfbfbf;
	text-decoration: none;
	text-transform: uppercase;
	font-family: 'Rajdhani', sans-serif;
	font-weight: 300;
	margin-left: 30px;
}

footer nav a:first-child{margin-left: 0;}

footer nav a:hover{
	color: #394754;
}

footer .copy, footer .etincelle{
	display: inline-block;
	vertical-align: middle;
	color: #bfbfbf;
	font-size:14px;
	font-weight: 300;
	width: 30%;
}

footer .etincelle{
	text-align: right;
	line-height: 19px;
	text-decoration: none;
}

footer .etincelle span{
	display: inline-block;
	vertical-align: middle; 
}

footer .etincelle img{
	display: inline-block;
	vertical-align: middle; 
	width: 64px;
	height: 19px;
	margin-left: 8px;
}

.menu-ico{display: none;}

a.btn{
	display: inline-block;
	padding: 7px 14px;
	border:1px solid #000;
}

a.btn:hover{
	background: #394754;
	border:1px solid #394754;
	color: #fff !important;
}

.bannerjob{
	display: block;
	width: 100%;
	margin-bottom: 40px;
	margin-top: -40px;
}

.bannerjob.real{
	margin-top: 0;
}

p.sloganheader br{display: none;}

@media screen and (max-width: 1200px) {
	
	nav.main a:not(:first-of-type){margin-left: 30px;}
	.top-nav li:not(:first-of-type):before, .hnav a:not(:first-of-type):before, nav.main a:not(:first-of-type):before{left: -15px;}
}
@media screen and (max-width: 1080px) {
	.slider .slide{
		height: 450px;
	}
	
	.captions, .realslider .captions{
		right: 20px;
		max-width: 70%;
		padding-left: 10px;
		padding-right: 10px;
	}
	
	a.logo{
		width: 240px;
   		height: 130px;
		display: block;
		margin: 20px auto;
	}
	.cdf a.logo{width: 200px;height: 116px;}
	.nav-container, .cdf .nav-container{
		width: 100%;
		text-align: center;
	}
	
	.top-nav li:first-child, .hnav a:first-child{margin-left: 0;}
	
	.top-nav li, .hnav a{margin-left: 20px;}
	
	.top-nav li:not(:first-child):before, .hnav a:not(:first-child):before{left: -10px;}
	
	.top-nav li:nth-child(2){padding-left: 60px;}
	.top-nav li:nth-child(2) img{height: 20px; top: 5px;}
	
	.prefoot p, .prefoot p:first-child{
		display: block;
		width: 100%;
		text-align: left;
		padding-left: 150px;
		border-left: none;
	}
	.prefoot p:nth-child(2):before, .prefoot p:nth-child(3):before{left: 45px;}
	
	footer nav{
		display: block;
		width: 100%;
		text-align: center;
		margin-bottom: 15px;
	}
	
	footer .copy, footer .etincelle{
		width: 50%;
	}
	
	img.gal4, img.gal4:not(:last-of-type), img.gal5{
		width: calc(50% - 20px);
		margin-left: 0;
		margin-right: 0;
		margin-bottom: 20px;
	}
	
	img.gal4:not(:last-of-type):nth-of-type(2n), img.gal4:nth-of-type(2n), img.gal5:nth-of-type(2n){
		margin-left: 20px;
	}
	
	
	.cdf .contact-img{height: 110px;}
	
	.cdf .top-nav li:nth-child(2){
		font-size: 18px;padding-left: 40px;
	}
	.cdf  .top-nav li:nth-child(2) img{
		height: 30px;
		top: 0;
	}
}

@media screen and (max-width: 1024px) {
	
	.top-nav li, .hnav a{
		display: block;
		margin: 5px auto;
	}
	.top-nav li:not(:first-child):before, .hnav a:not(:first-child):before{
		display: none;
	}
	.menu-ico{
		display: block;
		margin: 0 auto;
		width: 40px;
		height: 22px;
	}
	
	.menu-ico span{
		display: block;
		width: 100%;
		height: 4px;
		background: #fff;
		margin-bottom: 5px;
	}
	
	nav.main a{
		display: block;
		margin-top: 10px;
	}
	
	nav.main a:not(:first-of-type) {
		margin-left: 0px;
	}
	
	nav.main a:not(:first-of-type):before{display: none;}
}

@media screen and (max-width: 600px) {
	.top-nav li, .hnav a{
		display: block;
		margin: 5px auto;
	}
	
	.captions, .realslider .captions{
		max-width: 100%;
		width: calc(100% - 20px);
		right: 10px;
		padding: 10px;
		font-size: 18px;
	}
	
	.captions .title{margin-bottom: 5px;}
	
	.bx-wrapper{position: relative;}
	
	.slider .slide{height: 300px;}
	
	.top-nav li:not(:first-child):before, .hnav a:not(:first-child):before{
		display: none;
	}
	
	section.content .wrap{padding: 45px 5px;}
	
	.prefoot p, .prefoot p:first-child{padding-left: 60px;}
	
	.prefoot p:nth-child(1):before, .prefoot p:nth-child(2):before, .prefoot p:nth-child(3):before{left: 15px;}
	
	footer nav a{
		margin-left: 10px;
		font-size:13px;
	}
	
	footer .copy, footer .etincelle{
		width: 100%;
		text-align: left;
	}
	
	footer .etincelle{margin-top: 20px;}
	
	.menu-ico{
		display: block;
		margin: 0 auto;
		width: 40px;
		height: 22px;
	}
	
	.menu-ico span{
		display: block;
		width: 100%;
		height: 4px;
		background: #fff;
		margin-bottom: 5px;
	}
	
	nav.main a{
		display: block;
		margin-top: 10px;
	}
	
	nav.main a:not(:first-of-type) {
		margin-left: 0px;
	}
	
	nav.main a:not(:first-of-type):before{display: none;}
	
	img.gal4, img.gal4:not(:last-of-type),img.gal4:not(:last-of-type):nth-of-type(2n), img.gal4:nth-of-type(2n), img.gal5{
		width: 100%;
		margin-left: 0 !important;
	}
	
	img.gal2{
		width: 100%;
		margin-left: 0;
		margin-right: 0;
		
	}
	
	.contact-div{
		display: block;
		margin-left: 0;
	}
	
	.half{width: 100%;}
	
	.cdf .top-nav li:nth-child(2) img{left: 60px;}
	.cdf .top-nav li:nth-child(2) {
		padding-left: 87px;
	}
	
	.bannerjob{margin-top: -20px;}
	.bannerjob.real{margin-top: 0px;}
	
	
	.cdf .top-nav li:nth-child(2){
		font-size: 14px;
	}
	.cdf  .top-nav li:nth-child(2) img{
		height: 20px;
		top: 5px;
	}
	p.sloganheader br{display: block;}
	p.sloganheader{font-size: 18px;margin-top: 15px;}
}









