/* =========================================================================
   css/pages/aboutus/main.css
   About Us page overrides — page-specific header, menu and mobile fixes.
   Keep this file focused on aboutus-only adjustments.
   ========================================================================= */

/* -------------------------------------------------------------------------
   ABOUT US HEADER + CURRENT MENU ITEM
   ------------------------------------------------------------------------- */

/* "About Us" current menu item stays black on desktop and scroll states */
.site-header .nav-menu .current-menu-item a,
.site-header.clone .nav-menu .current-menu-item a {
	color: #000000 !important;
}

.site-header .nav-menu .current-menu-item a:hover,
.site-header.clone .nav-menu .current-menu-item a:hover {
	color: #000000 !important;
}

/* -------------------------------------------------------------------------
   ABOUT US LANGUAGE BUTTON
   ------------------------------------------------------------------------- */

.aboutus-language-btn,
.aboutus-language-btn:hover,
.aboutus-language-btn.active,
.aboutus-language-btn:focus,
.aboutus-language-btn:active,
#language-btn.aboutus-language-btn {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	color: #ffffff !important;
	font-weight: bold !important;
	font-size: 14px !important;
	padding: 8px 16px !important;
	cursor: pointer !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	min-width: 40px !important;
	text-align: center !important;
	white-space: nowrap !important;
	display: inline-block !important;
	vertical-align: middle !important;
	line-height: 1 !important;
}

.aboutus-language-btn .lang-part,
.menu-item-language .lang-part {
	opacity: 0.6;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.aboutus-language-btn .lang-part.active,
.menu-item-language .lang-part.active {
	opacity: 1;
	color: #d4af37;
	font-weight: 700;
}

.aboutus-language-btn .lang-sep,
.menu-item-language .lang-sep {
	display: inline-block;
	margin: 0 8px;
	opacity: 0.6;
}

#language-btn.aboutus-language-btn {
	position: relative !important;
	z-index: 1 !important;
}

#language-btn.aboutus-language-btn .lang-part {
	display: inline !important;
	visibility: visible !important;
	opacity: 1 !important;
	width: auto !important;
	height: auto !important;
	padding: initial !important;
}

#language-btn.aboutus-language-btn .lang-sep {
	display: inline-block !important;
	visibility: visible !important;
	opacity: 1 !important;
	width: auto !important;
	height: auto !important;
	margin: 0 8px !important;
	padding: 0 !important;
}

.aboutus-language-btn::before,
.aboutus-language-btn::after,
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep),
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep)::before,
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep)::after {
	content: none !important;
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: none !important;
	background-image: none !important;
}

/* S'assurer que le logo reste blanc (car c'est logoblanc.png) */

/* ============================================================
   === MOBILE-ONLY logo layout — mirrors service/index.html ===
   === Desktop is intentionally UNTOUCHED (theme defaults).  ===
   ============================================================ */
@media screen and (max-width: 991px) {

	/* Foundation flex layout for the logo container (mobile only) */
	.site-branding-wrap {
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
		width: 100% !important;
	}

	.site-branding-center {
		text-align: center !important;
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
		flex: 1 !important;
	}

	.site-title a {
		display: flex !important;
		justify-content: center !important;
		align-items: center !important;
		text-decoration: none !important;
	}

	/* Logo: centré en mobile pour header non scrollé */
	.site-header:not(.clone) .site-title img {
		width: auto !important;
		display: block !important;
		margin: 0 auto !important;
		transform: translateY(-3px) !important;
	}

	/* Logo en mode scroll (clone) : centré, pas de translate */
	.site-header.clone .site-title img {
		width: auto !important;
		display: block !important;
		margin: 0 auto !important;
		transform: none !important;
	}

	/* Taille finale 30px (override de la règle générique du thème plus bas) */
	.site-header .logo-image,
	.site-header.clone .logo-image,
	.site-header .site-title img,
	.site-header.clone .site-title img {
		max-height: 30px !important;
	}
}

.aboutus-language-btn:hover {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	color: #ffffff !important;
	transform: none !important;
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
}

.aboutus-language-btn.active {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	color: #ffffff !important;
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
}

.aboutus-language-btn:focus {
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
}

.aboutus-language-btn:active {
	border: none !important;
	border-width: 0 !important;
}

/* -------------------------------------------------------------------------
   ABOUT US MENU BUTTON + HEADER LAYOUT
   ------------------------------------------------------------------------- */
.menu-toggle {
	order: 1 !important;
	margin-left: auto !important;
}

.nav-menu {
	order: 2 !important;
}

.language-switcher {
	order: 3 !important;
}

