/* ==========================================================================
   Landing Page V2 — empreinte-carbone.org
   Design: Trust & Authority SaaS B2B pattern
   Scoped under body .landing-page to override theme + Elementor kit styles
   ========================================================================== */

/* ---------- Design Tokens ---------- */

body .landing-page {
	--lp-primary: #00BAC7;
	--lp-primary-dark: #009AA5;
	--lp-secondary: #2C3E50;
	--lp-text: #4E4E4E;
	--lp-text-light: #6B7280;
	--lp-accent-bg: #F1F7F9;
	--lp-dark-blue: #0A0E15;
	--lp-white: #FFFFFF;
	--lp-border: #E2E8F0;
	--lp-radius: 8px;
	--lp-radius-lg: 16px;
	--lp-shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
	--lp-shadow-md: 0 4px 16px rgba(0,0,0,0.08);
	--lp-shadow-lg: 0 8px 32px rgba(0,0,0,0.1);
	--lp-transition: 0.25s ease-out;
	--lp-transition-slow: 0.4s ease-out;

	color: var(--lp-text);
	font-family: "Manrope", sans-serif;
	font-size: 16px;
	line-height: 1.6;
}

/* ---------- Global Resets ---------- */

body .landing-page h1,
body .landing-page h2,
body .landing-page h3 {
	font-family: "Manrope", sans-serif;
	color: var(--lp-dark-blue);
	font-weight: 700;
	margin: 0 0 16px;
	line-height: 1.2;
}

body .landing-page p {
	font-family: "Manrope", sans-serif;
	font-size: 16px;
	line-height: 1.6;
	color: var(--lp-text);
	margin: 0 0 16px;
}

body .landing-page p:last-child {
	margin-bottom: 5px;
}

body .landing-page span,
body .landing-page blockquote,
body .landing-page a {
	font-family: "Manrope", sans-serif;
}

body .landing-page section {
	padding: 72px 0;
}

/* ---------- Scroll Reveal ---------- */

body .landing-page .lp-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

body .landing-page .lp-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	body .landing-page .lp-reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* ---------- Buttons ---------- */

body .landing-page .landing-btn {
	display: inline-block;
	padding: 16px 32px;
	border-radius: var(--lp-radius);
	font-family: "Manrope", sans-serif;
	font-size: 17px;
	font-weight: 700;
	text-decoration: none;
	transition: all var(--lp-transition);
	cursor: pointer;
	letter-spacing: -0.01em;
}

body .landing-page .landing-btn:focus-visible {
	outline: 3px solid var(--lp-primary);
	outline-offset: 3px;
}

body .landing-page .landing-btn--primary {
	background: var(--lp-primary);
	color: var(--lp-white);
	border: 2px solid var(--lp-primary);
	box-shadow: 0 4px 14px rgba(0, 186, 199, 0.35);
}

body .landing-page .landing-btn--primary:hover {
	background: var(--lp-primary-dark);
	border-color: var(--lp-primary-dark);
	color: var(--lp-white);
	box-shadow: 0 6px 20px rgba(0, 186, 199, 0.45);
	transform: translateY(-2px);
}

body .landing-page .landing-btn--primary:active {
	transform: translateY(0);
	box-shadow: 0 2px 8px rgba(0, 186, 199, 0.3);
}

body .landing-page .landing-btn--outline {
	background-color: transparent;
	color: var(--lp-primary);
	border: 2px solid var(--lp-primary);
}

body .landing-page .landing-btn--outline:hover {
	background-color: var(--lp-primary);
	color: var(--lp-white);
	transform: translateY(-2px);
}

/* ---------- Hero ----------- */

body .landing-page .landing-hero {
	padding-top: clamp(120px, 13vh, 140px);
	padding-bottom: clamp(55px, 4vh, 48px);
	background: var(--lp-white);
	min-height: calc(100vh - 180px);
	min-height: calc(100dvh - 180px);
	display: flex;
	align-items: center;
}

body .landing-page .landing-hero .container {
	width: 100%;
}

body .landing-page .landing-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: 56px;
	align-items: center;
}

body .landing-page .landing-hero__content {
	text-align: left;
}

