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

@font-face {
    font-family: 'oswald_regularregular';
    src: url('../fonts/oswald-regular-webfont.woff2') format('woff2'),
         url('../fonts/oswald-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'oswaldbold';
    src: url('../fonts/oswald-bold-webfont.woff2') format('woff2'),
         url('../fonts/oswald-bold-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'pt_sansbold';
    src: url('../fonts/PTS75F-webfont.eot');
    src: url('../fonts/PTS75F-webfont.eot?#iefix') format('embedded-opentype'),
         url('../fonts/PTS75F-webfont.woff') format('woff'),
         url('../fonts/PTS75F-webfont.ttf') format('truetype'),
         url('../fonts/PTS75F-webfont.svg#pt_sansbold') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'pt_sansregular';
    src: url('../fonts/PTS55F-webfont.eot');
    src: url('../fonts/PTS55F-webfont.eot?#iefix') format('embedded-opentype'),
         url('../fonts/PTS55F-webfont.woff') format('woff'),
         url('../fonts/PTS55F-webfont.ttf') format('truetype'),
         url('../fonts/PTS55F-webfont.svg#pt_sansregular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

html{ height: 100%;}
body{
    margin:0; font-family:'pt_sansregular' !important; font-size: 17px !important; line-height: 30px !important; text-align: justify; color: #4c4c4c !important; min-height: 100%; position: relative;
}
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: 'oswaldbold';}
*{ box-sizing: border-box; }


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


header{
    width: 100%; height: 80px;
}
.header_top{
  width: 100%; height: 100%; background: #212122;
}


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

header .top_nav{
    height: 80px; line-height: 80px;
}
header nav{
    font-family: 'oswaldbold'; font-size: 15px; text-transform: uppercase; text-align: center;
    float: right;
    height: 80px; line-height: 80px;
}
header nav ul{ list-style-type: none; margin: 0; padding: 0;}
header nav ul li{
    float: left; position: relative;
    height: 80px; line-height: 80px;  vertical-align: middle;
}
header nav ul li+li{ margin-left: 0;}
header nav ul li a{
    display: block; position: relative; vertical-align: middle;
    color: #FFF; padding: 0 17px; height: 80px; line-height: 80px;
    overflow: hidden;
}
header nav ul li a .menu-image-title{ display: inline-block; line-height: 18px; vertical-align: middle; position: relative;}
header nav ul li a .icon{ display: inline-block; font-size: 25px; margin-bottom: 5px;}
header nav ul li a:before{
  display: block; width: 100%; height: 100%;
  content: ''; background: #a00b10;
  position: absolute; left: 0; bottom: -80px;
  transition:0.5s;
    -o-transition:0.5s;
    -webkit-transition:0.5s;
    -ms-transition:0.5s;
    -moz-transition:0.5s;
}
header nav ul li a.activ:before, header nav ul li a:hover:before{
    bottom: 0;
}


header nav ul.subMenu{
    width: 215px; position: absolute; left: 0; top: 80px; margin: 0;
    font-size: 15px; z-index: 1000; font-family: 'oswald_regularregular'; text-transform: none;
    border-bottom: solid 2px #a00b10; background: rgba(0,0,0,0.6); display: none;
}
header nav ul.subMenu li{
    display: block; float: none; margin: 0;
    overflow: hidden;
    -webkit-transition: 200ms ease-in;
    -moz-transition: 200ms ease-in;
    -o-transition: 200ms ease-in;
    transition: 200ms ease-in;
}
header nav ul.subMenu li+li{ border-top: solid 1px rgba(255,255,255,0.2); }
header nav ul.subMenu li{height: 35px; line-height: 35px;}
header nav ul.subMenu li a{ display: block; width: 215px; height: 35px; line-height: 35px; padding: 0 10px; text-align: left; border-bottom: none; color: #FFF;}
header nav ul.subMenu li a:before{ display: none; }
header nav ul li a:hover{ background: #a00b10; }
header nav ul li:hover > ul.subMenu{ display: block; }
header .showMenu{ display: none;}
header nav.phoneNav{ display: none;}


.slider{ width: 100%; height: auto; margin: auto; position: relative;}
.slider .placeHolder{ display: block; width: 100%; visibility: hidden;}
.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+.item{ display: none; }
.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: middle; color: #FFF; text-align: right;
}
.slider .layers .box{ width: 500px; float: right; margin-right: 80px; }
.slider .layers h1, .slider .layers h2{
  font-size: 32px; line-height: 40px;
  font-family: 'oswaldbold'; text-transform: uppercase;
  color: #a00b10; margin: 0 0 10px 0;
}
.slider .layers p{
  font-size: 28px; line-height: 35px; margin: 0 0 10px 0;
  font-family: 'oswald_regularregular';
}
.slider .arrows{ width: 100%; position: absolute; top: 47%;}
.slider .arrows a{ display: block; color:#FFF; font-size: 50px; margin: 0 13px;}
.slider .arrows a.previous{ float: left;}
.slider .arrows a.next{ float: right;}

.page_title{
  padding: 30px 0; position: relative; height: 500px;

}
.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 .container{ padding: 100px 0 20px 0;}
.breadcrumb{
  width: 100%; font-family: 'oswald_regularregular';
  list-style-type: none; margin: 0; padding: 0;
  font-size: 15px; border:none;
}
.breadcrumb li{
  display: inline-block; text-shadow:none;
}
.breadcrumb li+li:before{
    padding: 0 8px;
    color: #a00b10; font-size: 12px;
    content: ""; font-family: 'FontAwesome';
}
.breadcrumb a{ color: #a00b10}
.page_title p{
  font-size: 16px; width: auto; text-align: left; margin: 0 0 10px 0;
  text-align: center; font-family: 'pt_sansregular';
}
.page_title p strong{ font-family: 'pt_sansbold';}
.page_title .bande_slider{ background: none; color: #FFF;}

article{ padding: 20px; }
article p{ margin: 0 0 10px 0;}
article p+p{ margin-top: 10px;}
article+article{ margin-top: 35px;}
article a:hover{ color: #a00b10;}
p a{ color: #48b3dd;}
a.read_more{
  display: inline-block; padding: 7px 20px; margin: 20px 0; text-transform: uppercase;
  background: #a00b10; color: #FFF; border: solid 2px #a00b10;
}
a.read_more:hover{ background: #FFF; color: #a00b10; }
.strong_text{
  font-family: 'oswaldbold'; font-size: 17px; color: #212122;
  text-transform: uppercase; margin: 20px 0;
}

.header{ margin-bottom: 30px; }
.header h1, .header h2{
    font-size: 35px; line-height: 50px; text-align: center; color: #212122;
    margin: 30px 0 10px 0;
}
.header h1:after, .header h2:after{
  content: ''; display: block; margin: auto; margin-top: 0px;
  width: 130px; height: 1px; position: static;
  background: #a00b10;
}
.header p{ text-align: center; font-size: 20px; font-family: 'oswaldbold'; margin: 0; color: #3d3c3f;}


.title_page{ margin-bottom: 50px; }
.title_page p{ color: #000; text-transform: uppercase; }
.title_page h1{
  font-size: 30px; line-height: 35px; margin: 20px 0;
  font-family: 'oswaldbold'; text-align: left; text-transform: uppercase;
  color: #000; position: relative;
}
.title_page h1:after{
    content: ''; display: block; margin-top: 10px;
    width: 100px; height: 2px;
    background: #a00b10;
    position: absolute; left: 0; bottom: : 10px;
}
article h2{ 
    font-size: 25px; line-height: 30px; font-family: 'oswaldbold' !important;
    color: #212122; margin: 30px 0 10px 0; padding: 0; overflow: hidden;
    text-transform: uppercase;
    position: relative; padding-left: 10px;
}
article h2:after{
    content: ''; display: block;
    width: 2px; height: 50px;
    background: #a00b10;
    position: absolute; top: 0; left: 0;
}

article h3{ 
    font-size: 21px; line-height: 25px; text-transform: uppercase;
    color: #a00b10; margin: 30px 0 5px 0; padding: 0;
}

.container.decale{
  position: relative; margin-top: -50px; background: #FFF;
}

/*Features*/
.features{ margin: 200px 0 50px;}
.featureItem{
  margin: 0 3px; padding: 100px 20px 20px; margin-bottom: 20px; background: #f6f6f6;
  position: relative; text-align: center; display: block;
}
.featureItem .icon{
  width: 190px; height: 190px; margin: auto;
  position: absolute; left: 0; right: 0; top: -120px;
  -o-transition:0.2s;
    -webkit-transition:0.2s;
    -ms-transition:0.2s;
    -moz-transition:0.2s;
}
.featureItem:hover .icon{ top: -110px; }
.featureItem .img{
  width: 190px; height: 190px; overflow: hidden; 
  -webkit-border-radius: 100%; -moz-border-radius: 100%; -ms-border-radius: 100%; -o-border-radius: 100%; border-radius: 100%;
}
.featureItem .icon:before{
  display: block; width: 200px; height: 200px;
  -webkit-border-radius: 100%; -moz-border-radius: 100%; -ms-border-radius: 100%; -o-border-radius: 100%; border-radius: 100%;
  content: ''; position: absolute; bottom: -1px; left: -5px;
}
.featureItem .img img{ display: block; width: 100%; border: none; position: relative; }
.featureItem p{ font-size: 15px;}
.featureItem h2{
  font-size: 23px; margin: 0 0 5px 0; color: #000;
  transition:0.5s;
    -o-transition:0.5s;
    -webkit-transition:0.5s;
    -ms-transition:0.5s;
    -moz-transition:0.5s;
}
.featureItem h2:after{ display: none; }
.featureItem:hover h2{ color: #FFF !important; }
.featureItem.featureOrange{ border-top: solid 8px #ef4d22; border-bottom: solid 8px #ef4d22; }

.featureItem.featureOrange .icon:before{ background: rgba(239,77,34,0.2);}
.featureItem.featureOrange:hover{ background: #ef4d22; color: #FFF; }
.featureItem.featurePurple{ border-top: solid 8px #bb0649; border-bottom: solid 8px #bb0649; }

.featureItem.featurePurple .icon:before{ background: rgba(187,6,73,0.2);}
.featureItem.featurePurple:hover{ background: #bb0649; color: #FFF; }
.featureItem.featureBlue{ border-top: solid 8px #3382c7; border-bottom: solid 8px #3382c7; }

.featureItem.featureBlue .icon:before{ background: rgba(51,130,199,0.2);}
.featureItem.featureBlue:hover{ background: #3382c7; color: #FFF; }
.featureItem.featureGreen{ border-top: solid 8px #589849; border-bottom: solid 8px #589849; }

.featureItem.featureGreen .icon:before{ background: rgba(108,190,88,0.2);}
.featureItem.featureGreen:hover{ background: #589849; color: #FFF; }

.sectionOrange article h2:after, .sectionOrange .categories{background: #ef4d22;}
.sectionOrange .gallery .zoom_link{ color: #ef4d22; outline: 2px solid #ef4d22;}
.sectionPurple article h2:after, .sectionPurple .categories{background: #bb0649;}
.sectionPurple .gallery .zoom_link{ color: #bb0649; outline: 2px solid #bb0649;}
.sectionBlue article h2:after, .sectionBlue .categories{background: #3382c7;}
.sectionBlue .gallery .zoom_link{ color: #3382c7; outline: 2px solid #3382c7;}
.sectionGreen article h2:after, .sectionGreen .categories{background: #589849;}
.sectionGreen .gallery .zoom_link{ color: #589849; outline: 2px solid #589849;}
/*end of Features*/

/*gallery*/
.gallery{ margin: 20px 0; }
.gallery .img_box{
  height: auto; margin: 2px;
  position: relative; overflow: hidden;
}
.gallery .placeholder{
  display: block; width: 100%; height: auto; visibility: hidden;
}
.gallery .img_box figure{
  display: block; width: 100%; height: 100%;
  margin: 0; box-sizing: border-box; overflow: hidden;
  position: absolute; top: 0; left: 0;
}
.gallery .img_box figure img{ width: 100%; height: 100%; display: block; object-fit: cover;}
.gallery .img_box figure a{ display: block; width: 100%; height: 100%; }
.gallery .zoom_link{
  display: block; width: 100%; height: 100%;
  position: absolute; top: 0; left: 0;
  text-align: center; color: #a00b10; font-size: 50px;
  background: rgba(255,255,255,0.5);
  outline: 2px solid #a00b10; outline-offset: -10px;
  transform:scale(0,0);
}
.gallery .img_box:hover > .zoom_link{
    transform:scale(1,1);
}
.gallery .zoom_link .icon{ width: 100%; height: 100%; display: table}
.gallery .zoom_link .icon span{ display: table-cell; vertical-align: middle;}

#fancybox-content, #fancybox-wrap{ box-sizing: content-box !important; }
/*end of gallery*/

.catalogue{ max-width: 800px; margin: auto; }
.catalogue a{display: block; padding: 0 30px;}
.catalogue a img{
  display: block; border: none;
  max-width: 100%;
}
.catalogue a h2{ text-align: center; margin: 10px 0; }
.catalogue a h2:after{ display: none; }


.categories{
  background: #a00b10; color: #FFF; 
  margin: 20px; padding: 20px;
  font-family: 'oswald_regularregular'; font-size: 14px;
}
.categories h5{ font-size: 21px; margin: 0 0 10px 0; padding: 0; }
.categories ul{ list-style-type: none; margin: 0 0 0 15px; padding: 0;}
.categories li{ position: relative; padding: 5px 0; box-sizing:border-box; }
.categories li:before{content: ''; font-family: 'FontAwesome'; font-size: 13px; color: #FFF; position: absolute; left: -17px;}

.aside_article{
  background: #006a96; color: #FFF; 
  margin: 20px; padding: 20px;
  font-family: 'oswald_regularregular'; font-size: 14px;
}

.aside_img{margin: 20px;}

.buttonsLink{ text-align: center; margin: 20px 0; }
.buttonsLink a{
  display: inline; padding: 10px 23px;
  background: #a00b10; color: #FFF; text-transform: uppercase;
  border:solid 1px #a00b10;
}
.buttonsLink a:hover{ background: #FFF; }

/*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: #a00b10; position: absolute; left: -17px;}
/*end of simpleList*/

.simpleTable{ margin-top: 20px; width: 100%;}
.simpleTable th{ border: none; background: #246493; font-size: 15px; color: #212122000; 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 .map{ width: 100%; height: 450px; margin-bottom: 30px; }
.contact .map iframe, .contact .map #map{ width: 100%; height: 100%; }
.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: #a00b10; padding: 0 10px;}
.contact input[type="submit"], .contact button{background:#a00b10; 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*/

.button a{
  display: block; margin: 20px; padding: 20px 40px;
  background: #a00b10; border:solid 2px #FFF;
  font-family: 'oswaldbold'; text-transform: uppercase;
}
.button a:hover{ background: #FFF; border:solid 2px #a00b10; color: #a00b10;  }

.border_block{ border: solid 1px #a00b10; margin: 30px 0; padding: 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;}
.one_fifth{ width: 20%; float: left; box-sizing: border-box;}


.padding5{ padding: 5px;}
.padding10{ padding: 10px;}
.padding20{ padding: 20px;}
.paddingLeft{ padding-left: 30px;}
.paddingRight{ padding-right: 30px;}
.clear{ clear: both;}
.clearRight{ clear: right;}

/*animations*/
.animation-element{
    opacity: 0; position: relative;
    transition:1s;
    -o-transition:1s;
    -webkit-transition:1s;
    -ms-transition:1s;
    -moz-transition:1s;
}
.animation-element.in-view{ opacity: 1;}

.animation-element.slide-left {
  -moz-transition: all 500ms linear;
  -webkit-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  transition: all 500ms linear;
  -moz-transform: translate3d(-100px, 0px, 0px);
  -webkit-transform: translate3d(-100px, 0px, 0px);
  -o-transform: translate(-100px, 0px);
  -ms-transform: translate(-100px, 0px);
  transform: translate3d(-100px, 0px, 0px);
}

.animation-element.slide-right {
  -moz-transition: all 500ms linear;
  -webkit-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  transition: all 500ms linear;
  -moz-transform: translate3d(100px, 0px, 0px);
  -webkit-transform: translate3d(100px, 0px, 0px);
  -o-transform: translate(100px, 0px);
  -ms-transform: translate(100px, 0px);
  transform: translate3d(100px, 0px, 0px);
}

.animation-element.slide-bottom {
  -moz-transition: all 500ms linear;
  -webkit-transition: all 500ms linear;
  -o-transition: all 500ms linear;
  transition: all 500ms linear;
  -moz-transform: translate3d(0, 100px, 0px);
  -webkit-transform: translate3d(0, 100px, 0px);
  -o-transform: translate(0, 0px);
  -ms-transform: translate(0px, 0px);
  transform: translate3d(0px, 100px, 0px);
}

.animation-element.slide-left.in-view, .animation-element.slide-right.in-view, .animation-element.slide-bottom.in-view{
  -moz-transform: translate3d(0px, 0px, 0px);
  -webkit-transform: translate3d(0px, 0px, 0px);
  -o-transform: translate(0px, 0px);
  -ms-transform: translate(0px, 0px);
  transform: translate3d(0px, 0px, 0px);
}
/*end of animations*/

footer{ width: 100%; position: relative;
  background: #212122; color: #FFF;
  text-align: left; padding: 30px 0;
}
footer h3{ margin: 0 0 5px 0; color: #FFF; font-size: 15px; text-transform: uppercase;}
footer .site_map{border-bottom: solid 1px #a00b10; padding-bottom: 20px; }
footer .site_map h3 a:hover{ color: #FFF; }
footer .site_map ul{ list-style-type: none; margin: 0; padding: 0; font-size: 12px; line-height: 14px; }
footer .site_map ul li+li{ margin-top: 7px; }
footer .site_map ul a:hover{ color: #a00b10; }
footer nav{
  margin: 0 0 20px 0;
}
footer nav a{ display: block; text-transform: uppercase; font-size: 12px; color: #FFF;}
footer nav a:hover{ color: #FFF;}

footer .copyright{
    text-align: center;
    font-size: 14px; line-height: 20px;
}
footer .copyright .copy{ margin-top: 10px; }

footer .contacts{ line-height: 20px; font-size: 15px; }
footer .contacts .icon{
  clear: left; float: left; display: block;
  width: 30px; font-size: 21px; text-align: center;
  padding: 5px 0; color: #a00b10;
}
footer .contacts a{font-weight: bold;}
footer .contacts a:hover{ color: #a00b10;  }
footer .contacts .text{ display: block; margin-left: 40px; padding: 5px 0; }

footer .social{ text-align: right; }
footer .social ul{
    list-style-type: none; margin: 0; padding: 0;
    float: right;
}
footer .social ul li{ display: inline-block;}
footer .social ul li+li{ margin-left: 5px;}
footer .social ul a{
    display: block; width: 40px; height: 40px; line-height: 40px;
    background: #a00b10; color: #FFF;
    text-align: center; font-size: 18px;
    -webkit-border-radius: 100%; -moz-border-radius: 100%; -ms-border-radius: 100%; -o-border-radius: 100%; border-radius: 100%;
}



.social a.facebook:hover{ background: #3b5998; color: #FFF;}
.social a.twitter:hover{ background: #55acee; color: #FFF;}
.social a.google-plus:hover{ background: #dd4b39; color: #FFF;}
.social a.linkedin:hover{ background: #007bb5; color: #FFF;}
.social a.youtube:hover{ background: #bb0000; color: #FFF;}
.social a.viadeo:hover{ background: #f6876d; color: #FFF;}
.social a.instagram:hover{ background: #bc2a8d; color: #FFF;}
.social a.pinterest:hover{ background: #bd081c; color: #FFF;}