/* -------------------------------------------------------------------------
   MENU OPEN STATE HEADER + HAMBURGER COLORS
   ------------------------------------------------------------------------- */
.is-menu-toggled-on .site-header:not(.clone) .header-wrap:before {
	background: #000000 !important;
	opacity: 1 !important;
}

/* -------------------------------------------------------------------------
   HAMBURGER ICON OPEN STATE
   ------------------------------------------------------------------------- */
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
	background-color: #ffffff !important;
}

/* Isolation complète de l'animation du hamburger - ne s'applique qu'au bouton */

.is-menu-toggled-on .menu-toggle .lines {
	/* Animation spécifique au hamburger uniquement */
	background-color: transparent !important;
}

.is-menu-toggled-on .menu-toggle .lines:before {
	/* Animation spécifique au hamburger uniquement */
	top: 0 !important;
	transform: rotate(45deg) !important;
	background-color: #ffffff !important;
}

.is-menu-toggled-on .menu-toggle .lines:after {
	/* Animation spécifique au hamburger uniquement */
	bottom: 0 !important;
	transform: rotate(-45deg) !important;
	background-color: #ffffff !important;
}

/* Styles pour le language switcher quand le menu est ouvert */
.is-menu-toggled-on .site-header:not(.clone) .aboutus-language-btn {
	color: #ffffff !important;
}

.is-menu-toggled-on .site-header:not(.clone) .aboutus-language-btn:hover {
	color: #ffffff !important;
}

/* S'assurer que le header reste noir quand le menu est ouvert, même en mode scroll */
.is-menu-toggled-on .site-header.clone .header-wrap:before {
	background: #000000 !important;
	opacity: 1 !important;
}

/* Styles pour le hamburger en mode scroll quand le menu est ouvert */
.is-menu-toggled-on .site-header.clone .menu-toggle .lines,
.is-menu-toggled-on .site-header.clone .menu-toggle .lines:before,
.is-menu-toggled-on .site-header.clone .menu-toggle .lines:after {
	background-color: #ffffff !important;
}

/* S'assurer que le menu lui-même n'est pas affecté par l'animation du hamburger */
.is-menu-toggled-on .nav-menu {
	/* Le menu garde son comportement normal */
	display: block !important;
}

.is-menu-toggled-on .nav-menu ul {
	/* La liste du menu garde son comportement normal */
	display: block !important;
}

.is-menu-toggled-on .nav-menu li {
	/* Les éléments du menu gardent leur comportement normal */
	display: block !important;
}

.is-menu-toggled-on .nav-menu a {
	/* Les liens du menu gardent leur comportement normal */
	display: block !important;
}

/* Styles de base pour le hamburger - Adapté de l'exemple */
.menu-toggle {
	position: relative;
	cursor: pointer;
	z-index: 1000;
	display: block;
	width: 30px;
	height: 30px;
}

.menu-toggle .lines {
	display: block;
	width: 25px;
	height: 2px;
	background-color: #ffffff;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: all 0.3s ease;
}

.menu-toggle .lines:before,
.menu-toggle .lines:after {
	content: '';
	position: absolute;
	width: 25px;
	height: 2px;
	background-color: #ffffff;
	transition: all 0.3s ease;
}

.menu-toggle .lines:before {
	top: -8px;
}

.menu-toggle .lines:after {
	bottom: -8px;
}

/* Burger Animation to X */
.is-menu-toggled-on .menu-toggle .lines {
	background-color: transparent !important;
}

.is-menu-toggled-on .menu-toggle .lines:before {
	top: 0 !important;
	transform: rotate(45deg) !important;
	background-color: #ffffff !important;
	position: absolute !important;
	z-index: 10530 !important;
	width: 28px !important;
	display: block !important;
}

.is-menu-toggled-on .menu-toggle .lines:after {
	bottom: 0 !important;
	transform: rotate(-45deg) !important;
	background-color: #ffffff !important;
	position: absolute !important;
	z-index: 10530 !important;
	width: 28px !important;
	display: block !important;
}

/* FIX CONFLICTS MOBILE MENU - Raising Header Above Drawer */
.is-menu-toggled-on .site-header {
	z-index: 10500 !important;
}