body .landing-page .landing-hero h1 {
	font-size: 52px;
	line-height: 1.08;
	margin: 0 0 20px;
	color: var(--lp-dark-blue);
	font-weight: 800;
	font-family: "Manrope", sans-serif;
	letter-spacing: -0.02em;
}

body .landing-page .landing-hero__subtitle {
	font-size: 22px;
	line-height: 1.4;
	font-weight: 600;
	color: var(--lp-primary);
	margin: 0 0 20px;
	font-family: "Manrope", sans-serif;
}

body .landing-page .landing-hero__desc {
	margin: 0 0 32px;
	font-size: 17px;
	line-height: 1.7;
	color: var(--lp-text-light);
}

body .landing-page .landing-hero__microcopy {
	margin: 20px 0 0;
	font-size: 15px;
	font-weight: 600;
	color: var(--lp-dark-blue);
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

body .landing-page .landing-hero__microcopy .landing-hero__sep {
	color: var(--lp-primary);
	font-weight: 700;
}

body .landing-page .landing-hero__visual {
	position: relative;
}

/* ---------- Hero Bento Composition ---------- */

.hero-bento {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1.1;
	font-family: "Manrope", sans-serif;
	overflow: visible;
}

.hero-bento__card {
	position: absolute;
	background: #fff;
	border: 1px solid #E2E8F0;
	border-radius: 12px;
	padding: 14px;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
	box-sizing: border-box;
	transition: transform 0.3s ease;
}

/* Card 1 — MESURER : Donut (top-left) — height auto pour contenir les 3 scopes */
.hero-bento__card--donut {
	top: 0;
	left: 0;
	width: 46%;
	transform: rotate(1.5deg);
}

.hero-bento__card--donut:hover {
	transform: rotate(0deg);
}

/* Card 2 — PROJETER : Trajectoire (top-right) */
.hero-bento__card--chart {
	top: 2%;
	right: 0;
	width: 46%;
	transform: rotate(-1.5deg);
}

.hero-bento__card--chart:hover {
	transform: rotate(0deg);
}

/* Card 3 — LIVRER : Export (milieu, ANCRE, léger tilt) */
.hero-bento__card--export {
	top: 46%;
	left: 8%;
	width: 84%;
	padding: 16px;
	z-index: 3;
	transform: rotate(-1deg);
}

.hero-bento__card--export:hover {
	transform: rotate(0deg);
}

/* Card 4 — AGIR : Action (bottom-left, tilted) */
.hero-bento__card--action {
	top: 74%;
	left: 0;
	width: 50%;
	padding: 14px;
	transform: rotate(-2deg);
}

.hero-bento__card--action:hover {
	transform: rotate(0deg);
}

/* Card 5 — CONFIANCE : Social Proof (bottom-right, tilted) */
.hero-bento__card--proof {
	top: 76%;
	right: 0;
	width: 42%;
	padding: 16px 14px;
	transform: rotate(2deg);
	text-align: left;
}

.hero-bento__card--proof:hover {
	transform: rotate(0deg);
}

/* Header */
.hero-bento__header {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 10px;
}

.hero-bento__title {
	font-size: 13px;
	font-weight: 700;
	color: #0A0E15;
	letter-spacing: -0.01em;
}

.hero-bento__unit {
	font-size: 11px;
	color: #94A3B8;
	font-weight: 500;
}

.hero-bento__header {
	justify-content: space-between;
}

/* Scope legend pour Trajectoire */
.hero-bento__scope-legend {
	display: flex;
	gap: 10px;
	font-size: 10px;
	color: #64748B;
	font-weight: 600;
	margin-top: -4px;
	margin-bottom: 2px;
	justify-content: flex-end;
}

.hero-bento__scope-legend span {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

/* Chart SVG */
.hero-bento__chart {
	width: 100%;
	height: calc(100% - 58px);
	display: block;
}

.hero-bento__legend {
	display: flex;
	gap: 14px;
	margin-top: 8px;
	font-size: 10px;
	color: #64748B;
	font-weight: 500;
}

.hero-bento__legend span {
	display: inline-flex;
	align-items: center;
	gap: 5px;
}

.hero-bento__dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	flex-shrink: 0;
}

/* Donut */
.hero-bento__donut {
	position: relative;
	width: 110px;
	height: 110px;
	margin: 4px auto 8px;
}

.hero-bento__donut svg {
	width: 100%;
	height: 100%;
}

.hero-bento__donut-center {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	line-height: 1;
}

.hero-bento__donut-center strong {
	display: block;
	font-size: 22px;
	font-weight: 800;
	color: #0A0E15;
	letter-spacing: -0.02em;
}

.hero-bento__donut-center span {
	display: block;
	font-size: 9px;
	color: #94A3B8;
	margin-top: 2px;
	font-weight: 500;
}

.hero-bento__donut-legend {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 10px;
	color: #475569;
}

.hero-bento__donut-legend li {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 0;
	margin: 0;
}

.hero-bento__donut-legend li::before {
	display: none;
}

.hero-bento__donut-legend strong {
	margin-left: auto;
	color: #0A0E15;
	font-weight: 700;
}

/* Social Proof Card (Card 5) */
.hero-bento__proof-rating {
	font-size: 32px;
	font-weight: 800;
	color: #0A0E15;
	letter-spacing: -0.02em;
	line-height: 1;
	margin-bottom: 8px;
}

.hero-bento__proof-rating span {
	font-size: 16px;
	color: #94A3B8;
	font-weight: 600;
}

.hero-bento__proof-stars {
	color: #00B67A;
	font-size: 20px;
	letter-spacing: 3px;
	line-height: 1;
	margin-bottom: 8px;
}

.hero-bento__proof-meta {
	font-size: 12px;
	color: #64748B;
	font-weight: 500;
}

.hero-bento__proof-brand {
	color: #00B67A;
	font-weight: 700;
}

/* Action card — style bibliothèque d'actions */
.hero-bento__action-category {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	background: #EEF2FF;
	color: #4F46E5;
	border-radius: 100px;
	font-size: 11px;
	font-weight: 700;
	margin-bottom: 10px;
}

.hero-bento__action-category svg {
	width: 12px;
	height: 12px;
	flex-shrink: 0;
}

.hero-bento__action-title {
	font-size: 13px;
	font-weight: 700;
	color: #0A0E15;
	line-height: 1.3;
	margin: 0 0 12px;
	letter-spacing: -0.01em;
}

.hero-bento__action-metrics {
	display: flex;
	justify-content: space-between;
	gap: 8px;
	padding-top: 10px;
	border-top: 1px solid #E2E8F0;
}

.hero-bento__action-metrics > div {
	display: flex;
	flex-direction: column;
	gap: 2px;
	flex: 1;
	min-width: 0;
}

.hero-bento__metric-label {
	font-size: 9px;
	color: #94A3B8;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

.hero-bento__metric-value {
	font-size: 12px;
	color: #0A0E15;
}

.hero-bento__metric-value strong {
	font-weight: 700;
}

/* Export card */
.hero-bento__export-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 6px;
}

.hero-bento__export-check {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #10B981;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.hero-bento__export-check svg {
	width: 14px;
	height: 14px;
}

.hero-bento__export-title {
	font-size: 16px;
	font-weight: 700;
	color: #0A0E15;
	letter-spacing: -0.01em;
}

.hero-bento__export-sub {
	font-size: 11px;
	color: #64748B;
	margin: 0 0 14px;
	font-weight: 500;
}

.hero-bento__export-sub span {
	color: #CBD5E1;
	margin: 0 4px;
}

.hero-bento__export-files {
	display: flex;
	gap: 8px;
}

.hero-bento__export-file {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px 8px 8px;
	background: #fff;
	border: 1px solid #E2E8F0;
	border-radius: 10px;
	font-size: 13px;
	font-weight: 600;
	color: #0A0E15;
	transition: all 0.2s ease;
	cursor: default;
}

.hero-bento__export-file:hover {
	border-color: #00BAC7;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 186, 199, 0.12);
}

.hero-bento__file-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	border-radius: 6px;
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	font-family: "Manrope", sans-serif;
	flex-shrink: 0;
	letter-spacing: -0.02em;
}

