html { margin: 0px; overflow-x: hidden; }
body { margin: 0px; overflow: hidden; }

html::-webkit-scrollbar, body::-webkit-scrollbar  { display: none !important; }
html, body { -ms-overflow-style: none !important; scrollbar-width: none !important; }

/* MOBIL */
.mobilSupr { display: default !important; }
.justMobil { display: none !important; }
.mobilSuprTable { display: table !important; }
.justMobilTable { display: none !important; }

/* WIDTH */

.contenu {
	position: relative;
	display: inline-block;
	background-size: cover;
	background-position: center;
	vertical-align: middle;
  word-spacing: 0em;
	overflow: visible;
}

/* PAGE CONTENU */

.width-full {
	display: table;
	position: relative;
	width: 100vw;
	height: auto;
	min-width: 100vw;
	table-layout: fixed;
	word-spacing: -4em;
	margin: 0 auto;
	overflow: visible;
	vertical-align: middle;
}

.width-max {
	display: table;
	position: relative;
	width: 80vw;
	margin: 0 auto;
	table-layout: fixed;
	word-spacing: -4em;
	overflow: visible;
	padding: 0;
}

.width-grand {
	display: inline-table;
	position: relative;
	width: calc(3* (100vw/4) - 50px);
	margin: 0 50px 0 0;
	table-layout: fixed;
	word-spacing: -4em;
	overflow: visible;
	padding: 0;
	vertical-align: middle;
}

.width-petit {
	display: inline-table;
	position: relative;
	width: calc(100vw/4);
	margin: 0;
	table-layout: fixed;
	word-spacing: -4em;
	overflow: visible;
	padding: 0;
	vertical-align: middle;
}

/* MARGES */
.padding-top { padding-top: 80px; }
.padding-bottom { padding-bottom: 80px; }
.margin-top { padding-top: 80px; }
.margin-bottom { padding-bottom: 80px; }

/* BOX // WIDTH */
.entier {width: calc((100% / 1) - 40px); margin: 0px 20px; }
.entier-full {width: calc((100% / 1) - 0px); margin: 0px 0px; }
.demi {width: calc((100% / 2) - 40px ); margin: 0px 20px; }
.demi-full {width: calc((100% / 2) - 0px ); margin: 0px 0px; }
.tier {width: calc((100% / 3) - 40px); margin: 0px 20px; }
.tier-max {width: calc((100% / 3) - 20px); margin: 0px 10px; }
.tier-full {width: calc((100% / 3) - 0px); margin: 0px 0px; }
.deuxtier {width: calc(2*(100% / 3) - 40px); margin: 0px 20px; }
.deuxtier-full {width: calc(2*(100% / 3) - 0px); margin: 0px 0px; }
.quart {width: calc((100% / 4) - 40px); margin: 0px 20px; }
.quart-full {width: calc((100% / 4) - 0px); margin: 0px 0px; }
.troisquart {width: calc(3*(100% / 4) - 20px); margin: 0px 40px; }
.troisquart-full {width: calc(3*(100% / 4) - 0px); margin: 0px 0px; }
.cinquieme {width: calc((100% / 5) - 40px); margin: 0px 20px; }
.cinquieme-full {width: calc((100% / 5) - 0px); margin: 0px 0px; }
.sixieme {width: calc((100% / 6) - 40px); margin: 0px 20px; }
.sixieme-full {width: calc((100% / 6) - 0px); margin: 0px 0px; }
.cinqsixieme {width: calc(5*(100% / 6) - 40px); margin: 0px 20px; }
.cinqsixieme-full {width: calc(5*(100% / 6) - 0px); margin: 0px 0px; }
.deuxcinquieme {width: calc(2*(100% / 5) - 40px); margin: 0px 20px; }
.deuxcinquieme-left {width: calc(2*(100% / 5) - 20px); margin: 0px 20px 0 0; }
.deuxcinquieme-full {width: calc(2*(100% / 5) - 0px); margin: 0px 0px; }
.troiscinquieme {width: calc(3*(100% / 5) - 40px); margin: 0px 20px; }
.troiscinquieme-full {width: calc(3*(100% / 5) - 0px); margin: 0px 0px; }

