/* CSS Document */


/******************************* Base *******************************/

:root {
	
	--coul1 : #1b2949;
	--coul2 : #E1E6F2;
	--coul3 : #7689c3;
	--coul4 : #3366FF;
	
	/* Font size */
	--fsize1: 16px;
	--fsize2: 1.25em;
	--fsize3: 1.6em;
	--fsize4: 2.25em;
	--fsize5: 2.85em;
	--fsize6: 3.5em;
	--fsize7: 4.15em;
	--fsize8: 4.80em;
	--fsizemin : max(0.75em, 12px);
	
	--fontfam : "DM Serif Display";
	
	--light : 300;
	--bold : 500;
	
	--bshad : 1px 1px 10px rgba(0 0 0 / 10%);
	--bshad2 : 1px 1px 10px rgba(0 0 0 / 50%);
	
}

body {
	margin: 0;
	font-family: 'Rubik', sans-serif;
	color: var(--coul1);
	font-size: var(--fsize1);
	animation: fondu 1s forwards ease-in-out;
}

@keyframes fondu {
	from {opacity: 0;}
	to {opacity: 1;}
}

input, textarea, select {
	padding: 5px;
	border: none;
	margin: 10px;
	font-family: inherit;
	resize: none;
	transition: 0.5s;
    outline: none;
	box-shadow: var(--bshad);
	color: inherit;
	font-size: inherit;
}

input[type="submit"] {
	background-color: var(--coul1);
	color: #fff;
	transition: 0.5s;
	cursor: pointer;
	min-width: 200px;
}

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

input[type="submit"]:hover {
	background-color: var(--coul2);
	color: var(--coul1);
}

input[type="date"] {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	text-align: right;
}

input[type="date"]::-webkit-calendar-picker-indicator {
	margin-left: 0;
	margin-right: 20px;
}

input[type=number] {
	text-align: center;
}

input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
	opacity: 1;
	transition: 0.5s;
}

iframe {
	border: none;
}

hr {
	border: none;
	border-bottom: solid 1px var(--coul3);
}

h1, h2, h3, h4, h5, h6 {
	margin: 0;
	font-family: var(--fontfam);
}

img {
	-webkit-user-drag: none;
	-khtml-user-drag: none;
	-moz-user-drag: none;
	-o-user-drag: none;
	user-drag: none;
}


/******************************* Divers *******************************/


.page-avec-sousmenu {
	display: grid;
	grid-template-columns: 250px 1fr;
}

#popup {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.9);
	z-index: 199;
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 1;
	transition: 0.5s;
}

.popup-contenu {
	width: 1000px;
	max-width: 80vw;
	height: 600px;
	max-height: 80vh;
	background: url(../img/pattern-fond.png), #fff;
	display:flex;
	justify-content: space-between;
	align-items: center;
	padding: 5px;
	position:relative;
}

.popup-contenu video {
	height: 100%;
	width: 100%;
	object-fit: cover;
}

.popup-img-titre {
	max-width: 350px;
	width: 100%;
	margin-bottom: 20px;
}

.popup-img {
	height: 100%;
	max-width: 55%;
	object-fit:cover;
	vertical-align: middle;
	clip-path: polygon(0 0, 100% 0%, 86% 100%, 0% 100%);
}

.popup-texte {
	width: 45%;
	text-align:center;
	padding: 30px;
}

.popup-logo {
	max-width: 200px;
	margin-bottom: 20px;
	position: absolute;
	top: 20px;
	left: 20px;
}

#fermeturepopup {
	color: #fff;
	font-size: 2em;
	position: absolute;
	right: 20px;
	top: 20px;
	cursor: pointer;
	transition: 0.5s;
}

#fermeturepopup::after {
	content: "\292C";
}

#fermeturepopup:hover {
	color: #000;
}

.cachepopup {
	opacity: 0 !important;
}

.alerte {
	position: fixed;
	bottom: 0%;
	left: 50%;
	transform: translate(-50%, -50%);
	padding: 50px;
	text-align: center;
	background-color: var(--coul3);
	color: #fff;
	animation: disparait 4s forwards;
	pointer-events: none;
	user-select: none;
	z-index: 103;
	box-shadow: var(--bshad2);
}

