/*
Theme Name: Hello Elementor Child
Theme URI: https://guilhemdelachapelle.com
Description: Hello Elementor Child Theme
Author: guilhem delachapelle
Author URI: https://guilhemdelachapelle.com
Template: hello-elementor
Version: 1.0.0
Text Domain: hello-elementor-child
*/

:root {
	/* Fonts */
	--font-family-primary: "itc-avant-garde-gothic-pro", sans-serif;

	/* Colors */
	--color-medium-blue: #135E6C;
	--color-dark-blue: #183645;
	--color-grey: #F6F6F6;
	--color-light-blue: #A4F1FF;
	--color-light-green: #E5FEB0;
	--color-light-yellow: #FFF399;
	--color-white: #FFFFFF;

	/* Gradients */
	--gradient-primary: linear-gradient(45deg, var(--color-dark-blue) 0%, var(--color-medium-blue) 100%);

	/* Layout */
	--header-height: 88px;
	--sticky-offset: 24px;
}

html {
	scroll-padding-top: calc(var(--header-height) + var(--sticky-offset));
}

body {
	font-family: var(--font-family-primary);
	background-color: var(--color-white);
	color: var(--color-dark-blue);
}

/* Button Component */
.custom-button {
	display: inline-flex;
	align-items: center;
	padding: 12px 16px 12px 32px;
	background-color: var(--btn-bg);
	color: var(--btn-text);
	text-decoration: none;
	border-radius: 20px;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-size: 14px;
	transition: transform 0.2s ease, opacity 0.2s ease;
	gap: 16px;
	white-space: nowrap;
	flex-shrink: 0;
	z-index: 1;
}

.custom-button .btn-icon {
	flex-shrink: 0;
}

.custom-button:hover {
	opacity: 0.9;
	transform: translateY(-2px);
	color: var(--btn-text);
}

.custom-button .btn-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background-color: var(--btn-icon-bg);
	color: var(--btn-icon-color);
	border-radius: 50%;
}

.custom-button .btn-icon svg {
	width: 14px;
	height: 14px;
}

/* ===== LABEL (surtitre) ===== */
.label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-dark-blue);
	margin: 0;
}

.label::before {
	content: '';
	flex-shrink: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: var(--color-light-yellow);
}

/* ===== LAYOUT OVERRIDES (Elementor / Hello Elementor) ===== */
.site-main,
.page-content,
#content.site-main {
	max-width: none;
	width: 100%;
	padding: 0;
	margin: 0;
}

/* ===== HEADER ===== */
.site-header {
	background-color: var(--color-white);
	padding: 0;
	position: sticky;
	top: 0;
	z-index: 1000;
	max-width: 100vw !important;
	height: var(--header-height);
	display: flex;
	align-items: center;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
	transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

.site-header--scrolled {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
	border-bottom-color: transparent;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0 5%;
}

.site-header__left {
	flex: 0 0 250px;
}

.site-header__center {
	flex: 1;
	display: flex;
	justify-content: center;
}

.site-header__right {
	flex: 0 0 250px;
	display: flex;
	justify-content: flex-end;
}

.site-header__logo {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: var(--color-dark-blue);
	line-height: 1;
}

.site-header__logo-name {
	font-size: 20px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.18em;
}

.site-header__logo-title {
	font-size: 13px;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	opacity: 0.7;
	margin-top: 2px;
}

/* Nav */
.site-header__nav ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	gap: 40px;
}

.site-header__nav>ul>li>a {
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--color-dark-blue);
	text-decoration: none;
	position: relative;
	padding: 20px 0;
	display: flex;
	align-items: center;
	transition: opacity 0.2s ease;
}

.site-header__nav>ul>li>a:hover {
	opacity: 0.7;
}

/* Mega Menu stability fixes */
.site-header__menu .menu-item-has-children {
	position: relative;
}

/* Invisible bridge to prevent hover loss */
.site-header__menu .menu-item-has-children::after {
	content: '';
	position: absolute;
	top: 100%;
	left: -20px;
	width: calc(100% + 40px);
	height: 30px;
	/* Larger bridge */
	z-index: 5;
	display: none;
}

.site-header__menu .menu-item-has-children:hover::after {
	display: block;
}

.site-header__menu .menu-item-has-children>a::after {
	content: '';
	width: 8px;
	height: 5px;
	margin-left: 8px;
	background-image: url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L4 4L7 1' stroke='%23183645' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	transition: transform 0.3s ease;
}

.site-header__menu .menu-item-has-children:hover>a::after {
	transform: rotate(180deg);
}

/* Animations and visibility handled either by JS (recommended for reliability) or CSS */
.site-header__menu .menu-item-has-children .sub-menu {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	width: 260px;
	background-color: var(--color-white);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
	border-radius: 12px;
	padding: 16px;
	margin-top: 10px;
	border: 1px solid rgba(0, 0, 0, 0.05);
	display: none;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease, transform 0.3s ease;
	z-index: 100;
}

.site-header__menu .menu-item-has-children.is-active .sub-menu {
	display: block;
	opacity: 1;
	pointer-events: auto;
}

.site-header__menu .sub-menu li {
	display: block;
	margin-bottom: 4px;
}

.site-header__menu .sub-menu li:last-child {
	margin-bottom: 0;
}

.site-header__menu .sub-menu li a {
	font-size: 14px;
	font-weight: 400;
	color: var(--color-dark-blue);
	text-decoration: none;
	padding: 10px 16px;
	display: block;
	border-radius: 8px;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.site-header__menu .sub-menu li a:hover {
	background-color: var(--color-grey);
	color: var(--color-medium-blue);
}

/* Overwrite Hello Elementor defaults */
.site-header {
	width: 100%;
}

/* ===== HAMBURGER + MOBILE MENU ===== */
.site-header__burger {
	display: none;
	position: relative;
	width: 44px;
	height: 44px;
	padding: 0;
	cursor: pointer;
	z-index: 1100;
	color: var(--color-dark-blue);
}

.site-header__burger,
.site-header__burger:hover,
.site-header__burger:focus,
.site-header__burger:active {
	background: transparent !important;
	background-color: transparent !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	color: var(--color-dark-blue) !important;
}

.site-header__burger:focus-visible {
	outline: 2px solid var(--color-dark-blue) !important;
	outline-offset: 2px;
}

.site-header__burger-line {
	position: absolute;
	left: 10px;
	right: 10px;
	height: 2px;
	background-color: var(--color-dark-blue);
	border-radius: 2px;
	transform-origin: center;
	transition: transform 0.3s ease, opacity 0.2s ease, top 0.3s ease;
}

.site-header__burger-line:nth-child(1) { top: 14px; }
.site-header__burger-line:nth-child(2) { top: 21px; }
.site-header__burger-line:nth-child(3) { top: 28px; }

.site-header__burger.is-open .site-header__burger-line:nth-child(1) {
	top: 21px;
	transform: rotate(45deg);
}

.site-header__burger.is-open .site-header__burger-line:nth-child(2) {
	opacity: 0;
}

.site-header__burger.is-open .site-header__burger-line:nth-child(3) {
	top: 21px;
	transform: rotate(-45deg);
}

/* Fullscreen overlay menu */
.mobile-menu {
	position: fixed;
	top: var(--header-height);
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 999;
	background-color: var(--color-white);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	visibility: hidden;
	opacity: 0;
	transform: translateY(-12px);
	transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s linear 0.3s;
	display: none;
}

.mobile-menu.is-open {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s linear 0s;
}

.mobile-menu__inner {
	min-height: 100%;
	padding: 64px 6% 48px;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.mobile-menu__nav .mobile-menu__list,
.mobile-menu__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.mobile-menu__list > li > a,
.mobile-menu .menu-item > a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 4px;
	font-size: 22px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--color-dark-blue);
	text-decoration: none;
	border-bottom: 1px solid rgba(11, 31, 58, 0.08);
	transition: color 0.2s ease, padding-left 0.2s ease;
}

