/*Header start*/
#masthead {
	position: fixed;
	top: 0; left: 0; width: 100%;
	background: #fff;
	z-index: 1000;

	transition: all 0.3s ease;
}

.header-inner {
	/*max-width: calc(1800px + 3rem);*/
	max-width: 1770px;
	margin: 0 auto;
	padding: 2rem 0!important;
	transition: padding 0.3s ease;
}

.top-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.logoHeader { display: flex; align-items: center; gap: 10px; }

.logoHeader .fullLogo img{ 
	width: 10.9rem;
	transition:opacity 0.4s ease;
}
.logoHeader .scrolledLogo img{ 
	width: 2rem;
	transition:opacity 0.4s ease;
}
.scrolledLogo{
	opacity: 0;

}
.scrolled .fullLogo{ 
	opacity: 0;
	display: none;
}
.scrolled .scrolledLogo{
	opacity: 1;
	transition:opacity 0.4s ease;
}

.scrolled .wpml-ls-legacy-list-horizontal {
	display: inline-block;
	border: none;
	position: absolute;
	right: 0;
}


.quote,
.top-links {
	flex: 1;
	text-align: center;

}

.quote {
	opacity: 1;
	transform: translateX(50%) translateY(2rem);
	visibility: visible;
	text-align: right;
	right: 6rem;
	max-width: 36%;
}

.quote h2{
	color: var(--gris);
	margin-bottom: 0 !important;
}
.quote h2 span{
	color: var(--vertF);
}
.top-links {
	display: none;
	opacity: 0;
	transform: translateY(-10px);
}
.hamburger {
	width: 2.5rem;
	height: 2.5rem;
	position: relative;
	cursor: pointer;
	top: 2rem;
}
.scrolled .hamburger {
	top: 0;
}

/*.bg_textureGris .container8 img{     
	padding-bottom: 3.75em; 
}*/
.bg_textureGris .container8 .image100{     
	padding-bottom: 3.75em; 
}


.ajoutCredit {
	display: none;
}
.home .ajoutCredit {
	display: block;
}
.ajoutCredit span{
	font-size: 0.5rem;
}

.scrolled .header-inner {


	padding: 1rem 0 0 !important;

}


.hamburger span {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 3px;
	background: var(--vertF);
	transition: transform 0.3s ease, opacity 0.3s ease;
	border-radius: 5px;
}

.hamburger span:first-child {
	transform: translateY(-6px);
}

.hamburger span:last-child {
	transform: translateY(6px);
}

.hamburger.open span:first-child {
	transform: rotate(45deg);
}

.hamburger.open span:last-child {
	transform: rotate(-45deg);
}

.bottom-row {
	margin-top: 5rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 1rem;
	/*transition: opacity 0.3s ease;*/
	align-items: center;
}

.scrolled .bottom-row {
	margin-top: 0rem;

}
.scrolled .top-row {
	border-bottom: 1px solid var(--vertF);
	padding-bottom: 1rem;
	margin-bottom: -1px;

}

#masthead.scrolled .quote {
	opacity: 0;
	transform: translateY(-100%);
	visibility: hidden;
	pointer-events: none;
	position: absolute;
}

#masthead.scrolled .top-links {
	transform: translateY(0);
	align-items: center;
	opacity: 1;
	display: inline-flex;
	justify-content: center;
}
#masthead.scrolled .topMenuLinks {
	display: flex;
	align-items: center;
}
#masthead.scrolled .topMenuLinks li{
	margin: 0 2rem;
}

#masthead.scrolled .bottom-row {
	opacity: 0;
	pointer-events: none;
	height: 0;
	overflow: hidden;
}

#masthead.scrolled .header-inner {
	padding: 0.5rem 1rem 1.5rem 1rem;
}
#masthead.scrolled .topSocials {
	margin-right: 8rem;
}
#masthead .topSocials .fa-linkedin-in{
	transform: scale(1.15);
}
#masthead.scrolled .header-inner ul{
	padding-left: 0;
}

.header-inner ul {
	padding-bottom: 0!important;
}

.menu-overlay {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	background: white;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(-10px);
	transition: max-height 0.4s ease, transform 0.4s ease;
	box-shadow: 0 4px 8px rgba(0,0,0,0.05);
}

.menu-overlay.open {
	max-height: 800px;
	opacity: 1;
	transform: translateY(0);
	max-width: calc(100% + 3rem);
	margin: 0 auto;
	padding: 1.5rem;
	z-index: -1;
}

.menu-content {

	margin: 0 auto;
	padding: 2rem 2rem;
	display: flex;
	/*justify-content: space-between;*/
	flex-wrap: wrap;

}
.menu-section{
	width: 33.33%;
}

.menu-menu-centre{
	padding-left: 2.5rem !important;
}
.menu-section h4 {
	margin-bottom: 0.5rem;
}

.menu-section ul {
	list-style: none;
	margin: 0;
	padding: 0;
	padding-left: 0 !important;
}

.menu-section ul li {
	margin-bottom: 0.25rem;
}

.content {
	padding-top: 180px;
	padding: 2rem;
}
.header-inner ul{
	list-style: none;
}
.header-inner ul li{
	display: inline-block;
}

.header-inner i{
	color: var(--bleu);
	margin-right: 0.5rem;
}
.wpml-ls-legacy-list-horizontal a {

	padding: 0!important;

}
.wpml-ls-legacy-list-horizontal {
	padding: 0!important;
}