@keyframes disparait {
	0% {opacity: 1;}
	90% {opacity: 1;}
	99% {opacity: 0;}
	100% {opacity: 0; display: none;}
}

.disabled {
	pointer-events: none;
	opacity: 0.5;
}

.bouton {
	position: relative;
	text-align: center;
	cursor: pointer;
	user-select: none;
	z-index: 1;
	width: 200px;
	border: solid 2px;
	transition: 0.5s;
}

.bouton::before {
	content: "";
	position: absolute;
	left: 0%;
	top: 0;
	width: 20%;
	height: 100%;
	z-index: -1;
	transition: 0.5s;
	mix-blend-mode: color-dodge;
}

.bouton::after {
	content: "";
	position: absolute;
	right: 0%;
	top: 0;
	width: 20%;
	height: 100%;
	z-index: -1;
	transition: 0.5s;
	mix-blend-mode: color-dodge;
}

.bouton:hover {
	border: solid 2px transparent;
}

.bouton:hover::before, .bouton:hover::after {
	width:100%;
	background-color: var(--coul2);
}

.bouton a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 10px;
}

.boutonscrolltop {
	position: fixed;
	left: 20px;
	bottom: 20px;
	background-color: var(--coul2);
	width: 30px;
	height: 30px;
	font-size: var(--fsize3);
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 20px;
	border-radius: 50%;
	z-index: 15;
	box-shadow: var(--bshad);
	transition: 0.5s;
	line-height: 0;
	user-select: none;
}

.boutonscrolltop::after {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 20px;
	height: 20px;
	clip-path: polygon(50% 20%, 0% 75%, 20% 95%, 50% 60%, 80% 95%, 100% 75%);
	background-color: var(--coul1);
	transform: translate(-50%, -60%);
}

.boutonscrolltop:hover {
	transform: scale(1.3);
	background-color: var(--coul3);
	color: var(--coul2);
}

.fondgrisclair {
	background-color: #f5f5f5;
}


/******************************* Nav *******************************/

nav {
	z-index: 20;
	position: relative;
}

.menubandeau {
	height: 45px;
	padding: 0 20px;
	background-color: var(--coul3);
	color: #fff;
	display: flex;
	align-items: center;
	font-size: var(--fsize1);
}

.formlang button {
	border: none;
	background: none;
	cursor: pointer;
	color: inherit;
}

.menubandeau a , .formlang button {
	margin: 0 12px;
	font-size: 14px;
	font-weight: var(--light);
	border-bottom: solid 1px transparent;
	transition: 0.5s;
}

.menubandeau a:hover , .formlang button:hover  {
	border-bottom: solid 1px;
}

.menuprincipal {
	padding: 10px 20px;
	background-color: var(--coul1);
	display: grid;
	grid-template-columns:  1fr 1fr 1fr;
	align-items: center;
}

.menugauche {
	display: flex;
	justify-self:start;
}

.menugauche a {
	padding: 5px 12px;
	color: #fff;
	border-bottom: solid 1px transparent;
	transition: 0.5s;
}

.menugauche a:hover {
	border-bottom: solid 1px;
}

.lienlogo {
	justify-self:center;
}

.logo {
	max-width: 200px;
}

.recherchemenu {
	margin: 0 12px;
	justify-self: end;
	width: 430px;
	max-width: 90vw;
}

.recherchemenu input, .recherchemenu select {
	margin: 0;
	max-width: 160px;
}

input[name="radiorecherchemenu"] {
	display: none;
}

.ongletrechercheville, .ongletrecherchedepartement {
	padding: 10px;
	background-color: var(--coul2);
	color: var(--coul1);
	user-select: none;
	transition: 0.5s;
	cursor: pointer;
	text-align: center;
}

.conteneurformsrecherchemenu {
	overflow: hidden;
	width: 100%;
}

#recherchedepartement:checked ~ .flex .ongletrecherchedepartement, #rechercheville:checked ~ .flex .ongletrechercheville  {
	background-color: #fff;
}

.ongletrecherchedepartement {
	width: 230px;
}

.ongletrechercheville {
	width: 200px;
}

.sliderformsrecherchemenu {
	width: 200%;
	display: flex;
	justify-content: center;
	background-color: #fff;
	left: 0;
	position: relative;
	transition: 0.5s;
}

#rechercheville:checked ~ .conteneurformsrecherchemenu .sliderformsrecherchemenu {
	left: -100%;
}

