body {
	margin: 0;
	font-family: "Cabinet Grotesk", sans-serif;
	font-size: var(--fsize1);
	display: flex;
	flex-direction: column;
	align-items: center;
	grid-gap: var(--gap16);
	padding: var(--gap4);
	background-color: var(--coul-beige);
	color: var(--coul-blue);
}

main {
	display: flex;
	flex-direction: column;
	align-items: center;
	grid-gap: var(--gap16);
	width: 100%;
}

/* Header */

header {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	height: calc(100vh - (var(--gap4) * 2));
	padding: var(--gap4);
	overflow: hidden;
	width: 100%;
	border-radius: var(--radius10);
	position: relative;
	padding-bottom: var(--gap);
	background: var(--coul-blue);
	z-index: 10;
}

header:after {
	content: "";
	background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.45));
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
}

.header-logo {
	margin: auto;
	filter: drop-shadow(0px 5px 10px rgba(0,0,0,0.4));
	width: 600px;
	max-width: 90%;
}

.header-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	pointer-events: none;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.fit-top {
	object-position: center 10%;
}

.header-title {
	font-family: "CabinetGrotesk-Black";
	font-size: var(--fsize5);
	color: var(--coul-white);
	margin-top: auto;
	text-align: center;
	line-height: 120px;
}

.header-subtitle {
	font-family: "Cabinet Grotesk";
	font-size: var(--fsize3);
	color: var(--coul-white);
	text-align: center;
	display: block;
	line-height: normal;
}

#menu-hamburger {
	display: none;
	position: fixed;
	left: 0;
	top: 0;
	flex-direction: column;
	height: var(--responsive-hamburger-height);
	justify-content: center;
	align-items: center;
	grid-gap: 5px;
	cursor: pointer;
	user-select: none;
	margin-bottom: var(--gap2);
	width: 100%;
	background: var(--coul-blue);
	padding: var(--gap2);
	z-index: 100;
}

#menu-hamburger span {
	display: block;
	width: 60px;
	height: 3px;
	background-color: var(--coul-white);
}

nav {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	grid-gap: var(--gap2);
	padding: var(--gap2);
	border-radius: var(--radius10);
	background-color: var(--coul-white);
	transition: var(--transitionA);
}

#nav-links {
	display: flex;
	justify-content: space-between;
	align-items: center;
	grid-gap: var(--gap2);
}

#nav-links a {
	border-bottom: solid 2px transparent;
	transition: border var(--transitionA);
	display: flex;
	text-align: center;
	white-space: nowrap;
}

#nav-links a:not(.active-link):not(:first-of-type):hover {
	border-bottom: solid 2px;
}

#nav-links .active-link {
	background-color: var(--coul-beige);
	padding: var(--gap) var(--gap2);
	border-radius: var(--radius5);
}

.nav-fixed {
	position: fixed;
	max-width: calc(100% - var(--gap4) * 2);
	z-index: 90;
	top: 0;
	border-radius: 0;
	border-bottom-left-radius: var(--radius10);
	border-bottom-right-radius: var(--radius10);
	animation: slide-down 1s forwards;
}

@keyframes slide-down {
	from {transform: translateY(-100%);}
	to {transform: translateY(0);}
}

#cta-mobile-container {
	display: none;
	width: 100%;
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 90;
}

#cta-mobile-container a {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap);
	justify-content: center;
	align-items: center;
	width: 50%;
	padding: var(--gap4);
	text-align: center;
	background-color: var(--coul-white);
	color: var(--coul-blue);
}

#cta-mobile-container, #cta-mobile-container a {
	border: solid 1px var(--coul-white);
}

#cta-mobile-container a:last-of-type {
    background: linear-gradient(140deg, var(--coul-beige), var(--coul-golden));
}

#menu-closer {
	display: none;
	justify-content: center;
	align-items: center;
	align-self: flex-start;
	flex-shrink: 0;
	position: relative;
	cursor: pointer;
	user-select: none;
	width: 40px;
	height: 40px;
	margin-left: var(--gap4);
	margin-top: var(--gap4);
}