.scrolled .menu-primary-menu-container{
	display: inline-block;
}

.header-inner a,.menu-overlay a{
	font-family: var(--font-family);
	color: var(--vertF);
}
.menu-overlay a{
	font-size: 2rem;
	font-weight: 200;
	line-height: 1;

}
.menu-overlay .sub-menu a{
	font-size: 1rem;
	font-weight: 300;
	line-height: 1;

}

.middleLink li{
	margin: 0 2rem;
}
.menu-overlay.open .menu-section  ul li {
	margin-bottom: 2.5rem;
}

.menu-overlay.open .menu-section .sub-menu li {
	margin-bottom: 1rem!important;
}
.sub-menu{
	margin-top: 1rem!important;
}
body.menu-open {
	overflow: hidden;
	touch-action: none;
	height: 100vh;
}
@media (max-width: 1280px) {
	.menu-overlay a {
		font-size: 1.2rem;
	}
	.menu-overlay.open .menu-section ul li {
		margin-bottom: 1rem;
	}
	.menu-content {

		padding: 2rem 0rem;

	}
	.menu-overlay .sub-menu a {
		font-size: 0.8rem;

	}
	.menu-overlay.open .menu-section .sub-menu li {
		margin-bottom: 0.6rem !important;
	}
}
@media (max-width: 1140px) {
	#masthead.scrolled .topSocials {
		margin-right: 0rem;
	}

}
@media (max-width: 1024px) {
	.quote {
		transform: translateX(0%);
		max-width: 50%;
	}
	#masthead.scrolled .topMenuLinks li {
		margin: 0 0.5rem;
	}
}
@media (max-width: 950px) {
	.middleLink li {
		margin: 0 1rem;
	}

}
@media (max-width: 870px) {
	.middleLink li {
		margin: 0 0.5rem;
	}

}

@media (max-width: 768px) {
	.menu-section {
		width: 100%;
	}
	.menu-overlay.open {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
	}
	.menu-content {
		padding: 0rem 0rem;
	}

	.menu-overlay.open {

		padding: 1rem 1.5rem 8rem 1.5rem;
	}
	.bottom-row,.quote {
		display: none;
	}
	#masthead .top-links {
		transform: translateY(0);
		align-items: center;
		opacity: 1;
		display: inline-flex;
		justify-content: center;
	}
	#masthead .menu-primary-menu-container,#masthead .menu-primary-menu-anglais-container  {
		display: none;
	}

	.menu-content {
		flex-direction: column;
	}
}
@media (max-width: 640px) {
	.fullLogo{display: none!important;}
	.scrolledLogo {
		opacity: 1!important; 
	}

	.menu{
		padding-bottom: 0 !important;
		padding-top: 0 !important;
	}


}
/*Header End*/

/*slider video start*/
.bg_vertF .col4Titre h2,.bg_vertF .col4Titre h2 .accent{
	color: #fff;
	margin-bottom: 0 !important;
	font-weight: 300;
}

.col4Titre{
	margin-bottom: 3.5rem;
}

.bg_vertF {
	background-color: var(--vertF);
}

/* Styles pour le conteneur vidéo dans le slider */
.video-container {
	position: relative;
	width: 100%;
	height: 25.75rem;
	cursor: pointer;
	overflow: hidden;
	border-radius: 0px;
}

.video-thumbnail {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	display: flex
	;
	align-items: end;
	justify-content: flex-end;
	position: relative;
	transition: transform 0.3s ease;
}

.video-container:hover .video-thumbnail {
	transform: scale(1.05);
}

.play-button {
	width: 68px;
	height: 48px;
	transition: transform 0.3s ease;
	margin-bottom: 1rem;
	margin-right: 1rem;
}

.video-container:hover .play-button {
	transform: scale(1.2);
}

/* Styles pour le lightbox */
.video-lightbox {
	display: none;
	position: fixed;
	z-index: 9999;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.9);
}

.lightbox-content {
	position: relative;
	width: 90%;
	max-width: 1200px;
	height: 80%;
	margin: 5% auto;
	display: flex;
	flex-direction: column;
}

.lightbox-close {
	color: white;
	float: right;
	font-size: 32px;
	font-weight: bold;
	cursor: pointer;
	position: absolute;
	right: -40px;
	top: -40px;
	z-index: 10000;
}

.lightbox-close:hover {
	opacity: 0.7;
}

.video-wrapper {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}

#lightbox-video-container {
	width: 100%;
	height: 100%;
	max-height: 600px;
}

#lightbox-video-container iframe {
	width: 100%;
	height: 100%;
}



.sectionSliderVideo .slick-dots {
	position: relative !important;
	list-style: none !important;
	display: inline-block !important;
	text-align: center !important;
	padding: 0 !important;
	margin: 0 !important;
	width: calc(100% + 1rem) !important;
	left: -1rem;
}





/* Responsive */
@media (max-width: 1024px) {
	.video-container {

		height: 15.75rem;

	}
	.actifs-sidebar.open {
		width: 50%!important;
		max-width: 50%!important;

	}
}
@media (max-width: 768px) {

	.lightbox-content {
		width: 95%;
		height: 70%;
	}

	.lightbox-close {
		right: 10px;
		top: 10px;
	}
}
@media (max-width: 640px) {
	.sectionSliderVideo .sliderPad{
		margin-left: 0rem;
	}
	.sectionSliderVideo .le_slider {
		margin-left: 1rem;
	}
}
/*slider video end*/