.hero-bento__file-icon--pdf {
	font-size: 9px;
	letter-spacing: 0;
}

/* Responsive <992px (tablettes + petits laptops + mobile) : seule la card Export reste, en statique centrée */
@media (max-width: 991px) {
	.hero-bento {
		aspect-ratio: auto;
		max-width: 480px;
		margin: 0 auto;
		padding: 8px 0;
	}
	.hero-bento__card:not(.hero-bento__card--export) {
		display: none;
	}
	.hero-bento__card--export {
		position: static;
		width: 100%;
		left: auto;
		top: auto;
		transform: none;
	}
}

@media (max-width: 767px) {
	.hero-bento {
		max-width: 420px;
	}
	.hero-bento__export-title { font-size: 15px; }
	.hero-bento__export-file { font-size: 12px; padding: 6px 10px 6px 6px; }
}

/* ---------- Social Proof + Logo Carousel ---------- */

body .landing-page .landing-social-proof {
	padding: 8px 0 48px;
}

body .landing-page .landing-social-proof h2 {
	font-size: 22px;
	color: var(--lp-dark-blue);
	margin: 0 0 32px;
	font-weight: 600;
	letter-spacing: -0.01em;
}

.landing-logos-track {
	overflow: hidden;
	position: relative;
}

.landing-logos-track::before,
.landing-logos-track::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100px;
	z-index: 2;
	pointer-events: none;
}