.formrecherchemenu {
	display: flex;
	width: 50%;
	padding: 10px;
	justify-content: space-around;
	flex-wrap: wrap;
	grid-gap: 10px;
}

.shake {
	animation: shake 1s;
	animation-delay: 0.5s;
}

@keyframes shake {
	10%, 90% {transform: translate(-1px, 0);}

	20%, 80% {transform: translate(2px, 0);}

	30%, 50%, 70% {transform: translate(-4px, 0);}

	40%, 60% {transform: translate(4px, 0);}
}




/******************************* Accueil *******************************/

.slide-accueil {
	max-width: 100vw;
	overflow: hidden;
	position: relative;
}

.slide-accueil-slider {
	width: 300%;
	height: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	animation: slide 12s infinite;
	position: relative;
}

@keyframes slide {
	0% {left: 0;}
	28% {left: 0;}
	35% {left: -100%;}
	63% {left: -100%;}
	70% {left: -200%;}
	98% {left: -200%;}
	100% {left: 0;}
}

.slide-conteneur-points {
	display: flex;
	justify-content: center;
	align-items: center;
	grid-gap: 10px;
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
}


.slide-point {
	height: 10px;
	width: 10px;
	background-color: var(--coul1);
	border-radius: 50%;
	animation: couleur-point 12s infinite;
	opacity: 0.5;
}


.slide-point:nth-of-type(2) {
	animation-delay: 4s;
}


.slide-point:nth-of-type(3) {
	animation-delay: 8s;
}

@keyframes couleur-point {
	0% {opacity: 0.5}
	5% {opacity: 1}
	28% {opacity: 1}
	35% {opacity: 0.5}
	100% {opacity: 0.5}
}

.slide-unit {
	position: relative;
	height: 500px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
}

.slide-unit-texte {
	z-index: 1;
	position: relative;
	display: table;
	margin-left: 10%;
}

.slide-unit-titre {
	font-size: var(--fsize4);
	text-transform: uppercase;
}

.slide-unit-soustitre {
	font-size: var(--fsize2);
}

.slide-unit img {
	height: 100%;
	min-width: 100%;
	object-fit: cover;
	display: block;
	position: absolute;
	right: 0;
	top: 0;
}

.conteneur-side-boutons {
	position: fixed;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	z-index: 10;
}

#bouton-actus, #bouton-recherche {
	transform: rotate(-180deg);
	background-color: var(--coul2);
	padding: 20px 10px;
	writing-mode: tb-rl;
	text-align: center;
	cursor: pointer;
	transition: 0.5s;
	user-select: none;
	box-shadow: var(--bshad);
}

#bouton-actus:hover, #bouton-recherche:hover {
	padding-right: 20px;
	background-color: var(--coul3);
	color: #fff;
}

.liste-categorie-accueil {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    grid-gap: 20px;
    max-width: 90vw;
    margin: auto;
}

.categorie-accueil {
	width: 100%;
    padding: 40px;
    text-align: center;
    position: relative;
    font-size: var(--fsize3);
    background-color: var(--coul3);
    overflow: hidden;
    transition: 0.5s;
    white-space: nowrap;
}

.categorie-accueil:hover {
	background-color: var(--coul4);
	transform: translateY(-5px);
	box-shadow: var(--bshad2);
}

.categorie-accueil-img {
	position: absolute;
	height: 100%;
	width: 100%;
	object-fit: cover;
	opacity: 0.5;
	left: 0;
	top: 0;
	z-index: 0;
}

.categorie-accueil-nom {
	position: relative;
	z-index: 1;
	font-weight: var(--bold);
	color: #fff;
	text-shadow: var(--bshad2);
}

.bandeauaccueil {
	padding: 100px;
	padding-top: 150px;
	background: url(../img/pattern-fond.png), var(--coul1);
	color: #fff;
	clip-path: polygon(0 0, 100% 20%, 100% 100%, 0% 100%);
	background-attachment: fixed;
	background-repeat: no-repeat;
	background-size: cover;
}

.card {
	max-width: 420px;
	background: #fff;
	box-shadow: 0 0 45px rgba(0,0,0,0.1);
	margin: 20px;
}

.card:nth-of-type(2) {
	margin-top: 100px;
}

