
/**** NORMALIZE ************************************************************************************/

html, body{
	float: left;
	width: 100%;
	padding: 0;
	margin: 0;
	background: #ffffff;
	color: #000000;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 14px;
	position: relative;

	-webkit-text-size-adjust: none;
	-moz-text-size-adjust: none;
	-ms-text-size-adjust: none;
}
*{
	outline: none;
}
img {
	border: 0;
}
a {
	text-decoration: none;
}
h1, h2, h3, h4, h5, h6{
	display: inline;
	margin: 0;
	font-weight: normal;
	font-size: 14px;
}

/**** FIN NORMALIZE ********************************************************************************/

html, body{
	color: #444444;
	font-family: "Source Sans Pro";
	font-size: 16px;
}

a{
	color: #42a2dd;
}

@media (max-width: 768px) {

	html, body{
		font-size: 14px;
		margin-bottom: 0;
	}

}

/**** HEADER ***************************************************************************************/

.header{
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	float: left;
	width: 100%;
	height: 100px;
	background: #ffffff;
	box-shadow: 0 0 20px rgba(0,0,0,0.5);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
}
	.header_left{
		display: flex;
		flex-direction: row;
		align-items: center;
		float: left;
		height: 100%;
		padding: 20px;
		box-sizing: border-box;
	}
		.header_logo{
			display: flex;
			flex-direction: row;
			align-items: center;
			float: left;
			height: 100%;
		}
			.header_logo-image{
				float: left;
				height: 100%;
				margin-right: 20px;
			}
			.header_logo-text{
				display: flex;
				flex-direction: column;
				float: left;
			}
				.header_logo-top{
					display: flex;
					flex-direction: row;
					align-items: center;
					flex-wrap: wrap;
					float: left;
				}
					.header_logo-name{
						float: left;
						font-size: 28px;
						margin-right: 10px;
					}
					.header_logo-stars{
						float: left;
					}
						.header_logo-star{
							float: left;
							height: 14px;
							margin-right: 5px;
						}
						.header_logo-star:last-child{
							margin-right: 0;
						}
				.header_logo-bottom{
					display: flex;
					flex-direction: row;
					align-items: center;
					float: left;
				}
					.header_logo-baseline{
						float: left;
						font-size: 16px;
					}
	.header_right{
		float: left;
		height: 100%;
	}
		.header_booking{
			display: flex;
			flex-direction: column;
			justify-content: center;
			align-items: center;
			float: left;
			height: 100%;
			width: 150px;
			box-sizing: border-box;
			background: #444444;
		}
			.header_booking-icon{
				float: left;
				height: 40px;
				margin-bottom: 5px;
			}
			.header_booking-label{
				float: left;
				color: #ffffff;
				font-size: 20px;
				text-transform: uppercase;
			}

@media (max-width: 768px) {

	.header{
		height: 80px;
	}
	.header_logo-image{
		margin-right: 10px;
	}
	.header_logo-name{
		font-size: 16px;
		margin-right: 5px;
	}
	.header_logo-star{
		height: 10px;
		margin-right: 3px;
	}
	.header_logo-baseline{
		font-size: 12px;
	}
	.header_booking{
		width: 50px;
		height: 50px;
		margin: 15px;
	}
	.header_booking-icon{
		height: 25px;
		margin-bottom: 0;
	}
	.header_booking-label{
		display: none;
	}

}

@media (max-width: 425px) {

	.header_logo-image{
		display: none;
	}

}

/**** FIN HEADER ***********************************************************************************/


/**** PRECONTENT ***********************************************************************************/

.precontent{
	float: left;
	width: 100%;
	height: 600px;
	position: relative;
	z-index: 1;
}
	.precontent_diaporama{
		float: left;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 1;
	}
		.precontent_diaporama-slide{
			float: left;
			width: 100%;
			height: 100%;
			background: no-repeat center center;
			background-size: cover;
		}
		.precontent_diaporama-pager{
			position: absolute;
			bottom: 40px;
			right: 80px;
			z-index: 101;
		}
			.precontent_diaporama-pager-item{
				float: left;
				height: 15px;
				width: 15px;
				margin-right: 10px;
				border: 1px solid #ffffff;
				border-radius: 50%;
				box-sizing: border-box;
				transition: all .3s ease-in-out;
				cursor: pointer;
			}
			.precontent_diaporama-pager-item:last-child{
				margin-right: 0;
			}
			.precontent_diaporama-pager-item.cycle-pager-active{
				background: #ffffff;
			}

@media (max-width: 1024px) {

	.precontent{
		height: 400px;
	}

}

@media (max-width: 768px) {

	.precontent{
		margin-top: 80px;
		height: 250px;
	}

}

@media (max-width: 425px) {

	.precontent{
		height: 200px;
	}

}

/**** FIN PRECONTENT *******************************************************************************/


/**** SIDEBAR **************************************************************************************/