/*Bannière accueil start*/

.video-banner {
	position: relative;
	width: 100%;
	height: 100vh;
	
	margin-top: 10.5rem;
	/*max-height: 40rem;*/
}

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

.video-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.25);
	z-index: 2;
}

.content-container {
	position: absolute;
	top: 50%;

	transform: translateY(-50%) translateX(30%);
	z-index: 3;
	color: white;


}

.text-box {
	background: none;
	padding: 0;
	position: relative;
}

.small-title {
	color: #fff;
	line-height: 1;
	margin-bottom: 0;
	font-size: clamp(1.5rem, -0.3721rem + 4.7443vw, 3.55rem);
	letter-spacing: 1px;
	position: absolute;
	left: 4rem;
	top: -2.5rem;
}
.small-titleEN{
	color: #fff;
	line-height: 1;
	margin-bottom: 0;
	font-size: clamp(1.5rem, -0.3721rem + 3.5443vw, 3.05rem);
	letter-spacing: 1px;
	position: absolute;
	left: 0;
	top: -2.5rem;
}
.main-title {
	font-size: clamp(5.5rem, -1.7143rem + 18.4286vw, 15.6rem);
	font-weight: 300;
	margin-bottom: 5px;
	line-height: 1;
	letter-spacing: -2px;
	color: #fff;
	font-family: var(--font-Bashield);
}

.subtitle {
	color: #fff;
	line-height: 1;
	margin-bottom: 0;
	letter-spacing: 1px;
	position: absolute;
	right: 0;
	bottom: 0rem;
	font-size: clamp(1.5rem, -0.3721rem + 4.7443vw, 3.55rem);
}

.vertical-line {
	position: absolute;
	width: 2px;
	height: 11.25rem;
	border-radius: 3px;
	background: #fff;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
	left: 42%;
	z-index: 9;
	bottom: -2.8rem;
	/*bottom: -7%;*/
}

.vertical-line::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 25%;
	background: var(--vertF);
	border-radius: 0 0 3px 3px;
}
.subBannerText{
	display: flex;
	align-items: center;
}
.rightBanner {
	padding-right: 0rem;
}
.leftBanner {
	padding-right: 2rem;
	padding-top: 1rem;

}
.leftBanner p,
.rightBanner p{
	font-family: var(--font-NewsReader);
}
.leftBanner p{
	font-size: 2rem;
	display: flex;
	font-weight: 500;
	font-style: italic;
}
.leftBanner p .gris{
	font-size: 5.5rem;
	font-style: italic;
}

.rightBanner p{
	font-family: var(--font-family);
	font-weight: 300;
	font-size: 1.5rem;
	line-height: 1;
}
.rightBanner p .bleu{
	font-style: normal;
	font-size: 1.75rem;
	font-family: var(--font-NewsReader);
	font-weight: 500;
}

.ctaBanner p,.ctaBanner a{
	font-weight: 500;
	font-size: 1rem;
	font-family: var(--font-NewsReader);
	font-style: italic;
}
.ctaBanner{
	margin-top: 1rem;
}
.bannerContainerSubText{
	padding-left: 25%;
	padding-right: 25%;
	display: inline-block;
	width: 100%;
}
/* Responsive */


@media (max-width: 1770px) {
	.maxW,.header-inner{
		padding-left: 3.33%!important;
		padding-right: 3.33%!important;
	}
	.scrolled .header-inner{
		padding-left: 3.33%!important;
		padding-right: 3.33%!important;
	}

}
@media (max-width: 1790px) {

	.small-title,
	.small-titleEN {

		top: -3.5rem;
	}
	.bannerContainerSubText{
		padding-left: 20%;
		padding-right: 20%;

	}
	.menu-overlay.open {

		padding: 0.5rem 8.33%;

	}
}

@media (max-width: 1480px) {
	.small-title,
	.small-titleEN {
		top: -3rem;
	}
	.video-banner {

		height: 70vh;

	}
	.text-box {

		scale: 0.7;
	}
	.vertical-line {
		height: 8.6rem;

	}
	.bannerContainerSubText{
		padding-left: 15%;
		padding-right: 15%;

	}
}
@media (max-width: 1280px) {
	.small-title,
	.small-titleEN {
		top: -3.2rem;
		left: 2rem;
	}

	.content-container {

		left: 0;
	}
	.actifs-sidebar.open,
	.actifs-sidebar{
		width: 41.6666666667%!important;
		max-width: 41.6666666667%!important;
	}


}
@media (max-width: 1140px) {
	.bannerContainerSubText{
		padding-left: 10%;
		padding-right: 10%;
		
	}


}






@media (max-width: 1024px) {

	.ctaBanner .h5050-text{
		padding-top: 0;
	}

	.ctaBanner p, .ctaBanner a {

		text-align: center;
	}
	.leftBanner p {
		
		display: inline-block; 

	}
	.subBannerText {
		display: inline-block;
		text-align: center;
	}
	.content-container {
		position: relative;
		top: 50%;
		transform: none;

	}
	.subtitle {

		position: relative;

		bottom: 1rem;

	}
	.vertical-line {

		height: 5.8rem;

	}
	.video-banner {
		height: 46vh;
	}
	.small-title,
	.small-titleEN {
		font-size: 1.5rem;
		position: relative;
		top: -0.4rem;
		left: 0rem;
	}

	.main-title {
		font-size: 5.5rem;
	}

	.subtitle {
		font-size: 1.5rem;

	}
}

