/* ================= BASE ================= */

/* Forcer Elementor à respecter le UI Kit */

.elementor-widget-heading h1.elementor-heading-title,
.elementor-widget-heading h2.elementor-heading-title,
.elementor-widget-heading h3.elementor-heading-title,
.elementor-widget-heading h4.elementor-heading-title,
.elementor-widget-heading h5.elementor-heading-title,
.elementor-widget-heading h6.elementor-heading-title
 {
	font-family: "Plus Jakarta Sans", sans-serif !important;
	/* font-size: unset !important; */
	font-weight: 400 !important;
	/* line-height: unset !important; */
}

.elementor-widget-heading h1.elementor-heading-title { font-size: 4rem !important; line-height: 4.5rem !important; }
.elementor-widget-heading h2.elementor-heading-title { font-size: 3rem !important; line-height: 3.625rem !important; }
.elementor-widget-heading h3.elementor-heading-title { font-size: 2rem !important; line-height: 2.313rem !important; text-transform: uppercase !important; }
.elementor-widget-heading h4.elementor-heading-title { font-size: 1.5rem !important; line-height: 1.75rem !important; }
.elementor-widget-heading h5.elementor-heading-title { font-size: 1.2rem !important; line-height: 1.375rem !important; }
.elementor-widget-heading h6.elementor-heading-title { font-size: 1rem !important; font-weight: 500 !important; line-height: 1.375rem !important; }

h1.elementor-heading-title { margin-bottom: 2rem; }
h2.elementor-heading-title { margin-bottom: 1.5rem; }
h3.elementor-heading-title { margin-bottom: 1rem; }
h4.elementor-heading-title { margin-bottom: 1rem; }
h5.elementor-heading-title { margin-bottom: 1rem; }
h6.elementor-heading-title { margin-bottom: 1rem; }

.inner-section {
	padding-top: 3.5rem !important;
	padding-bottom: 3.5rem !important;
}

.inner-section {
  transition-property: opacity !important;
  transition-duration: 1.2s !important;
  transition-timing-function: ease-in-out !important;
  transition-delay: 0.0s !important; /* <-- ton delay ici */
}

.inner-section.is-pre { opacity: 0; }
.inner-section.is-in  { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .inner-section { transition: none !important; }
  .inner-section.is-pre, .inner-section.is-in { opacity: 1 !important; }
}

.inner-section.e-con > .e-con-inner {
	gap: 1rem 3rem;
}

.elementor-widget-text-editor + .elementor-widget-heading h2 {
	margin-top: 2rem;
}

.column-gap {
	gap: 3rem !important;
}


.rounded,
.rounded-img img {
	border-radius: 0.75rem !important;
}

/*.elementor-widget-button .elementor-button {
	background-color: inherit !important;
}*/

.btn-primary .elementor-button,
#btn-primary.elementor-button,
.btn-primary-alt .elementor-button,
#btn-primary-alt.elementor-button,
.btn-secondary .elementor-button,
.btn-secondary-alt .elementor-button,
#btn-secondary-alt.elementor-button {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;

	padding: 1rem 1rem;
	border-radius: 1rem;
	overflow: hidden;

	background-color: none;
	border: none;
	text-decoration: none;
	font-size: 1.1rem;
	font-weight: 600;
	line-height: 1;
	cursor: pointer;

	transition: all 0.3s ease;
}

/* Neutralise le style interne Elementor */
.btn-primary .elementor-button-content-wrapper,
#btn-primary .elementor-button-content-wrapper,
.btn-primary-alt .elementor-button-content-wrapper,
#btn-primary-alt .elementor-button-content-wrapper,
.btn-secondary .elementor-button-content-wrapper,
.btn-secondary-alt .elementor-button-content-wrapper,
#btn-secondary-alt .elementor-button-content-wrapper {
	padding: 0;
	background: none !important;
	border-radius: 0;
}

/* Centrage vertical du texte */
.btn-primary .elementor-button-text,
#btn-primary .elementor-button-text,
.btn-primary-alt .elementor-button-text,
#btn-primary-alt .elementor-button-text,
.btn-secondary .elementor-button-text,
.btn-secondary-alt .elementor-button-text,
#btn-secondary-alt .elementor-button-text {
	display: inline-flex;
	align-items: center;
	line-height: 1;
}

