/* --- STYLES POUR LE FOOTER DE INDEX.HTML (HÉRITÉ DE AFRICA.HTML) --- */

/* --- STYLES POUR LES ICÔNES SOCIALES --- */
.elementor-element-7dcf136 .elementor-element {
	margin: 0 !important;
	padding: 0 !important;
}

.elementor-element-fa10d37,
.elementor-element-c4ca1c8,
.elementor-element-a7d0713,
.elementor-element-0a28e8d,
.elementor-element-ab3a18e,
.elementor-element-whatsapp {
	margin: 0 !important;
	padding: 0 !important;
	flex-grow: 0;
	flex-shrink: 0;
}

.elementor-element-fa10d37 .elementor-widget-container,
.elementor-element-c4ca1c8 .elementor-widget-container,
.elementor-element-a7d0713 .elementor-widget-container,
.elementor-element-0a28e8d .elementor-widget-container,
.elementor-element-ab3a18e .elementor-widget-container,
.elementor-element-whatsapp .elementor-widget-container {
	margin: 0 !important;
	padding: 0 !important;
}

/* --- STYLES POUR LES EFFETS HOVER DES BOUTONS SOCIAUX --- */
.elementor-element-fa10d37 a:hover,
.elementor-element-c4ca1c8 a:hover,
.elementor-element-a7d0713 a:hover,
.elementor-element-0a28e8d a:hover,
.elementor-element-ab3a18e a:hover,
.elementor-element-whatsapp a:hover {
	transform: translateY(-2px) !important;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
	opacity: 0.9 !important;
}

/* --- STYLES POUR L'ALIGNEMENT DU FOOTER --- */
/* Aligner les titres CONTACT US et LINKS avec leur contenu */
.elementor-element-f055c35 .qodef-m-title,
.elementor-element-d726f80 .qodef-m-title,
.elementor-element-701fde8 .qodef-m-title {
	text-align: left !important;
	margin-left: 0 !important;
	padding-left: 0 !important;
	font-weight: 300 !important;
	font-family: 'Onest', sans-serif !important;
	font-size: 18px !important;
}

/* Titre MISSION & VISION à gauche */
.elementor-element-9678fe9 .qodef-m-title {
	text-align: left !important;
	margin-left: 0 !important;
	padding-left: 0 !important;
	font-weight: 300 !important;
	font-family: 'Onest', sans-serif !important;
	font-size: 18px !important;
}

/* Aligner le titre MISSION & VISION à gauche */
.elementor-element-9678fe9 .qodef-m-title {
	text-align: left !important;
	margin-left: 0 !important;
	padding-left: 0 !important;
}

/* S'assurer que les conteneurs des titres sont alignés à gauche */
.elementor-element-f055c35 .elementor-widget-container,
.elementor-element-d726f80 .elementor-widget-container,
.elementor-element-701fde8 .elementor-widget-container,
.elementor-element-9678fe9 .elementor-widget-container {
	text-align: left !important;
}

/* Aligner spécifiquement les mots animés */
.elementor-element-f055c35 .qodef-e-word,
.elementor-element-d726f80 .qodef-e-word,
.elementor-element-701fde8 .qodef-e-word,
.elementor-element-9678fe9 .qodef-e-word {
	text-align: left !important;
	display: inline-block !important;
}

/* --- STYLES POUR LA COHÉRENCE DES COULEURS DES PROJETS --- */
/* Assurer que tous les éléments de projet dans le footer sont blancs */
.elementor-element-13e222f .elementor-heading-title,
.elementor-element-421a564 .elementor-heading-title,
.elementor-element-b8c769d .elementor-heading-title,
.elementor-element-0a2435e .elementor-heading-title,
.elementor-element-0541d16 .elementor-heading-title,
.elementor-element-heritage .elementor-heading-title,
.elementor-element-interior .elementor-heading-title,
.elementor-element-landscape .elementor-heading-title,
.elementor-element-strategy .elementor-heading-title {
	color: #ffffff !important;
	transition: color 0.3s ease !important;
	font-size: 16px !important;
	font-weight: 300 !important;
	font-family: 'Jost', sans-serif !important;
}