.mobile-menu .menu-item > a:hover {
	color: var(--color-medium-blue);
	padding-left: 8px;
}

/* Caret on items with submenu */
.mobile-menu .menu-item-has-children > a::after {
	content: '';
	flex-shrink: 0;
	width: 12px;
	height: 12px;
	background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L6 6L11 1' stroke='%23183645' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: center;
	transition: transform 0.25s ease;
}

.mobile-menu .menu-item-has-children.is-expanded > a::after {
	transform: rotate(180deg);
}

/* Sub-menu accordion (mobile) */
.mobile-menu .sub-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.mobile-menu .menu-item-has-children.is-expanded > .sub-menu {
	max-height: 1000px;
}

.mobile-menu .sub-menu li a {
	display: block;
	padding: 14px 4px 14px 16px;
	font-size: 16px;
	font-weight: 400;
	color: var(--color-dark-blue);
	text-decoration: none;
	border-bottom: 1px solid rgba(11, 31, 58, 0.05);
	opacity: 0.8;
	transition: opacity 0.2s ease, color 0.2s ease;
}

.mobile-menu .sub-menu li a:hover {
	opacity: 1;
	color: var(--color-medium-blue);
}

/* Footer of mobile menu */
.mobile-menu__footer {
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding-top: 32px;
	border-top: 1px solid rgba(11, 31, 58, 0.08);
}

.mobile-menu__phone {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	font-size: 16px;
	font-weight: 700;
	color: var(--color-dark-blue);
	text-decoration: none;
	border-radius: 999px;
	border: 1.5px solid var(--color-dark-blue);
	justify-content: center;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.mobile-menu__phone:hover {
	background-color: var(--color-dark-blue);
	color: var(--color-white);
}

.mobile-menu__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 16px 22px;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-dark-blue);
	background-color: var(--color-light-yellow);
	border-radius: 999px;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.mobile-menu__cta:hover {
	color: var(--color-dark-blue);
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(255, 243, 153, 0.45);
}

/* Body scroll lock when menu open */
html.has-mobile-menu-open,
body.has-mobile-menu-open {
	/* overflow: hidden; */
}

@media (max-width: 1024px) {
	.site-header__center {
		display: none;
	}

	.site-header__cta {
		display: none;
	}

	.site-header__burger {
		display: block;
	}

	.mobile-menu {
		display: block;
	}

	.site-header__left {
		flex: 0 0 auto;
	}

	.site-header__right {
		flex: 0 0 auto;
	}
}

/* ===== HERO ===== */
.hero {
	display: grid;
	grid-template-columns: 45fr 55fr;
	align-items: center;
	min-height: 85vh;
	padding: 80px 8% 80px 8%;
	gap: 60px;
	overflow: hidden;
}

.hero__content {
	max-width: 560px;
}

.hero__label {
	margin-bottom: 24px;
}

.hero__title {
	font-size: clamp(32px, 3.5vw, 35px);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-dark-blue);
	margin-bottom: 24px;
}

.hero__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin-bottom: 40px;
}

/* Media column */
.hero__media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	height: 640px;
}

.hero__decoration {
	position: absolute;
	top: 5%;
	left: 0;
	width: 78%;
	height: 90%;
	background-color: var(--color-light-green);
	border-radius: 24px;
}

.hero__image {
	position: relative;
	z-index: 1;
	width: 90%;
	height: 100%;
	border-radius: 20px;
	overflow: hidden;
}

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

/* ===== CITATION ===== */
.citation {
	padding: 80px 8%;
	display: flex;
	justify-content: center;
}

.citation__inner {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
	max-width: 1000px;
}

.citation__decoration {
	position: absolute;
	left: clamp(-50px, -3vw, -12px);
	width: clamp(60px, 8vw, 120px);
	height: 120%;
	background-color: var(--color-light-blue);
	border-radius: 16px;
	z-index: 0;
}

.citation__text {
	position: relative;
	z-index: 1;
	font-size: clamp(16px, 1.8vw, 22px);
	font-weight: 700;
	font-style: italic;
	line-height: 1.7;
	color: var(--color-dark-blue);
	margin: 0;
	border: none;
}

/* ===== CARDS CAROUSEL ===== */
.cards-carousel {
	background-color: var(--color-grey);
	padding: 80px 0 80px 8%;
	overflow: hidden;
}

/* Header 2 colonnes */
.cards-carousel__header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: center;
	margin-bottom: 48px;
	padding-right: 8%;
}

.cards-carousel__header-left {
	display: flex;
	flex-direction: column;
	gap: 20px;
	align-items: flex-start;
}

.cards-carousel__title {
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.cards-carousel__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin: 0;
}

/* Navigation */
.cards-carousel__nav {
	display: flex;
	gap: 12px;
}

.swiper-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 12px;
	border: none !important;
	background-color: var(--color-dark-blue) !important;
	color: var(--color-white) !important;
	cursor: pointer;
	transition: opacity 0.2s ease;
	outline: none !important;
	box-shadow: none !important;
}

.swiper-btn:hover,
.swiper-btn:focus,
.swiper-btn:active {
	opacity: 0.8;
	background-color: var(--color-dark-blue) !important;
	color: var(--color-white) !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
}

.swiper-btn.swiper-button-disabled {
	opacity: 0.35;
	pointer-events: none;
}

/* Swiper */
.cards-carousel__swiper {
	width: 100%;
	overflow: visible;
}

.cards-carousel__swiper .swiper-slide {
	height: auto;
}

/* Card */
.card-item {
	position: relative;
	border-radius: 24px;
	overflow: hidden;
	height: 500px;
	cursor: pointer;
}

/* Image layer */
.card-item__image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.card-item__image::after {
	content: '';
	position: absolute;
	inset: 0;
	background-color: rgba(24, 54, 69, 0.62);
}

.card-item__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Default state: title at bottom */
.card-item__footer {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0 32px 32px;
	z-index: 1;
	transition: opacity 0.35s ease;
}

.card-item__footer-title {
	font-size: 20px;
	font-weight: 500;
	line-height: 1.3;
	color: var(--color-white);
	margin: 0 0 16px;
}

/* Hover panel */
.card-item__panel {
	position: absolute;
	inset: 0;
	padding: 36px 32px;
	background-color: var(--color-light-blue);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 20px;
	opacity: 0;
	transition: opacity 0.35s ease;
}

.card-item:hover .card-item__panel {
	opacity: 1;
}

.card-item:hover .card-item__footer {
	opacity: 0;
}

.card-item__panel-title {
	font-size: 20px;
	font-weight: 500;
	line-height: 1.3;
	color: var(--color-dark-blue);
	margin: 0;
}