/* Texte + icône toujours visibles */
.btn-primary .elementor-button *,
#btn-primary.elementor-button *,
.btn-primary-alt .elementor-button *,
#btn-primary-alt.elementor-button *,
.btn-secondary .elementor-button *,
.btn-secondary-alt .elementor-button *,
#btn-secondary-alt.elementor-button * {
	background: none;
	position: relative;
	z-index: 2;
}

/* ================= PRIMARY ================= */

.btn-primary .elementor-button,
#btn-primary.elementor-button {
	color: #ffffff !important;
	background-color: #18181B !important;
}

.btn-primary .elementor-button:hover,
#btn-primary.elementor-button:hover {
	color: #ffffff !important;
	background-color: #3E3E41 !important;
	transform: scale(0.95);
}

/* ================= PRIMARY ALT ================= */

.btn-primary-alt .elementor-button,
#btn-primary-alt.elementor-button,
body.is-scrolled .elementor-location-header .elementor-sticky--active .btn-secondary-alt .elementor-button {
	color: #18181B !important;
	background-color: transparent !important;
	border: solid 1px #18181B !important;
}

.btn-primary-alt .elementor-button:hover,
#btn-primary-alt.elementor-button:hover,
body.is-scrolled .elementor-location-header .elementor-sticky--active .btn-secondary-alt .elementor-button:hover {
	color: #ffffff !important;
	background-color: #18181B !important;
	transform: scale(0.95);
}

/* ================= SECONDARY ================= */

.btn-secondary .elementor-button {
	color: #18181B !important;
	background-color: #ffffff !important;
}

.btn-secondary .elementor-button:hover {
	color: #18181B !important;
	background-color: #F4F4F5 !important;
	transform: scale(0.95);
}

/* ================= SECONDARY ALT ================= */

.btn-secondary-alt .elementor-button,
#btn-secondary-alt.elementor-button {
	color: #ffffff !important;
	background-color: transparent !important;
	border: solid 1px #ffffff !important;
}

.btn-secondary-alt .elementor-button:hover,
#btn-secondary-alt.elementor-button:hover {
	color: #CFCFCF !important;
	background-color: #F4F4F5 !important;
	transform: scale(0.95);
}

/* ================= HEADER ================= */
.elementor-location-header {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
}

.elementor-location-header .elementor-sticky--active {
	transition: background-color 0.8s ease;
}


