@charset "utf-8";
/* CSS Document */
@font-face {
font-family: 'Allura';
src: url('typo/Allura-Regular.ttf') format('truetype');
font-weight: normal;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Source';
src: url('typo/SourceSansPro-Bold.ttf') format('truetype');
font-weight: bold;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: 'Source';
src: url('typo/SourceSansPro-Regular.ttf') format('truetype');
font-weight: normal;
font-style: normal;
font-display: swap;
}


body,html{
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	font-family: 'Source';
	font-size: 16px;
	color: #ffffff;
	background-color: #252525;
}

/* TYPO ------------------------- */

p{
	margin: 0;
	padding: 0;
	display: inline-block;
}

h1{
	margin: 0;
	padding: 0;
	font-family: 'Source';
	font-size: 2em;
	font-weight: normal;
}
h1.principal{
	width: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
	font-weight: normal;
	position: relative;
	float: left;
	margin-bottom: 40px;
}
.sstitreH1{
	font-family: 'Allura';
	font-size: 1em;
}
h2{
	font-family: 'Allura';
	font-size: 1.6em;
	margin: 0;
	padding: 0;
	font-weight: normal;
}
h2.new{ border:1px solid #45bfdc; border-radius: 8px; padding: 10px 5px; text-align: center; background-color: rgba(0,0,0,0.9); }
h3{
	font-family: 'Allura';
	font-size: 2em;
	margin: 0;
	padding: 0;
	font-weight: normal;
}

.orange{ color:#ff9d11; }
.bleu{ color:#45bfdc; }

.lienStd{ color: #ffffff; text-decoration: none; }

/* ----------------------------- */

#Haut{
	width: 100%;
	position: relative;
	float: left;
	margin-bottom: 80px;
}
.bandeauSup{
	width: 100%;
	height: 80px;
	position: relative;
	float: left;
}
.nomCentreP{
	width:160px;
	text-align: center;
	position: absolute;
	float: left;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.txtDouble{ 
	font-size: 2em;
	line-height: 0.8em;
}
.hautGauche{
	position: relative;
	float: left;
	top: 50%;
	margin-left: 20px;
	transform: translateY(-50%);
}
.hautGauche img{ vertical-align:middle; }
.blocHLangue{
	position: relative;
	float: left;
	margin-right: 40px;
}
.blocHLangue select{
	border: 0;
	appearance: none;
	color: #ffffff;
	background: url("img/flecheSelect.png") 100% no-repeat;
	padding: 5px 15px 5px 5px;
	cursor: pointer;
}
.blocHLangue select option{
	border-bottom: 1px solid #000000;
	background-color: #252525;
	color: #ffffff;
	padding: 0;
}
.blocHResa{
	font-size: 1.2em;
	position: relative;
	float: left;
}
.blocHResa a{ text-decoration: none; }
.hautDroite{
	position: relative;
	float: right;
	top: 50%;
	transform: translateY(-50%);
}
.hautDroite img{ vertical-align:middle; }
.blocHMail, .blocHTel{
	font-size: 1.2em;
	position: relative;
	float: left;
	margin-right: 40px;
}
.blocHIcone{
	width: 40px;
	text-align: center;
	position: relative;
	float: left;
	margin-right: 20px;
}

.zonePhotoHaut{
	width: 100%;
	height: 700px;
	background-color: #3c3c3c;
	position: relative;
	float: left;
}
#LogoFlower{
	width:99px;
	height: 133px;
	position: absolute;
	float: right;
	right: 0;
	bottom:10px;
	z-index: 2;
}
#LogoFlower img{ max-width: 100%; }
.panoAcc{
    width:100%;
    height: 100%;
    position: absolute;
    float: left;
    z-index: 1;
	overflow: hidden;
}
.panoEtape1{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	float: left;
	background-image: url("img/fond/acc1.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	animation-name: accP1;
    animation-duration: 20s;
	animation-timing-function: linear;
    animation-delay: 0s;
	animation-iteration-count: infinite;
}
.panoEtape2{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	float: left;
	background-image: url("img/fond/acc2.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	animation-name: accP2;
    animation-duration: 20s;
	animation-timing-function: linear;
    animation-delay: 0s;
	animation-iteration-count: infinite;
}
.panoEtape3{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	float: left;
	background-image: url("img/fond/acc3.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	animation-name: accP3;
    animation-duration: 20s;
	animation-timing-function: linear;
    animation-delay: 0s;
	animation-iteration-count: infinite;
}

.panoBandeau{
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    float: left;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 50%; 
}
.panoBandeau.camping{ background-image: url("img/fond/camping.jpg"); }
.panoBandeau.services{ background-image: url("img/fond/service.jpg"); }
.panoBandeau.actualite{ background-image: url("img/fond/actualite.jpg"); }
.panoBandeau.piscine{ background-image: url("img/fond/piscine.jpg"); }
.panoBandeau.spa{ background-image: url("img/fond/spa.jpg"); }
.panoBandeau.loisirs{ background-image: url("img/fond/loisirs2024.jpg"); }
.panoBandeau.animations{ background-image: url("img/fond/animations.jpg"); }
.panoBandeau.nature{ background-image: url("img/fond/nature.jpg"); }
.panoBandeau.hebergement{ background-image: url("img/fond/heberg.jpg"); }
.panoBandeau.charente{ background-image: url("img/fond/charente.jpg"); }
.panoBandeau.activites{ background-image: url("img/fond/activites.jpg"); }
.panoBandeau.contact{ background-image: url("img/fond/contact2024.jpg"); }
.panoBandeau.flower{ background-image: url("img/fond/flower.jpg"); }
.panoBandeau.chien{ background-image: url("img/fond/chien.jpg"); }

#LogoPrincipal{
	width: 280px;
	height: 172px;
	position: absolute;
	float: left;
	z-index: 3;
	left: 50%;
	bottom: 0;
	transform: translate(-50%,50%);
}
#LogoPrincipal img{ max-width: 100%; }

/* MENU Principal --------------------- */
#BoutonMenuP{
	width:200px;
	height: 40px;
	background-color: #ff9d11;
	color: #252525;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.5em;
	position: absolute;
	float: left;
	top: 80px;
	left: 50%;
	transform: translateX(-50%);
	transition: .4s all;
	z-index: 3;
}
#BoutonMenuP:hover{ background-color: #ff7200; }
.menuIconeMenuP{
	width:32px;
	height:24px;
	position: relative;
	float: left;
}
.decoOpen{
	width: 100%;
	height: 100%;
	position: absolute;
	float: left;
	top:0;
	left: 0;
	z-index: 1;
	opacity: 1;
	transition: .2s all;
}
.decoClose{
	width: 100%;
	height: 100%;
	position: absolute;
	float: left;
	top:0;
	left: 0;
	z-index: 1;
	opacity: 0;
	transition: .2s all;
}
.decoOpen.openMenu{
	transform: rotateZ(359deg);
	opacity:0;
}
.decoClose.closeMenu{
	transform: rotateZ(359deg);
	opacity:1;
}
.nomIconeMenuP{
	position: relative;
	float: left;
	margin-left: 20px;
}

#SousMenuP{
	width: 100%;
	height: 220px;
	background-color: rgba(0,0,0,0.8);
	position: absolute;
	float: left;
	top: 80px;
	padding-top: 80px;
	z-index: 2;
}
.ensembleMenu{
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
}
.colonneMenu{
	position: relative;
	float: left;
	margin: 0 20px;
	/*border: 1px dashed #cccccc;*/
}
.colonneMenu a{ text-decoration: none; }
.barreMenu{
	width: 0;
	height: 1px;
	background-color: #45bfdc;
	position: absolute;
	float: left;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	transition: .2s all;
}
.bPrincipal{
	height: 34px;
	font-size: 1.3em;
	color: #ffffff;
	text-decoration: none;
	margin: 2px 0;
}
.bPrincipal:First-Letter{ color:#45bfdc; }
a .bPrincipal:before{ 
	content: url("img/flecheMenuBleu.png");
	margin-right: 5px;
	position: relative;
	float: left;
}
.colonneMenu:hover .bPrincipal .barreMenu{ width:100%; }

.ssMenu{
	position: relative;
	float: left;
	border-left: 1px solid #ffffff;
	padding-left: 10px;
}
.bSsPrincipal{
	height: auto;
	min-height: 30px;
	font-size: 1.1em;
	color:#ffffff;
	text-decoration: none;
	margin: 2px 0;
	position: relative;
	float: left;
	clear: both;
}
a .bSsPrincipal:before{ 
	content: url("img/flecheMenuBleu.png");
	margin-right: 5px;
	position: relative;
	float: left;
}
a .bSsPrincipal:hover .barreMenu{ width:100%; }


#Bas{
	width: 100%;
	position: relative;
	float: left;
	margin-top: 40px;
	margin-bottom: 50px;
}
.barreIconeBas{
	width:100%;
	position: relative;
	float: left;
	border-top: 1px solid #ff9d11;
	border-bottom: 1px solid #ff9d11;
	background-color: #151515;
}
.ligneIcone{
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
}
.caseIcone{
	min-width:80px;
	text-align: center;
	position: relative;
	float: left;
	margin: 0 20px;
	padding: 5px;
}
.caseIcone a{ color: #ffffff; text-decoration:none; }
.fdCaseIcone{
	width: 100%;
	height: 0;
	background-color: #252525;
	position: absolute;
	bottom:0;
	left: 0;
	float: left;
	z-index: -1;
	transition: .2s all;
}
.caseIcone:hover .fdCaseIcone{
	height: 100%;
}

.ligneCoord{
	width: 100%;
	height: 280px;
	position: relative;
	float: left;
	margin: 20px 0;
}
.ligneCoord a{ color: #ffffff; text-decoration: none; }
.titreBas{
	font-size: 0.9em;
	color: #ff9d11;
	position: relative;
	float: left;
	margin-bottom: 15px;
	clear: both;
}
.titreBas.droite{ float: right; }
.titreBas.centre{ left: 50%; transform: translateX(-50%); }
.zoneCoord{
	position: absolute;
	float: left;
	left: 20px;
	top: 0;
}
.infoCoord{
	border-left: 1px solid #ffffff;
	padding: 0 0 0 10px;
	position: relative;
	float: left;
	clear: both;
}
.detailCoord{
	position: relative;
	float: left;
	margin-bottom: 10px;
	clear: both;
}
.detailCoord img{ vertical-align: middle; }
.detailCoord.tel{ font-size: 1.8em; }
.detailCoord.mail{ font-size: 1.4em; }
.detailCoord.adresse{ 
	display: flex;
	align-items: center;
}

.zonePartenaire{
	position: absolute;
	float: right;
	right: 20px;
	top: 0;
}
.infoPartenaire{
	border-right: 1px solid #ffffff;
	padding: 0 10px 0 0;
	position: relative;
	float: left;
	clear: both;
}
.fullPartenaire{
	width: 100%;
	height: 80px;
	text-align: center;
	position: relative;
	float: right;
	margin-bottom: 10px;
	clear: both;
}
.fullPartenaire img{
	max-height: 100%;
	width:auto;
	float: right;
}
.detailPartenaire{
	text-align: right;
	position: relative;
	float: right;
	margin-bottom: 10px;
	clear: both;
	font-size: 0.8em;
}

.zoneCarte{
	width: 290px;
	position: absolute;
	float: left;
	left: 50%;
	transform: translateX(-50%);
	top: 0;
}
.copy{
	width: 100%;
	border-top: 2px solid #ff9d11;
	text-align: center;
	position: relative;
	float: left;
	margin:20px 0;
	padding-top:10px;
}
.copy a{ color: #ffffff; text-decoration: none; }

/* BANDEAU RESA --------------------- */
.bandResaBas{
	width: 100%;
	height: 60px;
	background-color: #ff9d11;
	border-top: 1px solid #252525;
	position: fixed;
	float: left;
	display: flex;
	align-items: center;
	justify-content: center;
	bottom: 0;
	z-index: 5;
}
.zoneResa{ width: 100%; max-width: 800px; position: relative; float: left; }
.resaLigne{
	display: flex;
	align-items: center;
	position: relative;
	float: left;
	gap: 0 10px;
}
.chpDateR{
	width:150px;
	padding: 0 20px;
	height: 30px;
	border-radius: 15px;
	display: inline-block;
	border: 1px solid #252525;
	margin: 5px;
	color: #000000;
	font-family: 'Arial';
	font-size: 1em; 
	position: relative;
	float: left;
}
.chpSubR{
	width: auto;
	height: 30px;
	font-size: 1em;
	text-align: center;
	color: #ff9d11;
	border-radius: 15px;
	display: inline-block;
	background-color: #252525;
	border: 1px solid #ffffff;
	padding: 0 40px;
	margin: 5px 0;
	cursor: pointer;
	position: relative;
	float: left;
}

.zoneWAvis{
	width: 450px;
	border: 1px solid red;
	position: fixed;
	float: left;
	bottom: 60px;
	right: 0;
	z-index: 10;
}


/* BOUTON & ANIM --------------------- */
.boutResaCote{
	width:250px;
	height: 40px;
	background-color: #ff9d11;
	color: #ffffff;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1em;
	position: fixed;
	float: left;
	top: 40%;
	right:-105px;
	transform: rotateZ(-90deg);
	transition: .4s all;
	z-index: 3;
}
.boutResaCote:hover{ background-color: #ff7200; }

.boutonCadreA{ cursor: pointer; }
.cadreBouton{
	width: calc(100% + 20px);
	height: calc(100% + 10px);
	position: absolute;
	float: left;
	top: -5px;
	left: -10px;
	z-index: 2;
}
.cadreBouton .coinBD{
	width:1px;
	height: 1px;
	border: 1px solid #ffffff;
	border-left: none;
	border-bottom: none;
	position: absolute;
	float: left;
	top: 0;
	left:0;
	z-index: 2;
	opacity: 0;
	transition: height 0.15s ease-out, width 0.15s ease-out 0.15s;
}
.cadreBouton .coinBD.coulOrange{
	width:1px;
	height: 1px;
	border: 1px solid #ff9d11;
	border-left: none;
	border-bottom: none;
	position: absolute;
	float: left;
	top: 0;
	left:0;
	z-index: 2;
	opacity: 0;
	transition: height 0.15s ease-out, width 0.15s ease-out 0.15s;
}
.cadreBouton .coinBG{
	width:1px;
	height: 1px;
	border: 1px solid #ffffff;
	border-right: none;
	border-top: none;
	position: absolute;
	float: left;
	top: 0;
	left: 0;
	z-index: 2;
	opacity: 0;
	transition: width 0.15s ease-out, height 0.15s ease-out 0.15s;
	
}
.cadreBouton .coinBG.coulOrange{
	width:1px;
	height: 1px;
	border: 1px solid #ff9d11;
	border-right: none;
	border-top: none;
	position: absolute;
	float: left;
	top: 0;
	left: 0;
	z-index: 2;
	opacity: 0;
	transition: width 0.15s ease-out, height 0.15s ease-out 0.15s;
	
}
.boutonCadreA:hover .cadreBouton .coinBD{
	opacity: 1;
	width:100%;
	height: 100%;
	transition: width 0.15s ease-out, height 0.15s ease-out 0.15s;
}
.boutonCadreA:hover .cadreBouton .coinBG{
	opacity: 1;
	width:100%;
	height:100%;
	transition: height 0.15s ease-out, width 0.15s ease-out 0.15s;
}

.boutonBase{
	width:auto;
	min-width: 140px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ffffff;
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
}
.boutonBase:hover .boutonFleche{ margin-left: 20px; }
.boutonBase.posCentrer{ position: relative;  float: left; left: 50%; transform:translateX(-50%); }
.boutonTxt{
	position: relative;
	float: left;
}
.boutonFleche{
	position: relative;
	float: left;
	display: inline-block;
	margin-left: 10px;
	transition: .4s all;
}

.boutonResaPage{
	width:200px;
	min-width: 140px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #45bfdc;
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	clear: both;
	margin: 40px 0;
	left: 50%;
	transform: translateX(-50%);
	position: relative;
	float: left;
}
.boutonResaPage:hover .boutonFleche{ margin-left: 20px; }
.boutonResaPage.posCentrer{ position: relative;  float: left; left: 50%; transform:translateX(-50%); }

.boutonResaPage.actu{
	margin: 10px 0 20px 0;
	left:0;
	transform: none;
}

.boutonZoom{
	width: 160px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ff9d11;
	background-color: rgba(0,0,0,0.8);
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	clear: both;
	margin: -25px 0 40px 0;
	left: 50%;
	transform: translateX(-50%);
	position: relative;
	float: left;
}
.boutonZoom.vBleu{ border: 1px solid #45bfdc; }
.boutonZoom:hover .boutonFleche{ margin-left: 20px; }

.boutonSuite{
	width: 160px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ff9d11;
	background-color: rgba(0,0,0,0.8);
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	clear: both;
	margin: 10px 0 40px 0;
	left: 50%;
	transform: translateX(-50%);
	position: relative;
	float: left;
}
.boutonSuite.vBleu{ border: 1px solid #45bfdc; }
.boutonSuite:hover .boutonFleche{ margin-left: 20px; }

/* SECTION & PAGE BASE -----------------------------*/
.page{
	width:100%;
	max-width: 1300px;
	position: relative;
	float: left;
	clear: both;
	margin: 40px 0;
	left: 50%;
	transform: translateX(-50%);
}
.page100{
	width:100%;
	position: relative;
	float: left;
	clear: both;
	margin: 40px 0;
}
.page100.fdAccNews{
	background-image: url("img/fdAccNews2024.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAccAquatique{
	background-image: url("img/fdAccAqua.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAccSpa{
	background-image: url("img/fdAccSpa.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAccMh{
	background-image: url("img/fdAccMh.webp");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAccAvis{
	background-image: url("img/fdAccAvis.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdPiscActivite{
	background-image: url("img/fdPiscActivite.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdPiscNocturne{
	background-image: url("img/fdPiscNocturne.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdSpaBien{
	background-image: url("img/fdSpaBien.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdCampResa{
	background-image: url("img/fdCampResa.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdServBar{
	background-image: url("img/fdServBar2024.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdServConf{
	background-image: url("img/fdServConf2024.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdEquipEnfant{
	background-image: url("img/fdEquipEnf.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdEquipAdo{
	background-image: url("img/fdEquipAdo.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdEquipSport{
	background-image: url("img/fdEquipSport.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAnimJour{
	background-image: url("img/fdAnimJour2024.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdAnimSoir{
	background-image: url("img/fdAnimSoir.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdCompost{
	background-image: url("img/fdCompost.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdHeb1{
	background-image: url("img/fdHeb1.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdHeb2{
	background-image: url("img/fdHeb2.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdHeb3{
	background-image: url("img/fdHeb3.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdHeb4{
	background-image: url("img/fdHeb4.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdHeb5{
	background-image: url("img/fdHeb5.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdLocMh{
	background-image: url("img/fdLocMh.webp");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdPlage{
	background-image: url("img/fdPlage.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdZoo{
	background-image: url("img/fdZoo.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdSport{
	background-image: url("img/fdSport.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdContact{
	background-image: url("img/fdContact.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdFlower1{
	background-image: url("img/fdFlower1.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdFlower2{
	background-image: url("img/fdFlower2.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdChien{
	background-image: url("img/fdChien.jpg");
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}
.page100.fdArticle{
	background-size: cover;
	background-position: 50%;
	min-height: 500px;
}


.contenu{
	width:100%;
	max-width: 1300px;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
}

.entete{
	display: block;
	position: relative;
	float: left;
	background-color: #252525;
	padding: 5px 20px;
	clear: both;
}
.bordEntete{
	width:2px;
	height: 90%;
	background-color: #45bfdc;
	position: absolute;
	float: left;
	left: 5px;
}
.entete.impaire{
	float: right;
	/*border-left: 2px solid #ff9d11;*/
}
.entete.impaire .bordEntete{
	background-color: #ff9d11;
}

.sep{
	width:100%;
	position: relative;
	float: left;
	margin-bottom: 40px;
}
.col100{
	width:calc(100% - 40px);
	padding: 0 20px;
	position: relative;
	float: left;
}
.col100.cadreG{
	padding: 20px;
	background-color: rgba(0,0,0,0.75);
	margin: 40px 0;
	clear: both;
}
.col100.sepMobi{
	margin-top: 10px;
	border-top:1px solid #3e3e3e;
	border-bottom:1px solid #3e3e3e;
}
.col50{
	width:calc(50% - 40px);
	padding: 0 20px;
	position: relative;
	float: left;
}
.col50.news{
	border:1px solid #333333;
	padding: 0 15px;
	margin: 0 5px;
}
.col50.cadreG{
	padding: 20px;
	background-color: rgba(0,0,0,0.75);
	margin: 40px 0;
	clear: both;
}
.col50.cadreG.impaire{
	padding: 20px;
	background-color: rgba(0,0,0,0.75);
	margin: 40px 0;
	float: right;
	clear: both;
}

.col30{
	width:calc(33% - 40px);
	padding: 0 20px;
	position: relative;
	float: left;
}
.col30.impaire{
	background-color: rgba(0,0,0,0.75);
}

.ligneFlex{
	width: 100%;
	display: flex;
	align-items: center;
	position: relative;
	float: left;
}
.ligneFlex.marge{
	margin-bottom: 30px;
}
.ligneFlex.margeDouble{
	margin-bottom: 60px;
}
.ligneFlex.accNews{
	width: calc(100% - 10px);
	justify-content: space-between;
	align-items:flex-start;
	margin: 20px 5px 40px 5px;
}
.ligneFlex.alignTop{
	align-items:flex-start;
}
.ligneFlex.alignFull{
	align-items: stretch;
}
.ligneFlex.accActu{
	width: calc(100% - 20px);
	background-color: #333333;
	padding: 10px;
	gap:20px;
}
.ligneFlex .logoAcc{
	width: 110px;
	height: 100px;
	position: relative;
	float: left;
	margin: 0 10px;
}
.ligneFlex .logoAcc img{ max-width: 100%; height: auto; position: absolute; float: left; top: 50%; left: 50%; transform: translate(-50%, -50%); }

.imgMW{
	max-width: calc(100% - 2px);
	height: auto;
	display: block;
}
.bordOrange{
	border: 1px solid #ff9d11;
}
.centreTxt{ text-align: center; }


.bulleMot{
	display: flex;
	justify-content: center;
	align-items: center;
	background-color:#ffffff;
	padding: 5px 10px;
	border:1px solid #ff9d11;
	border-radius: 8px;
	box-shadow: 0 0 3px #000000;
	position: absolute;
	float: left;
	z-index: 2;
}
.bulleMot.bordB{ border:1px solid #45bfdc; }
.bulleMot.visuG{
	top: 40px;
	left: 0;
	transform: rotate(-15deg) translate(20px, -20px);
}
.bulleMot.visuD{
	top: 40px;
	right: 0;
	transform: rotate(15deg) translate(-20px, -20px);
}
.bulleMot p{
	font-size: 2em;
	font-weight: bold;
	font-family: Allura;
}

/* GALERIE PHOTO ------------------------ */
.gridPhoto{
	width: 100%;
	position: relative;
	float: left;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	/*grid-template-rows: minmax(10px, 250px) minmax(10px, 350px);*/
	column-gap: 20px;
	row-gap: 20px;
}
.caseMiniature{ position: relative; float: left; cursor: pointer; }
.cadreMiniature{
	width: calc(100% - 22px);
	height: calc(100% - 22px);
	border-top: 1px solid #ffffff;
	border-left: 1px solid #ffffff;
	border-right: 1px solid #ffffff;
	position: absolute;
	float: left;
	top: 10px;
	left: 10px;
	transition: 0.3s all;
	z-index: 2;
}
.caseMiniature:hover .cadreMiniature{
	background-color: rgba(0,0,0,0.8);
}

.legendeMiniature{
	width: calc(100% - 20px);
	text-align: center;
	font-size: 1em;
	color: #ffffff;
	padding: 4px 0;
	position: absolute;
	float: left;
	bottom: 10px;
	left: 10px;
	z-index: 3;
	opacity: 1;
	transition: 0.3s all;
}
.caseMiniature:hover .legendeMiniature{
	bottom: calc(50% - 10px);
}

.gridPhotoMobi{
	width: 100%;
	position: relative;
	float: left;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	/*grid-template-rows: 1fr;*/
	column-gap: 20px;
	row-gap: 20px;
}
.caseMiniatureMobi{ 
	width:100%;
	height: 100px;
	position: relative; 
	float: left; 
	cursor: pointer; 
	overflow: hidden;
}
.cadreMiniatureMobi{
	width: calc(100% - 12px);
	height: calc(100% - 12px);
	position: absolute;
	float: left;
	top: 5px;
	left: 5px;
	transition: 0.3s all;
	z-index: 2;
}
.caseMiniatureMobi:hover .cadreMiniatureMobi{
	background-color: rgba(0,0,0,0.8);
}
.photoMobi{
	width: 100%;
	height: 100%;
	position: absolute;
	float: left;
}
.photoMobi img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}
.legendeMiniatureMobi{
	width: calc(100% - 20px);
	text-align: center;
	font-size: 0.8em;
	color: #ffffff;
	padding: 4px 0;
	position: absolute;
	float: left;
	bottom: 10px;
	left: 10px;
	z-index: 3;
	opacity: 0;
	transition: 0.3s all;
}
.caseMiniatureMobi:hover .legendeMiniatureMobi{
	bottom: calc(50% - 10px);
	opacity: 1;
}

.grandePhotoMobi{
	width: 100%;
	max-height: 400px;
	position: relative;
	float: left;
	overflow: hidden;
}
.grandePhotoMobi img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: 50% 50%;
}
.grandePhotoMobi:hover .cadreMiniatureMobi{
	background-color: rgba(0,0,0,0.8);
}
.grandePhotoMobi:hover .legendeMiniatureMobi{
	bottom: calc(50% - 10px);
	opacity: 1;
}


/* ACCUEIL ------------------------------ */
/* ACTU -- */
.zoneActu{
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.9);
	position: fixed;
	float: left;
	z-index: 15;
}
.cadreActu{
	width: auto;
	max-width: 1280px;
	max-height: calc(90% - 20px);
	padding: 10px;
	background-color: #252525;
	border: 2px solid #ff9d11;
	position: absolute;
	float: left;
	animation-name: animActu;
    animation-duration: 2s;
	animation-timing-function: ease-in-out;
    animation-delay: 0s;
	animation-iteration-count: 1;
	animation-fill-mode: forwards;
}
.colTxtNw{
	width: calc(50% - 20px);
	position: relative;
	float: left;
	margin: 0 10px;
	clear: both;
}
.colPhotoNw{
	width: calc(50% - 20px);
	position: relative;
	float: left;
	margin: 0 10px;
}
.photoNew{
    width: 100%;
    /*max-height: 350px;*/
    position: relative;
    float: left;
    left: 50%;
    transform: translateX(-50%);
    overflow: hidden;
}
.photoNew img{ 
    width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}
.closeActu{
width:50%;
max-width: 150px;
background-color:#ff9d11;
border-radius:0 0 8px 8px;
color:#000000;
font-size:0.9em;
text-align:center;
vertical-align:middle;
position:relative;
float:left;
padding: 4px;
margin-top:-10px;
left: 50%;
transform: translateX(-50%);
margin-bottom: 5px;
clear: both;
}
.closeActu a{
color:#000000;
text-decoration:none;
}

@keyframes animActu{
	from,10%{
		bottom: 0;
		left: 50%;
		transform: translate(-50%,100%);
	}
	45%{
		bottom: 60%;
		left: 50%;
		transform: translate(-50%,50%);
	}
	70%{
		bottom: 45%;
		left: 50%;
		transform: translate(-50%,50%);
	}
	90%,100%{
		bottom: 50%;
		left: 50%;
		transform: translate(-50%,50%);
	}
}
/* -- */

.caseActu{
	width: 320px;
	min-height: 220px;
	background-color: #252525;
	position: relative;
	float: left;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
	border-radius: 8px;
	cursor: pointer;
}
.caseActu.fin{
	width: 220px;
	justify-content: center;
}
.dateActu{
	width:120px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	/*background-color: #45bfdc;
	color: #ffffff;*/
	color: #45bfdc;
	font-size: 0.9em;
	text-align: center;
	position: relative;
	float: left;
}
.visuActu{
	width: 100%;
	height: 160px;
	position: relative;
	float: left;
	overflow: hidden;
}
.visuActu img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: 50% 50%;
}
.trameActu{
	width: 0;
	height: 100%;
	font-size: 1.2em;
	white-space: nowrap;
	background-color: rgba(0,0,0,0.8);
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	float: left;
	top: 0;
	left: 0;
	z-index: 2;
	overflow: hidden;
	transition: all 0.4s;
}
.titreActu{
	width: 100%;
	min-height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-bottom: 1px solid #ff9d11;
	color: #ff9d11;
	text-align: center;
	font-size: 1.1em;
	position: relative;
	float: left;
}
.caseActu:hover .trameActu{
	width: 100%;
}
.iconeActu{
	width: 120px;
	height: 60px;
	position: relative;
	float: left;
	margin-bottom: 20px;
}
.suiteActu{
	width: calc(100% - 40px);
	text-align: center;
	font-family: 'Allura';
	font-size: 1.6em;
	color: #ff9d11;
	padding: 5px 0;
	border-top: 1px solid #666666;
	border-bottom:1px solid #666666;
}


.vidP{
width:calc(100% - 2px);
/*border:1px solid #dddddd;*/
position:relative;
float:left;
}

.grillePhotoAccueil{
	width: 100%;
	height: 700px;
	position: relative;
	float: left;
}
.grilleCaseGauche{
	width: 50%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
	background-image: url("img/accueil-gheberg.jpg");
}
.grilleCaseDroiteH{
	width: 50%;
	height: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
	background-image: url("img/accueil-gaqua.jpg");	
}
.grilleCaseDroiteD{
	width: 25%;
	height: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	background-position: 50%;
	background-repeat: no-repeat;
	background-image: url("img/accueil-gregion.jpg");	
}
.grilleCaseDroiteG{
	width: 25%;
	height: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	background-size: cover;
	background-position: 50%;
	background-repeat: no-repeat;
	background-image: url("img/accueil-gdetente.jpg");	
}

.titreGrille{
	width: 90%;
	max-width: 400px;
	text-align: center;
	position: relative;
	z-index: 2;
}
.detailGrille{
	width: 100%;
	height: 0;
	position: relative;
	margin-top: 40px;
	overflow: hidden;
	transition: .4s all;
}
.fdGrille{
	width: 100%;
	height: 0;
	position: absolute;
	float: left;
	background-color: rgba(0,0,0,0.8);
	top: 50%;
	transform: translateY(-50%);
	transition: .4s all;
}
.grilleAction:hover .fdGrille{ 
	height: 100%; 
}
.grilleAction:hover .detailGrille{ 
	height: 150px;
}

.colNew{
	width: 270px;
	position: relative;
	float: left;
}
.titreNew{
	font-size: 1.5em;
	font-weight: bold;
}
.boutonNews{
	width:calc(100% - 22px);
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ff9d11;
	background-color: rgba(0,0,0,0.5);
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
}
.boutonNews:hover .boutonFleche{ margin-left: 20px; }
.boutonNews.posCentrer{ position: relative;  float: left; left: 50%; transform:translateX(-50%); }

.col50.carteCH{
	width:calc(50% - 40px);
	text-align: center;
	left: 50%;
	top: 100px;
	padding: 0 20px;
	position: absolute;
	float: left;
}

.colAvis{
	width: 280px;
	position: relative;
	float: left;
	padding: 10px 20px;
}
.colAvis .coinBD{
	width:40px;
	height: 40px;
	border: 1px solid #ff9d11;
	border-left: none;
	border-top: none;
	position: absolute;
	float: left;
	bottom: 0;
	right:0;
	z-index: 2;
}
.colAvis .coinBD.bleu{ border: 1px solid #45bfdc; 	border-left: none; border-top: none; }
.colAvis .coinHG{
	width:40px;
	height: 40px;
	border: 1px solid #ff9d11;
	border-right: none;
	border-bottom: none;
	position: absolute;
	float: left;
	top: 0;
	left:0;
	z-index: 2;
}
.colAvis .coinHG.bleu{ border: 1px solid #45bfdc; border-right: none; border-bottom: none; }
.titreAvis{
	width: 100%;
	display: inline-block;
	margin-bottom: 10px;
}
.noteAvis{
	width: 100%;
	text-align: center;
	position: relative;
	float: left;
	margin-top: 10px;
}


/* ESPACE AQUATIQUE --------------------------------- */
.ligneLogo{
	width: 100%;
	display: flex;
	align-items:center;
	justify-content: space-between;
	position: relative;
	float: left;
}
.zoneLogo{
	width:110px;
	position: relative;
	float: left;
	margin: 5px;
}
.rondLogo{
	width: 105px;
	height: 105px;
	border: 2px solid #45bfdc;
	border-radius: 50%;
	position: relative;
	float: left;
}
.rondLogo.bordOrange{
	border: 2px solid #ff9d11;
}
.rondLogo img{
	max-width: 100%;
	position: absolute;
	float: left;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
.infoLogo{
	width:100%;
	position: relative;
	float: left;
	text-align: center;
}


/* ACTUALITE ----------------------- */
.photoActu{
	width: 100%;
	text-align: center;
	position: relative;
	float: left;
	margin-top: 10px;
}
.flexActu{
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	position: relative;
	float: left;
	gap:20px;
}
.ligneActu{
	width: calc(100% - 50px);
	min-height: 150px;
	border:1px solid #333333;
	padding: 0 15px;
	position: relative;
	float: left;
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.infoActu{
	width: calc(100% - 420px);
	position: relative;
	float: left;
	margin: 10px 0;
}
.accesActu{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	border: 1px solid #45bfdc;
	background-color: #000000;
	color: #ffffff;
	position: relative;
	float: left;
	padding: 5px 10px;
}
.illusActu{
	width: 420px;
	height: 100%;
	position: relative;
	float: left;
}
.photoLigneActu{
	width: 100%;
	height: 100%;
	position: relative;
	float: left;
	/*background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;*/
}
.photoLigneActu img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
}
.triangleMasque{
	width: 40px;
	height: 100%;
	background-color: #252525;
	clip-path: polygon(0 0, 0% 100%, 100% 0);
	position: absolute;
	float: left;
	top: 0;
	left: 0;
	z-index: 2;
}
.boutonTransparent{
	width: 100%;
	height: 100%;
	position: absolute;
	float: left;
	top: 0;
	left: 0;
	z-index: 5;
}

/* LOCATION --------------------- */
.ensembleGamme{
	width:calc(100% - 12px);
	border: 1px solid #ffffff;
	padding: 5px;
	display: flex;
	justify-content: space-between;
	align-content: stretch;
	flex-wrap: wrap;
	position: relative;
	float: left;
}
.blocGamme{
	width:calc(33% - 4px);
	text-align: center;
	position: relative;
	float: left;
	padding: 5px 0;
	margin: 0 2px;
}
.blocGamme.std{ border-bottom: 1px solid #ffffff; }
.blocGamme.conf{ border-bottom: 1px solid #45bfdc; }
.blocGamme.prem{ border-bottom: 1px solid #ff9d11; }
.optionGamme{
	width: 100%;
	text-align: center;
	position: relative;
	float: left;
	margin-top: 10px;
}
.listeOption{
	width: 100%;
	position: relative;
	float: left;
}
.listeOption ul{
	width:33%;
	text-align: left;
	list-style: none;
	position: relative;
	float: left;
	display: inline-block;
	margin: 0;
	padding: 0;
}

.ligneMH{
	width: 100%;
	position: relative;
	float: left;
	display: flex;
}
.caseMH{
	width:98px;
	height: 98px;
	background-color: #252525;
	text-align: center;
	font-size: 0.9em;
	position: relative;
	float: left;
	margin: 0 4px;
}
.caseMH.vbleu{ border: 1px solid #45bfdc; }
.caseMH.vorange{ border: 1px solid #ff9d11; }
.caseMH.vblanc{ border: 1px solid #ffffff; }
.caseMH.long{
	width:calc(100% - 330px);
}
.caseMH p{
	width: 100%;
	position: absolute;
	float: left;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
.photoMH{
	max-width: 100%;
	border: 1px solid #45bfdc;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
	margin-bottom: 30px;
}
.photoMH.vOrange{ border: 1px solid #ff9d11; }

.lotBoutonMH{
	width: 100%;
	position: absolute;
	float: left;
	display: flex;
	justify-content: center;
	bottom: 0;
	left: 0;
	z-index: 2;
}
.boutonGalMH{
	width: 170px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ff9d11;
	background-color: #252525;
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	margin: 0 5px;
	position: relative;
	float: left;
}
.boutonGalMH.vBleu{ border: 1px solid #45bfdc; }
.boutonGalMH:hover .boutonFleche{ margin-left: 20px; }

.boutonInvMH{
	width: 120px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	vertical-align: middle;
	padding: 10px;
	border: 1px solid #ff9d11;
	background-color: #252525;
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	margin: 0 5px;
	position: relative;
	float: left;
}
.boutonInvMH.vBleu{ border: 1px solid #45bfdc; }
.boutonInvMH:hover .boutonFleche{ margin-left: 20px; }


.menuMH{
	width: 100%;
	max-width: 600px;
	position: relative;
	float: left;
	display: flex;
	justify-content: space-between;
	margin: -40px 0 60px 0;
	left: 50%;
	transform: translateX(-50%);
	clear: both;
}
.bAccesMH{
	width: 130px;
	height: 50px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	vertical-align: middle;
	padding: 5px;
	background-color: #3e3e3e;
	color: #ffffff;
	text-decoration: none;
	cursor: pointer;
	margin: 0 5px;
	position: relative;
	float: left;
}
.txtBAcces{
	position: relative;
	float: left;
	z-index: 2;
	margin-left: 10px;
	transition: 0.4s all;
}
.txtBAcces.vOrange .mav{ color: #ff9d11 ; }
.txtBAcces .mav{ color: #45bfdc ; }
.caseFlecheBAcces{
	width: 20px;
	height: calc(100% - 10px);
	background-color: #45bfdc;
	position: absolute;
	float: left;
	right: 5px;
	transition: 0.4s all;
}
.caseFlecheBAcces.vOrange{ background-color: #ff9d11; }
.caseFlecheBAcces img{
	position: absolute;
	float: left;
	top: 50%;
	left: calc(100% - 10px);
	transform: translate(-50%, -50%);
}
.bAccesMH:hover .txtBAcces{ margin-left: 15px; }
.bAccesMH:hover .txtBAcces .mav{ color:#252525; }
.bAccesMH:hover .caseFlecheBAcces{ width: calc(100% - 10px); }
.bAccesMH:hover .caseFlecheBAcces img{ left: calc(100% - 10px); }

.trameNoir{
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.8);
	position: fixed;
	float: left;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 10;
	overflow: hidden;
}
.closeTrame{
	width: 100px;
	height: 30px;
	background-color: #000000;
	color: #ffffff;
	text-decoration: none;
	border: 1px solid #ff9d11;
	position: relative;
	float: left;
	display: flex;
	align-items: center;
	justify-content: space-around;
	clear: both;
	left: 50%;
	transform: translateX(-50%);
}
.bigX{
	font-size: 2em;
	color: #ff9d11;
}
#PrixAff{
	max-width: calc(100% - 20px);
	max-height: calc(100% - 20px);
	padding: 10px;
	background-color: #ffffff;
	position: relative;
	float: left;
	clear: both;
	overflow: auto;
}
.zonePrixMH{
	max-height: 90%;
	position: fixed;
	float: left;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	overflow: auto;
}


/* REGION ----------------------------- */
.grilleTxt{
	width: 100%;
	position: relative;
	float: left;
	margin-top: 10px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 15px;
  	row-gap: 20px;
}
.colRegion{
	/*width:calc(50% - 45px);
	margin: 0 20px 20px 20px;*/
	position: relative;
	float: left;
	display: flex;
	align-items: stretch;
	border-bottom: 1px solid #3e3e3e;
	border-right:1px solid #3e3e3e;
}
.gaucheRegion{
	width:200px;
	position: relative;
	float: left;
	background-color: #3e3e3e;
	padding: 0 5px;
}
.droiteRegion{
	width:calc(100% - 240px);
	position: relative;
	float: left;
	margin-left: 20px;
	padding-right: 10px;
}
.titreRegion{
	width:100%;
	text-align: center;
	font-size: 1.4em;
	position: relative;
	float: left;
	margin: 10px 0;
}

.blocFAQ{
	width: 100%;
	position: relative;
	float: left;
	margin-bottom: 5px;
}
.enteteQuest{
	width: calc(100% - 20px);
	min-height: 30px;
	background-color: #000000;
	border-bottom: 1px solid #ff9d11;
	padding: 10px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap:5px;
	cursor: pointer;
}
.nomQuest{
	width: calc(100% - 50px);
	font-size: 1.2em;
	text-transform: uppercase;
	position: relative;
}
.nomQuest:first-letter{
	font-weight: bold;
	font-size: 1.2em;
	color: #ff9d11;
}
.flecheQuest{
	width: 20px;
	height: 15px;
	background-color: #ff9d11;
	clip-path: polygon(50% 50%, 100% 0, 100% 50%, 50% 100%, 0 50%, 0 0);
	position: relative;
}
.flecheQuest.actif{ clip-path: polygon(50% 0, 100% 50%, 100% 100%, 50% 50%, 0 100%, 0 50%); }
.infoQuest{
	width: 100%;
	max-height: 0;
	position: relative;
	overflow: hidden;
	transition: all 0.6s;
}
.infoQuest p{ position: relative; margin:20px; }
.infoQuest.actif{ max-height:500px; } 

/* CONTACT ------------------------ */
.cadreHoraire{
	width:300px;
	border: 2px solid #ff9d11;
	padding: 10px;
	border-radius: 8px;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
}
.enteteCadreHoraire{
	width:100%;
	background-color: #ff9d11;
	color: #ffffff;
	text-align: center;
	position: relative;
	float: left;
}

.formulaire{
	width:calc(100% - 20px);
	width: 500px;
	position: relative;
	float: left;
	margin: 0 10px;
}
.chp100{
	width:calc(100% - 60px);
	max-width:500px;
	padding: 0 20px;
	height: 30px;
	border-radius: 15px;
	display: inline-block;
	border: 1px solid #45bfdc;
	margin: 5px;
	color: #000000;
	font-family: 'Arial';
	font-size: 1em; 
	position: relative;
	float: left;
}
.chp100.adresse{ width:calc(100% - 200px);}
.chp100::placeholder{ color:#666666; }
.chpAr100{
	width:calc(100% - 60px);
	max-width:500px;
	padding: 0 20px;
	height: 160px;
	border-radius: 15px;
	/*display: inline-block;/*/
	border: 1px solid #45bfdc;
	margin: 5px;
	color: #000000;
	font-family: 'Arial';
	font-size: 1em; 
	position: relative;
	float: left;
}
.chpAr100::placeholder{ color:#666666; }
.formLigne{
	width:calc(100% - 20px);
	margin: 5px;
	position: relative;
	float: left;
}
.chpMini{
	width:40px;
	padding: 0 20px;
	height: 30px;
	border-radius: 15px;
	display: inline-block;
	border: 1px solid #45bfdc;
	margin: 10px;
	color: #000000;
	font-family: 'Arial';
	font-size: 1em; 
}
.chpSub{
	width: auto;
	height: 30px;
	font-size: 1em;
	text-align: center;
	color: #3e3e3e;
	border-radius: 15px;
	display: inline-block;
	background-color: #45bfdc;
	border: 1px solid #ffffff;
	padding: 0 40px;
	margin: 5px 0;
	cursor: pointer;
	position: relative;
	float: left;
}

.message{
width:350px;
max-width: 90%;
background-color:#ffffff;
border:1px solid #ff9d11;
border-radius:8px;
font-size:1em;
color: #000000;
text-align:center;
height:auto;
padding:4px;
box-shadow: 0 0 5px #666666;
position:fixed;
top:50%;
left:50%;
transform:translate(-50%, -50%);
z-index:11;
overflow:auto;
}
.closeF{
width:100px;
background-color:#ff9d11;
border-radius:0 8px 0 8px;
color:#000000;
font-size:0.9em;
text-align:center;
line-height:25px;
vertical-align:middle;
position:relative;
float:left;
padding: 4px;
top:0;
left: 50%;
transform: translateX(-50%);
}
.closeF a{
color:#000000;
text-decoration:none;
}

#Carte{
	width:100%;
	height: 550px;
	position: relative;
	float: left;
	margin-bottom: 20px;
}
#Detail{
	width:100%;
	color: #000000;
	background-color: #ffffff;
	position: relative;
	float: left;
}


/* CARTE ------------------------------------ */
.planSelect{
	width:100%;
	max-width: 500px;
	padding: 10px;
	background-color: #45bfdc;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
	margin-bottom: 10px;
}

#PlanLoges{
width:100%;
height:800px;
overflow:hidden;
position:relative;
float:left;
}
#ZoneLoges{
width:100%;
height:900px;
overflow:hidden;
position:relative;
float:left;
}

#FichePlan{
width:370px;
border:1px solid #45bfdc;
background-color:rgba(0,0,0,0.8);
color:#FFFFFF;
float:left;
position:fixed;
margin-left:10px;
top:50%;
transform: translateY(-50%);
opacity:0;
}
#resultFiche{
	position: relative;
	float: left;
	margin: 10px;
}
.vignetteFiche{
width:180px;
height:120px;
position:relative;
float:left;
border:1px solid #ffffff;
border-radius:8px 8px 8px 8px;
left:50%;
transform:translateX(-50%);
overflow:hidden;
}
	.vignetteFiche img{
	max-width:100%;
	position:absolute;
	top:50%;
	left:50%;
	transform:translate(-50%, -50%);
	}

.infoFiche{
width:100%;
position:relative;
float:left;
}

.bFiche{
width:180px;
height:40px;
line-height:40px;
vertical-align:middle;
background-color:#45bfdc;
position:relative;
float:left;
text-align:center;
color:#252525;
border-radius:8px 8px 8px 8px;
left:50%;
transform:translateX(-50%);
}

.ligneDoc{
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	float: left;
	left: 50%;
	transform: translateX(-50%);
	clear: both;
	margin: 20px 0;
}



/* --------------------------------------------------------------- */
/* ANIMATION ---------------------- */
/* ACCUEIL ----------------------- */
@keyframes accP1{
	from,20%{
		opacity: 1;
	}
	32%{
		opacity: 0;
	}
	88%{
		opacity: 0;
	}
	100%{
		opacity: 1;
	}
}

@keyframes accP2{
	from{
		opacity: 0;
	}
	20%{
		opacity:0;
	}
	32%{
		opacity: 1;
	}
	52%{
		opacity:1;
	}
	64%,100%{
		opacity: 0;
	}
}

@keyframes accP3{
	from,52%{
		opacity: 0;
	}
	52%{ 
		opacity: 0;
	}
	64%{
		opacity: 1;
	}
	88%{
		opacity:1;
	}
	100%{
		opacity: 0;
	}
}