.landing-logos-track::before {
	left: 0;
	background: linear-gradient(to right, var(--lp-white, #fff), transparent);
}

.landing-logos-track::after {
	right: 0;
	background: linear-gradient(to left, var(--lp-white, #fff), transparent);
}

.landing-logos-track__inner {
	display: flex;
	gap: 48px;
	align-items: center;
	animation: landing-scroll-logos 35s linear infinite;
	width: max-content;
}

.landing-logos-track__item {
	flex-shrink: 0;
}

.landing-logos-track__item img {
	height: 50px;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.5;
	transition: all var(--lp-transition);
}

.landing-logos-track__item img:hover {
	filter: grayscale(0%);
	opacity: 1;
}

@keyframes landing-scroll-logos {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
	.landing-logos-track__inner {
		animation: none;
		flex-wrap: wrap;
		justify-content: center;
		gap: 32px;
		width: auto;
	}
}

/* ---------- Features / Tabs ---------- */

body .landing-page .landing-features {
	background-color: var(--lp-accent-bg);
}

body .landing-page .landing-features h2 {
	font-size: 34px;
	margin-bottom: 24px;
}

body .landing-page .landing-features__subtitle {
	margin: 0 auto 40px;
	font-size: 16px;
	line-height: 1.7;
	color: var(--lp-text-light);
}

body .landing-page .landing-tabs__nav {
	display: flex;
	justify-content: center;
	gap: 12px;
	margin-bottom: 48px;
	flex-wrap: wrap;
}

body .landing-page .landing-tabs__btn {
	padding: 12px 28px;
	border: 2px solid var(--lp-primary);
	border-radius: 100px;
	background: transparent;
	color: var(--lp-primary);
	font-family: "Manrope", sans-serif;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: all var(--lp-transition);
}

body .landing-page .landing-tabs__btn:focus-visible {
	outline: 3px solid var(--lp-primary);
	outline-offset: 2px;
}

body .landing-page .landing-tabs__btn.is-active,
body .landing-page .landing-tabs__btn:hover {
	background-color: var(--lp-primary);
	border-color: var(--lp-primary);
	color: var(--lp-white);
	box-shadow: 0 4px 12px rgba(0, 186, 199, 0.25);
}

body .landing-page .landing-tabs__panel {
	display: none;
	animation: lp-fade-in 0.35s ease-out;
}

body .landing-page .landing-tabs__panel.is-active {
	display: block;
}

@keyframes lp-fade-in {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

body .landing-page .landing-tabs__panel p {
	font-size: 16px;
	line-height: 1.7;
	color: var(--lp-text);
}

body .landing-page .landing-tabs__panel img {
	width: 100%;
	height: auto;
	border-radius: var(--lp-radius-lg);
	box-shadow: var(--lp-shadow-md);
}

/* ---------- Stats / Chiffres clés ---------- */

body .landing-page .landing-stats {
	background: var(--lp-dark-blue);
	padding: 56px 0;
}

body .landing-page .landing-stat {
	padding: 24px 16px;
}

body .landing-page .landing-stat__number {
	display: block;
	font-family: "Manrope", sans-serif;
	font-size: 32px;
	font-weight: 800;
	color: var(--lp-primary);
	margin-bottom: 8px;
	letter-spacing: -0.02em;
}

body .landing-page .landing-stat__label {
	display: block;
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
	font-weight: 500;
}

/* ---------- Report Banner ---------- */

body .landing-page .landing-report-banner {
	background: linear-gradient(135deg, var(--lp-dark-blue) 0%, var(--lp-secondary) 100%);
	padding: 64px 0;
}

body .landing-page .landing-report-banner__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 48px;
}

body .landing-page .landing-report-banner__text {
	flex: 1;
}

body .landing-page .landing-report-banner__text h2 {
	color: var(--lp-white);
	font-size: 28px;
	margin-bottom: 12px;
}

body .landing-page .landing-report-banner__text p {
	color: rgba(255, 255, 255, 0.85);
	font-size: 16px;
	line-height: 1.7;
	margin: 0;
}

body .landing-page .landing-report-banner__text strong {
	color: var(--lp-white);
}

body .landing-page .landing-report-banner__action {
	flex-shrink: 0;
}

body .landing-page .landing-report-banner .landing-btn--primary {
	white-space: nowrap;
}

@media (max-width: 767px) {
	body .landing-page .landing-report-banner__inner {
		flex-direction: column;
		text-align: center;
		gap: 24px;
	}
}

/* ---------- Comparatif ---------- */

body .landing-page .landing-compare {
	background: var(--lp-white);
}

body .landing-page .landing-compare h2 {
	font-size: 34px;
	margin-bottom: 12px;
}

body .landing-page .landing-compare__subtitle {
	margin: 0 auto 48px;
	font-size: 16px;
	color: var(--lp-text-light);
}

body .landing-page .landing-compare__grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1.15fr;
	gap: 20px;
	align-items: stretch;
}

body .landing-page .landing-compare__card {
	border-radius: var(--lp-radius-lg);
	padding: 32px 28px;
	height: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
}

/* Alternatives — muted */
body .landing-page .landing-compare__card--alt {
	background: #F8FAFC;
	border: 1px solid #E2E8F0;
}

body .landing-page .landing-compare__card--alt .landing-compare__title {
	color: #64748B;
}

body .landing-page .landing-compare__card--alt .landing-compare__list li {
	color: #64748B;
}

/* Notre solution — highlighted */
body .landing-page .landing-compare__card--featured {
	background: linear-gradient(160deg, #0d7377 0%, #00BAC7 100%);
	color: #fff;
	box-shadow: 0 16px 48px rgba(0, 186, 199, 0.25);
}

body .landing-page .landing-compare__card--featured .landing-compare__title {
	color: #fff;
}

body .landing-page .landing-compare__card--featured .landing-compare__list li {
	color: rgba(255, 255, 255, 0.95);
}

body .landing-page .landing-compare__badge {
	position: absolute;
	top: 20px;
	right: 20px;
	background: #fff;
	color: #0d7377;
	font-size: 11px;
	font-weight: 700;
	padding: 5px 12px;
	border-radius: 100px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

body .landing-page .landing-compare__title {
	font-size: 20px;
	font-weight: 700;
	margin: 0 0 24px;
	line-height: 1.2;
}

body .landing-page .landing-compare__list {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	flex: 1;
}

body .landing-page .landing-compare__list li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 10px 0;
	font-size: 15px;
	line-height: 1.5;
}

body .landing-page .landing-compare__list li::before {
	display: none;
}

body .landing-page .landing-compare__icon {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 1px;
}

body .landing-page .landing-compare__icon svg {
	width: 14px;
	height: 14px;
}

body .landing-page .landing-compare__icon--neg {
	background: #FEE2E2;
	color: #DC2626;
}

body .landing-page .landing-compare__icon--pos {
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
}

body .landing-page .landing-compare__cta {
	display: inline-block;
	text-align: center;
	background: #fff;
	color: #0d7377;
	font-weight: 700;
	font-size: 16px;
	padding: 14px 24px;
	border-radius: var(--lp-radius);
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	margin-top: auto;
}

body .landing-page .landing-compare__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
	color: #0d7377;
}

/* Responsive */
@media (max-width: 991px) {
	body .landing-page .landing-compare__grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}

	body .landing-page .landing-compare__card--featured {
		order: -1; /* Notre solution en premier sur mobile */
	}
}

/* ---------- Compliance / Conformité ---------- */

body .landing-page .landing-compliance {
	background: var(--lp-accent-bg);
}

body .landing-page .landing-compliance h2 {
	font-size: 34px;
	margin-bottom: 12px;
}

body .landing-page .landing-compliance__subtitle {
	margin: 0 auto 48px;
	font-size: 16px;
	color: var(--lp-text-light);
}

body .landing-page .landing-compliance__item {
	background: var(--lp-white);
	border: 1px solid var(--lp-border);
	border-radius: var(--lp-radius);
	padding: 32px 24px;
	height: 100%;
	transition: box-shadow var(--lp-transition);
}

body .landing-page .landing-compliance__item:hover {
	box-shadow: var(--lp-shadow-sm);
}

body .landing-page .landing-compliance__item strong {
	display: block;
	font-size: 20px;
	color: var(--lp-dark-blue);
	margin-bottom: 4px;
	font-family: "Manrope", sans-serif;
}

body .landing-page .landing-compliance__item span {
	font-size: 14px;
	color: var(--lp-text-light);
}

/* ---------- SEO Content ---------- */

body .landing-page .landing-seo-content {
	background: var(--lp-white);
}

body .landing-page .landing-seo-content h2 {
	font-size: 28px;
	margin-bottom: 16px;
}

body .landing-page .landing-seo-content h3 {
	font-size: 20px;
	margin-top: 32px;
	margin-bottom: 12px;
}

body .landing-page .landing-seo-content p {
	font-size: 16px;
	line-height: 1.8;
	color: var(--lp-text);
}

/* ---------- Trustpilot ---------- */

body .landing-page .landing-trustpilot {
	padding: 48px 0;
}

body .landing-page .landing-trustpilot h2 {
	font-size: 28px;
	margin-bottom: 24px;
}

/* ---------- Partners ---------- */

body .landing-page .landing-partners h2 {
	font-size: 34px;
	margin-bottom: 36px;
}

body .landing-page .landing-partners__grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 32px;
	align-items: center;
	margin-top: 40px;
}

body .landing-page .landing-partners__item img {
	max-width: 100%;
	max-height: 56px;
	object-fit: contain;
	margin: 0 auto;
	display: block;
	filter: grayscale(100%);
	opacity: 0.5;
	transition: all var(--lp-transition);
}

body .landing-page .landing-partners__item img:hover {
	filter: grayscale(0%);
	opacity: 1;
}

/* ---------- Testimonials ---------- */

body .landing-page .landing-testimonials {
	background-color: var(--lp-accent-bg);
}

body .landing-page .landing-testimonials h2 {
	font-size: 34px;
	margin-bottom: 36px;
}

body .landing-page .landing-testimonial-card {
	background: var(--lp-white);
	border-radius: var(--lp-radius-lg);
	padding: 32px;
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: var(--lp-shadow-sm);
	border: 1px solid var(--lp-border);
	transition: box-shadow var(--lp-transition), transform var(--lp-transition);
}

body .landing-page .landing-testimonial-card:hover {
	box-shadow: var(--lp-shadow-md);
	transform: translateY(-2px);
}

body .landing-page .landing-testimonial-card__stars {
	color: #F59E0B;
	font-size: 18px;
	margin-bottom: 16px;
	letter-spacing: 3px;
}

body .landing-page .landing-testimonial-card blockquote {
	flex: 1;
	font-size: 15px;
	line-height: 1.7;
	color: var(--lp-text);
	margin: 0 0 24px;
	font-style: italic;
	position: relative;
}

body .landing-page .landing-testimonial-card__author {
	border-top: 1px solid var(--lp-border);
	padding-top: 16px;
}

body .landing-page .landing-testimonial-card__author strong {
	display: block;
	font-family: "Manrope", sans-serif;
	font-weight: 700;
	font-size: 15px;
	color: var(--lp-dark-blue);
}

body .landing-page .landing-testimonial-card__author span {
	font-size: 13px;
	color: var(--lp-text-light);
}

/* ---------- FAQ ---------- */

body .landing-page .landing-faq h2 {
	font-size: 34px;
	margin-bottom: 36px;
}

body .landing-page .landing-faq__list {
	margin: 0 auto;
}

body .landing-page .landing-faq__item {
	border: 1px solid var(--lp-border);
	border-radius: var(--lp-radius);
	padding: 0;
	margin-bottom: 8px;
	background: var(--lp-white);
	transition: box-shadow var(--lp-transition);
}

body .landing-page .landing-faq__item:hover {
	box-shadow: var(--lp-shadow-sm);
}

body .landing-page .landing-faq__item[open] {
	box-shadow: var(--lp-shadow-sm);
}

body .landing-page .landing-faq__item summary {
	padding: 20px 24px;
	font-family: "Manrope", sans-serif;
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: var(--lp-dark-blue);
	transition: color var(--lp-transition);
}

body .landing-page .landing-faq__item summary:focus-visible {
	outline: 3px solid var(--lp-primary);
	outline-offset: -3px;
	border-radius: var(--lp-radius);
}

body .landing-page .landing-faq__item summary::-webkit-details-marker {
	display: none;
}

body .landing-page .landing-faq__item summary::after {
	content: "+";
	font-size: 22px;
	font-weight: 400;
	color: var(--lp-primary);
	transition: transform var(--lp-transition);
	display: inline-block;
	margin-left: 16px;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	line-height: 28px;
	text-align: center;
	border-radius: 50%;
	background: var(--lp-accent-bg);
}

body .landing-page .landing-faq__item[open] summary::after {
	content: "\2212";
	background: var(--lp-primary);
	color: var(--lp-white);
}

body .landing-page .landing-faq__answer {
	padding: 0 24px 20px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--lp-text);
}