/* FONT // PARA */
.font-cap { text-transform: uppercase; }
.font-underline { text-decoration: underline; }
.font-italique { font-style: italic; }
.para-left { text-align: left; }
.para-justify { text-align: justify; }
.para-center { text-align: center; }
.para-right { text-align: right; }

/* ALIGNEMENT */
.vertical-align-top { vertical-align: top; }
.vertical-align-bottom { vertical-align: bottom; }

/* ESPACE VIDE */
.espace-vide-10 { height: 10px; width: 100%; }
.espace-vide-20 { height: 20px; width: 100%; }
.espace-vide-30 { height: 30px; width: 100%; }
.espace-vide-40 { height: 40px; width: 100%; }
.espace-vide-50 { height: 50px; width: 100%; }
.espace-vide-60 { height: 60px; width: 100%; }
.espace-vide-100 { height: 100px; width: 100%; }
.espace-vide-200 { height: 200px; width: 100%; }
.espace-vide-300 { height: 300px; width: 100%; }

/* BANDES IMAGES */
.bande-10 { height: 10vh; }
.bande-15 { height: 15vh; }
.bande-20 { height: 20vh; }
.bande-30 { height: 30vh; }
.bande-35 { height: 35vh; }
.bande-40 { height: 40vh; min-height: 400px; }
.bande-50 { height: 50vh; min-height: 500px; }
.bande-60 { height: 60vh; min-height: 600px; }
.bande-70 { height: 70vh; min-height: 700px; }
.bande-80 { height: 80vh; min-height: 800px; }

.image-back {
	background-size: cover;
	background-position: center;
}

/* BACKGROUND COLOR */

.background-color-corpo { background-color: var(--color-projet-corpo); }
.background-color-cardis { background-color: #173357; }
.background-color-dispo { background-color: var(--color-selecteur-dispo); }

.background-vert-clair { background-color: var(--color-selecteur-dispo); }
.background-vert-fonce { background-color: var(--color-gris-fonce); }

.background-color-corpo p, .background-color-cardis p, .background-color-cardis a, .background-color-cardis h4, .background-color-cardis h2, .background-color-cardis h3 { color: white; }

/* MARGES */

.shadow-right { box-shadow: inset -70px 0 0 0 white; }
.shadow-left { box-shadow: inset 70px 0 0 0 white; }

/* DIVERS */

.hideBtn { display: none !important; }
.bande-image-img { height: auto; }

/* SVG */

.cls-1 { fill: var(--color-gris-fonce); }

/* P // H */

p, a, i {
	font-family: 'Light', sans-serif;
	color: var(--color-gris-fonce);
	font-size: 0.8vw;
	line-height: 1.8vw;
	text-decoration: none;
}

sup {
	font-size: 60%;
	line-height: 0;
}

b {
	font-family: 'Bold', sans-serif;
}

a.en-savoir-plus, a.en-savoir-moins, a.simple {
	display: inline-block;
	font-family: 'medium', sans-serif;
	cursor: pointer;
	padding: 14px 20px;
	margin: 20px 0;
	text-transform: uppercase;
	font-size: 0.6vw;
	line-height: 1vw;
	letter-spacing: 0.2vw;
	border-radius: var(--border-radius);
	background-color: var(--color-selecteur-reser);
	color: white;
}

a.bouton {
	display: inline-block;
	font-family: 'medium', sans-serif;
	cursor: pointer;
	padding: 14px 20px;
	margin: 20px 0;
	text-transform: uppercase;
	font-size: 0.7vw;
	line-height: 1.1vw;
	letter-spacing: 0.2vw;
	border-radius: var(--border-radius);
	background-color: var(--color-gris-fonce);
	color: white;
}

h1 {
		font-family: 'Light', sans-serif;
		font-size: 1.6vw;
		line-height: 2.2vw;
		padding: 20px 40px;
		color: var(--color-projet-corpo);
}

h1 b {
		font-family: 'SemiBold', sans-serif;
}

h2 {
		font-family: 'Medium', sans-serif;
		font-size: 2.6vw;
		line-height: 3.8vw;
		padding: 6px 0 20px 0;
		color: var(--color-selecteur-dispo);
}

h2 span {
		display: inline-block;
		position: relative;
}

h2 span:before {
	content: '';
	position: absolute;
	width: 100%;
	height: 0.4vw;
	bottom: 0px;
	left: 0px;
	background-color: var(--color-selecteur-reser);
}

h3 {
		font-family: 'Regular', sans-serif;
		font-size: 1.2vw;
		line-height: 1.8vw;
		padding: 6px 0;
}

h4 {
		font-family: 'Light', sans-serif;
	 	text-transform: uppercase;
		font-size: 0.6vw;
		letter-spacing: 0.3vw;
		padding: 10px 0;
}

p.credits {
	font-family: 'Light', sans-serif;
	text-transform: uppercase;
	font-size: 0.5vw;
	line-height: 0.7vw;
	letter-spacing: 0.1vw;
	padding: 10px 0;
}

p.carte-visite {
	font-family: 'Regular', sans-serif;
	font-size: 0.9vw;
	line-height: 1.2vw;
}

p.carte-visite b {
	font-family: 'Bold', sans-serif;
}

p.carte-visite i {
	font-size: 60%;
	text-transform: uppercase;
	color: white;
}

p.colonne {
	columns: 2;
	column-gap: 40px;
}

p.legende-cote {
	color: white;
	display: inline-block;
	padding: 40px 40px 20px 40px;
	font-family: 'Bold', sans-serif;
	font-size: 1.8vw;
	line-height: 2.6vw;
}

p.legende-cote span { color: var(--color-selecteur-reser); }

p.legende-cote img { width: 40px; }

/* GALERIE ACCUEIL */

#galerie-accueil {
	position: relative;
	width: 100vw;
	height: 95vh;
	min-height: 400px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	word-spacing: 0em;
	transition-duration: 1s;
} #galerie-accueil.full { height: 100vh; }

