/*
	rouge foncé : 8e0000
	rouge clair : df0220
*/

/* =============================================================================
   CSS GLOBAUX
   ========================================================================== */

.clear{
	clear: both;
}

/* The clearfix method */
.clearfix {
  *zoom: 1;
}
.clearfix:before,
.clearfix:after {
  display: table;
  content: "";
}
.clearfix:after {
  clear: both;
}
.clear {
	clear: both;
}
.alignright {
	float: right;
}
.alignleft {
	float: left;
}

/* Content Mobile/Desktop */
.mobile-content {	
	display:none;
}
.normal-content {	
	display:block;
}

/* The box-sizing method */
*,
*:after,
*::before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

/* Pour effacer les transitions */
.notransition {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -o-transition: none !important;
  -ms-transition: none !important;
  transition: none !important;
}

/* =============================================================================
   SLICK SLIDER
   ========================================================================== */
.slick-slider { position: relative; display: block; box-sizing: border-box; -moz-box-sizing: border-box; -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -ms-touch-action: pan-y; touch-action: pan-y; -webkit-tap-highlight-color: transparent; }
.slick-list { position: relative; overflow: hidden; display: block; margin: 0; padding: 0; }
.slick-list:focus { outline: none; }
.slick-loading .slick-list { background: white url("../img/ajax-loader.gif") center center no-repeat; }
.slick-list.dragging { cursor: pointer; cursor: hand; }
.slick-slider .slick-list, .slick-track, .slick-slide, .slick-slide img { -webkit-transform: translate3d(0, 0, 0); -moz-transform: translate3d(0, 0, 0); -ms-transform: translate3d(0, 0, 0); -o-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }
.slick-track { position: relative; left: 0; top: 0; display: block; zoom: 1; }
.slick-track:before, .slick-track:after { content: ""; display: table; }
.slick-track:after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }
.slick-slide { float: left; height: 100%; min-height: 1px; display: none; }
.slick-slide img { display: block; pointer-events: none;}
.slick-slide.slick-loading img { display: none; }
.slick-slide.dragging img { pointer-events: none; }
.slick-initialized .slick-slide { display: block; }
.slick-loading .slick-slide { visibility: hidden; }
.slick-vertical .slick-slide { display: block; height: auto; }


/* =============================================================================
   CUSTOM SCROLLBAR
   ========================================================================== */
::-webkit-scrollbar {
	width: 10px;
	height:10px;
}
::-webkit-scrollbar-button:start:decrement,
::-webkit-scrollbar-button:end:increment  {
	display: none;
}
::-webkit-scrollbar-track-piece  {
	background-color: rgba(0,0,0,0.2);
}
::-webkit-scrollbar-thumb:vertical {
	background: #e6b61e;
}

/* =============================================================================
   EFFET SUR LES LIENS
   ========================================================================== */
a {
	transition: all 0.2s ease-in;
}


/* =============================================================================
   FONTS
   ========================================================================== */