/* ---------- CTA Closing ---------- */

body .landing-page .landing-cta-closing {
	background: linear-gradient(135deg, var(--lp-dark-blue) 0%, var(--lp-secondary) 100%);
	padding: 96px 0;
}

body .landing-page .landing-cta-closing p {
	margin: 0 auto 32px;
	font-size: 17px;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.9);
}

body .landing-page .landing-cta-closing strong {
	color: var(--lp-white);
	font-size: 20px;
	display: block;
	margin-bottom: 12px;
	line-height: 1.4;
}

body .landing-page .landing-cta-closing .landing-btn--primary {
	background: var(--lp-primary);
	border-color: var(--lp-primary);
	font-size: 18px;
	padding: 18px 40px;
}

/* ---------- Blog ---------- */

body .landing-page .landing-blog h2 {
	font-size: 34px;
	margin-bottom: 36px;
}

body .landing-page .landing-blog-card {
	background: var(--lp-white);
	border-radius: var(--lp-radius-lg);
	overflow: hidden;
	box-shadow: var(--lp-shadow-sm);
	border: 1px solid var(--lp-border);
	height: 100%;
	display: flex;
	flex-direction: column;
	transition: box-shadow var(--lp-transition), transform var(--lp-transition);
}

body .landing-page .landing-blog-card:hover {
	box-shadow: var(--lp-shadow-md);
	transform: translateY(-4px);
}