.card-item__line {
	height: 1px;
	background-color: currentColor;
	opacity: 0.25;
	border: none;
	flex-shrink: 0;
}

.card-item__footer .card-item__line {
	background-color: var(--color-white);
	opacity: 0.5;
}

.card-item__panel-text {
	font-size: 14px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin: 0;
	flex: 1;
	overflow: hidden;
}

.card-item__panel-cta {
	margin-top: auto;
}

/* ===== MARQUEE ===== */
.marquee-section {
	overflow: hidden;
	padding: 70px 0;
}

.marquee-bands {
	transform: skewY(-4deg);
	display: flex;
	flex-direction: column;
	gap: 0;
}

.marquee-track {
	overflow: hidden;
	padding: 18px 0;
}

.marquee-track--1 {
	background-color: var(--color-medium-blue);
}

.marquee-track--2 {
	background-color: var(--color-light-yellow);
}

.marquee-inner {
	display: flex;
	align-items: center;
	white-space: nowrap;
	width: max-content;
	will-change: transform;
	animation: marquee-left 30s linear infinite;
}

.marquee-inner--reverse {
	animation-name: marquee-right;
}

@keyframes marquee-left {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-50%);
	}
}

@keyframes marquee-right {
	from {
		transform: translateX(-50%);
	}

	to {
		transform: translateX(0);
	}
}

.marquee-item {
	font-size: clamp(26px, 4vw, 50px);
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 0 clamp(24px, 4vw, 48px);
}

.marquee-track--1 .marquee-item {
	color: var(--color-light-yellow);
}

.marquee-track--2 .marquee-item {
	color: var(--color-medium-blue);
}

/* ===== SERVICES LIST ===== */
.services-list {
	padding: 60px 5%;
}

.services-list__inner {
	background: var(--gradient-primary);
	border-radius: 24px;
	padding: 64px;
}

.services-list__header {
	margin-bottom: 56px;
}

.services-list__header .label {
	color: rgba(255, 255, 255, 0.7);
	margin-bottom: 24px;
}

.services-list__header .label::before {
	background-color: var(--color-light-blue);
}

.services-list__title {
	font-size: clamp(22px, 2.5vw, 34px);
	font-weight: 700;
	line-height: 1.35;
	color: var(--color-white);
	margin: 0;
	max-width: 780px;
}

/* Row */
.service-item {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
	padding: 28px 0 28px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
	text-decoration: none;
	position: relative;
	transition:
		transform 0.5s cubic-bezier(0.22, 0.61, 0.36, 1),
		padding-left 0.5s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.service-item:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.15);
}

/* Accent gauche */
.service-item::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 0;
	background-color: var(--color-light-yellow);
	border-radius: 2px;
	transition: height 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.service-item--linked {
	cursor: pointer;
}

.service-item--linked:hover {
	transform: translateX(10px);
	padding-left: 16px;
}

.service-item--linked:hover::before {
	height: 60%;
}

.service-item__left {
	display: flex;
	align-items: center;
	gap: 24px;
}

.service-item__number {
	font-size: 25px;
	letter-spacing: 2px;
	font-weight: 400;
	color: rgba(255, 255, 255, 0.35);
	flex-shrink: 0;
	width: 28px;
	transition: color 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.service-item--linked:hover .service-item__number {
	color: var(--color-light-yellow);
}

.service-item__title {
	font-size: 20px;
	font-weight: 400;
	color: var(--color-white);
	margin: 0;
	transition: color 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.service-item__text {
	font-size: 14px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.55);
	margin: 0;
	transition: color 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.service-item--linked:hover .service-item__text {
	color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 768px) {
	.services-list__inner {
		padding: 40px 28px;
	}

	.service-item {
		grid-template-columns: 1fr;
		gap: 8px;
	}
}

/* ===== ARCHIVE ===== */
.container {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 5%;
}

/* ===== SINGLE ARTICLE ===== */

.single-article {
	padding: 48px 8% 80px;
}

.single-article__title {
	font-size: clamp(24px, 3vw, 42px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0 0 32px;
	max-width: 780px;
}

.single-article__thumbnail {
	border-radius: 20px;
	overflow: hidden;
	margin-bottom: 48px;
}

.single-article__thumbnail img {
	width: 100%;
	height: auto;
	display: block;
	max-height: 480px;
	object-fit: cover;
}

/* Corps : 2 colonnes */
.single-article__body {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 48px;
	align-items: start;
}

/* Contenu éditorial */
.single-article__content {
	font-size: 15px;
	line-height: 1.8;
	color: var(--color-dark-blue);
}

.single-article__content p {
	margin: 0 0 20px;
}

.single-article__content h2 {
	font-size: clamp(20px, 2vw, 28px);
	font-weight: 700;
	line-height: 1.25;
	color: var(--color-dark-blue);
	margin: 40px 0 16px;
}

.single-article__content h3 {
	font-size: clamp(16px, 1.5vw, 20px);
	font-weight: 600;
	color: var(--color-dark-blue);
	margin: 32px 0 12px;
}

.single-article__content blockquote {
	background-color: var(--color-light-green);
	border: none;
	border-radius: 12px;
	padding: 28px 32px;
	margin: 32px 0;
}

.single-article__content blockquote p {
	font-style: italic;
	font-weight: 600;
	font-size: 15px;
	line-height: 1.7;
	color: var(--color-dark-blue);
	margin: 0;
}

.single-article__content ul,
.single-article__content ol {
	padding-left: 20px;
	margin: 0 0 20px;
}

.single-article__content li {
	margin-bottom: 8px;
}

.single-article__content a {
	color: var(--color-medium-blue);
	text-decoration: underline;
}

/* Sidebar CTA */
.single-article__sidebar {
	position: sticky;
	top: calc(var(--header-height) + var(--sticky-offset));
}

.sidebar-cta {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	min-height: 260px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background: var(--gradient-primary);
	background-color: var(--color-dark-blue);
}

.sidebar-cta__image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.sidebar-cta__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sidebar-cta__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(10, 30, 45, 0.88) 0%, rgba(10, 30, 45, 0.35) 100%);
	z-index: 1;
}

.sidebar-cta__content {
	position: relative;
	z-index: 2;
	padding: 28px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 20px;
}

.sidebar-cta__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-white);
	line-height: 1.3;
	letter-spacing: -0.01em;
	margin: 0;
}

.sidebar-cta .custom-button {
	padding: 10px 14px 10px 22px;
	gap: 12px;
	font-size: 13px;
	letter-spacing: 0.08em;
	white-space: nowrap;
	max-width: 100%;
}

.sidebar-cta .custom-button .btn-icon {
	width: 28px;
	height: 28px;
}

.sidebar-cta .custom-button:hover {
	transform: translateY(-2px);
	opacity: 1;
	box-shadow: 0 8px 20px rgba(255, 243, 153, 0.25);
}

/* "Pour aller plus loin" */
.related-articles {
	padding: 80px 8%;
}

.related-articles__heading {
	font-size: clamp(22px, 2.5vw, 34px);
	font-weight: 700;
	color: var(--color-dark-blue);
	text-align: center;
	margin: 0 0 48px;
}