.is-menu-toggled-on .site-header .site-branding {
	position: fixed !important;
	top: 15px !important;
	left: 20px !important;
	transform: none !important;
	z-index: 10510 !important;
	pointer-events: none !important;
	display: flex !important;
	justify-content: flex-start !important;
	width: auto !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.is-menu-toggled-on .site-header .site-branding-wrap {
	width: auto !important;
}

.is-menu-toggled-on .site-header .site-branding-center {
	justify-content: flex-start !important;
}

.is-menu-toggled-on .site-header .site-branding a {
	pointer-events: auto !important;
	display: block !important;
}

.is-menu-toggled-on .menu-toggle {
	z-index: 10520 !important;
	position: fixed !important;
	top: 10px !important;
	right: 15px !important;
	left: auto !important;
	margin: 0 !important;
}

.is-menu-toggled-on .site-header.clone .menu-toggle {
	z-index: 10520 !important;
	position: fixed !important;
	top: 10px !important;
	right: 15px !important;
	left: auto !important;
	margin: 0 !important;
}

/* -------------------------------------------------------------------------
   LANGUAGE BUTTON PSEUDO-ELEMENT CLEANUP
   ------------------------------------------------------------------------- */
.aboutus-language-btn::before,
.aboutus-language-btn::after {
	content: none !important;
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: none !important;
	background-image: none !important;
}

/* -------------------------------------------------------------------------
   LANGUAGE BUTTON FORCE OVERRIDES
   ------------------------------------------------------------------------- */
.aboutus-language-btn,
.aboutus-language-btn:hover,
.aboutus-language-btn:focus,
.aboutus-language-btn:active,
.aboutus-language-btn.active,
.aboutus-language-btn::before,
.aboutus-language-btn::after {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
}

/* Styles ultra-spécifiques pour éliminer tout élément perturbateur */
#language-btn.aboutus-language-btn {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-width: 0 !important;
	border-style: none !important;
	border-color: transparent !important;
	outline: none !important;
	outline-width: 0 !important;
	box-shadow: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-webkit-border-radius: 0 !important;
	-moz-border-radius: 0 !important;
	border-radius: 0 !important;
	-webkit-appearance: none !important;
	-moz-appearance: none !important;
	appearance: none !important;
	position: relative !important;
	z-index: 1 !important;
}

/* Supprimer tous les éléments enfants qui pourraient causer des icônes */
/* Masquer les éléments décoratifs éventuels, mais préserver les parties EN/FR */
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep),
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep)::before,
#language-btn.aboutus-language-btn *:not(.lang-part):not(.lang-sep)::after {
	content: none !important;
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	width: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	background: none !important;
	background-image: none !important;
}

/* Réactiver explicitement l'affichage pour EN/FR et le séparateur */
#language-btn.aboutus-language-btn .lang-part {
	display: inline !important;
	visibility: visible !important;
	opacity: 1 !important;
	width: auto !important;
	height: auto !important;
	padding: initial !important;
}

#language-btn.aboutus-language-btn .lang-sep {
	display: inline-block !important;
	visibility: visible !important;
	opacity: 1 !important;
	width: auto !important;
	height: auto !important;
	margin: 0 8px !important;
	/* enforce spacing */
	padding: 0 !important;
}

/* -------------------------------------------------------------------------
   LANGUAGE BUTTON TEXT + LAYOUT ENFORCEMENT
   ------------------------------------------------------------------------- */
#language-btn.aboutus-language-btn {
	color: #ffffff !important;
	font-weight: bold !important;
	font-size: 14px !important;
	padding: 8px 16px !important;
	cursor: pointer !important;
	text-transform: uppercase !important;
	letter-spacing: 1px !important;
	min-width: 40px !important;
	text-align: center !important;
	white-space: nowrap !important;
	display: inline-block !important;
	vertical-align: middle !important;
	line-height: 1 !important;
}

/* -------------------------------------------------------------------------
   HEADER RIGHT-SIDE POSITIONING
   ------------------------------------------------------------------------- */
.layout-medium {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
}

.nav-menu {
	flex: 1;
	display: flex;
	justify-content: center;
}