body .landing-page .landing-blog-card__img {
	display: block;
	overflow: hidden;
}

body .landing-page .landing-blog-card__img img {
	width: 100%;
	height: 200px;
	object-fit: cover;
	transition: transform var(--lp-transition-slow);
}

body .landing-page .landing-blog-card:hover .landing-blog-card__img img {
	transform: scale(1.04);
}

body .landing-page .landing-blog-card__content {
	padding: 24px;
	flex: 1;
	display: flex;
	flex-direction: column;
}

body .landing-page .landing-blog-card__date {
	font-size: 13px;
	color: var(--lp-text-light);
	margin-bottom: 8px;
	font-weight: 500;
}

body .landing-page .landing-blog-card__content h3 {
	font-size: 18px;
	margin-bottom: 10px;
	line-height: 1.4;
}

body .landing-page .landing-blog-card__content h3 a {
	color: var(--lp-dark-blue);
	text-decoration: none;
	transition: color var(--lp-transition);
}

body .landing-page .landing-blog-card__content h3 a:hover {
	color: var(--lp-primary);
}

body .landing-page .landing-blog-card__content p {
	font-size: 14px;
	color: var(--lp-text-light);
	line-height: 1.6;
}

/* ---------- Responsive ---------- */

/* Viewports courts (laptops 13-14" ~768-850px) — resserrer le hero pour garder social proof au-dessus du fold */
@media (min-width: 992px) and (max-height: 850px) {
	body .landing-page .landing-hero h1 {
		font-size: 44px;
	}
	body .landing-page .landing-hero__subtitle {
		font-size: 19px;
		margin-bottom: 16px;
	}
	body .landing-page .landing-hero__desc {
		font-size: 15px;
		margin-bottom: 24px;
	}
	body .landing-page .landing-hero__microcopy {
		margin-top: 14px;
		font-size: 14px;
	}
	.hero-bento {
		aspect-ratio: 1 / 0.88;
	}
}