#menu-closer span {
	height: 3px;
	width: 60px;
	background-color: var(--coul-blue);
	display: block;
	transition: var(--transitionA);
}

#menu-closer span:nth-of-type(1) {
	position: absolute;
	transform-origin: center;
	transform: rotate(45deg);
}

#menu-closer span:nth-of-type(2) {
	position: absolute;
	transform-origin: center;
	transform: rotate(-45deg);
}

/* Content */


.success {
	padding: var(--gap4);
	background-color: var(--coul-blue);
	color: var(--coul-white);
}

.error {
	padding: var(--gap4);
	background-color: var(--coul-red);
	color: var(--coul-white);
}

.standard-container {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap);
	text-align: center;
	max-width: var(--page-width);
}

.self-center {
	align-self: center;
}

.homepage-title {
	font-size: var(--fsize3);
	font-family: var(--fontfam);
	font-weight: normal;
}

#map-box {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	position: relative;
	border-radius: var(--radius10);
	overflow: hidden;
	z-index: 1;
	color: var(--coul-white);
	padding: var(--gap4);
	background-color: var(--coul-blue);
}

h2 {
	text-transform: uppercase;
	font-family: "CabinetGrotesk-Bold";
	text-align: center;
	font-size: var(--fsize2);
}

#map-box h2 {
	text-align: left;
}

#map-box > * {
	user-select: none;
}

#map-box-background {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -1;
	opacity: var(--bg-opacity);
	pointer-events: none;
}

#map-box-links {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	grid-gap: var(--gap2);
	font-size: var(--fsize2);
	max-width: 650px;
}

#map-box-links a {
	border-bottom: solid 2px transparent;
	transition: var(--transitionA);
	white-space: nowrap;
}

#map-box-links a:hover {
	border-bottom: solid 2px;
}

#map-box-separator {
	height: 2px;
	width: 100px;
	background-color: var(--coul-white);
}

#map-box-map {
	fill: var(--coul-white);
	height: 570px;
	flex: 1 1;
	min-width: 400px;
	max-width: 100%;
}

.map-box-map-destination {
	transition: var(--transitionA);
}

.map-box-map-destination:hover {
	transition: var(--transitionA);
}

.map-box-map-destination-highlighter {
	fill: transparent;
	transition: var(--transitionA);
}

.highlight .map-box-map-destination-highlighter, .map-box-map-destination:hover .map-box-map-destination-highlighter{
	fill: rgba(255,255,255,0.4)
}

.no-highlight {
  opacity: 0.3;
}

.col-gap-40 {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap4);
	align-items: center;
}

.col-gap-80 {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap8);
	align-items: center;
}

#destination-intro {
	display: flex;
	grid-gap: var(--gap8);
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
}

#destination-intro-text {
	max-width: 700px;
}

#destination-advantages-container {
	display: flex;
	grid-gap: var(--gap2);
	max-width: 640px;
	flex-wrap: wrap;
	justify-content: center;
	margin-top: var(--gap8);
}

.destination-advantage {
	padding: var(--gap) var(--gap2);
	border: solid 2px;
	border-radius: var(--radius10);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	grid-gap: var(--gap2);
	width: 300px;
	max-width: 100%;
}

.destination-advantage img {
	max-height: 40px
}

.tags-container {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	grid-gap: var(--gap2);
}

.tag {
	padding: var(--gap2);
	border: solid 2px;
	border-radius: var(--radius10);
	text-align: center;
}

.img-and-tags {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap-reverse;
	grid-gap: var(--gap4);
}

.img-and-tags h2 {
	flex-basis: 100%;
	text-align: center;
}

.img-and-tags:nth-of-type(odd) {
	flex-direction: row-reverse;
}

.img-and-tags-img {
	max-width: 100%;
	width: 700px;
	height: 350px;
	object-fit: cover;
	border-radius: var(--radius10);
}