.card-conteneur-img {
	width: 100%;
	height: 320px;
}

.card-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.card-text {
	position: relative;
	font-size: var(--fsize2);
	padding: 40px 10px;
}

.card-titre {
	position: absolute;
	bottom: 100%;
	left: 0;
	transform: translateY(25%);
	text-transform: uppercase;
	font-weight: var(--bold);
	color: #fff;
	font-size: var(--fsize4);
}


/******************************* Liste des résidences *******************************/

.conteneurlisteresidences {
	display: flex;
}

.listeresidences {
	width: 60%;
}

.liste-menu-top {
	background-color: #fff;
	position: sticky;
	z-index: 2;
	top:0;
	border-bottom: solid 5px var(--coul2);
	display: flex;
}

.liste-conteneur-filtres {
	display: flex;
	justify-content: space-evenly;
	align-items: center;
	width: 60%;
}

.liste-conteneur-logo {
	width: 40%;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	height: 80px;
}

.liste-logo-top {
	transform: translateY(-100%);
	background-color: #fff;
	z-index: 500;
	transition: 0.5s;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	box-shadow: var(--bshad);
}

.liste-logo-top-visible {
	transform: translateY(0%);
}

.liste-separateur-filtres {
	height: 50px;
	width: 1px;
	border-left: solid 2px var(--coul2);
}

.liste-bloc-filtres {
	text-align: center;
	min-width: 300px;
	max-width: 50%;
	padding: 10px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.liste-bloc-filtres input[type="submit"] {
	min-width: auto;
	padding-left: 20px;
	padding-right: 20px;
}

.titrelisteresidence {
	width: 100%;
	margin: 20px 0;
	text-align: center;
	font-size: var(--fsize4);
}

.nbresultats {
	width: 100%;
	text-align: center;
	color: var(--coul3);
}

.residence {
	height: 450px;
	width: 280px;
	position: relative;
	transition: 0.5s;
	margin: 20px;
	overflow: hidden;
}

.residence:hover {
	transform: translateY(-5px);
}

.residence-disabled {
	pointer-events: none;
	opacity: 0.5;
}

.liste-bandeau-annonce {
	position: absolute;
	left: 50%;
	top: 50%;
	width: 150%;
	background-color: var(--coul2);
	text-align: center;
	padding: 5px;
	transform: translate(-50%, -50%) rotate(-20deg);
	box-shadow: var(--bshad2);
	text-transform: uppercase;
}

.imgresidence {
	height: 85%;
	width: 100%;
	object-fit: cover;
	border-top-left-radius: 50px;
	border-bottom-right-radius: 50px;
}

.bloctexteresidence {
	background-color: #fff;
	border-radius: 10px;
	padding: 15px;
	text-align: center;
	width: 90%;
	box-shadow: var(--bshad);
	position: absolute;
	bottom: 5%;
	left: 50%;
	transform: translateX(-50%);
}

.liste-ville {
	font-weight: var(--bold);
	font-size: var(--fsize2);
}

.liste-proximite {
	padding: 5px;
	border: solid 1px var(--coul3);
	border-left: none;
	border-right: none;
}

.liste-bouton {
	background-color: var(--coul3);
	padding: 5px;
	color: #fff;
	transition: 0.5s;
}

.liste-bouton:hover {
	background-color: var(--coul1);
}

.conteneurlistemap {
	position:sticky;
	top:80px;
	height: calc(100vh - 80px);
	width: 40%;
	z-index: 1;
}



/******************************* Fiche résidence *******************************/

.ficheresidence {
	display: grid;
	grid-template-columns: 250px 1fr;
}

.fiche-logo-top {
	width: 160px;
	margin: auto;
	display: block;
	position: absolute;
	top: 0;
	right: 5px;
	z-index: 19;
	background: #fff;
	transform: translateY(-100%);
	transition: 0.5s;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
}

.fiche-logo-top-visible {
	transform: translateY(0%);
}

.fiche-retour {
	background-color: var(--coul2) !important;
	color: var(--coul1) !important;
}

.fiche-sepretour {
	width: 30%;
	margin: 0;
}

.sousmenu {
	top: 0;
	position: sticky;
	height: max-content;
	z-index: 21;
}

.sousmenu-titre {
	display: none;
}


.sousmenu a {
	display: block;
	width: 95%;
	padding: 10px;
	margin: 5px 0 ;
	background-color: var(--coul3);
	color: #fff;
	transition: 0.2s;
}

.sousmenu a:hover {
	width: 100%;
}

.sousmenu .sousmenuresponsive {
	display: none;
}

#chkouvremenu, #btnouvresousmenu {
	display: none;
}