@media (min-width: 992px) and (max-height: 720px) {
	body .landing-page .landing-hero h1 {
		font-size: 38px;
	}
	body .landing-page .landing-hero__subtitle {
		font-size: 17px;
	}
	body .landing-page .landing-hero__grid {
		gap: 40px;
	}
	.hero-bento {
		aspect-ratio: 1 / 0.82;
	}
}

@media (max-width: 991px) {
	body .landing-page .landing-hero {
		padding-top: 120px;
		padding-bottom: 48px;
	}

	body .landing-page .landing-hero__grid {
		grid-template-columns: 1fr;
		gap: 40px;
		text-align: center;
	}

	body .landing-page .landing-hero__content {
		text-align: center;
	}

	body .landing-page .landing-hero__microcopy {
		justify-content: center;
	}

	body .landing-page .landing-hero h1 {
		font-size: 40px;
	}

	body .landing-page .landing-hero__subtitle {
		font-size: 20px;
	}

	body .landing-page .landing-hero__visual {
		max-width: 600px;
		margin: 0 auto;
	}

	body .landing-page .landing-features h2,
	body .landing-page .landing-testimonials h2,
	body .landing-page .landing-faq h2,
	body .landing-page .landing-blog h2,
	body .landing-page .landing-partners h2 {
		font-size: 28px;
	}

	body .landing-page .landing-partners__grid {
		grid-template-columns: repeat(4, 1fr);
	}

	body .landing-page section {
		padding: 56px 0;
	}
}