.img-and-tags .tags-container {
	max-width: 700px;
}

.destination-logo {
	width: 400px;
	max-width: 70vw;
}

.destination-logo svg * {
	fill: var(--coul-blue);
}

.subtitle {
	text-align: center;
}

/* Sliders */

#destination-slides {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap4);
	justify-content: center;
	align-items: center;
	overflow: hidden;
	width: 100%;
}

.sliders-categories {
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: var(--gap4);
	width: 100%;
	white-space: nowrap;
}

.sliders-category {
	background-color: transparent;
	padding: var(--gap2) var(--gap4);
	border-radius: var(--radius10);
	cursor: pointer;
	user-select: none;
	border: solid 2px transparent;
	transition: var(--transitionA);
}

.sliders-category.filter:first-of-type {
	margin-left:auto;
}

.sliders-category.filter:last-of-type {
	margin-right:auto;
}

.sliders-category:hover {
	border: solid 2px var(--coul-blue);
}

.sliders-category.filter-selected {
	background-color: var(--coul-blue);
	color: var(--coul-white);
}

.filtered-hidden {
	opacity: 0;
	pointer-events: none;
	height: 0;
	overflow: hidden;
}

.sliders-container {
	width: 100%;
}

.slider {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap2);
	max-height: 80vh;
}

.slider-images {
	display: flex;
	grid-gap: var(--gap2);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	align-self: flex-start;
	min-width: 100%;
	-ms-overflow-style: none;
	scrollbar-width: none;
	align-items: stretch;
}

.slider-images::-webkit-scrollbar {
	display: none;
	width: 0;
	height: 0;
}

.slider-image-unit {
	flex: 0 0 calc((100% - 2 * var(--gap2)) / 3); /* 5 images visibles avec 4 gaps entre */
	scroll-snap-align: start;
	position: relative;
	display: flex;
	height: 400px;
}

.slider-image-unit img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--radius10);
}

.slider-navigation {
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: var(--gap2);
}

.slider-navigation button {
	border: none;
	background: transparent;
	font-size: var(--fsize2);
	color: inherit;
	display: flex;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	user-select: none;
	transition: var(--transitionA);
	padding: var(--gap);
	border-radius: var(--radius5);
}

.slider-navigation button:hover {
	background: var(--coul-blue);
	color: var(--coul-white);
}

.slider-navigation-disabled button {
	filter: grayscale(1);
	opacity: 0.5;
	cursor: not-allowed;
}

.capacities-container {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	max-width: var(--page-width);
}

.capacity {
	width: 33%;
	padding: var(--gap2);
	min-width: 200px;
}

.capacity img {
	max-width: 60px;
}

:root {
	--review-max-height: 400px;
}

#reviews {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap);
	width: 100%;
}

#reviews-wrapper {
	max-height: calc((var(--review-max-height) * 2) + var(--gap2));
	width: 100%;
	overflow: hidden;
	position: relative;
}

#reviews-wrapper::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: var(--gap8);
	background: linear-gradient(180deg, transparent, var(--coul-beige));
}

.reviews-unfold#reviews-wrapper::after {
	display: none;
}

#reviews-container {
	column-width: 500px;
	column-gap: var(--gap2);
	width: 100%;
}

#reviews-container::-webkit-scrollbar {
	display: none;
	width: 0;
	height: 0;
}

.reviews-unfold {
	max-height: unset !important;
}

.review {
	display: inline-block;
	min-width: 100%;
	margin-bottom: var(--gap2);
	padding: var(--gap4);
	text-align: left;
	border: solid 2px;
	border-radius: var(--radius10);
}

.review > *:not(:last-child) {
	margin-bottom: var(--gap2);
}

.review-stars {
	width: 100px;
	aspect-ratio: 2000 / 328;
	mask-image: url(/assets/img/review-stars.png);
	mask-size: contain;
	mask-repeat: no-repeat;
	filter: drop-shadow(20px 0px 0px var(--coul-white));
}