.language-switcher {
	flex-shrink: 0;
}

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

	/* === Mobile header layout — mirror service/index.html === */
	/* Centrage vertical du header-wrap-inner */
	.site-header .header-wrap-inner {
		display: flex !important;
		align-items: center !important;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
	}

	/* Centrage vertical du site-branding (parent du logo) */
	.site-header .site-branding {
		display: flex !important;
		align-items: center !important;
	}

	/* Menu burger à droite, taille 30x30 (identique service) */
	.menu-toggle {
		height: 30px !important;
		width: 30px !important;
		display: block !important;
		order: 1 !important;
		margin-left: auto !important;
	}

	/* Menu-wrap en flex + min-height = 56px pour aligner verticalement */
	.menu-wrap {
		padding-top: 0 !important;
		padding-bottom: 0 !important;
		min-height: 56px !important;
		display: flex !important;
		align-items: center !important;
	}

	/* Layout-medium en flex space-between sur toute la largeur */
	.layout-medium {
		display: flex !important;
		align-items: center !important;
		justify-content: space-between !important;
		width: 100% !important;
	}

	.language-switcher {
		margin-left: 10px;
	}

	.aboutus-language-btn {
		font-size: 12px !important;
		padding: 6px 12px !important;
		min-width: 35px !important;
	}

	/* Masquer le language switcher sur mobile et afficher l'option dans le menu */
	.language-switcher {
		display: none !important;
	}

	.menu-item-language {
		display: block !important;
	}

	/* Styles pour le texte du header en mobile - Texte blanc pour être visible */
	.site-header:not(.clone) .nav-menu a,
	.site-header:not(.clone) .menu-toggle .lines,
	.site-header:not(.clone) .menu-toggle .lines:before,
	.site-header:not(.clone) .menu-toggle .lines:after {
		color: #ffffff !important;
	}

	.site-header:not(.clone) .menu-toggle .lines,
	.site-header:not(.clone) .menu-toggle .lines:before,
	.site-header:not(.clone) .menu-toggle .lines:after {
		background-color: #ffffff !important;
	}

	/* Quand le menu est ouvert en mobile - Texte blanc */
	.is-menu-toggled-on .site-header:not(.clone) .nav-menu a,
	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
		color: #ffffff !important;
	}

	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines,
	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:before,
	.is-menu-toggled-on .site-header:not(.clone) .menu-toggle .lines:after {
		background-color: #ffffff !important;
	}

	/* Animation d'entrée du menu - slide depuis la droite */
	.nav-menu {
		transform: translateX(100%);
		transition: transform 0.3s ease-in-out;
	}

	.is-menu-toggled-on .nav-menu {
		transform: translateX(0);
	}

	/* Styles pour le menu mobile quand il est ouvert - Plein écran noir */
	.is-menu-toggled-on .nav-menu {
		position: fixed !important;
		top: 0 !important;
		right: 0 !important;
		width: 100% !important;
		height: 100vh !important;
		background: #000000 !important;
		display: flex !important;
		flex-direction: column !important;
		align-items: flex-start !important;
		justify-content: flex-start !important;
		padding-top: 140px !important;
		z-index: 10100 !important;
		transform: translateX(0) !important;
		transition: transform 0.3s ease !important;
		overflow-y: auto !important;
		-webkit-overflow-scrolling: touch !important;
	}

	.is-menu-toggled-on .nav-menu ul {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		gap: 0 !important;
		padding: 0 40px;
		width: 100%;
	}

	.is-menu-toggled-on .nav-menu li {
		display: block;
		width: 100%;
	}

	.is-menu-toggled-on .nav-menu a {
		color: #ffffff !important;
		font-size: 20px !important;
		font-weight: 500 !important;
		text-transform: uppercase !important;
		letter-spacing: 2px !important;
		text-decoration: none;
		transition: all 0.3s ease;
		display: block;
		padding: 22px 0 !important;
		border-bottom: 1px solid #ffffff !important;
	}

	.is-menu-toggled-on .nav-menu .current-menu-item a {
		color: #ffffff !important;
	}

	.is-menu-toggled-on .nav-menu a:hover {
		color: #ffffff !important;
		opacity: 0.8;
		padding-left: 10px;
	}

	/* Style spécial pour l'élément language dans le menu */
	.is-menu-toggled-on .menu-item-language a {
		border-bottom: none;
		font-weight: 600;
		color: #cccccc !important;
	}

	/* Animation des éléments du menu - apparition progressive */
	.is-menu-toggled-on .nav-menu li {
		opacity: 0;
		transform: translateX(20px);
		animation: slideInMenu 0.3s ease forwards;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(1) {
		animation-delay: 0.1s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(2) {
		animation-delay: 0.2s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(3) {
		animation-delay: 0.3s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(4) {
		animation-delay: 0.4s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(5) {
		animation-delay: 0.5s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(6) {
		animation-delay: 0.6s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(7) {
		animation-delay: 0.7s;
	}

	.is-menu-toggled-on .nav-menu li:nth-child(8) {
		animation-delay: 0.8s;
	}

	@keyframes slideInMenu {
		to {
			opacity: 1;
			transform: translateX(0);
		}
	}
}

/* -------------------------------------------------------------------------
   DESKTOP LANGUAGE SWITCHER BEHAVIOR
   ------------------------------------------------------------------------- */
@media screen and (min-width: 992px) {
	.language-switcher {
		display: flex !important;
	}

	.menu-item-language {
		display: none !important;
	}
}