@media (max-width: 1024px) {
	.single-article__body {
		grid-template-columns: 1fr;
	}

	.single-article__sidebar {
		position: static;
	}

	.sidebar-cta {
		min-height: 200px;
	}
}

/* ===== ARCHIVE / CATEGORY POSTS ===== */

.archive-posts {
	padding: 80px 8%;
}

.archive-posts__heading {
	font-size: clamp(24px, 2.5vw, 36px);
	font-weight: 700;
	color: var(--color-dark-blue);
	text-align: center;
	margin: 0 0 48px;
}

.posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
}

.post-card {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.post-card__thumbnail {
	position: relative;
	display: block;
	border-radius: 16px;
	overflow: hidden;
	text-decoration: none;
	aspect-ratio: 4/3;
}

.post-card__thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.post-card__thumbnail:hover img {
	transform: scale(1.04);
}

.post-card__arrow {
	position: absolute;
	bottom: 16px;
	right: 16px;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background-color: var(--color-light-yellow);
	color: var(--color-dark-blue);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.post-card__title {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-dark-blue);
	margin: 0;
	text-align: center;
}

.post-card__title a {
	text-decoration: none;
	color: inherit;
}

.archive-pagination {
	margin-top: 60px;
	display: flex;
	justify-content: center;
}

/* ===== CTA BANNER ===== */
.cta-banner {
	padding: 40px 5%;
}

.cta-banner__inner {
	position: relative;
	border-radius: 24px;
	overflow: hidden;
	min-height: 480px;
	display: flex;
	align-items: center;
}

.cta-banner__image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.cta-banner__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cta-banner__content {
	position: relative;
	z-index: 1;
	margin: 40px;
	padding: 52px 48px;
	border-radius: 16px;
	background-color: rgba(24, 54, 69, 0.42);
	backdrop-filter: blur(24px);
	-webkit-backdrop-filter: blur(24px);
	max-width: 800px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 32px;
}

.cta-banner__title {
	font-size: clamp(24px, 2.8vw, 30px);
	font-weight: 700;
	line-height: 1.25;
	color: var(--color-white);
	margin: 0;
}

@media (max-width: 768px) {
	.cta-banner__content {
		margin: 24px;
		padding: 36px 28px;
		max-width: 100%;
	}
}

/* ===== FAQ ===== */
.faq {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: start;
	padding: 80px 8%;
}

.faq__header {
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: sticky;
	top: calc(var(--header-height) + var(--sticky-offset));
}

.faq__title {
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.faq__list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* Item */
.faq-item {
	border-radius: 12px;
	background-color: var(--color-grey);
	overflow: hidden;
	transition: background-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}

.faq-item:not([open]):hover {
	background-color: var(--color-light-yellow);
	transform: scale(1.02);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
}

.faq-item[open] {
	background-color: var(--color-light-yellow);
}

.faq-item__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 20px 24px;
	cursor: pointer;
	list-style: none;
	user-select: none;
}

.faq-item__summary::-webkit-details-marker {
	display: none;
}

.faq-item__question {
	font-size: 16px;
	font-weight: 500;
	color: var(--color-dark-blue);
	line-height: 1.4;
}

/* Icône +/× */
.faq-item__icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1.5px solid var(--color-dark-blue);
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	transition: transform 0.25s ease;
}