.fiche-conteneur {
	display: grid;
	grid-template-columns: 50% 50%;
}

.fiche-coord {
	padding: 20px;
	font-size: var(--fsize2);
	min-height: 50vh;
	background-color: var(--coul2);
	z-index: 1;
	position: sticky;
	top: 0;
}

.fiche-coord h1 {
	font-size: var(--fsize4);
	font-weight: var(--bold);
	margin: 0;
}

.fiche-coord-proximite {
	padding: 5px;
	border: solid 1px;
	border-left: none;
	border-right: none;
	display: table;
	color: var(--coul3);
}

.fiche-coord-acces {
	margin: 0;
	padding: 0 20px;
	font-size: var(--fsize1);
	color: var(--coul3);
}

.fiche-coord-etiquette {
	background: var(--coul3);
	display: table;
	padding: 10px;
	color: #fff;
	font-size: var(--fsizemin);
}

.fiche-texte-presentation {
	text-align: center;
	position: relative;
	padding: 10px;
	max-width: 600px;
	width: 80%;
	margin: auto;
}

.fiche-col2 {
	position: sticky;
	top: 0;
}

.fiche-slide {
	height: 50vh;
	position: sticky;
	top: 50%;
}

.fiche-slide #diaporom {
	background: none;
	box-shadow: none;
	width: 100%;
	height: 100%;
	display: initial;
}

.fiche-slide #containerrom {	
	height: 100%;
	width: 100%;
}

.fiche-slide .imgdiaporom {
	top: 0;
	transform: unset;
	height: 100%;
	width: 100%;
	object-fit: cover;
}

.fiche-defile section {
	padding: 20px;
}

.fiche-defile section h2 {
	margin: 0;
	font-size: var(--fsize2);
	font-weight: var(--bold);
	color: var(--coul3);
	background-color: var(--coul2);
	padding: 5px;
	margin-bottom: 20px;
}

.blocservices {
	display: flex;
	justify-content: space-around;
}

.service {
	margin: 10px 0;
	display: flex;
	align-items: center;
	height: 25px;
}

.pictoservice {
	margin-right: 10px;
}

.nbappart {
	text-align: center;
	padding: 10px;
	border-top: solid 1px var(--coul3);
	border-bottom: solid 1px var(--coul3);
}

.typesappartement {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 10px;
}

.colpmr {
	grid-template-columns: 1fr 1fr auto;
}

.typesappartement div {
	border-bottom: solid 1px var(--coul2);
	padding: 5px;
}

.tarifcourt {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
	grid-gap: 10px;
	text-align: center;
}

.tarifcourt div {
	border-bottom: solid 1px var(--coul2);
	padding: 5px;
}

.fiche-conteneur-formulaire {
	max-width: 650px;
	margin: auto;
	background-color: #fff;
	border-radius: 20px;
	box-shadow: var(--bshad);
	overflow: hidden;
	padding: 20px 0;
}

.fiche-formulaire-chck {
	display: none;
}

#chcknextform1:checked ~ .fiche-slider-formulaire  {
	left: -100%;
}

#chcknextform2:checked ~ .fiche-slider-formulaire  {
	left: -200%;
}

.fiche-slider-formulaire {
	display: grid;
	width: 300%;
	grid-template-columns: 1fr 1fr 1fr;
	transition: 0.5s;
	position: relative;
	left: 0;
}

.fiche-slider-formulaire > .fiche-formulaire-unit {
	padding: 0 20px;
}

.fiche-contenu-formulaire {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 20px;
	align-items: center;
}

.fiche-contenu-formulaire select{
	height: fit-content;
}

.fiche-contenu-formulaire input, .fiche-contenu-formulaire select, .fiche-contenu-formulaire textarea {
	padding: 10px;
	margin: 0;
}

.fiche-contenu-formulaire input[required], .fiche-contenu-formulaire select[required], .fiche-contenu-formulaire textarea[required] {
	border: solid 1px var(--coul3);
}