.review-stars-fill {
	background-color: var(--coul-golden);
	height: 100%;
}

.review-author {
	font-family: "CabinetGrotesk-Bold";
}

#show-more-reviews {
	align-self: center;
	width: 400px;
	max-width: 100%;
}

.reviews-unfold ~ #show-more-reviews {
	position: sticky;
	bottom: var(--gap2);
}

.flex-row-gap8 {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	grid-gap: var(--gap8);
}

.coord-access {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap8);
	max-width: 650px;
}

.coord-access h2 {
	text-align: left;
}

.access-map {
	max-height: 80vh;
	width: 650px;
	max-width: 100%;
	border-radius: var(--radius10);
}

/* Legal */

.centered-content h1 {
	text-align: center;
	font-size: var(--fsize3);
}

.centered-content {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: stretch;
	max-width: var(--page-width);
	grid-gap: var(--gap);
}

/* Hotel video */

#hotel-video-container {
	position: fixed;
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 200;
	animation: fading 0.5s;
	display: none;
	background-color: var(--coul-black);
}

.hotel-video-visible {
	display: flex !important;
}

#hotel-video-closer {
	display: flex;
	justify-content: center;
	align-items: center;
	align-self: flex-start;
	flex-shrink: 0;
	position: relative;
	cursor: pointer;
	user-select: none;
	width: 40px;
	height: 40px;
	margin-left: var(--gap4);
	margin-top: var(--gap4);
}

#hotel-video-closer span {
	height: 3px;
	width: 60px;
	background-color: var(--coul-white);
	display: block;
	transition: var(--transitionA);
}

#hotel-video-closer span:nth-of-type(1) {
	position: absolute;
	transform-origin: center;
	transform: rotate(45deg);
}

#hotel-video-closer span:nth-of-type(2) {
	position: absolute;
	transform-origin: center;
	transform: rotate(-45deg);
}

#hotel-video {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}

/* Bord de mer */

#seaside-destinations-container {
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: var(--gap4);
	flex-wrap: wrap;
}

#seaside-destinations {
	display: flex;
	flex-direction: column;
	grid-gap: var(--gap);
	width: 100%;
}

.seaside-destination {
	position: relative;
	width: 600px;
	max-width: 100%;
	height: 400px;
	border-radius: var(--radius10);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	padding: var(--gap2);
	justify-content: flex-end;
	transition: var(--transitionA);
}

.seaside-destination:hover {
	transform: translateY(calc(-1 * var(--gap)));
}

.seaside-destination::after {
	content: "";
	background: linear-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.45));
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100%;
	height: 100%;
}

.seaside-destination img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -1;
}

.seaside-destination h3 {
	font-family: "CabinetGrotesk-Bold";
	color: var(--coul-white);
	font-size: var(--fsize1);
}

.seaside-destination p {
	color: var(--coul-white);
}

/* Contact */

.contact-form {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 750px;
	max-width: 100%;
	flex-wrap: wrap;
	grid-gap: var(--gap);
}

.contact-form p {
	text-align: center;
	width: 100%;
}

.contact-form input:not([type="submit"]), .contact-form select, .contact-form textarea {
	flex: 1 1 auto;
	background-color: var(--coul-light-grey);
	border: solid 1px var(--coul-grey);
}

.contact-form > * {
	width: 100%;
}

.contact-form > div {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	grid-gap: var(--gap);
}

.contact-form .button-blue {
	width: auto;
}

input[name="middle_name"] {
	height: 0 !important;
	font-size: 0 !important;
	padding: 0 !important;
	border: none !important;
	margin: 0 !important;
	width: 0;
}

/* Video */

#video-page {
	display: flex;
	flex-direction: column;
	align-items: center;
	grid-gap: var(--gap4);
	width: 100%;
}

#video {
	width: 100%;
	max-height: 70vh;
	object-fit: contain;
}