.faq-item__icon::before,
.faq-item__icon::after {
	content: '';
	position: absolute;
	background-color: var(--color-dark-blue);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

.faq-item__icon::before {
	width: 12px;
	height: 1.5px;
}

.faq-item__icon::after {
	width: 1.5px;
	height: 12px;
}

.faq-item[open] .faq-item__icon::after {
	transform: rotate(90deg);
	opacity: 0;
}

/* Réponse */
.faq-item__answer {
	padding: 0 24px 24px;
	font-size: 14px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.75;
}

.faq-item__answer p {
	margin: 0;
}

@media (max-width: 768px) {
	.faq {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.faq__header {
		position: static;
	}
}

/* ===== CABINET SECTION ===== */

.cabinet {
	padding: 40px 5%;
}

.cabinet__inner {
	background: var(--gradient-primary);
	border-radius: 28px;
	padding: 64px 72px;
	display: flex;
	flex-direction: column;
	gap: 64px;
}

/* En-tête */
.cabinet__top {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.cabinet__top .label {
	color: var(--color-white);
}

.cabinet__top .label::before {
	background-color: var(--color-light-yellow);
}

.cabinet__title {
	font-size: clamp(20px, 2vw, 30px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-white);
	margin: 0;
}

/* Corps */
.cabinet__body {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 60px;
	align-items: start;
}

.cabinet__left {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.cabinet__subtitle {
	font-size: clamp(15px, 1.3vw, 18px);
	font-weight: 700;
	color: var(--color-white);
	line-height: 1.4;
	margin: 0;
}

.cabinet__text {
	font-size: 14px;
	line-height: 1.8;
	color: rgba(255, 255, 255, 0.65);
	margin: 0;
}

/* Grille des stats : diagonale image / gradient */
.cabinet__stats {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-template-rows: 1fr 1fr;
	gap: 14px;
	height: 100%;
}

.cabinet-stat {
	position: relative;
	height: 100%;
	border-radius: 18px;
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	min-height: 160px;
}

/* Positions diagonales */
.cabinet-stat--1 {
	grid-column: 1 / 4;
}

/* image, large haut-gauche */
.cabinet-stat--2 {
	grid-column: 4 / 6;
}

/* gradient, petit haut-droite */
.cabinet-stat--3 {
	grid-column: 1 / 3;
}

/* gradient, petit bas-gauche */
.cabinet-stat--4 {
	grid-column: 3 / 6;
}

/* image, large bas-droite */

/* Cards image */
.cabinet-stat--image .cabinet-stat__image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.cabinet-stat--image .cabinet-stat__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.cabinet-stat__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, #183645 0%, #1a8fa6 100%);
	z-index: 1;
	opacity: .9;
}

/* Cards gradient */
.cabinet-stat--gradient {
	background: linear-gradient(135deg, #183645 0%, #1a8fa6 100%);
}

/* Contenu commun */
.cabinet-stat__content {
	position: relative;
	z-index: 2;
	padding: 24px 28px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	width: 100%;
}

.cabinet-stat__value {
	font-size: clamp(22px, 2.2vw, 32px);
	font-weight: 500;
	color: var(--color-light-yellow);
	line-height: 1.1;
}

.cabinet-stat__label {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.4;
}

@media (max-width: 1024px) {
	.cabinet__inner {
		padding: 48px 40px;
	}

	.cabinet__body {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.cabinet__stats {
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: unset;
	}

	.cabinet-stat--1,
	.cabinet-stat--2,
	.cabinet-stat--3,
	.cabinet-stat--4 {
		grid-column: auto;
	}
}

@media (max-width: 640px) {
	.cabinet__inner {
		padding: 40px 24px;
	}

	.cabinet__stats {
		grid-template-columns: 1fr;
	}
}

/* ===== SOMMAIRE SECTION ===== */

.sommaire {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	padding: 80px 8%;
	align-items: start;
}

/* Panneau gauche */
.sommaire__panel {
	position: sticky;
	top: calc(var(--header-height) + var(--sticky-offset));
	border-radius: 24px;
	overflow: hidden;
	min-height: 560px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	align-items: flex-start;
}

.sommaire__panel-image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.sommaire__panel-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sommaire__panel-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(10, 30, 45, 0.9) 0%, rgba(10, 30, 45, 0.4) 60%, transparent 100%);
	z-index: 1;
}

.sommaire__panel-content {
	position: relative;
	z-index: 2;
	margin: 24px;
	border-radius: 16px;
	padding: 36px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 24px;
	background-color: rgba(19, 94, 108, 0.55);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
}

.sommaire__panel-content .label {
	color: var(--color-white);
}

.sommaire__panel-text {
	font-size: clamp(18px, 2vw, 26px);
	font-weight: 500;
	line-height: 1.4;
	color: var(--color-white);
	margin: 0;
}

/* Liste d'étapes droite */
.sommaire__list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.sommaire-item {
	background-color: var(--color-grey);
	border-radius: 16px;
	padding: 28px 32px;
	display: flex;
	flex-direction: column;
	gap: 20px;
	min-height: 350px;
	display: flex;
	justify-content: center;
}

.sommaire-item__number {
	font-size: 20px;
	font-weight: 500;
	color: var(--color-dark-blue);
	opacity: 0.4;
	letter-spacing: 0.05em;
}

.sommaire-item__title {
	font-size: 20px;
	font-weight: 700;
	color: var(--color-dark-blue);
	margin: 0;
	line-height: 1.3;
}

.sommaire-item__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.sommaire-item__list-item {
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 13px;
	font-style: italic;
	color: var(--color-dark-blue);
}

.sommaire-item__list-icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background-color: var(--color-light-green);
	color: var(--color-dark-blue);
	display: flex;
	align-items: center;
	justify-content: center;
}

@media (max-width: 1024px) {
	.sommaire {
		grid-template-columns: 1fr;
	}

	.sommaire__panel {
		position: relative;
		top: auto;
		min-height: 420px;
	}
}

/* ===== TABS SECTION ===== */

.tabs-section {
	padding: 80px 8%;
}

.tabs-section__header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: end;
	margin-bottom: 56px;
}

.tabs-section__header-left {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.tabs-section__title {
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.tabs-section__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin: 0;
}

/* Nav */
.tabs-section__nav {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	border-bottom: 1px solid var(--color-grey);
	margin-bottom: 56px;
	gap: 0;
}

.tab-btn {
	flex: 0 0 auto;
	background: none !important;
	background-color: transparent !important;
	border: none !important;
	border-bottom: 3px solid transparent !important;
	margin-bottom: -1px;
	padding: 16px 24px;
	font-family: var(--font-family-primary);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-dark-blue) !important;
	opacity: 0.45;
	cursor: pointer;
	transition: opacity 0.2s ease, border-color 0.2s ease;
	text-align: left;
	box-shadow: none !important;
	outline: none !important;
	border-radius: 0 !important;
}

.tab-btn:hover,
.tab-btn:focus,
.tab-btn:active {
	background: none !important;
	background-color: transparent !important;
	border-color: transparent !important;
	border-bottom-color: transparent !important;
	box-shadow: none !important;
	outline: none !important;
	color: var(--color-dark-blue) !important;
	opacity: 0.75;
}

.tab-btn--active,
.tab-btn--active:hover,
.tab-btn--active:focus {
	opacity: 1;
	border-bottom-color: var(--color-dark-blue) !important;
}

/* Panels */
.tab-panel {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}

.tab-panel[hidden="true"] {
	display: none;
}

.tab-panel--no-image {
	grid-template-columns: 1fr;
}

.tab-panel__content {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.tab-panel__title {
	font-size: clamp(22px, 2.5vw, 34px);
	font-weight: 700;
	line-height: 1.25;
	color: var(--color-dark-blue);
	margin: 0;
}

.tab-panel__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.75;
	margin: 0;
}

.tab-panel__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.tab-panel__list-item {
	display: flex;
	align-items: center;
	gap: 16px;
	font-size: 14px;
	font-style: italic;
	color: var(--color-dark-blue);
}

.tab-panel__list-icon {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background-color: var(--color-light-blue);
	color: var(--color-dark-blue);
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Media */
.tab-panel__media {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.tab-panel__decoration {
	position: absolute;
	top: 5%;
	left: 0;
	width: 90%;
	height: 90%;
	background-color: var(--color-light-blue);
	border-radius: 20px;
	z-index: 0;
}

.tab-panel__image {
	position: relative;
	z-index: 1;
	width: 92%;
	height: 420px;
	object-fit: cover;
	border-radius: 20px;
	display: block;
	margin-left: auto;
}

@media (max-width: 1024px) {
	.tabs-section__header {
		grid-template-columns: 1fr;
	}

	.tab-panel {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	.tab-panel__media {
		justify-content: center;
	}
}

@media (max-width: 768px) {
	.tabs-section__nav {
		flex-direction: column;
	}

	.tab-btn {
		border-bottom: none;
		border-left: 3px solid transparent;
		margin-bottom: 0;
		margin-left: -1px;
		white-space: break-spaces;
	}

	.tab-btn--active {
		border-left-color: var(--color-dark-blue);
		border-bottom-color: transparent;
	}
}

/* ===== CARDS GRID ===== */

.cards-grid {
	padding: 80px 8%;
}

.cards-grid__header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: end;
	margin-bottom: 48px;
}

.cards-grid__header-left {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.cards-grid__title {
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.cards-grid__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin: 0;
}

.cards-grid__list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
}

.grid-card {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	min-height: 460px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background: linear-gradient(135deg, #183645 0%, #1a8fa6 100%);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.grid-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.15);
}

.grid-card__image {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.grid-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.5s ease;
	opacity: 0.25;
}

.grid-card:hover .grid-card__image img {
	transform: scale(1.04);
}

.grid-card::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.35) 0%, transparent 60%);
	z-index: 1;
}

.grid-card__content {
	position: relative;
	z-index: 2;
	padding: 32px;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.grid-card__title {
	font-size: 20px;
	font-weight: 600;
	color: var(--color-white);
	margin: 0;
	line-height: 1.3;
}

.grid-card__separator {
	border: none;
	border-top: 1px solid rgba(255, 255, 255, 0.35);
	margin: 0;
}

.grid-card__text {
	font-size: 14px;
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}

@media (max-width: 1024px) {
	.cards-grid__header {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.cards-grid__list {
		grid-template-columns: 1fr;
	}
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
	.posts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.hero {
		grid-template-columns: 1fr;
		padding: 60px 5%;
		min-height: auto;
		gap: 40px;
	}

	.hero__media {
		height: 420px;
	}
}

@media (max-width: 640px) {
	.posts-grid {
		grid-template-columns: 1fr;
	}
}

/* ===== CONTACT ===== */
.contact-section {
	padding: 80px 8%;
}

.contact-section__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: start;
}

.contact-section__info {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.contact-section__title {
	font-size: clamp(28px, 3vw, 40px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.contact-section__text {
	font-size: 15px;
	line-height: 1.75;
	color: var(--color-dark-blue);
	opacity: 0.7;
	margin: 0;
}

.contact-section__contact-row {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: 12px;
}

.contact-section__phone,
.contact-section__whatsapp {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	height: 52px;
	padding: 0 24px;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-decoration: none;
	border-radius: 999px;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.contact-section__phone {
	background-color: var(--color-dark-blue);
	color: #fff;
	box-shadow: 0 6px 16px rgba(11, 31, 58, 0.2);
}

.contact-section__phone:hover {
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(11, 31, 58, 0.28);
	opacity: 1;
}

.contact-section__whatsapp {
	background-color: #25D366;
	color: #fff;
	box-shadow: 0 6px 16px rgba(37, 211, 102, 0.3);
}

.contact-section__whatsapp:hover {
	background-color: #1ebe57;
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(37, 211, 102, 0.4);
}

.contact-section__btn-icon {
	flex-shrink: 0;
}

.contact-section__details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	padding: 28px;
	background-color: rgba(0, 0, 0, 0.025);
	border-radius: 16px;
}

.contact-section__detail {
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.contact-section__detail--full {
	grid-column: 1 / -1;
}

.contact-section__detail-icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background-color: var(--color-light-yellow);
	color: var(--color-dark-blue);
}

.contact-section__detail-body {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}

.contact-section__detail-title {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-dark-blue);
	margin: 0;
	opacity: 0.55;
}

.contact-section__detail-text {
	font-size: 15px;
	line-height: 1.55;
	color: var(--color-dark-blue);
	margin: 0;
}

.contact-section__access-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 15px;
	line-height: 1.5;
	color: var(--color-dark-blue);
}

@media (max-width: 540px) {
	.contact-section__details {
		grid-template-columns: 1fr;
		padding: 22px;
	}

	.contact-section__phone,
	.contact-section__whatsapp {
		flex: 1 1 auto;
	}
}

.contact-section__advantages {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.contact-section__advantages-title {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-dark-blue);
	margin: 0;
}

.contact-section__advantages-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.contact-section__advantages-item {
	display: flex;
	align-items: center;
	gap: 14px;
	font-size: 15px;
	line-height: 1.5;
	color: var(--color-dark-blue);
}

.contact-section__advantages-icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background-color: var(--color-light-yellow);
	border-radius: 50%;
	color: var(--color-dark-blue);
}

.contact-section__form {
	position: sticky;
	top: calc(var(--header-height) + var(--sticky-offset));
}

/* Liens dans le formulaire Elementor (mention RGPD, conditions, etc.) */
.contact-section__form a,
.contact-section__form a:link,
.contact-section__form a:visited {
	color: var(--color-dark-blue);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: opacity 0.2s ease;
}

.contact-section__form a:hover,
.contact-section__form a:focus {
	color: var(--color-medium-blue);
	opacity: 0.85;
}

@media (max-width: 768px) {
	.contact-section {
		padding: 60px 5%;
	}

	.contact-section__inner {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.contact-section__form {
		position: static;
	}
}

/* ===== LEGAL (mentions légales, politique de confidentialité) ===== */
.legal-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 80px 8% 120px;
}

.legal-section__header {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding-bottom: 32px;
	margin-bottom: 48px;
	border-bottom: 1px solid rgba(11, 31, 58, 0.12);
}

.legal-section__title {
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-dark-blue);
	margin: 0;
}

.legal-section__updated {
	font-size: 14px;
	color: var(--color-dark-blue);
	opacity: 0.55;
	margin: 0;
}

.legal-section__content {
	font-size: 16px;
	line-height: 1.75;
	color: var(--color-dark-blue);
}

.legal-section__content > * + * {
	margin-top: 1.25em;
}

.legal-section__content h2 {
	font-size: clamp(22px, 2.4vw, 28px);
	font-weight: 700;
	line-height: 1.3;
	color: var(--color-dark-blue);
	margin: 2.4em 0 0.6em;
}

.legal-section__content h2:first-child {
	margin-top: 0;
}

.legal-section__content h3 {
	font-size: clamp(18px, 1.8vw, 20px);
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-dark-blue);
	margin: 1.8em 0 0.5em;
}