body.is-scrolled .elementor-location-header .elementor-sticky--active {
	background-color: #ffffff;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

/* Logo : blanc par défaut, baseline sans fill (avant scroll) */
.elementor-location-header svg path:not(.baseline) {
	fill: #ffffff !important;
	transition: fill 0.8s ease;
}
.elementor-location-header svg path.baseline { fill: #000000 !important; }

/* Logo : couleurs originales après scroll (is-scrolled) */
body.is-scrolled svg path[fill="#C61315"] { fill: #C61315 !important; }
body.is-scrolled svg path[fill="#26336A"] { fill: #26336A !important; }
body.is-scrolled svg path[fill="#1D1D1B"] { fill: #1D1D1B !important; }
body.is-scrolled svg path.baseline         { fill: #ffffff !important; }

/* ================= NAV MENU ================= */

/* Nav container */
.goudier-nav {
	position: relative;
}

.goudier-nav-menu {
	display: flex;
	align-items: center;
	list-style: none;
	gap: 0.5rem;
	margin: 0;
	padding: 0;
}

/* Items */
.goudier-nav-menu .nav-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1rem;
	border-radius: 2rem;
	font-weight: 500;
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.3s ease, background-color 0.3s ease;
}

/* Disque sous l'item (pseudo-élément) */
.goudier-nav-menu .nav-link::after {
	content: "";
	position: absolute;
	bottom: -0.3rem;
	left: 50%;
	transform: translateX(-50%) translateY(-8px);
	width: 10px;
	height: 10px;
	border-radius: 50%;
	opacity: 0;
	transition: opacity 0.8s ease, transform 0.8s ease;
	pointer-events: none;
}

/* ---------- NON SCROLLÉ ---------- */

/* Item actif */
.goudier-nav-menu .current-menu-item > .nav-link {
	background-color: #ffffff;
	color: #000000;
}

/* Item inactif */
.goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link {
	background-color: transparent;
	color: #ffffff;
}

/* Hover inactif : disque blanc */
.goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link::after {
	background-color: #ffffff;
}

.goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link:hover::after {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

/* ---------- SCROLLÉ ---------- */

/* Item actif */
body.is-scrolled .goudier-nav-menu .current-menu-item > .nav-link {
	background-color: #000000;
	color: #ffffff;
}

/* Item inactif */
body.is-scrolled .goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link {
	background-color: transparent;
	color: #000000;
}

/* Hover inactif : couleur rouge */
body.is-scrolled .goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link:hover {
	color: #C61315;
}

/* Hover inactif : disque rouge */
body.is-scrolled .goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link::after {
	background-color: #C61315;
}

body.is-scrolled .goudier-nav-menu .nav-item:not(.current-menu-item) > .nav-link:hover::after {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

/* --- Dropdown classique (sous-menus non mega) --- */
.nav-item {
	position: relative;
}

.nav-item > .sub-menu {
	position: absolute;
	top: calc(100% + 0.75rem);
	left: 50%;
	transform: translateX(-50%) translateY(8px);
	min-width: 200px;
	list-style: none;
	margin: 0;
	padding: 0;
	background-color: #ffffff;
	border-radius: 0.75rem;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	z-index: 100;
}

.nav-item:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}

.sub-menu-item {
	list-style: none;
}

.sub-menu-item > a {
	display: block;
	padding: 0.85rem 1.25rem;
	color: #18181B;
	font-weight: 500;
	font-size: 0.875rem;
	text-decoration: none;
	white-space: nowrap;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.sub-menu-item > a:hover {
	background-color: #F4F4F5;
	color: #C61315;
}

.sub-menu-item:first-child > a {
	border-radius: 0.75rem 0.75rem 0 0;
}

.sub-menu-item:last-child > a {
	border-radius: 0 0 0.75rem 0.75rem;
}

/* Ne pas appliquer le dropdown au mega menu */
.has-mega-menu > .sub-menu {
	display: none;
}


/* ================= FOOTER ================= */

footer,
footer p,
footer span,
footer a,
footer li,
footer h1,
footer h2,
footer h3,
footer h4,
footer h5,
footer h6 {
	color: #ffffff !important;
}

.footer-agencies,
.footer-agencies * {
	text-align: left !important;
	padding-inline-start: 0 !important;
	justify-content: left !important;
	margin-top: 0 !important;
}

.footer-agencies .elementor-heading-title {
	font-family: Gotham;
	font-size: 1rem;
	font-style: normal;
	font-weight: 400;
	line-height: 1.3125rem; /* 131.25% */
}

footer .elementor-widget-heading h4.elementor-heading-title {
	font-size: 1rem !important;
	line-height: 1.3125rem !important;
	font-weight: 500 !important;
	margin-bottom: 0 !important;
}

.footer-agencies .elementor-widget-text-editor,
.footer-agencies .goudier-phone {
	font-family: Gotham;
	font-size: 1rem;
	font-style: normal;
	font-weight: 300;
	line-height: 1.3125rem; /* 131.25% */
}

.footer-agencies .elementor-icon-list-icon {
	display: none !important;
}

.goudier-social-networks .elementor-icon {
	padding: 8px;
	border-radius: 50%;
	background-color: #2D2D2D;
	transition: background-color 0.8s ease;
}

.goudier-social-networks .elementor-icon .circle,
.goudier-social-networks .elementor-icon .photobox,
.goudier-social-networks .elementor-icon .outline,
.goudier-social-networks .elementor-icon .centerpoint {
	transition: fill 0.8s ease;
}

.goudier-social-networks .elementor-icon:hover {
	background-color: #ffffff;
}

.goudier-social-networks .elementor-icon:hover .circle,
.goudier-social-networks .elementor-icon:hover .photobox,
.goudier-social-networks .elementor-icon:hover .outline,
.goudier-social-networks .elementor-icon:hover .centerpoint {
	fill: #000000;
}


/* ================= BREADCRUMB ================= */

.goudier-breadcrumb {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.25rem;
	font-size: 1rem !important;
	line-height: 1.4rem !important;
	margin-bottom: 1rem;
}

.goudier-breadcrumb a,
.goudier-breadcrumb span {
	text-decoration: none;
	font-size: 1rem !important;
	line-height: 1.4rem !important;
}

.goudier-breadcrumb a {
	transition: opacity 0.3s ease;
}

.goudier-breadcrumb a:hover {
	opacity: 0.7;
}

.goudier-breadcrumb .current {
	opacity: 0.7;
}

.goudier-breadcrumb .separator {
	display: inline-flex;
	align-items: center;
	opacity: 0.5;
	margin: 0 0.25rem;
}

.goudier-breadcrumb .separator svg {
	width: 1.2em;
	height: 1.2em;
}

/* ================= Complianz ================= */



/* ================= MEGA MENU ================= */

/* --- Has mega menu : positionnement pour le panel --- */
.has-mega-menu {
	position: static;
}

/* Masquer le sous-menu standard si jamais */
.has-mega-menu > .sub-menu {
	display: none;
}

/* --- Mega Panel (dropdown) --- */
.mega-panel {
	position: absolute;
	top: calc(100% + 0.75rem);
	left: 0;
	width: 80%;
	max-width: 700px;
	min-height: 400px;
	max-height: 75vh;
	background-color: #ffffff;
	border-radius: 1rem;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
	display: flex;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	z-index: 100;
}

.has-mega-menu.is-open > .mega-panel {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* --- Colonne gauche : Catégories (onglets) --- */
.mega-categories-col {
	display: flex;
	flex-direction: column;
	width: 50%;
	min-width: 180px;
	background-color: #F9F9F9;
	border-radius: 1rem 0 0 1rem;
	border-right: 1px solid #F6F6F6;
	overflow-y: auto;
}

.mega-categories-title {
	padding: 1.5rem 1.25rem 1.5rem;
	font-weight: 400;
	font-size: 2rem;
	text-transform: none;
	letter-spacing: 0.05em;
	color: #A1A1AA;
}

.mega-categories {
	display: flex;
	flex-direction: column;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mega-cat-item:first-child {
	border-radius: 1rem 0 0 0;
}

.mega-cat-item:first-child > .mega-cat-link {
	border-radius: 1rem 0 0 0;
}

.mega-cat-item {
	position: static;
}

.mega-cat-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.5rem 1.25rem;
	color: #18181B;
	font-weight: 700;
	font-size: 0.9rem;
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.mega-cat-thumb {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
	background-color: #E4E4E7;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mega-cat-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.mega-cat-item:hover .mega-cat-thumb img,
.mega-cat-item.is-active .mega-cat-thumb img {
	opacity: 1;
}

.mega-cat-item.has-children > .mega-cat-link::after {
	content: "";
	width: 7px;
	height: 7px;
	border-right: 2px solid #A1A1AA;
	border-bottom: 2px solid #A1A1AA;
	transform: rotate(-45deg);
	flex-shrink: 0;
	margin-left: auto;
	transition: border-color 0.2s ease;
}

.mega-cat-item.has-children:hover > .mega-cat-link::after,
.mega-cat-item.has-children.is-active > .mega-cat-link::after {
	border-color: #C61315;
}

.mega-cat-item:hover > .mega-cat-link,
.mega-cat-item.is-active > .mega-cat-link {
	background-color: #ffffff;
	color: #C61315;
}

/* --- Colonne droite : Sous-catégories --- */
.mega-subcategories {
	position: absolute;
	top: 0;
	left: 50%;
	width: 50%;
	bottom: 0;
	padding: 0;
	overflow-y: auto;
	display: none;
	border-radius: 0 1rem 1rem 0;
}

.mega-subcategories.is-active {
	display: block;
}

.mega-subcategories-header {
	position: relative;
	display: flex;
	align-items: flex-end;
	padding: 1.25rem;
	min-height: 200px;
	border-bottom: 1px solid #E4E4E7;
	margin-bottom: 0.25rem;
	overflow: hidden;
}

.mega-subcategories-header img {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: translate(-50%, -50%);
	display: block;
}

.mega-subcategories-header::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.3) 100%);
}

.mega-subcategories-header-title {
	position: relative;
	z-index: 1;
	font-weight: 700;
	font-size: 1.5rem;
	color: #ffffff;
}

.mega-subcat-list {
	display: flex;
	flex-direction: column;
	list-style: none;
	margin: 0;
	padding: 0;
}

.mega-subcat-item {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 0.75rem;
	padding: 0.6rem 1.25rem;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.mega-subcat-item:hover {
	background-color: #F4F4F5;
}

.mega-subcat-thumb {
	width: 40px;
	height: 40px;
	flex-shrink: 0;
	border-radius: 50%;
	overflow: hidden;
	background-color: #E4E4E7;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mega-subcat-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.mega-subcat-link {
	color: #18181B;
	font-weight: 500;
	font-size: 0.875rem;
	text-decoration: none;
	transition: color 0.2s ease;
}

.mega-subcat-item:hover .mega-subcat-link {
	color: #C61315;
}

/* --- Scrollbar discrète --- */
.mega-subcategories {
	scrollbar-width: thin;
	scrollbar-color: #D4D4D8 transparent;
}

.mega-subcategories::-webkit-scrollbar {
	width: 4px;
}

.mega-subcategories::-webkit-scrollbar-track {
	background: transparent;
}

.mega-subcategories::-webkit-scrollbar-thumb {
	background-color: #D4D4D8;
	border-radius: 4px;
}


/* ================= HAMBURGER (masqué desktop) ================= */

.goudier-burger {
	display: none;
}


/* Verrouillage scroll quand menu mobile ouvert */
body.mobile-menu-open {
	overflow: hidden;
}


/* ================= PERSONNALISATION DES WIDGETS ================= */

.avis-google.elementor-widget-reviews .swiper-horizontal {
	margin-left: 0;
	margin-right: 0;
	padding-bottom: 5rem !important;
	position: relative;
}

.avis-google.elementor-widget-reviews .elementor-swiper-button {
	position: absolute !important;
	left: inherit !important;
	top: inherit !important;
	bottom: 0 !important;
	width: 2.25rem;
	height: 2.25rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;

	border-radius: 5px;

	background-color: none;
	border: none;
	text-decoration: none;
	font-size: 1rem;
	font-weight: 400;
	line-height: 1;

	color: #18181B !important;
	background-color: #ffffff !important;
	cursor: pointer;

	transition: all 0.3s ease;
}

.avis-google.elementor-widget-reviews .elementor-swiper-button.elementor-swiper-button-prev { right: 50px !important; }
.avis-google.elementor-widget-reviews .elementor-swiper-button.elementor-swiper-button-next { right: 0px !important; }

.avis-google.elementor-widget-reviews .elementor-swiper-button svg {
	display: none;
}

.avis-google.elementor-widget-reviews .elementor-swiper-button::after {
	font-family: "eicons";
	font-weight: 400;
	font-style: normal;
	color: #18181B;
	font-size: 16px;
}

.avis-google.elementor-widget-reviews .elementor-swiper-button-prev::after {
	content: "\e8bf";
}

.avis-google.elementor-widget-reviews .elementor-swiper-button-next::after {
	content: "\e8c0";
}

.avis-google.elementor-widget-reviews .elementor-swiper-button:hover {
	color: #18181B !important;
	background-color: #F4F4F5 !important;
	width: 2rem;
	height: 2rem;
}

.elementor-widget-shortcode.no-filters .fg-filtering-container {
	display: none !important;
}

/* Trustindex — footer (note + logo Google) en blanc sur fond sombre */
.ti-footer.ti-footer-grid.source-Google,
.ti-footer.ti-footer-grid.source-Google * {
	color: #ffffff !important;
}

#formulaire_de_contact .elementor-field-option {
	display: flex;
	align-items: flex-start;
}

#formulaire_de_contact .elementor-field-option input[type="radio"],
#formulaire_de_contact .elementor-field-option input[type="checkbox"] {
	margin-right: 0.5rem;
	margin-top: 6px;
}

#formulaire_de_contact .elementor-field-group-project .elementor-field-subgroup {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	column-gap: 1rem;
	row-gap: 0.25rem;
}

#formulaire_de_contact .elementor-field-group-project .elementor-field-subgroup .elementor-field-option {
	flex: unset;
	width: auto;
}


/* ================= RESPONSIVE < 1024px ================= */

@media (max-width: 1023px) {
	.elementor-widget-heading h1.elementor-heading-title { font-size: 1.75rem !important; line-height: 2.125rem !important; }
	.elementor-widget-heading h2.elementor-heading-title { font-size: 1.5rem !important; line-height: 1.875rem !important; }
	.elementor-widget-heading h3.elementor-heading-title { font-size: 1.125rem !important; line-height: 1.438rem !important; }
	.elementor-widget-heading h4.elementor-heading-title { font-size: 1rem !important; line-height: 1.25rem !important; }
	.elementor-widget-heading h5.elementor-heading-title { font-size: 0.938rem !important; line-height: 1.125rem !important; }
	.elementor-widget-heading h6.elementor-heading-title { font-size: 0.813rem !important; font-weight: 500 !important; line-height: 1rem !important; }

	h1.elementor-heading-title { margin-bottom: 1.5rem; }
	h2.elementor-heading-title { margin-bottom: 1rem; }

	.inner-section {
		padding-top: 1.5rem !important;
		padding-bottom: 1.5rem !important;
	}

	.inner-section.e-con > .e-con-inner {
		gap: 1rem;
		padding-block-start: 1rem !important;
		padding-block-end: 1rem !important;
	}

	.goudier-breadcrumb {
		flex-direction: column;
		align-items: center;
		gap: 0.15rem;
		font-size: 0.875rem !important;
		line-height: 1.2rem !important;
	}

	.goudier-breadcrumb a,
	.goudier-breadcrumb span {
		font-size: 0.875rem !important;
		line-height: 1.2rem !important;
	}

	.goudier-breadcrumb .separator {
		transform: rotate(90deg);
	}

	.column-gap {
		gap: 1rem !important;
	}

	.btn-primary .elementor-button,
	#btn-primary.elementor-button,
	.btn-primary-alt .elementor-button,
	#btn-primary-alt.elementor-button,
	.btn-secondary .elementor-button,
	.btn-tertiary .elementor-button,
	.btn-tertiary-alt .elementor-button {
		padding: 0.8rem 1.2rem;
		border-radius: 2.5rem;
		font-size: 0.875rem;
	}

	.footer-agencies,
	.footer-agencies * {
		text-align: center !important;
		justify-content: center !important;
	}

	#formulaire_de_contact .elementor-field-group-project .elementor-field-subgroup {
		grid-template-columns: repeat(2, 1fr);
	}

	/* --- Hamburger --- */
	.goudier-burger {
		display: flex;
		flex-direction: column;
		justify-content: center;
		gap: 5px;
		width: 48px;
		height: 48px;
		padding: 10px;
		background: none;
		border: none;
		cursor: pointer;
		z-index: 1001;
		position: relative;
		transform: scale(1) rotate(0deg);
		opacity: 1;
		transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1),
		            opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1);
		/* Reset Elementor tap highlight */
		-webkit-tap-highlight-color: transparent;
		outline: none;
	}

	.goudier-burger:focus,
	.goudier-burger:active,
	.goudier-burger:hover {
		background: none;
		outline: none;
		box-shadow: none;
	}

	/* Spin + Scale out le burger pendant l'ouverture */
	.goudier-nav.is-burger-hiding .goudier-burger {
		transform: scale(0) rotate(180deg);
		opacity: 0;
		pointer-events: none;
	}

	.burger-line {
		display: block;
		width: 100%;
		height: 2px;
		background-color: #ffffff;
		border-radius: 2px;
		transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease;
	}

	body.is-scrolled .burger-line {
		background-color: #18181B;
	}

	/* Réapparaît en fixed avec Spin + Scale in */
	.goudier-nav.is-mobile-open .goudier-burger {
		position: fixed;
		top: 1.25rem;
		right: 1.5rem;
		animation: burgerSpinIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) 0.15s forwards;
		transform: scale(0) rotate(-180deg);
		opacity: 0;
	}

	@keyframes burgerSpinIn {
		from {
			transform: scale(0) rotate(-180deg);
			opacity: 0;
		}
		to {
			transform: scale(1) rotate(0deg);
			opacity: 1;
		}
	}

	.goudier-nav.is-mobile-open .burger-line:nth-child(1) {
		transform: translateY(7px) rotate(45deg);
		background-color: #18181B;
	}

	.goudier-nav.is-mobile-open .burger-line:nth-child(2) {
		opacity: 0;
	}

	.goudier-nav.is-mobile-open .burger-line:nth-child(3) {
		transform: translateY(-7px) rotate(-45deg);
		background-color: #18181B;
	}

	/* --- Overlay fullscreen --- */
	.goudier-nav {
		display: block;
	}

	.goudier-nav-menu {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100dvh;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		gap: 0;
		padding: 5rem 1.5rem 2rem;
		background-color: #ffffff;
		overflow-y: auto;
		z-index: 1000;
		opacity: 0;
		visibility: hidden;
		transform: translateX(100%);
		transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	}

	.goudier-nav.is-mobile-open .goudier-nav-menu {
		opacity: 1;
		visibility: visible;
		transform: translateX(0);
	}

	/* --- Items mobiles --- */
	.goudier-nav-menu .nav-link {
		color: #18181B !important;
		background-color: transparent !important;
		padding: 1rem 0;
		border-radius: 0;
		font-size: 1.25rem;
		font-weight: 600;
		border-bottom: 1px solid #E4E4E7;
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.goudier-nav-menu .nav-link::after {
		display: none;
	}

	/* Chevron pour items avec sous-menu */
	.nav-item.menu-item-has-children > .nav-link::after,
	.has-mega-menu > .nav-link::after {
		content: "";
		display: block;
		width: 8px;
		height: 8px;
		border-right: 2px solid #18181B;
		border-bottom: 2px solid #18181B;
		transform: rotate(45deg) !important;
		transition: transform 0.3s ease;
		opacity: 1 !important;
		position: static;
		flex-shrink: 0;
		margin-left: 0.5rem;
		background: none;
		border-radius: 0;
	}

	.nav-item.is-mobile-expanded > .nav-link::after,
	.has-mega-menu.is-mobile-expanded > .nav-link::after {
		transform: rotate(-135deg) !important;
	}

	/* --- Dropdown classique en accordéon --- */
	.nav-item > .sub-menu,
	.nav-item:hover > .sub-menu {
		position: static !important;
		left: auto !important;
		top: auto !important;
		transform: none !important;
		opacity: 1 !important;
		visibility: visible !important;
		box-shadow: none;
		background-color: transparent;
		border-radius: 0;
		padding: 0;
		padding-left: 1rem;
		min-width: 0;
		width: 100%;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}

	.nav-item.is-mobile-expanded > .sub-menu {
		max-height: 500px;
	}

	.sub-menu-item > a {
		padding: 0.75rem 0;
		border-bottom: 1px solid #F4F4F5;
		font-size: 1rem;
		white-space: normal;
	}

	/* --- Mega menu en accordéon --- */
	.mega-panel {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border-radius: 0;
		background-color: transparent;
		display: block;
		min-height: 0;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}

	.has-mega-menu.is-mobile-expanded > .mega-panel {
		max-height: 5000px;
	}

	.mega-categories-col {
		width: 100%;
		min-width: 0;
		background-color: transparent;
		border-radius: 0;
		border-right: none;
	}

	.mega-categories-title {
		display: none;
	}

	.mega-cat-link {
		padding: 0.875rem 1rem;
		font-size: 1.1rem;
		font-weight: 600;
		border-bottom: 1px solid #E4E4E7;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		gap: 0.75rem;
	}

	.mega-cat-item.has-children .mega-cat-link::after {
		content: "";
		display: block;
		width: 7px;
		height: 7px;
		border-right: 2px solid #18181B;
		border-bottom: 2px solid #18181B;
		transform: rotate(45deg);
		transition: transform 0.3s ease;
		flex-shrink: 0;
		margin-left: auto;
	}

	.mega-cat-item.is-mobile-expanded .mega-cat-link::after {
		transform: rotate(-135deg);
	}

	.mega-subcategories {
		position: static;
		width: 100%;
		border-radius: 0;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
		padding-left: 1rem;
	}

	.mega-subcategories.is-mobile-expanded {
		display: block;
		max-height: 3000px;
	}

	.mega-subcategories-header {
		display: none;
	}

	.mega-subcat-item {
		padding: 0.6rem 0;
		border-bottom: 1px solid #F4F4F5;
	}

	.mega-subcategories::-webkit-scrollbar {
		display: none;
	}
}