#galerie-accueil-gauche {
	position: absolute;
	display: flex;
	flex-direction: column;
	bottom: 6%;
	left: 0px;
	width: calc((3*(100vw/4)) - 40px);
	height: auto;
	margin-right: 40px;
}

#galerie-accueil-droite {
	position: absolute;
	display: flex;
	flex-direction: column;
	bottom: 6%;
	right: 0px;
	width: calc(100vw/4);
	height: auto;
}

/* MENU PRINCIPAL */

#menu-principal {
	position: relative;
	background-color: white;
	width: 100%;
	z-index: 1000;
	transition-duration: 0.4s;
	transform: translate(0%, 0);
} #menu-principal.hide { transform: translate(-100%, 0); }

#menu-principal.on {
	position: fixed;
	width: calc(3*(100vw/4));
	top: 0px;
	box-shadow: 0 0 6px 0px var(--color-gris-moyen);
}

#menu-principal ul {
	display: table;
	width: 90%;
	table-layout: auto;
	margin: 20px auto;
	vertical-align: middle;
	transition-duration: 0.4s;
}

#menu-principal ul li {
	position: relative;
	display: table-cell;
	transition-duration: 0.4s;
	vertical-align: center;
}

#menu-principal ul li:hover {
	transform: translate(0, -10%);
}

#menu-principal ul li span.hover {
	position: absolute;
	width: 100%;
	top: 100%;
	left: 50%;
	text-align: center;
	font-size: 0.7vw;
	letter-spacing: 0.12vw;
	text-transform: uppercase;
	transform: translate(-50%, -200%);
	transition-duration: 0.4s;
	opacity: 0;
	color: var(--color-selecteur-dispo);
}

#menu-principal ul li:hover span.hover {
	transform: translate(-50%, -70%);
	opacity: 1;
}

#menu-principal ul li p {
	display: inline-block;
	font-family: 'Medium', sans-serif;
	display: block;
	background-color: var(--color-selecteur-dispo);
	padding: 20px 10px;
	margin: 6px;
	text-align: center;
	color: white;
	font-size: 0.7vw;
	letter-spacing: 0.12vw;
	text-transform: uppercase;
	vertical-align: middle;
	border-radius: var(--border-radius);
} #menu-principal ul li:nth-child(1) p { background-color: white; }