.legal-section__content h4 {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-dark-blue);
	margin: 1.4em 0 0.4em;
}

.legal-section__content p {
	margin: 0;
	color: var(--color-dark-blue);
	opacity: 0.85;
}

.legal-section__content a {
	color: var(--color-dark-blue);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: opacity 0.2s ease;
}

.legal-section__content a:hover {
	opacity: 0.65;
}

.legal-section__content strong {
	font-weight: 700;
	color: var(--color-dark-blue);
}

.legal-section__content ul,
.legal-section__content ol {
	margin: 0;
	padding-left: 1.4em;
	color: var(--color-dark-blue);
	opacity: 0.85;
}

.legal-section__content li + li {
	margin-top: 0.4em;
}

.legal-section__content ul li::marker {
	color: var(--color-light-yellow);
}

.legal-section__content blockquote {
	margin: 1.5em 0;
	padding: 16px 22px;
	border-left: 3px solid var(--color-light-yellow);
	background-color: rgba(0, 0, 0, 0.025);
	border-radius: 0 8px 8px 0;
	font-style: italic;
	color: var(--color-dark-blue);
}

.legal-section__content blockquote p {
	margin: 0;
	opacity: 1;
}

.legal-section__content hr {
	border: 0;
	height: 1px;
	background-color: rgba(11, 31, 58, 0.12);
	margin: 2.5em 0;
}

.legal-section__content table {
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
	margin: 1.5em 0;
}

.legal-section__content th,
.legal-section__content td {
	padding: 12px 14px;
	text-align: left;
	border-bottom: 1px solid rgba(11, 31, 58, 0.1);
	vertical-align: top;
}

.legal-section__content th {
	font-weight: 700;
	background-color: rgba(0, 0, 0, 0.025);
}

@media (max-width: 768px) {
	.legal-section {
		padding: 56px 5% 80px;
	}

	.legal-section__header {
		padding-bottom: 24px;
		margin-bottom: 32px;
	}

	.legal-section__content {
		font-size: 15px;
	}
}

/* ===== SITE FOOTER ===== */
.site-footer {
	background-color: var(--color-dark-blue);
	color: var(--color-white);
	max-width: 100vw !important;
	padding-block-start: 0px !important;
}

/* Bande CTA */
.site-footer__cta {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	padding: 40px 8%;
	background: var(--gradient-primary);
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
	overflow: hidden;
	min-height: 300px;
}

.site-footer__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	opacity: 0.12;
	pointer-events: none;
}

.site-footer__cta-title {
	font-size: clamp(22px, 3vw, 36px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-white);
	margin: 0;
	max-width: 600px;
}

/* Corps */
.site-footer__body {
	padding: 64px 8%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 48px;
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	text-align: center;
}

.site-footer__brand-name {
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 800;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-white);
}

.site-footer__brand-subtitle {
	font-size: clamp(13px, 1.5vw, 16px);
	font-weight: 400;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-white);
	opacity: 0.7;
}

/* Navigation 3 colonnes */
.site-footer__nav {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	width: 100%;
	max-width: 860px;
}

.site-footer__nav-col {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.site-footer__nav-title {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-white);
	opacity: 0.5;
	margin: 0 0 4px;
}

.site-footer__nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.site-footer__nav-list li a {
	font-size: 14px;
	font-weight: 400;
	color: var(--color-white);
	text-decoration: none;
	opacity: 0.85;
	transition: opacity 0.2s ease;
}