@font-face {
	font-family: 'cgtimes';
	src: url('../fonts/cgtimes-regular-webfont.eot');
	src: url('../fonts/cgtimes-regular-webfont.eot?#iefix') format('embedded-opentype'),
			 url('../fonts/cgtimes-regular-webfont.woff2') format('woff2'),
			 url('../fonts/cgtimes-regular-webfont.woff') format('woff'),
			 url('../fonts/cgtimes-regular-webfont.ttf') format('truetype'),
			 url('../fonts/cgtimes-regular-webfont.svg#cgtimes') format('svg');
	font-weight: normal;
	font-style: normal;
} 
@font-face {
    font-family: 'arrus';
    src: url('../fonts/arrus-webfont.eot');
    src: url('../fonts/arrus-webfont.eot?#iefix') format('embedded-opentype'),
				url('../fonts/arrus-webfont.svg#arrus') format('svg'),
				url('../fonts/arrus-webfont.woff') format('woff'),
        url('../fonts/arrus-webfont.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'arrusbold';
    src: url('../fonts/arrusbold-webfont.eot');
    src: url('../fonts/arrusbold-webfont.eot?#iefix') format('embedded-opentype'),
				url('../fonts/arrusbold-webfont.svg#arrusbold') format('svg'),
				url('../fonts/arrusbold-webfont.woff') format('woff'),
        url('../fonts/arrusbold-webfont.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'helioscondregular';
    src: url('../fonts/helioscondregular-webfont.eot');
    src: url('../fonts/helioscondregular-webfont.eot?#iefix') format('embedded-opentype'),
				url('../fonts/helioscondregular-webfont.svg#helioscondregular') format('svg'),
         url('../fonts/helioscondregular-webfont.woff') format('woff'),
         url('../fonts/helioscondregular-webfont.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'helioscondbold';
    src: url('../fonts/helioscondbold-webfont.eot');
    src: url('../fonts/helioscondbold-webfont.eot?#iefix') format('embedded-opentype'),
		     url('../fonts/helioscondbold-webfont.svg#helioscondbold') format('svg'),
         url('../fonts/helioscondbold-webfont.woff') format('woff'),
         url('../fonts/helioscondbold-webfont.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
}

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


/* =============================================================================
   BODY
   ========================================================================== */
body {	
	position: relative;
	width:100%;
	background:#000;
	margin: 0 auto;
	padding:0;
	text-align: center; 	
}


/* =============================================================================
   BACK IMG & VIDEO
   ========================================================================== */
#back {
	position:fixed;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background: #000;
	/* 
	background: #000 url(../img/back.jpg) top center no-repeat;
	background-position: center top;
	*/	
}

#back_degrade {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	z-index:2;
	transition: all 0.4s ease;
	background: linear-gradient(to bottom,  rgba(0,0,0,1) 2%,rgba(0,0,0,0.1) 7%,rgba(0,0,0,0) 12%,rgba(0,0,0,0) 76%,rgba(0,0,0,0.2) 83%,rgba(0,0,0,1) 92%); 
}

#back_video {
  position: absolute;
  top: 0;
	right: 0;
	bottom: 0;
	left: 0;
  overflow: hidden;
}
#back_video > video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* 1. No object-fit support: */
@media (min-aspect-ratio: 16/9) {
  #back_video > video { height: 300%; top: -100%; }
}
@media (max-aspect-ratio: 16/9) {
  #back_video > video { width: 300%; left: -100%; }
}
/* 2. If supporting object-fit, overriding (1): */
@supports (object-fit: cover) {
  #back_video > video {
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
  }
}

#back_img {
	position: absolute;
	left:50%;
	transform: translateX(-50%);
}

/* =============================================================================
   MAIN CONTENT
   ========================================================================== */
	 
#container {
	position:relative;	
	width:100%;
	max-width:1200px;
	padding:0;
	margin:auto;
}
#container:after {
	content:'';
	display:block;
	clear:both;
}
#main {	
	position:relative;
	float:left;
	width: 100%;
	text-align: left;
	margin:auto;
	/* background-color: rgba(0, 0, 0, 0.5); */
	z-index: 2;
	/* background: rgba(0,0,0,0.86);	*/
	opacity:0;
	font-family: "Helvetica Neue", Tahoma, 'helioscondregular', Arial, "Helvetica CY", Helvetica, sans-serif;
	color:#fff;
	margin-top:130px;
}

/* =============================================================================
   TITLE
   ========================================================================== */
#title {
	position: absolute;
	z-index:10;
	height:42px;
	text-shadow: 1px 1px 2px black, 0 0 5px black, 0 0 5px black;
}

#title h1:before,
#title h1:after {
	content:'';
	display:block;
	width:100%;
	height:1px;
	position: absolute;
	left:0;
}

#title h1:before {
	top:0;
}

#title h1:after {
	bottom:0;
}

#title h1 {
	position: relative;
	float:left;
	display: block;	
	z-index:2;
	height:42px;
	font-family: 'helioscondbold', Arial, "Helvetica CY", Helvetica, sans-serif;
	font-weight: normal;
	font-size:20px;
	line-height:42px;	
	padding:0px 30px 0px 30px;	
	text-transform:uppercase;
	color: #fff;
	text-shadow: 1px 1px 2px black, 0 0 5px black, 0 0 5px black;	
}