.fiche-formulaire-unit textarea {
	width: 100%;
	padding: 10px;
	margin: 0;
}

.fiche-formulaire-progression {
	display: flex;
	justify-content: center;
	align-items: center;
}

.progress-ok, .progress-no {
	height: 5px;
	width: 50px;
	border-radius: 5px;
	background-color: var(--coul3);
	margin: 10px;
}

.progress-no {
	opacity: 0.5;
}

.nextformulaire {
	padding: 10px;
	display: block;
	margin: 20px auto;
}

.info {
	position: absolute;
	left: 10%;
	top: 110%;
	background-color: var(--coul2);
	color: var(--coul1);
	padding: 10px;
	z-index: 10;
	opacity: 0;
	pointer-events: none;
	transition: 0.5s;
}

.afficheinfo:hover + .info {
	opacity: 1;
}

.conteneurresidencesproximite {
	display: flex;
	flex-wrap: wrap;
	grid-gap: 20px;
	align-items: center;
	justify-content: center;
}

.residenceproximite {
	width: 350px;
	background-color: #fff;
	border-top-left-radius: 20px;
	box-shadow: var(--bshad);
	overflow: hidden;
}

.fiche-map {
	height: 50vh;
	overflow: hidden;
	position: relative;
	background: linear-gradient(rgba(255,255,255,0.8), rgba(255,255,255,0.8)), url("/img/map-sample.png");
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: center;
	display: flex;
	justify-content: center;
	align-items: center;
}

#fiche-map-cookie-consent {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	padding: 20px;
	background-color: var(--coul2);
	border-radius: 10px;
	opacity: 1;
	transition: 0.2s;
}

.fiche-map .bouton {
	display: block;
	margin: 10px auto;
	padding: 10px;
}

/******************************* Map *******************************/


.map {
	height: 100%;
	width: 100%;
}

.map-logo{
	position: absolute;
	z-index: 500;
	left: 0;
	bottom: 0;
	background: rgba(255,255,255,0.7);
	user-select: none;
	pointer-events: none;
}

.leaflet-container {
	font: inherit;
}

.leaflet-marker-icon {
	border-radius: 50%;
	transition: 0.5s;
	transform-origin: center;
	box-sizing: initial;
}

.iconemapactif {
	background-color: var(--coul2);
	z-index: 10000 !important;
	position: relative;
	box-shadow: 0px 0px 5px #000;
	padding: 10px;
	left: -10px;
	top: -10px;
}

.leaflet-popup-content-wrapper {
	padding: 0;
	border-radius: 0;
	border-bottom-right-radius: 20px;
	border-top-left-radius: 20px;
	overflow: hidden;
}

.leaflet-popup-content {
	margin: 0;
	min-width: 270px;
	max-width: 270px;
}

.imgpopupmap {
	width: 100%;
	height: 200px;
	object-fit: cover;
}


.boutonpopupmap {
	background-color: var(--coul3);
	padding: 5px;
	color: #fff !important;
	transition: 0.5s;
	width: 100%;
	display: block;
}

.boutonpopupmap:hover {
	background-color: var(--coul1);
}

.textepopupmap {
	text-align: center;
	padding: 20px;
}

.leaflet-popup-close-button {
	font-size: var(--fsize4) !important;
	height: auto !important;
	width: auto !important;
	line-height: normal !important;
	user-select: none !important;
	padding-right: 10px !important;
	color: #fff !important;
	text-shadow: var(--bshad2) !important;
	transition: 0.5s;
}

.leaflet-popup-close-button:hover {
	color: var(--coul2) !important;
}



/* Séjours */

.zone-pattern {
	background: url(../img/pattern-fond.png);
	background-attachment: fixed;
	background-size: cover;
}

.conteneur-formules {
	display: table;
	margin: auto;
}

.formule-categorie {
	width: 255px;
	font-size: var(--fsize2);
	padding: 20px;
	background-color: #fff;
	box-shadow: var(--bshad);
	display: table;
	text-align: center;
}

.formule-unit {
	max-width: 95vw !important;
	overflow-x: auto;
	margin: 20px 0;
	border-radius: 20px;
	box-shadow: var(--bshad);
	display: flex;
	justify-content: flex-start;
	align-items: center;
}