.site-footer__nav-list li a:hover {
	opacity: 1;
}

/* Bas de page */
.site-footer__bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 8%;
	border-top: 1px solid rgba(255, 255, 255, 0.15);
	font-size: 12px;
	color: var(--color-white);
	opacity: 0.6;
}

.site-footer__copyright,
.site-footer__credit {
	font-size: 12px;
	color: var(--color-white);
}

.site-footer__credit a {
	color: var(--color-white);
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: opacity 0.2s ease;
}

.site-footer__credit a:hover {
	opacity: 1;
	color: var(--color-white);
}

@media (max-width: 768px) {
	.site-footer__cta {
		flex-direction: column;
		align-items: flex-start;
		padding: 40px 5%;
		gap: 24px;
	}

	.site-footer__body {
		padding: 48px 5%;
		align-items: flex-start;
	}

	.site-footer__brand {
		align-items: flex-start;
		text-align: left;
	}

	.site-footer__nav {
		grid-template-columns: 1fr 1fr;
		max-width: 100%;
	}

	.site-footer__bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		padding: 20px 5%;
	}
}

/* ===== TABLE SECTION ===== */
.table-section {
	padding: 80px 8%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 40px;
}

.table-section__header {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 100%;
}

.table-section__title {
	font-size: clamp(24px, 2.5vw, 36px);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-dark-blue);
	margin: 0;
}

.table-section__wrapper {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	border-radius: 12px;
	border: 1px solid rgba(24, 54, 69, 0.12);
	max-width: 100%;
}

.table-section__wrapper table {
	border-collapse: collapse;
	font-family: var(--font-family-primary);
	font-size: 14px;
	color: var(--color-dark-blue);
}

.table-section__wrapper thead tr {
	background: var(--gradient-primary);
}

.table-section__wrapper thead th {
	padding: 28px 24px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-align: center;
	color: var(--color-white);
	white-space: nowrap;
}

.table-section__wrapper tbody tr {
	border-bottom: 1px solid rgba(24, 54, 69, 0.08);
	transition: background-color 0.15s ease;
}

.table-section__wrapper tbody tr:last-child {
	border-bottom: none;
}

.table-section__wrapper tbody tr:nth-child(even) {
	background-color: var(--color-grey);
}

.table-section__wrapper tbody tr:hover {
	background-color: rgba(164, 241, 255, 0.15);
}

.table-section__wrapper tbody td {
	padding: 14px 20px;
	line-height: 1.5;
	vertical-align: top;
}

.table-section__wrapper tfoot tr {
	background-color: var(--color-grey);
	border-top: 2px solid rgba(24, 54, 69, 0.15);
}

.table-section__wrapper tfoot td,
.table-section__wrapper tfoot th {
	padding: 14px 20px;
	font-weight: 600;
	font-size: 13px;
}

@media (max-width: 768px) {
	.table-section {
		padding: 60px 5%;
	}

	.table-section__wrapper thead th,
	.table-section__wrapper tbody td,
	.table-section__wrapper tfoot td,
	.table-section__wrapper tfoot th {
		padding: 12px 14px;
		font-size: 13px;
	}
}

/* ===== GLOBAL RESPONSIVE REFINEMENTS ===== */

/* Tablet (≤ 1024px) */
@media (max-width: 1024px) {
	:root {
		--header-height: 72px;
	}

	.site-header__logo-name {
		font-size: 18px;
	}

	.site-header__logo-title {
		font-size: 11px;
		letter-spacing: 0.28em;
	}

	/* Cards carousel: stack header */
	.cards-carousel {
		padding: 60px 0 60px 5%;
	}

	.cards-carousel__header {
		grid-template-columns: 1fr;
		gap: 32px;
		padding-right: 5%;
		margin-bottom: 32px;
	}

	/* Cabinet */
	.cabinet {
		padding: 32px 5%;
	}

	.cabinet__top .label {
		margin-bottom: 0;
	}

	/* Tabs */
	.tabs-section {
		padding: 60px 5%;
	}

	.tab-panel__image {
		height: 320px;
		width: 100%;
	}

	.tab-panel__decoration {
		width: 92%;
	}

	/* Cards grid */
	.cards-grid {
		padding: 60px 5%;
	}

	.grid-card {
		min-height: 380px;
	}

	/* Sommaire */
	.sommaire {
		padding: 60px 5%;
	}

	.sommaire-item {
		min-height: 0;
		padding: 28px;
	}

	/* FAQ */
	.faq {
		padding: 60px 5%;
	}

	/* Services list */
	.services-list {
		padding: 32px 5%;
	}

	.services-list__inner {
		padding: 48px 40px;
	}

	/* Single article */
	.single-article {
		padding: 40px 5% 60px;
	}

	.related-articles {
		padding: 60px 5%;
	}

	/* Contact */
	.contact-section {
		padding: 60px 5%;
	}

	.contact-section__inner {
		gap: 56px;
	}

	/* CTA banner */
	.cta-banner__inner {
		min-height: 380px;
	}

	.cta-banner__content {
		margin: 24px;
		padding: 40px 32px;
	}

	/* Citation */
	.citation {
		padding: 60px 5%;
	}

	/* Marquee */
	.marquee-section {
		padding: 48px 0;
	}

	/* Footer */
	.site-footer__cta {
		flex-direction: column;
		align-items: flex-start;
		padding: 40px 5%;
		min-height: 0;
		gap: 24px;
	}

	.site-footer__body {
		padding: 56px 5%;
	}
}

/* Mobile (≤ 768px) */
@media (max-width: 768px) {
	:root {
		--header-height: 68px;
		--sticky-offset: 16px;
	}

	/* Hero */
	.hero__title {
		font-size: clamp(26px, 6vw, 32px);
	}

	.hero__decoration {
		width: 85%;
		height: 85%;
	}

	.hero__image {
		width: 95%;
	}

	/* Citation */
	.citation__inner {
		/* padding-left: clamp(20px, 6vw, 40px); */
	}

	/* Cards carousel */
	.card-item {
		height: 440px;
	}

	.card-item__panel,
	.card-item__footer {
		padding: 28px 24px;
	}

	/* Services list */
	.services-list__inner {
		padding: 36px 24px;
	}

	.services-list__header {
		margin-bottom: 36px;
	}

	.service-item__left {
		gap: 16px;
	}

	.service-item__title {
		font-size: 18px;
	}

	.service-item--linked:hover {
		transform: none;
		padding-left: 0;
	}

	/* Cabinet */
	.cabinet__inner {
		padding: 40px 24px;
		gap: 40px;
	}

	.cabinet__top {
		gap: 16px;
	}

	/* Tabs */
	.tabs-section__header {
		margin-bottom: 36px;
	}

	.tabs-section__nav {
		margin-bottom: 36px;
	}

	.tab-panel__image {
		height: 260px;
	}

	/* Cards grid */
	.grid-card {
		min-height: 340px;
	}

	.grid-card__content {
		padding: 24px;
	}

	/* Sommaire */
	.sommaire__panel-content {
		margin: 16px;
		padding: 28px 24px;
	}

	/* FAQ */
	.faq-item__summary {
		padding: 18px 20px;
	}

	.faq-item__answer {
		padding: 0 20px 20px;
	}

	/* Single article */
	.single-article__content {
		font-size: 14px;
	}

	.single-article__content blockquote {
		padding: 22px 24px;
	}

	/* Posts grid */
	.post-card__arrow {
		width: 38px;
		height: 38px;
	}

	/* CTA banner */
	.cta-banner {
		padding: 32px 5%;
	}

	.cta-banner__inner {
		min-height: 320px;
	}

	/* Contact */
	.contact-section__inner {
		gap: 40px;
	}

	.contact-section__phone,
	.contact-section__whatsapp {
		flex: 1 1 calc(50% - 6px);
		min-width: 0;
		height: 48px;
		font-size: 15px;
		padding: 0 16px;
	}

	/* Footer */
	.site-footer__nav {
		grid-template-columns: 1fr 1fr;
		gap: 32px 24px;
	}

	.site-footer__brand-name {
		letter-spacing: 0.15em;
	}

	.site-footer__brand-subtitle {
		letter-spacing: 0.25em;
	}

	/* Mobile menu refinements */
	.mobile-menu__list > li > a,
	.mobile-menu .menu-item > a {
		font-size: 20px;
		padding: 16px 4px;
	}
}

