@charset "UTF-8";
/* CSS Document */

@font-face {
    font-family: 'latoregular';
    src: url('../fonts/lato-regular-webfont.woff2') format('woff2'),
         url('../fonts/lato-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}
@font-face {
    font-family: 'latolight';
    src: url('../fonts/lato-light-webfont.woff2') format('woff2'),
         url('../fonts/lato-light-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'latobold';
    src: url('../fonts/lato-bold-webfont.woff2') format('woff2'),
         url('../fonts/lato-bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}
@font-face {
    font-family: 'montserratbold';
    src: url('../fonts/montserrat-bold-webfont.woff2') format('woff2'),
         url('../fonts/montserrat-bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}
@font-face {
    font-family: 'montserratmedium';
    src: url('../fonts/montserrat-medium-webfont.woff2') format('woff2'),
         url('../fonts/montserrat-medium-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}
@font-face {
    font-family: 'montserratregular';
    src: url('../fonts/montserrat-regular-webfont.woff2') format('woff2'),
         url('../fonts/montserrat-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}


html{ height: 100%;}
body{
    margin: 0;
    min-height: 100%;
    position: relative;
    font-family: 'latoregular';
    font-size: 19px;
    line-height: 25px;
    text-align: justify;
    color: #0e4b77;
}
header, section, footer, article, aside{ display:block;}
a{ color: inherit; text-decoration: none;
    transition:0.5s;
    -o-transition:0.5s;
    -webkit-transition:0.5s;
    -ms-transition:0.5s;
    -moz-transition:0.5s;
}

h1, h2, h3, h4, h5{ font-weight: normal; font-family: 'montserratregular';}



.wrapper{ width: 100%; height: 100%; margin: auto; overflow: hidden; text-align: left;}
.container{ width: 95%; max-width: 1200px; margin: auto;}


header{
    width: 100%; height: 145px; z-index: 9999;
    position: absolute; top: 0; left: 0; right: 0;
}

header .logo{
    display: table; vertical-align: middle; float: left;
    height: 145px; line-height: 145px;
}
header .logo a{
    display: table-cell; vertical-align: middle; line-height: 1;
}
header .logo a img{ display: block; border: none;}

header .top_nav{
    height: 145px; line-height: 145px;
}
header nav{
    font-family: 'montserratmedium'; font-size: 13px; text-transform: uppercase; text-align: center;
    float: right;
    height: 145px; line-height: 145px;
}
header nav ul{ list-style-type: none; margin: 0; padding: 0;}
header nav ul li{
    display: inline-block; position: relative;
    height: 50px; line-height: 50px;  vertical-align: middle;
}
header nav ul li+li{ margin-left: 2px;}
header nav ul li a{
    display: block; position: relative; vertical-align: middle;
    color: #333; padding: 0 10px; height: 50px; line-height: 50px;
    border-bottom: solid 3px rgba(24,160,195,0);
}
header nav ul li a .menu-image-title{ display: inline-block; line-height: 18px; vertical-align: middle;}
header nav ul li a:hover, header nav ul li a.activ{ border-bottom: solid 3px rgba(24,160,195,1);}


header nav ul li a.activ:after, header nav ul li a:hover:after{
    opacity: 1;
}
header .showMenu{ display: none;}
header nav.phoneNav{ display: none;}


.slider{
  width: 100%; height: 550px; margin: auto; position: relative;
  background: linear-gradient(to top, #d5d4d5, #FFF);
}
.slider .banner{ position: absolute; width: 100%; height: 100%; top: 0; left: 0; overflow: hidden;}
.slider .banner .item{
    width: 100%; height: 100%; position: absolute; top: 0; left: 0;
}
.slider .banner .item img{ display: block; width: 100%; height: 100%; object-fit:cover}
.slider .layers{
  display: table; width: 100%; height: 100%;
}
.slider .layers .content{
  display: table-cell; width: 100%; height: 100%; position: relative;
  vertical-align: bottom; color: #7e7e7e; text-align: left;
}
.slider .layers h1{
  font-size: 22px; line-height: 30px;
  font-family: 'montserratbold' !important;
  text-transform: uppercase; color: #18a0c3;
}
.slider .layers p{
  font-size: 16px;  width: auto; text-align: left; margin: 0 0 10px 0;
}
.slider .layers p strong{ font-weight: normal; font-family: 'latobold'; color: #18a0c3; }
.slider .layers .button a{
  display: inline-block; padding: 10px 30px;
  background: #18a0c3; border:solid 2px #18a0c3;
  font-family: 'montserratbold'; text-transform: uppercase;
  font-size: 25px; color: #FFF; 
  -webkit-border-radius: 8px; -moz-border-radius: 8px; -ms-border-radius: 8px; -o-border-radius: 8px; border-radius: 8px;
}

.slider .layers .button a:hover{ background: none; border:solid 2px #18a0c3; color: #18a0c3;  }
.bande_slider{
    background: #18a0c3; color: #FFF; padding: 20px 0; text-align: center;
}
.bande_slider h2{ font-size: 28px; line-height: 34px; text-align: center; margin: 0;}
.bande_slider p{ font-size: 21px; line-height: 30px; }

.bande_slider .form_content{ display: none; color: #000; }


.page_title{
  background: #18a0c3;
  padding: 30px 0; position: relative; height: auto;
}
.page_title .back_img{
  width: 100%; height: 100%; overflow: hidden;
  position: absolute; top: 0; left: 0;
}
.page_title .back_img img{
  display: block; width: 100%; height: 100%;
  object-fit: cover;
}
.page_title .back_img:after{
  display: block; width: 100%; height: 100%;
  content: ""; background: rgba(0,0,0,0.5);
  position: absolute; top: 0; left: 0:;
}
.page_title .container{ position: relative; padding-top: 150px;}
.page_title .breadcrumb{
  width: 100%; font-family: 'montserratregular';
  list-style-type: none; margin: 0; padding: 0 0 20px 0;
  font-size: 12px; color: #FFF; border:none;
}
.page_title .breadcrumb li{
  display: inline-block; text-shadow:none;
}
.page_title .breadcrumb li+li:before{
    padding: 0 8px;
    color: #18a0c3; font-size: 12px;
    content: ""; font-family: 'FontAwesome';
}
.page_title .breadcrumb a{ color: #FFF}
.page_title h1{
  font-size: 30px; line-height: 35px; margin: 0;
  font-family: 'montserratbold'; text-align: left;
  color: #FFF;
}
.page_title h1:after{
    content: ''; display: block; margin-top: 10px;
    width: 90px; height: 2px;
    background: #d5a544;
}
.page_title p{
  font-size: 16px;  width: auto; text-align: left; margin: 0 0 10px 0;
  text-align: center;
}
.page_title p strong{ font-size: 19px; font-weight: normal; font-family: 'montserratbold'; color: #18a0c3; }
.page_title .bande_slider{ background: none;}





article p{ margin: 0 0 10px 0;}
article p+p{ margin-top: 10px;}
article+article{ margin-top: 35px;}
article a:hover{ color: #18a0c3;}
p a{ color: #48b3dd;}

.header{ margin-bottom: 50px; }
.header h1, .header h2{
    font-size: 30px; line-height: 40px; text-align: center; color: #18a0c3;
    margin: 30px 0 10px 0; text-transform: uppercase;
}
.header h1:after, .header h2:after{
    content: ''; display: block; margin: auto; margin-top: 5px;
    width: 90px; height: 2px;
    background: #18a0c3;
}
.header p{ text-align: center; font-size: 20px; text-transform: uppercase; color: #000;}

article h2{ 
    font-size: 28px; line-height: 32px; font-family: 'montserratregular';
    color: #4c4c4c; margin: 30px 0 20px 0; padding: 0; text-transform: uppercase;
}
article h2 span{ color: #18a0c3; }
article .title h2{ text-align: center;}


article h3{ 
    font-size: 17px; line-height: 20px; text-transform: uppercase;
    color: #18a0c3; margin: 30px 0 5px 0; padding: 0;
}

section.divided{ background: #EFEFEF; padding: 20px 0 0 0;}
section.divided .container{ padding-bottom: 30px;}
.divided .box{
  margin: 0 20px 20px 20px; box-shadow: 0 0 5px #CCC;
  background: #FFF; padding: 40px 30px;
}


/*Features*/
.features{ margin: 50px 0;}
.featureItem{ padding: 0 10px; margin-bottom: 20px;}
.featureItem figure{ width: 100%; margin: 0; padding: 0;}
.featureItem figure a{
  display: block; width: 100%; height: auto;
  position: relative; overflow: hidden;
  -webkit-border-radius: 20px; -moz-border-radius: 20px; -ms-border-radius: 20px; -o-border-radius: 20px; border-radius: 20px;
}
.featureItem figure img{ display: block; width: 100%;}
.featureItem figcaption{
  width: 100%; box-sizing: border-box;
  padding: 10px; background: rgba(24,160,195,0.7); color: #FFF; font-size: 14px; text-align: justify;
  position: absolute; left: 0; bottom: 0;
}
.featureItem figcaption h2{
  text-transform: uppercase; font-family: 'montserratmedium';
  margin: 0 0 5px 0; color: #FFF; font-size: 15px; line-height: 20px;
}
.featureItem figcaption p{ margin: 0; text-align: left; }
/*end of Features*/

.parallax{
  width: 100%; height: auto; position: relative;
  background: url(../img/parallax.jpg) no-repeat fixed center;
  -webkit-background-size: cover; -moz-background-size: cover; -ms-background-size: cover; -o-background-size: cover; background-size: cover;
  margin: 30px 0; padding: 50px 0;
}
.parallax .parallax_content{position: relative;color: #FFF;}
.parallax h2{ font-size: 32px; line-height: 40px; font-family: 'montserratbold'; text-transform: uppercase;}
.parallax p{ font-size: 17px; line-height: 25px; }
.parallax .overlay{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; background: rgba(0,0,0,0.5);}


/*formulaire*/
.form_content h3{ font-family: 'montserratbold'; color: #000; }
.form_content .form_block{
  padding: 30px; background: #FFF;
}
.form_content .input{ padding: 5px; box-sizing: border-box;}
.form_content .input label{
  display: block; margin-bottom: 5px;
  color: #000;
}
.form_content .input input, .form_content .input select{
  width: 100%; padding: 10px;
  border: none; background: #EEE;
  box-sizing: border-box; line-height: inherit;
}
.form_content .input option{ padding: 10px; }
.form_content .input select{ padding: 0; }
.form_content p{ font-size: 12px;}
.form_content .submit{
  text-align: center;
}
.form_content .submit button{
  padding: 10px 25px; background: #18a0c3; color: #FFF;
  font-family: 'montserratbold'; border: none;
  text-transform: uppercase; font-size: 20px;
}
.form_content .submit button i{ display: inline-block; margin-left: 18px; color: #FFF;}

.form_content .form_block h4{ font-family: 'montserratbold'; margin: 20px 0 5px 0; color: #18a0c3;}

.form_content .form_block .hidden{ display: none;}
/*end of formulaire*/


/*rappel*/
.rappel_block{
    width: 100%; padding: 10px 0;
    background: #18a0c3;
}
.rappel_block h2{
    color: #FFF;
}
.rappel_form{}
.rappel_form .input{
    width: 100%; position: relative;
    padding: 10px 30px; box-sizing:border-box;
}
.rappel_form .input input{
    display: block; border: none; width: 100%;
    box-sizing:border-box; padding: 10px 30px;
    color: #222222;
}
.rappel_form .input button{
    padding: 15px 35px; background: #404041; color: #FFF;
    font-family: 'montserratbold'; border: none;
    font-size: 17px;
}
.rappel_form .input button i{ display: inline-block; margin-left: 18px; color: #18a0c3;}
/*end of rappel*/



/*actualites*/
.actualites article .img{
  float: left; width: 15%;
}
.actualites article .img img{ display: block; max-width: 100%;}
.actualites article .text{
  width: 85%; float: left; padding: 0 0 0 20px;
  box-sizing:border-box;
}
.actualites article h3,.actualite article h3{ margin: 0;}
.actualites article .date, .actualite article .date{ font-size: 12px; margin-bottom: 5px; color: #18a0c3;}
.actualites article .text p{ margin: 0;}
.actualites article .read_more_link{
  display: inline-block; padding: 5px 15px; text-transform: uppercase;
  font-size: 12px; line-height: 1; color: #FFF; background: #18a0c3;
}

.actualite article .img{
  float: left; margin: 0 10px 10px 0;
}

.pagination{ margin: 20px 15px; text-align: center;}
.pagination a{
  display: inline-block; height: 25px; line-height: 25px; padding: 0 10px;
  font-size: 13px; background: #FFF; color: #CCC; border:solid 1px #18a0c3;
}
.pagination a:hover, .pagination a.activ{background: #FFF; color: #c1c1c1;}

.pagination a:hover, .pagination a.activ{background: #18a0c3; color: #FFF;}

/*end of actualites*/




/*simpleList*/
.simpleList{ list-style-type: none;}
.simpleList li{ position: relative; padding: 5px 0; box-sizing:border-box;}
.simpleList li:before{content: ''; font-family: 'FontAwesome'; font-size: 11px; color: #18a0c3; position: absolute; left: -17px;}
/*end of simpleList*/

.simpleTable{ margin-top: 20px; width: 100%;}
.simpleTable th{ border: none; background: #246493; font-size: 15px; color: #000000; font-weight: normal; padding: 5px 10px; text-align: center; color: #FFF; font-size: 12px; font-weight: bold;}
.simpleTable th span{ display: block; font-weight: normal; font-size: 10px;}
.simpleTable tr:nth-child(2n+2){background: rgba(0,0,0,0.1);}
.simpleTable td{ padding: 5px 10px;}


/*contact*/
.contact article h2{ text-transform: uppercase;  font-size: 17px; margin: 20px 0 10px 0;}
.contact label{ display: block; float: left; padding: 10px 5px;}
.contact input{ border:solid #dfdfdf 1px; width:100%; padding:10px 15px; box-sizing: border-box;}
.contact select{ border:solid #dfdfdf 1px; width:100%; padding:8px 15px; box-sizing: border-box;}
.contact input[type="file"]{ width: auto;}
.contact textarea{border:solid #dfdfdf 1px; width:100%; padding:10px 15px; height:100px; box-sizing: border-box; margin-top: 20px;}
.contact .buttons{ float: right;}
.contact .buttons a.formLink{ display: inline-block; color: #18a0c3; padding: 0 10px;}
.contact input[type="submit"], .contact button{background:#18a0c3; color:#FFFFFF;  border:none; margin:10px 0; padding:5px 15px; font-size:12px; width: auto;}

.contact .borderSep{ margin: 20px 0; border-bottom: solid 1px #dfdfdf;}
.dateSelector{ position: relative;}
.dateSelector a{ display: block; position: absolute; top: 10px; right: 10px;}
.contact .montant{ text-align: right; font-size: 20px;}
/*End of contact*/

.border_block{ margin: 30px 0; padding: 0 30px;}

.borderSep{ width: 100%; margin: 30px 0; border-bottom: solid 1px #CACACA;}


.msg_ok{ font-weight:bold; color:#72a132; margin-bottom: 10px;}
.msg_ok i{ font-size: 25px;}
.msg_ko{ font-weight:bold; color:red; margin-bottom: 10px;}
.msg_ko i{ font-size: 25px;}

.requiredField{ background:#dd7171; color:#7d0000;}
.requiredFieldTxt{ color:#cf0000; font-size: 11px; font-weight: bold; display: none;}

.imgFull{ display: block; margin: auto; max-width: 100%; margin-bottom: 10px;}
.imgCenter{ display: block; margin: 10px auto; max-width: 100%;}
.imgLeft{ display: block; float: left; margin: 0 20px 20px 0;}
.borderImg{ padding: 5px; background: #FFF; border: solid 1px #d3d3d3;}

.row-fluid{ margin-bottom: 40px;}
.one_half{ width: 50%; float: left; box-sizing: border-box;}
.one_third{ width: 33.33%; float: left; box-sizing: border-box;}
.two_third{ width: 66.66%; float: left; box-sizing: border-box;}
.one_fourth{ width: 25%; float: left; box-sizing: border-box;}
.three_fourth{ width: 75%; float: left; box-sizing: border-box;}



.padding5{ padding: 5px;}
.padding10{ padding: 10px;}
.padding20{ padding: 20px;}
.clear{ clear: both;}
.clearRight{ clear: right;}



footer{ width: 100%; position: relative;
  background: #000; color: #FFF;
  text-align: left;
}
footer nav{
  padding: 20px 0; text-align: center;
}
footer nav a{
  display: inline-block; color: #FFF; padding: 0 10px;
  text-transform: uppercase; font-size: 10px;
}
footer nav a:hover{ color: #FFF;}


footer .copyright{
    background: #E5E5E5;
    font-size: 13px; line-height: 15px;
    padding: 10px 0; color: #AAA;
    text-transform: uppercase; text-align: center;
}

