/* HOMEPAGE */
section.carousel {
	height: 100%;
}
.homepage, .page {
	padding-top: 0px;
	height: 100vh;
}
.page.erreur_404 {
	padding-top: 100px;
}
.page.erreur_404 h1, .page.erreur_404 h2 {
	text-transform: uppercase;
    font-weight: 700;
	font-size:1.5rem;
}
.page.erreur_404 h2 {
	font-size:1rem;
}

/*
.slider-counter {
	background: url(../img/big-arrow.svg) no-repeat left;
	background-size: 40px;
    position: absolute;
    bottom: 10px;
    right: 10px;
    z-index: 10;
    font-size: 65px;
    line-height: 100px;
    color: #fff;
    padding: 5px 10px;
    padding-left: 60px;
    transition: 1s;
    height: 110px;
    display: flex;
    font-family: 'Mavel Bd';
}
.slider-baseline {
    position: absolute;
    top: 50%;
    left: 80px;
    font-family: 'grossregular', sans-serif;
    color: #fff;
    z-index: 20;
    font-size: 50px;
    line-height: 60px;
    text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
	transform: translateY(-50%);
}
.slider-baseline.slider-baseline-2 {
    top: inherit;
	bottom: 80px;
	transform: translateY(0px);
}
*/
.owl-carousel-home {
	height: 100vh;
	width: 100%;
	display: flex;
}
.owl-carousel-home .content {
	height: auto;
    display: flex;
    flex-direction: column;
    align-items: start;
    justify-content: end;
    color: #000;
    position: absolute;
    right: 40px;
    bottom: 60px;
    background-color: #ffffff;
    padding: 10px 20px;
    text-align: left;
	max-width: 40%;
}
.owl-carousel-home .link-bottom {
	position: absolute;
	bottom: 30px;
}
.owl-carousel-home .link-bottom a {
	margin: 0px 5px;
}
.owl-carousel-home .item, .owl-carousel.owl-carousel-home.owl-drag .owl-item, .owl-carousel.owl-carousel-home .owl-stage, .owl-carousel.owl-carousel-home .owl-stage-outer {
	height: 100%;
}
.owl-carousel-home h2 {
	font-size: 14px;
}
.owl-carousel-home p {
	font-size: 12px;
	line-height: 18px;
	font-weight: 400;
	text-align: left;
}
.owl-dots {
	position: absolute;
	bottom: 100px;
}
.owl-carousel-home .owl-item {
	opacity: 0;
	transition: opacity 1s ease-in-out;
}
  
.owl-carousel-home .owl-item.active {
	opacity: 1;
}
/* REALISATIONS */
.realisations h2 {
	font-size: 1.2rem;
}
.realisations .annee, .realisation .annee {
	background: #000;
    display: inline-flex;
    padding: 2px 5px;
    color: #fff;
    font-size: 11px;
    margin: 10px 0px;
}
.grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	grid-auto-rows: 0px;
	gap: 1rem;
	justify-content: start;
	margin-bottom: 90px;
}
.grid-item {
	background: #fff;
	border-radius: 0.5rem;
	/* box-shadow: 0 2px 6px rgba(0,0,0,0.1); */
	padding: 0.5rem;
}
.grid-item img {
	width: 100%;
	height: auto;
	border-radius: 0;
	margin-bottom: 0.5rem;
	transition:.5s;
}
.grid-item:hover img {
	opacity: 0.8;
	border-radius: 0.5rem;
}

/* FICHE REALISATION */
.realisation h1 {
	
}
.realisation p {
	font-size: 15px;
    line-height: 24px;
}
/* TEMPLATE SINGLE */
.template-single {
	display: flex;
	align-items: center;
	justify-content: center;
}