/* Small mobile (≤ 480px) */
@media (max-width: 480px) {
	:root {
		--header-height: 64px;
	}

	.site-header__inner {
		padding: 0 5%;
	}

	.site-header__logo-name {
		font-size: 16px;
		letter-spacing: 0.15em;
	}

	.site-header__logo-title {
		font-size: 10px;
		letter-spacing: 0.22em;
	}

	/* Hero */
	.hero {
		padding: 48px 5%;
		gap: 32px;
	}

	.hero__media {
		height: 320px;
	}

	.hero__title {
		font-size: clamp(24px, 7vw, 30px);
	}

	/* Citation */
	.citation {
		padding: 48px 5%;
	}

	.citation__text {
		line-height: 1.6;
	}

	/* Marquee */
	.marquee-section {
		padding: 32px 0;
	}

	/* Cards carousel */
	.card-item {
		height: 400px;
	}

	.card-item__footer-title,
	.card-item__panel-title {
		font-size: 18px;
	}

	/* Services list */
	.services-list__inner {
		padding: 28px 20px;
		border-radius: 18px;
	}

	.service-item__number {
		font-size: 20px;
		width: 22px;
	}

	.service-item__title {
		font-size: 16px;
	}

	.service-item__text {
		font-size: 13px;
	}

	/* Cabinet */
	.cabinet__inner {
		padding: 32px 20px;
		border-radius: 22px;
	}

	.cabinet-stat__content {
		padding: 20px 22px;
	}

	/* Tabs */
	.tabs-section {
		padding: 48px 5%;
	}

	.tab-btn {
		padding: 14px 16px;
		font-size: 10px;
	}

	.tab-panel__image {
		height: 220px;
	}

	/* Cards grid */
	.grid-card {
		min-height: 300px;
	}

	/* Sommaire */
	.sommaire-item {
		padding: 24px 22px;
	}

	/* FAQ */
	.faq {
		padding: 48px 5%;
		gap: 28px;
	}

	.faq-item__question {
		font-size: 15px;
	}

	/* Single article */
	.single-article {
		padding: 32px 5% 48px;
	}

	.single-article__title {
		font-size: clamp(22px, 6vw, 28px);
		margin-bottom: 24px;
	}

	.single-article__thumbnail {
		margin-bottom: 32px;
		border-radius: 14px;
	}

	.single-article__thumbnail img {
		max-height: 280px;
	}

	.single-article__content h2 {
		margin: 32px 0 12px;
	}

	.related-articles {
		padding: 48px 5%;
	}

	/* CTA banner */
	.cta-banner {
		padding: 24px 5%;
	}

	.cta-banner__inner {
		min-height: 280px;
	}

	.cta-banner__content {
		margin: 16px;
		padding: 28px 22px;
		gap: 24px;
	}

	/* Contact */
	.contact-section {
		padding: 48px 5%;
	}

	.contact-section__phone,
	.contact-section__whatsapp {
		flex: 1 1 100%;
	}

	.contact-section__details {
		padding: 22px 20px;
	}

	/* Footer */
	.site-footer__cta {
		padding: 32px 5%;
		min-height: 200px;
	}

	.site-footer__body {
		padding: 40px 5%;
		gap: 36px;
	}

	.site-footer__nav {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	/* Mobile menu */
	.mobile-menu__inner {
		padding: 64px 5% 40px;
		gap: 28px;
	}

	.mobile-menu__list > li > a,
	.mobile-menu .menu-item > a {
		font-size: 18px;
		padding: 14px 4px;
	}

	.mobile-menu__footer {
		padding-top: 24px;
	}
}

/* ===== BREADCRUMB (Yoast SEO) ===== */
.breadcrumb {
	display: block;
	margin: 0 0 16px;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-dark-blue);
	opacity: 0.6;
	line-height: 1.5;
}

.breadcrumb a {
	color: var(--color-dark-blue);
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.breadcrumb a:hover {
	opacity: 0.65;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.breadcrumb .breadcrumb_last,
.breadcrumb [aria-current="page"] {
	font-weight: 700;
	opacity: 1;
}

/* Séparateur Yoast (par défaut "»" ou similaire) — on cible le texte autour des liens */
.breadcrumb > span > span,
.breadcrumb > span {
	display: inline;
}

/* Dans le hero/article, on enlève l'opacité du dernier crumb car le contexte est sombre/coloré */
.legal-section__header .breadcrumb,
.single-article__header .breadcrumb,
.contact-section__info .breadcrumb,
.hero__content .breadcrumb {
	margin-bottom: 20px;
}

/* ===== HERO TRUSTINDEX ===== */
.hero__trustindex {
	margin: 0 0 8px;
}

.hero__trustindex:empty {
	display: none;
}

/* Trustindex peut générer du contenu volumineux — on cale le widget */
.hero__trustindex > * {
	max-width: 100%;
}

/* ===== SCROLL REVEAL ANIMATIONS ===== */
/* Les classes .reveal sont posées par main.js, puis .is-revealed est ajouté
   quand l'élément entre dans le viewport (IntersectionObserver). */

@keyframes reveal-in {
	from {
		opacity: 0;
		transform: translate3d(0, 28px, 0);
	}

	to {
		opacity: 1;
		transform: translate3d(0, 0, 0);
	}
}

@keyframes reveal-in-fade {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.reveal {
	opacity: 0;
}

.reveal.is-revealed {
	animation: reveal-in 0.9s cubic-bezier(0.22, 0.61, 0.36, 1) var(--reveal-delay, 0s) both;
}

/* Variante "fade seul" pour les éléments où une translation casserait
   un positionnement spécial (sticky, absolute, décoration de fond). */
.reveal--fade.is-revealed {
	animation: reveal-in-fade 1s cubic-bezier(0.22, 0.61, 0.36, 1) var(--reveal-delay, 0s) both;
}

/* Respecter le réglage système "réduire les animations" */
@media (prefers-reduced-motion: reduce) {

	.reveal,
	.reveal--fade {
		opacity: 1 !important;
		animation: none !important;
	}
}



/* TrustIndex */

.ti-widget {
	text-align: left!important;
}

.ti-widget-container {
	margin: 1em 0px!important;
}