/* =============================================================================
   BOUTON
   ========================================================================== */
.btn {
	position: relative;
	display:inline-block;
	float:left;
	font-family: 'helioscondbold', Arial, "Helvetica CY", Helvetica, sans-serif;
	letter-spacing: 1px;
	font-weight: 400;
	text-shadow: 0 0 1px rgba(255,255,255,0.3);	
	font-size: 1.35em;
	line-height: 2em;
	outline: none;
	text-align:center;	
}
.btn a {
	text-decoration: none;
	text-transform: uppercase;	
}

/* BTN 3D */
.btn3d a {
	line-height: 50px;
	perspective: 1000px;
	color: #fff;
}
.btn3d a span {
	position: relative;
	display: inline-block;
	padding: 0 28px;
	background: rgba(0,0,0,0.3);
	transition: transform 0.3s;
	transform-origin: 50% 0;
	transform-style: preserve-3d;
}
.csstransforms3d .btn3d a span::before {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.3);
	content: attr(data-hover);
	transition: background 0.3s;
	transform: rotateX(-90deg);
	transform-origin: 50% 0;
}
.btn3d a:hover span,
.btn3d a:focus span {
	outline: none;
	transform: rotateX(90deg) translateY(-25px);
}
.csstransforms3d .btn3d a:hover span::before,
.csstransforms3d .btn3d a:focus span::before {
	background: rgba(0,0,0,0.3);
}

/* BTN SLIDE */
.btn.btnSlide {
	position: relative;
	z-index: 1;
	overflow: hidden;
}
.btnSlide a {
	overflow: hidden;
}
.btnSlide a:hover,
.btnSlide a:focus {
	outline: none;
}
.btnSlide a span {
	display: block;
	padding: 9px 20px;
	background: #000;
	color:#fff;
	transition: transform 0.3s;
}
.btnSlide a::before {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	padding: 9px 20px;
	width: 100%;
	height: 100%;
	background: #fff;
	color:#000;
	content: attr(data-hover);
	transition: transform 0.3s;
	-webkit-transform: translateX(-25%);
}
.btnSlide a:hover span,
.btnSlide a:focus span {
	transform: translateX(100%);
}
.btnSlide a:hover::before,
.btnSlide a:focus::before {
	transform: translateX(0%);
}



/* =============================================================================
   LOADING
   ========================================================================== */
#loading {
	position:fixed;
	display: table;
	width: 100%;
	height:100%;
	z-index:0;
	display:none;
}
#loading_circle {
	width:50%;
	height:auto;
	display: table-cell;
	vertical-align: middle;
	text-align:center;
}
#loading_circle1 {
	margin: auto;
  position: absolute;
  bottom: 0;
  left: 0;
  top: 0;
  right: 0;
	background-color: rgba(0,0,0,0);
	border:5px solid rgba(255,255,255,0.9);
	opacity:.9;
	border-right:5px solid rgba(0,0,0,0);
	border-left:5px solid rgba(0,0,0,0);
	border-radius:50px;
	box-shadow: 0 0 35px #75a6ad;
	width:50px;
	height:50px;
  text-align:center; /* centrage horizontal */
	-moz-animation:spinPulse 1s infinite ease-in-out;
	-webkit-animation:spinPulse 1s infinite linear;
}
#loading_circle2 {
	margin: auto;
  position: absolute;
  bottom: 0;
  left: 0;
  top: 0;
  right: 0;
	background-color: rgba(0,0,0,0);
	border:5px solid rgba(255,255,255,0.9);
	opacity:.9;
	border-left:5px solid rgba(0,0,0,0);
	border-right:5px solid rgba(0,0,0,0);
	border-radius:50px;
	box-shadow: 0 0 15px #75a6ad; 
	width:30px;
	height:30px;
	-moz-animation:spinoffPulse 1s infinite linear;
	-webkit-animation:spinoffPulse 1s infinite linear;
}