/* Effet hover cohérent pour tous les éléments de projet - reste blanc */
.elementor-element-13e222f .elementor-heading-title a,
.elementor-element-421a564 .elementor-heading-title a,
.elementor-element-b8c769d .elementor-heading-title a,
.elementor-element-0a2435e .elementor-heading-title a,
.elementor-element-0541d16 .elementor-heading-title a,
.elementor-element-heritage .elementor-heading-title a,
.elementor-element-interior .elementor-heading-title a,
.elementor-element-landscape .elementor-heading-title a,
.elementor-element-strategy .elementor-heading-title a,
.elementor-element-13e222f .elementor-heading-title a:hover,
.elementor-element-421a564 .elementor-heading-title a:hover,
.elementor-element-b8c769d .elementor-heading-title a:hover,
.elementor-element-0a2435e .elementor-heading-title a:hover,
.elementor-element-0541d16 .elementor-heading-title a:hover,
.elementor-element-heritage .elementor-heading-title a:hover,
.elementor-element-interior .elementor-heading-title a:hover,
.elementor-element-landscape .elementor-heading-title a:hover,
.elementor-element-strategy .elementor-heading-title a:hover {
	color: #ffffff !important;
	text-decoration: none !important;
	font-weight: 300 !important;
	font-size: 16px !important;
	font-family: 'Jost', sans-serif !important;
}

/* --- ESPACEMENTS POUR LES ÉLÉMENTS DE PROJET --- */
/* Ajouter des marges entre les éléments de projet */
.elementor-element-heritage,
.elementor-element-interior,
.elementor-element-landscape,
.elementor-element-strategy {
	margin-top: 8px !important;
	margin-bottom: 3px !important;
}

/* Espacement général pour tous les éléments de projet */
.elementor-element-13e222f,
.elementor-element-421a564,
.elementor-element-b8c769d,
.elementor-element-0a2435e,
.elementor-element-0541d16,
.elementor-element-heritage,
.elementor-element-interior,
.elementor-element-landscape,
.elementor-element-strategy {
	margin-bottom: 6px !important;
}

/* --- STYLES POUR LA COHÉRENCE DES LIENS DANS LA SECTION LINKS --- */
/* Assurer que tous les liens dans la section LINKS sont blancs */
.elementor-element-74f5361 .elementor-heading-title a,
.elementor-element-16b69b6 .elementor-heading-title a,
.elementor-element-e90a0d1 .elementor-heading-title a,
.elementor-element-0c21dbe .elementor-heading-title a,
.elementor-element-rise-link .elementor-heading-title a,
.elementor-element-social-link .elementor-heading-title a,
.elementor-element-project-link .elementor-heading-title a,
.elementor-element-news-link .elementor-heading-title a,
.elementor-element-contact-link .elementor-heading-title a {
	color: #ffffff !important;
	text-decoration: none !important;
	transition: color 0.3s ease !important;
	font-weight: 300 !important;
	font-size: 16px !important;
	font-family: 'Jost', sans-serif !important;
}

/* Effet hover cohérent pour tous les liens - reste blanc */
.elementor-element-74f5361 .elementor-heading-title a:hover,
.elementor-element-16b69b6 .elementor-heading-title a:hover,
.elementor-element-e90a0d1 .elementor-heading-title a:hover,
.elementor-element-0c21dbe .elementor-heading-title a:hover,
.elementor-element-rise-link .elementor-heading-title a:hover,
.elementor-element-social-link .elementor-heading-title a:hover,
.elementor-element-project-link .elementor-heading-title a:hover,
.elementor-element-news-link .elementor-heading-title a:hover,
.elementor-element-contact-link .elementor-heading-title a:hover {
	color: #ffffff !important;
	text-decoration: none !important;
}

/* Espacements pour les éléments de liens */
.elementor-element-rise-link,
.elementor-element-social-link,
.elementor-element-project-link,
.elementor-element-news-link,
.elementor-element-contact-link {
	margin-top: 8px !important;
	margin-bottom: 3px !important;
}

/* --- STYLES POUR LE FOOTER --- */
/* Footer avec background noir comme le header */
.site-footer {
	background-color: #000000 !important;
	width: 100%;
	margin-top: auto !important;
	padding: 0 !important;
}

.site-footer .site-info {
	background-color: #000000 !important;
	color: #ffffff !important;
	padding: 15px 0;
	text-align: center;
	margin: 0 !important;
}