.formule-titre {
	background: var(--coul3);
	align-self: stretch;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	padding: 20px;
	color: var(--coul1);
	width: 255px;
	min-width: 255px;
	text-align: center;
}

.tableau-formules {
	padding: 10px;
	border-spacing: 20px 0;
	text-align: center;
}

.tableau-formules thead th {
	min-width: 130px;
}

.sejours-services-equipements {
	display: flex;
	justify-content: space-around;
	align-items: flex-start;
	flex-wrap: wrap;
}

.sejours-services-equipements .quarante {
	min-width: 300px;
}

.appartements-sejours {
	padding: 50px 10px;
}

.slide-sejours {
	width: 500px;
	max-width: 90vw;
	height: 300px;
	overflow: hidden;
	position: relative;
}

.slide-sejours-slider {
	width: 300%;
	height: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	animation: slide 12s infinite;
	position: relative;
}

@keyframes slide {
	0% {left: 0;}
	28% {left: 0;}
	35% {left: -100%;}
	63% {left: -100%;}
	70% {left: -200%;}
	98% {left: -200%;}
	100% {left: 0;}
}

.slide-sejours:hover .slide-sejours-slider,  .slide-sejours:hover .slide-point{
	animation-play-state: paused;
}

.slide-sejours-unit {
	position: relative;
	height: 100%;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
}

.slide-sejours-unit img{
	height: 100%;
	width:100%;
	object-fit: cover;
}

.slide-sejours .slide-point{
	background-color: var(--coul2);
}

.sejours-texte-appartements {
	padding: 20px;
	width: 550px;
	max-width: 90vw;
}

.centre-affaires-bloc {
	margin: 10px;
}


.centre-affaires-img {
	margin: 10px;
	width: 300px;
	max-width: 90vw;
}

.centre-affaires-texte {
	max-width: 600px;
	background-color: #fff;
	padding: 10px;
	border-radius: 20px;
	box-shadow: var(--bshad);
}




/******************************* Solutions *******************************/

.solutions-bandeau {
	position: relative;
	padding: 100px 0;
}

.solutions-programme {
	padding: 40px;
	background-color: #fff;
	border-radius: 30px;
	box-shadow: var(--bshad);
	color: var(--coul3);
}

.solutions-programme-liste {
	display: flex;
	justify-content: space-between;
	grid-gap: 30px;
	flex-wrap: wrap;
}

.solutions-programme-liste > div {
	width: 40%;
	min-width: 200px;
}

.solutions-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0.1;
	z-index: 0;
}


.solutions-pelemele {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	grid-gap: 20px;
	width: 800px;
	height: 450px;
	max-width: 90vw;
}

.solutions-pelemele img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.solutions-pelemele > img:nth-of-type(1) {
	height: 70%;
	width: 50%;
}

.solutions-pelemele-col2 {
	display: flex;
	flex-direction: column;
	height: 100%;
	width: 50%;
	grid-gap: 20px;
	overflow: hidden;
}

.solutions-pelemele .solutions-pelemele-col2 img:nth-of-type(1) {
	height: 45%;
	width: 100%;
}

.solutions-pelemele .solutions-pelemele-col2 img:nth-of-type(2) {
	height: 55%;
	width: 100%;
}

.gauche10p {
	margin-left: 10%;
}

.droite10p {
	margin-right: 10%;
}


.solutions-texte {
	position: relative;
	z-index: 1;
	width: 80%;
}

.solutions-services-equipements {
	padding: 20px;
}

.solutions-services-equipements .service {
	margin : 10px;
	width: 210px;
	justify-content: center;
}


/******************************* Pied *******************************/

footer {
	padding: 20px;
}


footer a {
	transition: 0.5s;
}


footer a:hover {
	color : var(--coul2);
}

.footer-texte {
	margin-top: 60px;
}

.contactform {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	margin: auto;
	max-width: 500px;
	min-width: 250px;
	color: var(--coul1);
	grid-gap: 10px;
}

.contactform input[type="text"], .contactform input[type="email"], .contactform select {
	width: 49%;
	margin: 0;
	padding: 10px;
	border: solid 1px transparent;
	
}

.contactform textarea {
	width: 100%;
	margin: 0;
	padding: 10px;
}

.contactform input[type="submit"] {
	margin: auto;
}

.contactform input[type="checkbox"] {
	margin: 0;
}

.h-captcha {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
}