#menu-principal ul li:nth-child(1) p img {
	display: inline-block;
	vertical-align: middle;
	width: 10vw;
}

#menu-principal ul li p span {
	position: relative;
	display: inline-block;
	width: 1vw;
	height: 1vw;
	margin: 0 1vw 0 0;
	vertical-align: middle;
}

#menu-principal ul li p span.mobilSupr {
	position: relative;
	display: inline;
	margin: 0 0 0 0;
	vertical-align: middle;
}

#menu-principal ul li p span svg {
	position: absolute;
	width: 1vw;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#menu-principal ul li p span svg .cls-1 {
	fill: var(--color-selecteur-reser);
}

#signature-accueil {
	display: table;
	position: relative;
	width: 100%;
	background-color: var(--color-bleu-cardis);
	text-align: center;
	transition-duration: 0.4s;
	z-index: 1000;
}

#signature-accueil.on {
	position: fixed;
	top: 0px;
	width: calc(100vw/4);
}

#signature-accueil p {
	display: table-cell;
	vertical-align: middle;
}

#signature-accueil img {
	width: 16vw;
}

#fenetre-actu {
	margin-bottom: 40px;
	background-color: var(--color-selecteur-dispo);
	padding: 40px 60px;
	transition-duration: 0.4s;
	transform: translate(100%, 0);
}

#fenetre-actu.on {
	transform: translate(0, 0);
}

#fenetre-actu h1,
#fenetre-actu p,
#fenetre-actu-scroll h1,
#fenetre-actu-scroll p {
	color: white;
	padding: 0;
}

#fenetre-actu h1,
#fenetre-actu-scroll h1 {
	font-family: 'Medium', sans-serif;
	font-size: 1.9vw;
	line-height: 2.4vw;
	padding: 0 0 40px 0;
}

#fenetre-actu ul li p,
#fenetre-actu-scroll ul li p {
	display: inline-block;
	vertical-align: middle;
	font-family: 'Light', sans-serif;
	font-size: 0.8vw;
	line-height: 1.2vw;
	text-transform: uppercase;
	padding: 0 20px 0 0;
}

#fenetre-actu ul li p a.bouton-blanc,
#fenetre-actu-scroll ul li p a.bouton-blanc {
	display: inline-block;
	padding: 1vw;
	font-family: 'Bold', sans-serif;
	font-size: 0.5vw;
	line-height: 1.2vh;
	letter-spacing: 0.1vw;
	background-color: white;
	color: var(--color-selecteur-dispo);
	vertical-align: middle;
}

#bouton-close-actu,
#bouton-close-scroll {
	position: absolute;
	top: 20px;
	left: 20px;
	width: 20px;
	height: 20px;
	cursor: pointer;
}

#bouton-close-actu span,
#bouton-close-scroll span {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 10%;
	background-color: white;
	transition-duration: 0.2s;
}

#bouton-close-actu span:nth-child(1), #bouton-close-scroll span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg);}
#bouton-close-actu span:nth-child(2), #bouton-close-scroll span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg);}

#bouton-close-actu:hover span:nth-child(1), #bouton-close-scroll:hover span:nth-child(1) { transform: translate(-50%, -50%) rotate(-45deg);}
#bouton-close-actu:hover span:nth-child(2), #bouton-close-scroll:hover span:nth-child(2) { transform: translate(-50%, -50%) rotate(45deg);}

#actuMobil { display: none; }
#actuMobil.on { display: none; }


#fenetre-actu-scroll {
	position: fixed;
	top: 15%;
	right: 0px;
	background-color: var(--color-selecteur-reser);
	padding: 40px 60px;
	transition-duration: 0.8s;
	transform: translate(100%, 0);
	width: calc(25vw - 120px);
	z-index: 1000;
}

#fenetre-actu-scroll.on {
	transform: translate(0%, 0);
}

#fenetre-actu-scroll.off {
	transform: translate(100%, 0);
}