@-moz-keyframes spinPulse {
	0% { -moz-transform:rotate(160deg); opacity:0; box-shadow:0 0 1px #75a6ad;}
	50% { -moz-transform:rotate(145deg); opacity:1; }
	100% { -moz-transform:rotate(-320deg); opacity:0; }
}
@-moz-keyframes spinoffPulse {
	0% { -moz-transform:rotate(0deg); }
	100% { -moz-transform:rotate(360deg);  }
}
@-webkit-keyframes spinPulse {
	0% { -webkit-transform:rotate(160deg); opacity:0; box-shadow:0 0 1px #75a6ad; }
	50% { -webkit-transform:rotate(145deg); opacity:1;}
	100% { -webkit-transform:rotate(-320deg); opacity:0; }
}
@-webkit-keyframes spinoffPulse {
	0% { -webkit-transform:rotate(0deg); }
	100% { -webkit-transform:rotate(360deg); }
}

/* =============================================================================
   TOP
   ========================================================================== */
#top {
  position: absolute;
	left:0;
	top:0;
	width:0;
	height:0;
}



/* =============================================================================
   FOOTER
   ========================================================================== */
#footer {
	position:fixed;
	z-index:4;		
	width:100%;	
	height:auto;
	min-height:100px;
	left:0px;
	bottom:0px; 	
	text-align:center;
	transition:all 0.4s ease-in-out;
	background-color: rgba(0, 0, 0, 0.4); 
	padding:30px 10px 10px 10px;
  margin-top:20px;
}
#footer-content {
	position:relative;
	margin:auto;	
	max-width:1050px;
	height:auto;
}
#logos {
	position:relative;
	display:inline-block;
	float:left;
}
#logos img {
	margin: 0px 12px 0px 12px;
}
#legal {
	position:relative;
	float:left;
	margin:auto;
	width:100%;
	max-width:1050px;
	font-size: 9px;
	line-height: 12px;
	color: #8d8d8d;
	font-family: 'helioscondregular', Arial, "Helvetica CY", Helvetica, sans-serif;
	text-align:center;
	clear: both;
}

@media screen and (max-width: 1035px) {
	#logos {
		float: none;
	}
}


/* =============================================================================
   COMINGSOON
   ========================================================================== */
#comingsoon {
	width:100%;
	margin:auto;
	text-align:center;
	padding:15px;
}
#comingsoon img {
	width:100%;
}


/* =============================================================================
   OVERLAY POUR LES PETITES HAUTEURS
   ========================================================================== */
#warning {
	display:none;
	position:fixed;
	z-index:10000;
	background:#fff;
	width:100%;
	height:100%;
}
#warning-txt {
	position:absolute;
	top:40%;
	width:100%;
	font-family: 'helioscondregular', Arial, "Helvetica CY", Helvetica, sans-serif;
  color: #000;
  text-align: center;  
	font-size:15px;
	line-height:20px;	
}



/* =============================================================================
   MEDIA QUERIES DESKTOP
   ========================================================================== */
@media screen and (min-width: 1000px) {
	#main {
		margin-top:90px;
	}	
}
@media screen and (min-width: 1000px) and (max-width: 1059px) {
	#title h1 {
		margin-left:0px;			
	}
}

@media screen and (min-width: 769px) and (max-width: 999px) {
	#main {
		margin-top:42px;
		/* overflow:hidden; */
	}
	#title h1 {
		margin-left:0px;		
	}
	
}


/* =============================================================================
   MEDIA QUERIES TABLET
   ========================================================================== */
/*
@media screen and (min-width: 768px) {	
	#back_img {
		width:100%;
	}
}
*/

@media screen and (min-width: 501px) and (max-width: 768px) {	

	#main {
		margin-top:42px;
	}
	#title h1 {
		margin-left:0px;
		padding-left:15px;
		font-size:18px;			
	}
}

@media screen and (max-width: 768px) {
	#footer #logos img {
		max-height:20px;
	}
	
}

/* =============================================================================
   MEDIA QUERIES MOBILE
   ========================================================================== */
@media screen and (max-width:500px) {
	
	#main {
		margin-top:42px;
	}
	#title h1 {
		margin-left:0px;
		padding-left:10px;
		font-size:11px;			
	}
	
}