.sidebar{
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 40px;
	height: 400px;
	position: fixed;
	right: 0;
	top: 100px;
	z-index: 11;
}
.sidebar.accueil{
	height: 500px;
}
	.sidebar_item{
		float: left;
		width: 300px;
		height: 40px;
		/*margin: 5px 0;*/
		box-sizing: border-box;
		cursor: pointer;
		transition: all .3s ease-in-out;
	}
	.sidebar_item:hover{
		margin-left: -260px;
	}
		.sidebar_item-icon{
			float: left;
			width: 40px;
			height: 40px;
			padding: 10px;
			box-sizing: border-box;
			background: #444444;
		}
		.sidebar_item-label{
			float: left;
			width: 260px;
			height: 40px;
			line-height: 40px;
			padding: 0 10px;
			box-sizing: border-box;
			background: #666666;
			color: #ffffff;
			font-size: 16px;
			transition: all .3s ease-in-out;
		}
		.sidebar_item:hover .sidebar_item-label{
			opacity: 1;
		}

@media (max-width: 1024px) {

	.sidebar{
		height: 300px;
	}

}

@media (max-width: 768px) {

	.sidebar{
		flex-direction: row;
		width: 100%;
		height: auto;
		padding: 20px;
		margin-top: 100px;
		border-bottom: 1px solid rgba(0,0,0,0.3);
		box-sizing: border-box;
		position: relative;
		top: auto;
		z-index: 9;
	}
	.sidebar_item{
		width: auto;
		margin: 0 10px;
	}
	.sidebar_item:hover{
		margin: 0 10px;
	}
	.sidebar_item-label{
		display: none;
	}

}

/**** FIN SIDEBAR **********************************************************************************/


/**** CONTENT **************************************************************************************/

.content{
	display: flex;
	flex-direction: column;
	align-items: center;
	float: left;
	width: 100%;
	padding: 40px 60px;
	box-sizing: border-box;
	background: #ffffff;
	position: relative;
	z-index: 5;
}
	.content_center{
		display: flex;
		flex-direction: column;
		align-items: center;
		float: left;
		width: 100%;
		max-width: 1120px;
	}
		.content_title{
			float: left;
			font-size: 28px;
			text-align: center;
		}
		.content_subtitle{
			float: left;
			font-size: 22px;
			text-align: center;
		}
		.content_text{
			display: flex;
			flex-direction: column;
			align-items: center;
			float: left;
			width: 100%;
		}
			.content_text-center{
				float: left;
				width: 100%;
				line-height: 28px;
				max-width: 768px;
				margin-top: 30px;
				text-align: center;
			}
			.content_text-splitted{
				display: flex;
				flex-direction: row;
				float: left;
				width: 100%;
				margin-top: 30px;
			}
				.content_text-left{
					float: left;
					width: 48%;
					margin-right: 4%;
				}
				.content_text-right{
					float: left;
					width: 48%;
				}
					.content_text-title{
						display: inline-block;
						font-size: 20px;
						margin: 10px;
						font-weight: bold;
					}

@media (max-width: 768px) {

	.content{
		padding: 30px;
	}
	.content_title{
		font-size: 22px;
	}
	.content_subtitle{
		font-size: 20px;
	}

}

/**** FIN CONTENT **********************************************************************************/


/**** ADDRESS **************************************************************************************/

.address{
	display: flex;
	flex-direction: column;
	justify-content: center;
	float: left;
	height: 100px;
	line-height: 16px;
	padding: 20px;
	border-left: 1px solid rgba(0,0,0,0.3);
	box-sizing: border-box;
	background: #ffffff;
	text-align: center;
	font-size: 14px;
	position: fixed;
	right: 150px;
	top: 0;
	z-index: 11;
}
.address.nobooking{
	right: 0;
}
	.address_name{
		float: left;
		font-weight: 600;
	}
	.address_place{
		float: left;
	}
	.address_telephone{
		float: left;
		margin-top: 10px;
		color: inherit;
		font-size: 18px;
		font-weight: bold;
	}

@media (max-width: 1024px) {

	.address{
		width: 100%;
		height: auto;
		border: 0;
		border-top: 1px solid rgba(0,0,0,0.3);
		position: relative;
		top: auto;
		right: auto;
		z-index: 5;
	}

}

/**** FIN ADDRESS **********************************************************************************/


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

.footer{
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: flex-end;
	float: left;
	width: 100%;
	padding: 15px 70px 15px 20px;
	background: #444444;
	box-sizing: border-box;
	position: relative;
	z-index: 6;
}
	.footer_link{
		float: left;
		line-height: 20px;
		color: #ffffff;
		margin-right: 20px;
		font-size: 14px;
	}
	.footer_juliana{
		float: left;
		line-height: 20px;
		color: #ffffff;
		font-size: 14px;
	}
		.footer_juliana a {
			color: inherit;
		}

@media (max-width: 768px) {

	.footer{
		position: relative;
	}

}

@media (max-width: 480px) {

	.footer{
		flex-direction: column;
		align-items: flex-start;
		justify-content: flex-start;

	}

}

/**** FIN FOOTER ***********************************************************************************/

.rewind{
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	float: left;
	width: 50px;
	height: 50px;
	background: #444444;
	position: fixed;
	right: -50px;
	bottom: 0;
	z-index: 8;
	cursor: pointer;
	transition: right .3s ease-in-out;
}
.rewind.active {
    right: 0;
}
	.rewind_icon{
	    float: left;
	    height: 20px;
	}