/* GALERIE */

#controls-galerie {
	margin: 0px 5% 40px 5%;
}

#controls-galerie.full {
	margin: 0px 5%;
	position: absolute;
	bottom: 0px;
	width: 100%;
}

#controls-galerie ul {
	display: table;
	width: 70%;
}

#controls-galerie ul li {
	display: table-cell;
	text-align: center;
	cursor: pointer;
}

#controls-galerie ul li.vignette p {
	display: inline-block;
	vertical-align: bottom;
	width: 3vw;
	text-align: center;
}

#controls-galerie ul li.vignette p span {
	position: relative;
	display: inline-block;
	width: 100%;
	height: 15px;
	background-color: white;
	border-radius: var(--border-radius);
	transition-duration: 0.4s;
}

#controls-galerie ul li.vignette:hover p span {
	height: 30px;
	background-color: var(--color-selecteur-dispo);
}

#controls-galerie ul li.vignette.active p span {
	height: 30px;
	background-color: var(--color-selecteur-reser);
}

#controls-galerie ul li.play-video p {
	display: inline-block;
	padding: 2vw;
	background-color: var(--color-selecteur-reser);
	font-family: 'Medium', sans-serif;
	padding: 20px 30px;
	text-align: center;
	color: white;
	font-size: 0.7vw;
	letter-spacing: 0.12vw;
	text-transform: uppercase;
	vertical-align: bottom;
	border-radius: var(--border-radius);
	transition-duration: 0.4s;
}

#controls-galerie ul li.play-video:hover p {
	background-color: var(--color-selecteur-dispo);
}

#controls-galerie ul li.play-video p span {
	position: relative;
	display: inline-block;
	width: 1vw;
	height: 1vw;
	margin: 0 1vw 0 0;
	vertical-align: middle;
}

#controls-galerie ul li.play-video p span svg {
	position: absolute;
	width: 1vw;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#controls-galerie ul li.play-video p span svg .cls-1 {
	fill: white;
}

ul#galerie-accueil-images {
	position: absolute;
	width: 100%;
	height: 100%;
}

ul#galerie-accueil-images li {
	display: none;
	position: absolute;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	cursor: pointer;
} ul#galerie-accueil-images li.active { display: block; }

#gal-full-screen {
	position: absolute;
	top: 2vw;
	right: 2vw;
	width: 3vw;
	height: 3vw;
	background-color: white;
	border-radius: 2px;
	background-image: url('../svg/picto-gal-open.svg');
	background-position: center;
	background-size: 60%;
	background-repeat: no-repeat;
	cursor: pointer;
} #gal-full-screen.on { background-image: url('../svg/picto-gal-close.svg'); }

#gal-full-screen:hover {
	box-shadow: inset 0 0 0 4px var(--color-selecteur-dispo);
}

/* TABLE */

ul.table {
	display: table;
	table-layout: auto;
	width: 100%;
}

ul.table li {
	display: table-cell;
}

ul.table.bottom li {
	vertical-align: bottom;
}

ul.table li.border-right {
	border-right: 1px solid white;
	padding-right: 30px;
}

ul.table li.margin-left {
	padding-left: 40px;
}

ul.point-image {
	position: relative;
	display: table;
	width: calc(100% - 40px);
	border-radius: var(--border-radius);
	padding: 30px 20px;
}

ul.point-image li {
	display: table-cell;
	vertical-align: top;
}

ul.point-image li:nth-child(1) p {
	display: block;
	width: 1.5vw;
	height: 1.5vw;
	padding: 0 20px 0 10px;
	vertical-align: top;
}

ul.point-image li:nth-child(2) p {
	color: white;
	font-size: 1.1vw;
	line-height: 1.8vw;
	display: inline-block;
	vertical-align: top;
}

ul.point-image li p svg .cls-1 {
	fill: var(--color-selecteur-reser);
}

ul.point-image.vert-clair { background-color: var(--color-selecteur-dispo); }
ul.point-image.vert-sombre { background-color: var(--color-gris-fonce); }

ul.sommaire {
	display: table;
	width: 70%;
	margin: 20px auto 0 auto;
}