@media (max-width: 767px) {
	body .landing-page .landing-hero {
		padding-top: 100px;
		padding-bottom: 32px;
	}

	body .landing-page .landing-hero h1 {
		font-size: 30px;
		line-height: 1.15;
	}

	body .landing-page .landing-hero__subtitle {
		font-size: 17px;
	}

	body .landing-page .landing-hero__desc {
		font-size: 15px;
	}

	body .landing-page section {
		padding: 40px 0;
	}

	body .landing-page .landing-features h2,
	body .landing-page .landing-testimonials h2,
	body .landing-page .landing-faq h2,
	body .landing-page .landing-blog h2,
	body .landing-page .landing-partners h2 {
		font-size: 24px;
	}

	body .landing-page .landing-partners__grid {
		grid-template-columns: repeat(3, 1fr);
	}

	body .landing-page .landing-tabs__nav {
		gap: 6px;
	}

	body .landing-page .landing-tabs__btn {
		padding: 10px 18px;
		font-size: 13px;
	}

	body .landing-page .landing-tabs__panel .row {
		flex-direction: column-reverse;
	}

	body .landing-page .landing-tabs__panel img {
		margin-bottom: 24px;
	}

	body .landing-page .landing-btn {
		padding: 14px 24px;
		font-size: 15px;
		width: 100%;
		text-align: center;
	}

	body .landing-page .landing-cta-closing {
		padding: 56px 0;
	}

	body .landing-page .landing-cta-closing strong {
		font-size: 20px;
	}

	body .landing-page .landing-cta-closing .landing-btn--primary {
		font-size: 15px;
		padding: 14px 24px;
		width: 100%;
		text-align: center;
	}

	body .landing-page .landing-testimonial-card {
		padding: 24px;
	}

	body .landing-page .landing-faq__item summary {
		padding: 16px 20px;
		font-size: 15px;
	}
}