/* S'assurer que le texte dans le footer reste blanc */
.site-footer .site-info p,
.site-footer .site-info a {
	color: #ffffff !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* S'assurer que le footer principal reste en bas */
.elementor-element-906e93d {
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

/* Conteneur principal du footer */
.elementor-element-7dcf136 {
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

/* S'assurer qu'il n'y a pas d'espace blanc en bas */
html,
body {
	margin: 0 !important;
	padding: 0 !important;
}

/* Conteneur principal de la page */
#page {
	margin: 0 !important;
	padding: 0 !important;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

/* S'assurer que le contenu principal pousse le footer en bas */
.elementor {
	flex: 1 0 auto;
}

/* Supprimer tout padding/margin indésirable */
* {
	box-sizing: border-box;
}

/* --- STYLES POUR LA SECTION PROJECTS / WORKS --- */
.elementor-element-70ef4311 {
	width: 100% !important;
	max-width: 100% !important;
	overflow-x: hidden !important;
}

.elementor-element-6ea4c584 {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

/* Forcer le conteneur du carrousel à être full-width */
.elementor-element-537e2745 {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

.elementor-element-537e2745 .elementor-widget-container {
	padding: 0 !important;
	margin: 0 !important;
}

/* Titre WORKS - noir comme les autres titres */
.elementor-element-6bfbc4ca .qodef-m-title {
	font-size: 10vw !important;
	line-height: 1 !important;
	margin: 0 !important;
	color: #000000 !important;
	opacity: 1 !important;
}

/* Espacement avant le carrousel */
.elementor-element-6ea4c584 {
	margin-top: 60px !important;
}

/* Ajustements Responsive Mobile */
@media (max-width: 768px) {
	.elementor-element-70ef4311 {
		padding: 0 !important;
	}

	.elementor-element-413d310b .e-con-inner {
		padding: 0 20px !important;
	}

	.elementor-element-6bfbc4ca .qodef-m-title {
		font-size: 60px !important;
		margin-top: 10px !important;
		color: #000000 !important;
		opacity: 1 !important;
	}

	/* Espacement mobile avant le carrousel */
	.elementor-element-6ea4c584 {
		margin-top: 40px !important;
	}

	.elementor-element-713c0149 .elementor-heading-title {
		font-size: 18px !important;
		line-height: 1.4 !important;
	}

	.elementor-element-fbd58c0 {
		margin-top: 20px !important;
	}

	/* Carousel height on mobile */
	.elementor-element-537e2745 .bdt-prime-slider-skin-coral {
		height: 550px !important;
		/* Increase height slightly for better fit */
	}

	.elementor-element-537e2745 .bdt-slideshow-items {
		height: 550px !important;
	}

	.elementor-element-537e2745 .bdt-ps-slide-img {
		height: 550px !important;
	}

	/* Navigation arrows fix - ensure they are in the center right within the carousel */
	.elementor-element-537e2745 .bdt-navigation-arrows {
		position: absolute !important;
		top: 50% !important;
		right: 15px !important;
		left: auto !important;
		transform: translateY(-50%) !important;
		display: flex !important;
		flex-direction: column !important;
		gap: 15px !important;
		z-index: 1000 !important;
		opacity: 1 !important;
		visibility: visible !important;
		width: auto !important;
		height: auto !important;
	}

	.elementor-element-537e2745 .bdt-prime-slider-previous,
	.elementor-element-537e2745 .bdt-prime-slider-next {
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 40px !important;
		height: 40px !important;
		background-color: transparent !important;
		backdrop-filter: none !important;
		border: 1px solid rgba(255, 255, 255, 0.3) !important;
		border-radius: 4px !important;
		position: static !important;
		margin: 0 !important;
		transition: background-color 0.3s ease, border-color 0.3s ease !important;
		animation: none !important;
		/* Remove any plugin animations */
		transform: none !important;
		/* Ensure no parallax or hover shifts */
	}

	.elementor-element-537e2745 .bdt-prime-slider-previous:hover,
	.elementor-element-537e2745 .bdt-prime-slider-next:hover,
	.elementor-element-537e2745 .bdt-prime-slider-previous:active,
	.elementor-element-537e2745 .bdt-prime-slider-next:active {
		background-color: rgba(255, 255, 255, 0.2) !important;
		border-color: rgba(255, 255, 255, 0.8) !important;
		transform: none !important;
		/* Maintain static position on hover */
	}



	/* Force visibility of arrow icons if they are SVGs inside */
	.elementor-element-537e2745 .bdt-navigation-arrows a::before,
	.elementor-element-537e2745 .bdt-navigation-arrows a::after {
		color: #ffffff !important;
	}

	/* Read More button fix */
	.elementor-element-537e2745 .bdt-slideshow-content-wrapper {
		height: 100% !important;
		display: flex !important;
		flex-direction: column !important;
		justify-content: center !important;
		padding: 0 40px 0 20px !important;
	}

	.elementor-element-537e2745 .bdt-prime-slider-content {
		width: 100% !important;
		padding: 0 !important;
		margin: 0 !important;
	}

	.elementor-element-537e2745 .bdt-coral-btn {
		margin-top: 30px !important;
		display: inline-block !important;
		transform: none !important;
		/* Disable problematic parallax on mobile */
		opacity: 1 !important;
		visibility: visible !important;
	}

	.elementor-element-537e2745 .bdt-slide-btn {
		display: inline-flex !important;
		align-items: center !important;
		background: #ffffff !important;
		padding: 12px 24px !important;
		border-radius: 0 !important;
		text-transform: uppercase !important;
		font-weight: 600 !important;
		font-size: 14px !important;
		color: #000000 !important;
		box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3) !important;
		width: auto !important;
		height: auto !important;
	}

	.elementor-element-537e2745 .bdt-prime-slider-button-text {
		color: #000000 !important;
	}

	/* Titre du carrousel mobile */
	.elementor-element-537e2745 .bdt-title-tag {
		font-size: 28px !important;
		line-height: 1.2 !important;
		margin-bottom: 10px !important;
	}
}

@media (max-width: 480px) {
	.elementor-element-6bfbc4ca .qodef-m-title {
		font-size: 50px !important;
		color: #000000 !important;
		opacity: 1 !important;
	}

	.elementor-element-713c0149 .elementor-heading-title {
		font-size: 16px !important;
	}
}

/* --- AJUSTEMENT POSITION LOGO HEADER MOBILE (SANS SCROLL) --- */
/* --- AJUSTEMENT POSITION LOGO HEADER (TABLETTE GÉNÉRALE) --- */
@media screen and (min-width: 851px) and (max-width: 991px) {

	#masthead .logo-image,
	#masthead .site-header:not(.clone) .logo-image,
	#masthead .site-header.clone .logo-image {
		transform: translateX(-120px) translateY(-3px) !important;
	}
}

/* --- AJUSTEMENT POSITION LOGO HEADER MOBILE (< 768px) --- */
@media screen and (max-width: 768px) {

	/* Monter de 4px (Target: -7px) with high specificity */
	#masthead .logo-image,
	#masthead .site-header:not(.clone) .logo-image,
	#masthead .site-header.clone .logo-image {
		transform: translateX(-120px) translateY(-1px) !important;
	}
}

@media screen and (max-width: 480px) {

	#masthead .logo-image,
	#masthead .site-header:not(.clone) .logo-image,
	#masthead .site-header.clone .logo-image {
		transform: translateX(-70px) translateY(-1px) !important;
	}
}

/* === FIX ISOLÉ iPAD AIR 5 (769px - 850px) === */
@media screen and (min-width: 769px) and (max-width: 850px) {

	/* SUPER HAUTE SPÉCIFICITÉ ID */
	#masthead .logo-image,
	#masthead .site-header:not(.clone) .logo-image,
	#masthead .site-header.clone .logo-image {
		transform: translateX(-70px) translateY(-13px) !important;
		margin-top: 0 !important;
		max-width: 85% !important;
	}
}

/* --- FOOTER LOGO ALIGNMENT (MOBILE) --- */
@media screen and (max-width: 768px) {

	/* Force left alignment for the footer logo container */
	.elementor-element-a3c724e {
		align-items: flex-start !important;
		justify-content: flex-start !important;
		text-align: left !important;
	}

	.footer-logo-wrapper {
		text-align: left !important;
		margin-left: 0 !important;
		padding-left: 0 !important;
		display: block !important;
		width: 100% !important;
	}

	.footer-logo-wrapper img {
		margin-left: 0 !important;
		margin-right: auto !important;
		display: block !important;
	}
}


/* --- ALIGNEMENT CONTENU BAS DE PAGE MOBILE (Social & Copyright) --- */
@media screen and (max-width: 768px) {

	/* Aligner les icônes sociales à gauche */
	.elementor-element-7dcf136 {
		justify-content: flex-start !important;
		padding-left: 0 !important;
	}

	/* Aligner le copyright à gauche */
	.site-footer .site-info {
		text-align: left !important;
		padding-left: 20px !important;
	}

	/* Assurer l'alignement à gauche des conteneurs parents */
	.elementor-element-af5edb2,
	.elementor-element-a3c724e {
		align-items: flex-start !important;
		text-align: left !important;
	}
}