@media (max-width: 768px) {
	.leftBanner .h5050-text,.rightBanner .h5050-text {
		padding-top: 0; 
	}
	.leftBanner p .gris {
		font-size: 3.5rem;
		font-style: normal;
	}
	.leftBanner {
		padding-right: 0;
		padding-top: 0;
	}

	.bannerContainerSubText{
		padding-left: 8.333%;
		padding-right: 8.333%;
		
	}
	.leftBanner p{
		line-height: 1;
	}
	.vertical-line {

		display: none;

	}
	.content-container {
		left: 20px;
		max-width: 400px;
	}
	.video-banner {
		height: 30vh;
	}
	.small-title,
	.small-titleEN {
		font-size: 1.2rem;
		letter-spacing: 1px;
	}

	.main-title {
		font-size: 4rem;
	}

	.subtitle {
		font-size: 1.3rem;
	}
}

@media (max-width: 480px) {
	.content-container {
		left: 15px;
		max-width: calc(100% - 30px);
	}

	.small-title,
	.small-titleEN {
		font-size: 1rem;
	}

	.main-title {
		font-size: 2.8rem;
		letter-spacing: -1px;
	}

	.subtitle {
		font-size: 1rem;
	}
}


/*Bannière accueil end*/




/*Map et list card start*/
/* Styles pour la section carte */
/*.carte-actifs-section {
	margin: 40px 0;
}*/

.carte-actifs-title {
	font-size: 2rem;
	margin-bottom: 1rem;
	text-align: center;
	color: #333;
}

.carte-actifs-container {
	position: relative;

	overflow: hidden;
	box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.actifs-map {
	width: 100%;

}

.carte-actifs-controls {
	position: absolute;
	top: 10px;
	right: 10px;
	display: flex;
	gap: 10px;
	z-index: 1000;
}

.btn-refresh-map,
.btn-fit-map {
	background: white;
	border: 1px solid #ccc;
	border-radius: 4px;
	padding: 8px 12px;
	cursor: pointer;
	font-size: 14px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.1);
	transition: all 0.3s ease;
}

.btn-refresh-map:hover,
.btn-fit-map:hover {
	background: #f0f0f0;
	transform: translateY(-1px);
}

.btn-refresh-map .dashicons,
.btn-fit-map .dashicons {
	font-size: 16px;
	vertical-align: middle;
	margin-right: 5px;
}

/* Styles pour les info windows */
.actif-info {
	max-width: 400px;
	max-height: 500px;

	line-height: 1.5;
}

.actif-carousel {
	position: relative;
	background: #fff;
}


.actif-item.active {
	display: block;
}

.actif-item:last-child {
	border-bottom: none;
}

.actif-title {
	font-size: 18px;
	font-weight: 600;
	color: #333;
	margin-bottom: 10px;
	line-height: 1.3;
}