ul.sommaire li {
	display: table-cell;
	position: relative;
	padding: 10px;
}

ul.sommaire li:nth-child(1) { text-align: right; }
ul.sommaire li:nth-child(2) { text-align: left; }

ul.sommaire li p span {
	display: inline-block;
	position: relative;
	width: 3.5vw;
	height: 3.5vw;
	vertical-align: middle;
	background-color: var(--color-selecteur-dispo);
	border-radius: var(--border-radius);
}

ul.sommaire li:nth-child(1) p span svg {
	display: block;
	position: relative;
	width: 50%;
	height: 50%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

ul.sommaire li:nth-child(2) p span svg {
	display: block;
	position: relative;
	width: 80%;
	height: 80%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

ul.sommaire li p span svg .cls-1 {
	fill: var(--color-selecteur-reser);
}

ul.sommaire li:nth-child(1) p span i {
	display: inline-block;
	position: absolute;
	font-family: 'Medium', sans-serif;
	bottom: 0px;
	right: 0px;
	height: auto;
	font-size: 1.4vw;
	line-height: 1.4vw;
	text-transform: uppercase;
	letter-spacing: 0.5vw;
	transform-origin: bottom right;
	transform: rotate(-90deg) translate(-20%, -10%);
}

/* TABELAU DISTANCES */

table#distances {
	width: 100%;
	table-layout: fixed;
}

table#distances tr td {
	border: 2px solid var(--color-selecteur-reser);
}

table#distances tr td p {
	padding: 0.6vw 1vw;
	font-size: 1vw;
	line-height: 1.3vw;
	color: var(--color-selecteur-reser);
}

table#distances tr td:nth-child(1) {
	border: 2px solid var(--color-selecteur-reser);
	background-color: var(--color-selecteur-reser);
}

table#distances tr td:nth-child(1) p {
	font-family: 'Medium', sans-serif;
	color: white;
	font-size: 0.8vw;
	letter-spacing: 0.1vw;
	text-transform: uppercase;
}

table#distances tr td p span {
	font-family: 'Medium', sans-serif;
	color: var(--color-gris-clair);
}

/* GOOGLE */

@media (max-width: 1700px) {

#menu-principal ul li p span {
	display: none; }
}

/* VIDEO */

.voir-video {
	position: absolute;
	top: 20%;
	left: 0%;
	background-color: white;
	z-index: 100000;
	transform: translate(0, -50%);
	box-shadow: inset 0px 0 0 0 var(--color-selecteur-dispo);
	transition-duration: 0.4s;
	cursor: pointer;
} .voir-video:hover { box-shadow: inset -10px 0 0 0 var(--color-selecteur-dispo); }

.voir-video a {
	display: block;
	padding: 1vw 2vw;
	font-family: 'Medium', sans-serif;
	font-size: 1.3vw;
	line-height: 1.8vw;
}

#galerie-video {
	position: fixed;
	z-index: 100000000;
	width: 100vw;
	height: 100vh;
	top: -200vh;
	background-color: var(--color-selecteur-dispo);
	transition-duration: 1s;
}

#galerie-video.open {
	top: 0px;
}

#galerie-video video {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%, -50%);
}

#galerie-video div.bouton-close {
	position: absolute;
	top: 50%;
	left: 0px;
	background-color: white;
	width: 4vw;
	height: 4vw;
	transform: translate(0, -50%);
	cursor: pointer;
}

#galerie-video div.bouton-close span {
	position: absolute;
	top: 50%;
	left: 50%;
	background-color: var(--color-selecteur-dispo);
	width: 60%;
	height: 5%;
	transition-duration: 0.4s;
}

#galerie-video div.bouton-close span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
#galerie-video div.bouton-close span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg); }

#galerie-video div.bouton-close:hover span:nth-child(1) { transform: translate(-50%, -50%) rotate(-45deg); }
#galerie-video div.bouton-close:hover span:nth-child(2) { transform: translate(-50%, -50%) rotate(45deg); }

/* GOOGLE */

.grecaptcha-badge { display: none; }