.template-single .content {
	width: 90%;
    max-width: 450px;
    height: auto;
    max-height: 70%;
    background-color: #fff;
    padding: 30px;
    text-align: justify;
    overflow-y: scroll;
}
.template-single h1 {
	font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    background: #000;
    display: inline-block;
    padding: 5px 10px;
    color: #fff;
    margin-bottom: 10px;
    margin-right: 0px;
}
.template-single p {
	font-size: 14px;
    line-height: 19px;
	margin-bottom: 0px;
}
.template-single ul {
	padding-left: 20px;
}
/* TEMPLATE SINGLE 2 */
.template-single-2 {
	padding-top: 100px;
}
/* FORMULAIRE DE CONTACT */
#svgContainer {
	max-width: 100%;
	max-height: 100%;
	background-image: linear-gradient(70deg, #f0f0f0 10%, #ffffff 100%);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	text-align: center;
}
.template-single.partenaires .content {
	max-width:1000px;
}
.template-single.partenaires h2 {
	font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 2px;
}
.contact h1 {
	
}
.contact .btn, .template-single-2 .btn {
	font-size: 12px;
    font-weight: 800;
    font-family: 'Lato';
    letter-spacing: 1px;
	border-radius: 0px;
}
@keyframes outline {
	from {
		stroke-dasharray: 0, 3.1416 * 55px * 2;
	}
	to {
		stroke-dasharray: 3.1416 * 55px * 2, 3.1416 * 55px * 2;
	}
}

#outline {
  animation: .38s ease-in outline;
  transform: rotate(0deg);
  transform-origin: center;
}

@keyframes circle {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(0);
  }
}

#white-circle {
  animation: .35s ease-in .35s forwards circle;
  transform: none;
  transform-origin: center;
}

@keyframes check {
  from {
    stroke-dasharray: 0, 75px;
  }
  to {
    stroke-dasharray: 75px, 75px;
  }
}

#check {
  animation: .34s cubic-bezier(0.65, 0, 1, 1) .8s forwards check; 
  stroke-dasharray: 0, 75px;
}

@keyframes check-group {
  from {
    transform: scale(1);
  }
  
  50% {
    transform: scale(1.09);
  }
  
  to {
    transform: scale(1);
  }
}

#check-group {
  animation: .32s ease-in-out 1.03s check-group;
  transform-origin: center;
}




@media screen and (max-width:1250px) {
	
}
@media screen and (max-width:991px) {
	.page {
		padding-top: 50px;
	}
}
@media screen and (max-width:768px) {
	.owl-carousel-home .content {
		bottom: 80px;
	}
	.homepage, .page {
		padding-top: 0px;
	}
	section.section-3 p, section.section-5 p {
		font-size: 1.4rem;
		line-height: 1.8rem;
	}
	.swiper, .swiper-single, .swiper-left {
		/* padding: 10px !important; */
		height: 230px;
	}
	.slider-counter {
		background-size: 21px;
        font-size: 29px;
        line-height: 30px;
        height: 32px;
        padding: 0px 0px 0px 31px;
	}
	.slider-baseline {
		left: 30px;
		font-size: 21px;
		width: 58%;
		line-height: 23px;
	}
	.offres .img {
		height: 230px;
	}
}
@media screen and (max-width:576px) {
	.block-fixed .square {
		width: 40px;
		height: 40px;
		font-size: 8px;
	}
	.block-fixed .square.booking {
		width: 40px;
        height: 80px;

	}
	.block-fixed {
		bottom: 109px;
		top: inherit;
	}
	.HPEV4-panel[data-panel-anchor="R"] {
		top: inherit !important;
        bottom: 0px !important;
	}
}


.ui-menu {
    position: absolute !important; /* Force l'apparition sous l'input */
    z-index: 1050; /* Plus haut que Bootstrap dropdowns */
    overflow-x: hidden; /* Pas de débordement horizontal */
    overflow-y: auto; /* Ajoute un scroll si nécessaire */
	background-color: #fff;
	padding: 0px;
	-moz-box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.1); 
    -webkit-box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.1); 
    -o-box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 0px 40px rgba(0, 0, 0, 0.1);
	margin-top: 10px;
}

.ui-menu-item {
    list-style: none; /* Supprime les puces */
    padding: 8px 12px;
    cursor: pointer;
}

.ui-menu-item:hover {
    background-color: #E2E2E2; /* Couleur hover (Bootstrap) */
}



/* SWIPEBOX */


.glightbox-clean .gslide-description {
	background: none !important;
}
.glightbox-clean .gdesc-inner {
	padding: 10px !important;
}
.glightbox-clean .gslide-title {
	font-size: 0.8em !important;
	color: #fff !important;
	margin-bottom: 0px !important;
}