.actif-type {
	display: inline-block;
	background: #007cba;
	color: white;
	padding: 4px 12px;
	border-radius: 15px;
	font-size: 12px;
	font-weight: 500;
	margin-bottom: 10px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.actif-location {
	color: #666;
	font-size: 14px;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
}

.actif-location::before {
	content: "📍";
	margin-right: 5px;
}

.actif-description {
	color: #555;
	font-size: 14px;
	line-height: 1.4;
	margin-bottom: 10px;
	max-height: 80px;
	overflow: hidden;
	text-overflow: ellipsis;
}

.actif-status {
	display: inline-block;
	padding: 6px 12px;
	border-radius: 6px;
	font-size: 12px;
	font-weight: 600;
	margin-bottom: 10px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.actif-status.disponible {
	background: #d4edda;
	color: #155724;
}

.actif-status.loue {
	background: #f8d7da;
	color: #721c24;
}

.actif-links {
	margin-top: 15px;
	padding-top: 15px;
	border-top: 1px solid #f0f0f0;
	display: flex;
	gap: 15px;
}

.actif-links a {
	color: #007cba;
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transition: color 0.3s ease;
}

.actif-links a:hover {
	color: #005a87;
	text-decoration: underline;
}

.carousel-nav {
	text-align: center;
	padding: 15px;
	background: #f8f9fa;
	border-top: 1px solid #eee;
}

.carousel-counter {
	color: #666;
	font-size: 14px;
	margin-bottom: 10px;
	font-weight: 500;
}

.carousel-buttons {
	display: flex;
	justify-content: center;
	gap: 12px;
	margin-bottom: 12px;
}

.carousel-btn {
	background: #007cba;
	color: white;
	border: none;
	padding: 8px 16px;
	border-radius: 6px;
	cursor: pointer;
	font-size: 14px;
	font-weight: 500;
	transition: background 0.3s ease;
}

.carousel-btn:hover {
	background: #005a87;
}

.carousel-btn:disabled {
	background: #ccc;
	cursor: not-allowed;
}

.carousel-dots {
	display: flex;
	justify-content: center;
	gap: 8px;
}

.carousel-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #ccc;
	cursor: pointer;
	border: none;
	padding: 0;
	transition: background 0.3s ease;
}

.carousel-dot.active {
	background: #007cba;
}

.carousel-dot:hover {
	background: #005a87;
}
/* Styles pour les filtres au-dessus de la carte */
.carte-actifs-filters {

}

.filters-container {
	display: flex;
	gap: 20px;
	align-items: end;
	flex-wrap: wrap;
}

.filter-group {
	display: flex;
	flex-direction: column;
	min-width: 200px;
}

.filter-group label {
	font-weight: 600;
	margin-bottom: 8px;
	color: #333;
	font-size: 14px;
}

.filter-group select {
	padding: 10px 12px;
	border: 1px solid #ddd;
	border-radius: 6px;
	font-size: 14px;
	background: white;
	cursor: pointer;
}

.filter-group select:focus {
	outline: none;
	border-color: #007cba;
	box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

.btn-clear-filters {
	background: #dc3545;
	color: white;
	border: none;
	padding: 10px 20px;
	border-radius: 6px;
	cursor: pointer;
	font-size: 14px;
	font-weight: 600;
	transition: background-color 0.2s;
}

.btn-clear-filters:hover {
	background: #c82333;
}

.carte-actifs-container {
	display: flex;
	position: relative;
	height: 100%;
	max-height: 80vh;
}

.actifs-sidebar {
	position: relative;
	width: 0;
	min-width: 0;
	max-width: 33.33%;
	background: #fff;
	border-right: 1px solid #ddd;

	transition: width 0.1s ease;
	display: flex;
	flex-direction: column;
	box-shadow: 2px 0 5px rgba(0,0,0,0.1);
}


.actifs-sidebar.open {
	width: 33.33%;
	min-width: 15rem;

}

.actifs-sidebar.open .sidebar-toggle-btn i{
	transform: rotate(0deg);
	transform-origin: center center;
}
.actifs-sidebar .sidebar-toggle-btn i{
	transform: rotate(180deg);
	transform-origin: center center;
}

.sidebar-toggle-btn{
	position: absolute;
	top: 15%;
	right: -1rem;
	z-index: 9;
	background-color: #fff !important;
	color: var(--vertF) !important;
	width: 1rem;
	height: 1.5rem;

}
.sidebar-toggle-btn i{

	transition: transform 0.3s ease-in-out;
}



.sidebar-header {
	padding: 0.35rem 0.8rem;
	display: flex;
	border-top: 1px solid var(--gris);
	/* border-bottom: 1px solid var(--gris);*/
}

.sidebar-header h3 {
	margin: 0;
	font-size: 16px;
}

.sidebar-toggle {
	background: none;
	border: none;
	cursor: pointer;
	padding: 5px;
	border-radius: 3px;
}

.sidebar-toggle:hover {
	background: #e9ecef;
}

.actifs-list {
	flex: 1;
	overflow-y: auto;

}

.actif-list-item {
	border-top: 1px solid var(--gris);
	border-bottom: 1px solid var(--gris);
	border-right: 1px solid var(--gris);
	margin-bottom: 0.6rem;
	cursor: pointer;
	transition: all 0.2s;
	background: white;

	width: 100%;
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.actif-list-item a,.card-link{


	display: flex;

	width: 100%;
}
.gm-style-iw-d .card-link .actif-image{
	height: 5.1rem;
}

.gm-ui-hover-effect{
	position: absolute!important;
	right: 0;
}


.actif-list-item:hover {
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);

}

.actif-list-item:hover .listActifTopPart svg,.actif-list-item:hover .listActifBotPart svg{
	transform: translateX(0.45rem);

}

.actif-list-item.active {
	border-color: #007cba;
	background: #f0f8ff;
}

.actif-list-item h4 {

	font-size: 1.5rem!important;
	font-family: var(--font-family);
	color: var(--vertF);
	margin-bottom: 0.5rem !important;
}
.card-link h4 {
	line-height: 1;
	font-size: 0.8rem!important;
	font-family: var(--font-family);
	color: var(--vertF);
	margin-bottom: 0.5rem !important;
}

.card-link:hover .listActifTopPart svg,.actif-list-item:hover .listActifBotPart svg{
	transform: translateX(0.45rem);

}



.actifSidebarTitle{
	color: var(--vertF)!important;
	font-size: 0.9rem;
	font-family: var(--font-NewsReader) !important;
	font-style: italic;
}
.activ-ville p{
	color: var(--bleu) !important;
	font-size: 0.7rem;
	margin-bottom: 0!important;
	font-weight: 500;
	line-height: 1;
}



.actif-list-item .actif-type {
	background: #e9ecef;
	padding: 2px 6px;
	border-radius: 3px;
	font-size: 11px;
	display: inline-block;
	margin-bottom: 5px;
}

.actif-list-item .actif-address {
	color: #666;
	font-size: 12px;
	margin-bottom: 5px;
}

.actif-list-item .actif-status {
	font-size: 11px;
	padding: 2px 6px;
	border-radius: 3px;
	font-weight: bold;
}

.actif-list-item .actif-status.disponible {
	background: #d4edda;
	color: #155724;
}

.actif-list-item .actif-status.loue {
	background: #f8d7da;
	color: #721c24;
}

.carte-actifs-map-container {
	flex: 1;
	position: relative;
}

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

.carte-actifs-controls {
	position: absolute;
	top: 10px;
	right: 10px;
	display: flex;
	gap: 5px;
}

.carte-actifs-controls button {
	background: white;
	border: 1px solid #ddd;
	padding: 8px 12px;
	border-radius: 4px;
	cursor: pointer;
	font-size: 12px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.carte-actifs-controls button:hover {
	background: #f8f9fa;
}

/* Styles pour l'infobulle scrollable */
.actif-info {
	max-width: 400px;
	max-height: 400px;


}

.actifs-scroll-container {
	max-height: 350px;
	overflow-y: auto;
	padding-right: 5px;
}

.actifs-scroll-container::-webkit-scrollbar {
	width: 6px;
}

.actifs-scroll-container::-webkit-scrollbar-track {
	background: #f1f1f1;
	border-radius: 3px;
}

.actifs-scroll-container::-webkit-scrollbar-thumb {
	background: #888;
	border-radius: 3px;
}

.actifs-scroll-container::-webkit-scrollbar-thumb:hover {
	background: #555;
}

.actif-item {
	padding: 15px;
	border-bottom: 1px solid #eee;
	margin-bottom: 10px;
}

.actif-item:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

.actif-image {
	width: 100%;
	height: 100%;
	height: 8.9rem;
	object-fit: cover;
	border-radius: 0;
	margin-bottom: 0;
}

.cards-view .actif-image {

	height: 13.1rem;

}



.actif-title {
	margin: 0 0 8px 0;
	font-size: 16px;
	font-weight: bold;
	color: #333;
}

.actif-type {
	background: #e9ecef;
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 12px;
	display: inline-block;
	margin-bottom: 8px;
	color: #666;
}

.actif-location {
	color: #666;
	font-size: 13px;
	margin-bottom: 8px;
}

.actif-description {
	color: #555;
	font-size: 13px;
	margin-bottom: 10px;
	line-height: 1.4;
}

.actif-status {
	font-size: 12px;
	padding: 4px 8px;
	border-radius: 4px;
	font-weight: bold;
	display: inline-block;
	margin-bottom: 10px;
}

.actif-status.disponible {
	background: #d4edda;
	color: #155724;
}

.actif-status.loue {
	background: #f8d7da;
	color: #721c24;
}

.actif-links a {
	color: #007cba;
	text-decoration: none;
	font-weight: 600;
	font-size: 13px;
}

.actif-links a:hover {
	text-decoration: underline;
}

.multiple-actifs-header {
	background: #f8f9fa;
	padding: 10px 15px;
	border-bottom: 2px solid #e9ecef;
	margin-bottom: 0;
	font-weight: bold;
	color: #333;
	text-align: center;
}
.checkbox-group {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 5px;
}

.actif-card .pastille {
	background-color: #EBF9FF;
	font-size: 0.6rem;
	display: inline-block;
	margin-bottom: 1rem;

	margin-left: 0em;
}

.actif-list-item .pastille {
	background-color: #EBF9FF;
	font-size: 0.6rem;
	display: inline-block;
	margin-bottom: 1rem;
	margin-top: 1rem;
	margin-left: 0em;
}
.actifs-scrollable-list .pastille {
	background-color: #EBF9FF;
	font-size: 0.6rem;
	display: inline-block;
	margin-bottom: 1rem;
	margin-top: 1rem;
	margin-left: 0em;
}
.gm-style-iw-d .card-link .pastille {
	background-color: #EBF9FF;
	font-size: 0.6rem;
	display: inline-block;
	margin-bottom: 1rem;
	margin-top: 1rem;
	margin-left: 0em;
}



.actifs-scrollable-list {
	max-height: 300px;
	overflow-y: auto;
	padding: 0 0.5rem;
	margin-top: 0.35rem;
}
.actifs-scrollable-list .bottomActifPad {
	padding:  1.25rem;
}

.actifs-scrollable-list  a{
	border-bottom: 1px solid var(--gris);
	margin-top: 0.5rem;
}

.actifs-scrollable-list .actif-item {
	padding: 15px;
	border-bottom: 1px solid #eee;
	background: white;
	margin-bottom: 10px;
	border-radius: 5px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.actifs-scrollable-list .actif-item:last-child {
	border-bottom: none;
	margin-bottom: 0;
}

.actifs-scrollable-list .actif-image {
	width: 100%;
	object-fit: cover;
	border-radius: 0;
	margin-bottom: 10px;
}

.actifs-scrollable-list .actif-title {
	margin: 0 0 10px 0;
	font-size: 16px;
	font-weight: bold;
	color: #333;
}

.actifs-scrollable-list .actif-type {
	background: #007cba;
	color: white;
	padding: 2px 8px;
	border-radius: 3px;
	font-size: 12px;
	display: inline-block;
	margin-bottom: 5px;
}

.actifs-scrollable-list .actif-location {
	color: #666;
	font-size: 14px;
	margin-bottom: 8px;
}

.actifs-scrollable-list .actif-description {
	color: #555;
	font-size: 14px;
	margin-bottom: 10px;
	line-height: 1.4;
}

.actifs-scrollable-list .actif-status {
	padding: 4px 8px;
	border-radius: 3px;
	font-size: 12px;
	font-weight: bold;
	display: inline-block;
	margin-bottom: 10px;
}

.actifs-scrollable-list .actif-status.disponible {
	background: #d4edda;
	color: #155724;
}

.actifs-scrollable-list .actif-status.loue {
	background: #f8d7da;
	color: #721c24;
}

.actifs-scrollable-list .actif-links a {
	color: #007cba;
	text-decoration: none;
	font-weight: bold;
	font-size: 14px;
}

.actifs-scrollable-list .actif-links a:hover {
	text-decoration: underline;
}

/* Scrollbar styling */
.actifs-scrollable-list::-webkit-scrollbar {
	width: 8px;
}

.actifs-scrollable-list::-webkit-scrollbar-track {
	background: #f1f1f1;
	border-radius: 4px;
}

.actifs-scrollable-list::-webkit-scrollbar-thumb {
	background: #888;
	border-radius: 4px;
}

.actifs-scrollable-list::-webkit-scrollbar-thumb:hover {
	background: #555;
}


.listActifTopPart svg,.listActifBotPart svg{
	max-width: 4rem;
	margin-left: 0.3rem;
	transition: all 0.25s ease;
}
.bottomActifPad{
	padding: 1rem 1.25rem;
}



/* Grilles en fractions */
.oneThird {
	width: 33.3333%;
}

.twoThird {
	width: 66.6667%;
	display: flex; /* Important pour forcer la hauteur */
	flex-direction: column;
}

/* Intérieur de la colonne texte */
.bottomActifPad {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	flex: 1;
	height: 100%;
}

/* Optionnel si tu veux que la colonne image s'étire aussi */
.oneThird {
	display: flex;
	align-items: center; /* ou `flex-start` si tu veux en haut */
	justify-content: center;
}



.cards-view {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem; /* espace entre les éléments */
	padding-top: 0.5rem;
}

.cards-view .actif-card {
	flex: 1 1 calc(25% - 1rem); /* 4 colonnes */
	background: #fff;
	box-sizing: border-box;
	border: 1px solid var(--gris);
}

.cards-view .actif-card .bottomInfos{


}
.cards-view .actif-card:hover .actif-image{
	transform: scale(1.1);


}

.cards-view .actif-image {

	/*object-fit: fill;*/

}


.cards-view  .actif-image{
	transition: transform 0.3s ease; /* Animation fluide sur 0.3 secondes */
	transform-origin: center; /* Point d'origine du zoom au centre */
	overflow: hidden;

}
.cards-view  .topInfos{
	overflow: hidden;

}
.cardLink .listActifBotPart h4{
	margin-bottom: 0.5rem !important;
}

.stickToBottom{
	margin-top: 2rem;
}

/*.page-id-797 .filtreTypes,.page-id-1298 .filtreTypes{display: none;}*/


/* Tablette : 2 colonnes */
@media (max-width: 991px) {
	.cards-view .actif-card {
		flex: 1 1 calc(50% - 1rem);
	}
}

/* Mobile : 1 colonne */
@media (max-width: 575px) {
	.cards-view .actif-card {
		flex: 1 1 100%;
	}
}



@media (max-width: 666px) {
	.actifs-list .card-link .listActifTopPart svg{
		display: none;
	}

	.actif-image {

		height: 4.9rem;

	}
}
@media (max-width: 768px) {
	.filters-container {
		flex-direction: column;
		gap: 15px;
	}

	.filter-group {
		min-width: 100%;
	}

	.actifs-sidebar.open {
		width: 100%;
		min-width: auto;
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		z-index: 999;
	}

	.carte-actifs-container {

	}
}

/* Animation bounce pour les markers */
@keyframes bounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-10px); }
}

.marker-bounce {
	animation: bounce 0.6s ease-in-out;
}
/* Responsive */
@media (max-width: 1800px) {
	.carte-actifs-filters {
		padding: 0 8.33%;
	}
}


@media (max-width: 1480px) {
	.carte-actifs-filters {
		padding: 0 1rem;
	}
}

@media (max-width: 1024px) {
	.actif-list-item a {
		display: inline-block;
		width: 100%;
	}

	.actifs-list .oneThird ,.actifs-list .twoThird {
		width: 100%;
	}
}


@media (max-width: 768px) {
	.carte-actifs-controls {
		position: static;
		justify-content: center;
		margin-top: 10px;
		background: rgba(255,255,255,0.9);
		padding: 10px;
		border-radius: 8px;
	}

	.actifs-map {
		height: 400px !important;
	}

	.actif-info {
		max-width: 280px;
	}

	.actif-title {
		font-size: 16px;
	}

	.carousel-buttons {
		flex-direction: column;
		gap: 8px;
	}

	.carousel-btn {
		width: 100%;
	}
}

@media (max-width: 640px) {
	.actifs-sidebar{
		max-width: 75%;
	}
	.actifs-sidebar.open {
		width: 75%!important;
		max-width: 75%!important;

	}
	.filter-checkboxes .checkbox-label {
		width: 100%;
		margin: 0 !important;
	}
	.view-toggle {
		display: inline-block!important;
		float: none!important; 
		margin: 0rem 0!important;
	}
	.sub-menu {
		margin-top: 1rem !important;
		padding: 0 !important;
	}

}

.actifCounter{
	font-size: 0.6rem;
	color: var(--vertF);
	font-family: var(--font-family);
}

/* Conteneur global des filtres */
.filters-inline {
	display: inline-flex;
	gap: 1.5rem;
	font-family: sans-serif;
	padding: 1rem 0;
}
.underFilters{
	padding-bottom: .5em;
}

/* Label de section cliquable */
.filter-section-label {
	font-size: 0.9rem;
	font-weight: 300;

	cursor: pointer;
	padding: 10px 12px;
	border: 1px solid #ddd;

	background-color: white;
	transition: background 0.3s, border 0.3s;
	display: flex;
	align-items: center;
	gap: 10px;
}

.filtreTypes{
	color: var(--bleu);
}
.filtreTypes:hover{
	color: var(--bleu);
}
.filtreTypes .toggle-icon{
	max-height: 0.9rem;
}
.filtreLieu{
	color: var(--vertF);
}
.filtreTypes .filtreLieu{
	max-height: 1rem;
}


.filter-section-label.active {
	background-color: #f0f8ff;
	/*border-color: #007cba;*/
	color: #007cba;
}


.filter-section-label.active .toggle-icon {
	/*transform: rotate(180deg);*/
	border-top-color: #007cba;
}

.checkbox-label:first-child {
	margin-left: 0!important; /* pas de marge pour le premier */
}
.filter-checkboxes {
	display: none;
	flex-wrap: wrap;
	gap: 1.5rem;
	/*margin-top: 10px;*/
	/*padding-left: 8px;*/
}

.filter-checkboxes.visible {
	display: flex;
}

.filter-checkboxes .checkbox-label {
	display: inline-flex;
	align-items: center;
	/*gap: 0.4em;*/
	font-size: 0.8rem;
	color: var(--vertF);
	cursor: pointer;
	user-select: none;
	margin: 0 1rem;
}
.filter-checkboxes .checkbox-label:first-of-type {
	/*margin-left: 0;*/
} 


.filter-checkboxes input[type="checkbox"],.filter-checkboxes input[type="radio"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 0.45rem;
	height: 0.45rem;
	background-color: white;
	border: 1px solid var(--vertF);
	border-radius: 3px;
	position: relative;
	cursor: pointer;
	transition: all 0.2s ease-in-out;
	display: inline-block;
	margin-right: 0.4rem;
}


/* Checkbox cochée : carré vert foncé avec coche blanche centrée */
.filter-checkboxes input[type="checkbox"]:checked,.filter-checkboxes input[type="radio"]:checked {
	background-color: var(--vertF); 
	border-color: #3d4b45;
}

/* Ajout de la coche blanche au centre */
.filter-checkboxes input[type="checkbox"]:checked::before{
	content: '';
	position: absolute;
	left: 2px;
	top: 1px;
	width: 3px;
	height: 4px;
	border-right: 1px solid white;
	border-bottom: 1px solid white;
	transform: rotate(45deg);
}
.filter-checkboxes input[type="radio"]:checked::before {
	content: '';
	position: absolute;
	left: 3px;
	top: 2px;
	width: 3px;
	height: 4px;
	border-right: 1px solid white;
	border-bottom: 1px solid white;
	transform: rotate(45deg);
}


/* Optionnel : focus stylé */
.filter-checkboxes input[type="checkbox"]:focus-visible,.filter-checkboxes input[type="radio"]:focus-visible {
	outline: 2px solid #007cba;
	outline-offset: 2px;
}

.view-toggle {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 0;
	margin: 1rem 0;
	float: right;

	border: 1px solid var(--bleu);
	border-radius: 1rem;
	max-height: 1.7rem;
	overflow: hidden;
}

.view-toggle button {
	padding: 6px 14px;
	background: #fff;
	color: var(--bleu) !important;
	font-size: 13px;
	border-radius: 0;
	cursor: pointer;
	transition: background 0.2s;
	border: none;
	position: relative;
}

.view-toggle button:not(:first-child) {
	margin-left: -9px;
}

.view-toggle button:first-child {
	border-radius: 1rem;
}
.view-toggle button:first-child.active {
	border-right: 1px solid var(--bleu);
	border-bottom: 1px solid var(--bleu);
}

.view-toggle button:last-child {
	border-radius: 1rem;
}
.view-toggle button:last-child.active {
	border-left: 1px solid var(--bleu);
	border-bottom: 1px solid var(--bleu);
}

.view-toggle button.active {

	background: #EBF9FF;
	color: var(--bleu) !important;
	z-index: 2;
}




.view-toggle button.active:hover {
	background: #fff;
	color: var(--bleu) !important;
}

.tabs-switcher {
	display: flex;
	gap: 8px;
	margin-bottom: 20px;
}

.tabs-switcher button {
	padding: 8px 16px;
	border: 1px solid #ccc;
	background: #f5f5f5;
	color: #333;
	border-radius: 4px;
	font-weight: 500;
	cursor: pointer;
	transition: background 0.2s;
}

.tabs-switcher button.active {
	background-color: #d4ecf7;
	border-color: #a4d3eb;
	color: #007cba;
}

.tabs-switcher button .dashicons {
	margin-right: 6px;
	font-size: 16px;
	vertical-align: middle;
}
.filter-checkboxes{
	display: none;
}


.gm-style-iw.gm-style-iw-c{
	min-width: 16.75rem !important;
}

/* Ou plus spécifique pour votre carte */
#map-container-<?php echo $map_id; ?> .gm-style-iw.gm-style-iw-c{
	min-width: 16.75rem !important;
}

.multipleLocations{
	margin-bottom: 0!important;
	font-family: var(--font-family);
	color: var(--vert);
	font-size: 0.6rem;
	line-height: 1;
	padding: 0 0.45rem;
}

.toggle-icon svg{
	max-width:  0.75rem;
}
/*Map et list card end*/