/* =============================================================================
   custom.css — vitrine-local visual overrides.
   TODO(design): migrate to @plateforme-agree/design v1.11 —
   move to packages/design/css/compositions/vitrine-animations.css, then
   drop the /css/* route and this file.
   Rule: DS2 tokens (var(--…)) only, no hardcoded hex.
   ============================================================================= */

/* Note : les overrides spécifiques à la home sont dans public/css/home/*.css
 * et chargés via /css/home.css en <link> APRÈS ce fichier dans layout.ts.
 * Cascade : custom.css (base Figma + fonts Mathéo) → home.css (mes overrides). */

/* Fonts are now centralized in @doxallia/design v1.13.0 (fonts.css). */

/* -----------------------------------------------------------------------------
   A — Hero : floating orbs + animated gradient.
   ::before at z-index 1 sits between backdrop (z:0) and text content (z:2).
   Visible whether the hero-wave canvas renders or the fallback is used.
   ----------------------------------------------------------------------------- */
@keyframes hero-gradient-drift {
	0%,
	100% {
		background-position: 0% 0%;
	}
	50% {
		background-position: 100% 100%;
	}
}

@keyframes hero-orbs-drift {
	from {
		transform: scale(1) translate(0px, 0px);
	}
	to {
		transform: scale(1.08) translate(30px, 20px);
	}
}

.mk-hero--wave::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background:
		radial-gradient(
			ellipse 55% 80% at 15% 65%,
			color-mix(in srgb, var(--color-brand) 40%, transparent) 0%,
			transparent 65%
		),
		radial-gradient(
			ellipse 45% 65% at 85% 15%,
			color-mix(in srgb, var(--color-brand-mid) 45%, transparent) 0%,
			transparent 60%
		),
		radial-gradient(
			ellipse 30% 50% at 55% 85%,
			color-mix(in srgb, var(--color-brand) 28%, transparent) 0%,
			transparent 55%
		);
	animation: hero-orbs-drift 6s ease-in-out infinite alternate;
}

.mk-hero--wave__fallback {
	background: linear-gradient(
		135deg,
		var(--color-bg) 0%,
		color-mix(in srgb, var(--color-brand) 20%, var(--color-bg)) 40%,
		color-mix(in srgb, var(--color-brand-mid) 25%, var(--color-bg)) 70%,
		var(--color-bg) 100%
	);
	background-size: 200% 200%;
	animation: hero-gradient-drift 6s var(--easing-smooth, ease-in-out) infinite;
}

@media (prefers-reduced-motion: reduce) {
	.mk-hero--wave::before {
		animation: none;
	}
	.mk-hero--wave__fallback {
		animation: none;
		background-size: 100% 100%;
	}
}

/* -----------------------------------------------------------------------------
   Schema Y — path-draw animation (IO-based, replaces DS2 scroll-driven).
   DS2 initializes stroke-dashoffset:35 (invisible). When .is-visible lands
   on .vitrine-schema-y, paths draw in sequence.
   ----------------------------------------------------------------------------- */
@keyframes schema-path-draw {
	from {
		stroke-dashoffset: 35;
	}
	to {
		stroke-dashoffset: 0;
	}
}

@supports (animation-timeline: view()) {
	.vitrine-schema-y path[stroke] {
		animation: none;
	}
}

.vitrine-schema-y.is-visible path[stroke] {
	animation: schema-path-draw 550ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.vitrine-schema-y.is-visible path[stroke]:nth-of-type(2) {
	animation-delay: 220ms;
}
.vitrine-schema-y.is-visible path[stroke]:nth-of-type(3) {
	animation-delay: 440ms;
}

/* -----------------------------------------------------------------------------
   Icon hover — all cards with .card__icon.
   ----------------------------------------------------------------------------- */
.card .card__icon {
	transition: transform
		var(--transition-smooth, 220ms cubic-bezier(0.25, 1, 0.5, 1));
}

.card:hover .card__icon {
	transform: scale(1.2) translateY(-2px);
}

/* -----------------------------------------------------------------------------
   Bento Invox-IA — flex-column layout, link anchored at bottom,
   badges extracted from copy to fill vertical whitespace.
   ----------------------------------------------------------------------------- */
.vitrine-bento__item--hero {
	display: flex;
	flex-direction: column;
	background:
		radial-gradient(
			ellipse 120% 80% at 100% 110%,
			color-mix(in srgb, var(--color-brand) 12%, white) 0%,
			transparent 60%
		),
		var(--color-surface);
	position: relative;
	overflow: hidden;
}

.vitrine-bento__item--hero::after {
	content: "";
	position: absolute;
	bottom: -40px;
	right: -40px;
	width: 200px;
	height: 200px;
	background: radial-gradient(
		circle,
		color-mix(in srgb, var(--color-brand) 10%, transparent) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.vitrine-bento__item--hero .card__desc {
	flex: 1;
}

.vitrine-bento__item--hero .card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	margin-top: 1rem;
	margin-bottom: 1rem;
}

.vitrine-bento__item--hero .card__badge {
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 0.25rem 0.6rem;
	border-radius: 999px;
	background: color-mix(in srgb, var(--color-brand) 8%, transparent);
	color: var(--color-brand);
	border: 1px solid color-mix(in srgb, var(--color-brand) 22%, transparent);
}

/* -----------------------------------------------------------------------------
   Navy alternate section — final CTA on navy gradient band.
   DS2 exposes these 4 vars specifically for container scoping.
   ----------------------------------------------------------------------------- */
.mk-cta-card--full {
	background: linear-gradient(
		150deg,
		var(--color-brand-mid) 0%,
		var(--color-brand) 100%
	);
	--btn-secondary-bg: rgba(255, 255, 255, 0.08);
	--btn-secondary-fg: var(--color-on-brand);
	--btn-secondary-border: rgba(255, 255, 255, 0.32);
	--btn-secondary-bg-hover: rgba(255, 255, 255, 0.18);
}

/* -----------------------------------------------------------------------------
   Hover lift — interactive cards.
   DS2+ tokens: --shadow-hover (dedicated navy hover shadow) + --transition-smooth.
   ----------------------------------------------------------------------------- */
.card--interactive {
	transition:
		transform var(--transition-smooth, 220ms cubic-bezier(0.25, 1, 0.5, 1)),
		box-shadow var(--transition-smooth, 220ms cubic-bezier(0.25, 1, 0.5, 1));
}

.card--interactive:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-hover);
}

/* =============================================================================
 * FIGMA REDESIGN — vitrine "PDP Espace design" (node 1140:2765)
 * Scope: .vitrine-fg-* + .mk-nav--figma + .mk-footer--figma
 * Tokens additionnels Figma → mappés ici en attendant migration DS package.
 * ============================================================================= */

:root {
	font-family: "Noto Sans", system-ui, sans-serif;
	/* Figma colour scale — additive on top of DS2 brand tokens */
	--fg-space: #141c52; /* navy strong — titres, body strong */
	--fg-cta: #2563eb; /* blue CTA — boutons primaires Figma */
	--fg-cta-hover: #1e4fc7;
	--fg-blue-900: #0e182c; /* body */
	--fg-blue-50: #ecf1fb; /* tint surface — pills, icon holders */
	--fg-blue-100: #dae4f8; /* light surface — clients band, form card */
	--fg-blue-300: #91ade9; /* accent border */
	--fg-blue-700: #2b4783; /* deep brand — pill on surface, form bottom border */
	--fg-blue-800: #1d2f58; /* navy card */
	--fg-bg-navy: #0b1f3a; /* hero navy bg */
	--fg-surface: #ffffff;
	--fg-text-muted: #666666;
	--fg-border-soft: #eae9ef;
	--fg-radius-card: 20px;
	--fg-radius-pill: 9999px;
	--fg-radius-input: 12px;
	--fg-max-width: 1160px;
	--fg-section-x: clamp(20px, 5vw, 140px);
	--fg-section-y: clamp(48px, 8vh, 80px);
}

/* ---------------------------------------------------------------------------
 * Buttons — Figma CTA + outline navy
 * ------------------------------------------------------------------------- */
.btn--cta {
	padding: 0.625rem 1.25rem;
	height: 44px;
	background: var(--fg-cta);
	color: #fff;
	border: 1px solid var(--fg-cta);
	border-radius: var(--fg-radius-pill);
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 18px;
	cursor: pointer;
	transition:
		background 200ms ease,
		transform 200ms ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	white-space: nowrap;
}
.btn--cta:hover {
	background: var(--fg-cta-hover);
	transform: translateY(-1px);
}
.btn--cta:focus-visible {
	outline: 2px solid var(--fg-cta);
	outline-offset: 2px;
}

.btn--outline-navy {
	padding: 0.625rem 1.25rem;
	height: 44px;
	background: #fff;
	color: var(--fg-space);
	border: 1px solid var(--fg-space);
	border-radius: var(--fg-radius-pill);
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 18px;
	cursor: pointer;
	transition: background 200ms ease;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	white-space: nowrap;
}
.btn--outline-navy:hover {
	background: var(--fg-blue-50);
}
.btn--outline-navy:focus-visible {
	outline: 2px solid var(--fg-space);
	outline-offset: 2px;
}

/* ---------------------------------------------------------------------------
 * Nav — Figma redesign: 4 pills + Globe + CTA
 * ------------------------------------------------------------------------- */
.mk-nav--figma {
	background: #fff;
	border-bottom: 1px solid #ecf1fb;
	font-family: "Noto Sans", system-ui, sans-serif;
	position: sticky;
	top: 0;
	z-index: 40;
}
.mk-nav--figma .mk-nav__inner {
	max-width: var(--fg-max-width);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5rem;
	padding: 20px clamp(20px, 5vw, 140px);
	height: 112px;
	width: 100%;
}
.mk-nav--figma .mk-nav__brand {
	display: inline-flex;
	flex-direction: column;
	gap: 0;
	color: var(--fg-space);
	text-decoration: none;
	line-height: 1.1;
	font-weight: 700;
	font-size: 1.5rem;
}
.mk-nav--figma .mk-nav__brand-name {
	font-weight: 700;
	font-size: 1.5rem;
	letter-spacing: -0.01em;
}
.mk-nav--figma .mk-nav__brand-logo {
	height: 32px;
	width: auto;
	display: block;
}
.mk-nav--figma .mk-nav__brand-sub {
	font-weight: 500;
	font-size: 0.75rem;
	color: var(--fg-text-muted);
}

.mk-nav__links--pills {
	display: flex;
	align-items: center;
	gap: 16px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.mk-nav__links .mk-nav__pill {
	display: inline-flex;
	align-items: center;
	height: 44px;
	padding: 8px 20px;
	background: #fff;
	color: var(--fg-space);
	border-radius: var(--fg-radius-pill);
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 18px;
	text-decoration: none;
	transition:
		transform 0.3s ease-out,
		background 0.2s ease;
	white-space: nowrap;
}
.mk-nav__links .mk-nav__pill:hover {
	background: var(--fg-blue-50);
	transform: scale(1.08);
}
.mk-nav__links .mk-nav__pill[aria-current="page"] {
	background: var(--fg-blue-50);
}

.mk-nav--figma .mk-nav__actions {
	display: flex;
	align-items: center;
	gap: 12px;
}

@media (max-width: 1024px) {
	.mk-nav--figma .mk-nav__links--pills {
		display: none;
	}
	.mk-nav--figma .mk-nav__actions .btn {
		display: none;
	}
	.mk-nav--figma .mk-nav__inner {
		height: auto;
		padding: 16px clamp(16px, 4vw, 24px);
	}
	.mk-nav--figma .mk-nav__mobile-toggle {
		display: block;
	}
}

.mk-nav__mobile-toggle > summary svg {
	transition: transform 0.2s ease-in-out;
}
.mk-nav__mobile-toggle[open] > summary svg {
	transform: rotate(-90deg);
}
.mk-nav__mobile-menu {
	background: #eef2f9 !important;
	font-family: "Noto Sans", system-ui, sans-serif;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 200;
	border-bottom: 2px solid var(--fg-blue-300);
}
.mk-nav__mobile-menu a {
	transition:
		transform 0.2s ease-out,
		background 0.2s ease,
		color 0.2s ease;
	border-radius: 8px;
	padding: 10px 12px !important;
}
.mk-nav__mobile-menu a:hover,
.mk-nav__mobile-menu a:active {
	transform: scale(1.03);
	background: #dce6f5;
}
.mk-nav__mobile-toggle[open] > .mk-nav__mobile-menu {
	animation: mobile-drawer-open 0.35s ease-in-out forwards;
}
.mk-nav__mobile-menu.is-closing {
	animation: mobile-drawer-close 0.35s ease-in-out forwards !important;
}
@keyframes mobile-drawer-open {
	from {
		clip-path: inset(0 0 100% 0);
	}
	to {
		clip-path: inset(0 0 -20px 0);
	}
}
@keyframes mobile-drawer-close {
	from {
		clip-path: inset(0 0 -20px 0);
	}
	to {
		clip-path: inset(0 0 100% 0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.mk-nav__mobile-toggle > summary svg {
		transition: none;
	}
	.mk-nav__mobile-toggle[open] > summary svg {
		transform: none;
	}
	.mk-nav__mobile-menu,
	.mk-nav__mobile-menu.is-closing {
		animation: none !important;
		clip-path: none;
	}
}

/* ---------------------------------------------------------------------------
 * Section base — shared container
 * ------------------------------------------------------------------------- */
.vitrine-fg-section {
	padding: var(--fg-section-y) var(--fg-section-x);
	width: 100%;
	overflow: clip;
}
.vitrine-fg-section__inner {
	max-width: var(--fg-max-width);
	margin: 0 auto;
	width: 100%;
}
.vitrine-fg-section__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	text-align: center;
	margin-bottom: 4rem;
}
.vitrine-fg-section__header--centered {
	width: 100%;
}
.vitrine-fg-section__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.25;
	color: var(--fg-space);
	max-width: 852px;
	margin: 0;
}
.vitrine-fg-section__title--on-navy {
	color: #fff;
}
.vitrine-fg-section__lead {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--fg-blue-900);
	max-width: 540px;
	margin: 0;
}
.vitrine-fg-section__title--on-navy + .vitrine-fg-section__lead {
	color: #fff;
}

/* Badge pills — 3 variantes (tint clair / navy / cta blue) */
.vitrine-fg-badge {
	display: inline-flex;
	align-items: center;
	height: 22px;
	padding: 4px 12px;
	border-radius: 20px;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 18px;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}
.vitrine-fg-badge--tint {
	background: var(--fg-blue-50);
	color: var(--fg-cta);
}
.vitrine-fg-badge--navy {
	background: var(--fg-blue-700);
	color: #fff;
}
.vitrine-fg-badge--cta {
	background: var(--fg-cta);
	color: #fff;
}

/* États interactifs — chips eyebrow cliquables (sélecteur [href] pour ne cibler
 * que les <a>, le badge --navy "Ils nous font confiance" reste un <span> décoratif. */
.vitrine-fg-badge[href] {
	text-decoration: none;
	cursor: pointer;
	transition:
		background-color 0.2s ease,
		transform 0.2s ease,
		box-shadow 0.2s ease;
}
.vitrine-fg-badge[href]:hover {
	transform: translateY(-1px);
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}
.vitrine-fg-badge--tint[href]:hover {
	background: color-mix(in srgb, var(--fg-blue-50) 70%, var(--fg-cta) 8%);
}
.vitrine-fg-badge--cta[href]:hover {
	background: color-mix(in srgb, var(--fg-cta) 88%, black 12%);
}
.vitrine-fg-badge--navy[href]:hover {
	background: color-mix(in srgb, var(--fg-blue-700) 90%, white 10%);
}
.vitrine-fg-badge[href]:active {
	transform: translateY(0);
	box-shadow: none;
}
.vitrine-fg-badge[href]:focus-visible {
	outline: 2px solid var(--fg-cta);
	outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce) {
	.vitrine-fg-badge[href] {
		transition: background-color 0.2s ease;
	}
	.vitrine-fg-badge[href]:hover,
	.vitrine-fg-badge[href]:active {
		transform: none;
		box-shadow: none;
	}
}

/* ---------------------------------------------------------------------------
 * §1 — Hero
 * ------------------------------------------------------------------------- */
.vitrine-fg-hero {
	border-bottom: 1px solid var(--fg-blue-50);
	background:
		radial-gradient(
			ellipse 90% 100% at 75% 80%,
			rgba(110, 148, 220, 0.6) 0%,
			transparent 70%
		),
		#fff;
	padding: var(--fg-section-y) var(--fg-section-x);
	min-height: 480px;
	display: flex;
	align-items: center;
}
.vitrine-fg-hero__inner {
	max-width: var(--fg-max-width);
	margin: 0 auto;
	width: 100%;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: 3rem;
	align-items: center;
}
.vitrine-fg-hero__content {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}
.vitrine-fg-hero__title {
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-size: clamp(2rem, 4vw, 2.25rem);
	font-weight: 700;
	line-height: 1.22;
	margin: 0;
}
.vitrine-fg-hero__title-line {
	color: var(--fg-space);
}
.vitrine-fg-hero__title-line--accent {
	color: var(--fg-cta);
}
.vitrine-fg-hero__title-line--gradient {
	background: linear-gradient(
		90deg,
		#bae6fd 0%,
		#7dd3fc 20%,
		#2563eb 50%,
		#1e3a8a 75%,
		#38bdf8 100%
	);
	background-size: 300% auto;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
@media (prefers-reduced-motion: no-preference) {
	.vitrine-fg-hero__title-line--gradient {
		animation: hero-gradient-shift 10s linear infinite;
	}
}
@keyframes hero-gradient-shift {
	from {
		background-position: 300% center;
	}
	to {
		background-position: 0% center;
	}
}
.vitrine-fg-hero__subtitle {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--fg-blue-900);
	margin: 0;
	max-width: 540px;
}
.vitrine-fg-hero__actions {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
.vitrine-fg-hero__visual {
	position: relative;
}
.vitrine-fg-hero__visual img {
	width: 100%;
	height: auto;
	display: block;
}

/* ---------------------------------------------------------------------------
 * Hero glass — vraie dalle de verre : facture POSÉE SUR le verre, marge givrée
 * tout autour, rim glow continu dont le point chaud FUIT le curseur, tilt 3D
 * piloté par le curseur.
 *
 * Architecture (issue Chromium #974857 : backdrop-filter ignore les masks) :
 * - .hero-aurora       : blobs bleus flous DERRIÈRE la dalle — ce que le verre filtre
 * - .hero-glass        : la dalle — padding = marge givrée visible (backdrop-filter),
 *                        background bleu translucide, biseau, tilt 3D
 * - .hero-glass__border: élément DOM séparé, z-index au-dessus de l'image,
 *                        rim glow continu (conic) + point chaud mobile (radial)
 * - .hero-screenshot   : facture nette, jamais filtrée, posée au centre
 * --------------------------------------------------------------------------- */

.vitrine-fg-hero__visual {
	perspective: 1100px;
	perspective-origin: center center;
}

/* Aurora bleue (DA Doxallia) derrière la dalle — donne matière au givré */
.hero-aurora {
	position: absolute;
	inset: -8% -6%;
	z-index: 0;
	pointer-events: none;
	filter: blur(38px);
}
.hero-aurora__blob {
	position: absolute;
	display: block;
	border-radius: 50%;
	opacity: 0.7;
}
.hero-aurora__blob--1 {
	width: 46%;
	height: 56%;
	top: -6%;
	left: 8%;
	background: radial-gradient(
		circle,
		rgba(56, 189, 248, 0.85),
		transparent 70%
	);
}
.hero-aurora__blob--2 {
	width: 52%;
	height: 60%;
	bottom: -10%;
	right: 4%;
	background: radial-gradient(circle, rgba(37, 99, 235, 0.8), transparent 70%);
}
.hero-aurora__blob--3 {
	width: 40%;
	height: 44%;
	top: 30%;
	left: 38%;
	background: radial-gradient(
		circle,
		rgba(125, 211, 252, 0.7),
		transparent 70%
	);
}
@media (prefers-reduced-motion: no-preference) {
	.hero-aurora__blob {
		animation: hero-aurora-drift 18s ease-in-out infinite alternate;
	}
	.hero-aurora__blob--2 {
		animation-duration: 22s;
		animation-direction: alternate-reverse;
	}
	.hero-aurora__blob--3 {
		animation-duration: 26s;
	}
}
@keyframes hero-aurora-drift {
	from {
		transform: translate3d(0, 0, 0) scale(1);
	}
	to {
		transform: translate3d(6%, -4%, 0) scale(1.08);
	}
}

.hero-glass {
	--light-x: 75%;
	--light-y: 100%;

	position: relative;
	z-index: 1;
	/* Pas de padding : la facture remplit toute la dalle (coins carrés) et
	 * overflow:hidden clippe ses coins au radius 14px → ils passent sous l'anneau
	 * arrondi. Pas de transform-style:preserve-3d (aucun enfant 3D) car il
	 * désactiverait overflow:hidden et laisserait les coins carrés déborder. */
	padding: 0;
	border-radius: 14px;
	overflow: hidden;
	/* Corps de verre NAVY translucide : donne le contraste pour que le spéculaire
	 * bleu-clair de la marge soit visible (sur fond clair, un verre pâle disparaît). */
	background: rgba(20, 28, 82, 0.5);
	backdrop-filter: blur(16px) saturate(1.4);
	-webkit-backdrop-filter: blur(16px) saturate(1.4);
	box-shadow:
/* Épaisseur de la dalle : tranche navy extrudée, dégradé lumière→ombre
		 * du haut vers le bas du chant, donne ~6px de relief physique. */
		0 1px 0 rgb(42, 54, 122),
		0 2px 0 rgb(30, 40, 100),
		0 4px 0 rgb(20, 28, 78),
		0 6px 0 rgb(13, 18, 56),
		0 32px 80px rgba(15, 35, 95, 0.32),
		0 12px 28px rgba(15, 35, 95, 0.2),
		0 2px 6px rgba(0, 0, 0, 0.08),
		/* Halo de bord qui irradie vers l'extérieur — jeu de lumière poussé */
		0 0 48px rgba(56, 189, 248, 0.55),
		0 0 18px rgba(186, 230, 253, 0.45);
	transform: translateZ(20px);
	will-change: transform, box-shadow;
	cursor: default;
	transition:
		transform 0.12s cubic-bezier(0.23, 1, 0.32, 1),
		box-shadow 0.12s ease;
}

/*
 * Marge lumineuse — la couche de lumière occupe TOUTE la marge (border = padding
 * de la dalle), pas juste un liseré. background-clip: border-box confine les
 * gradients dans la marge ; le padding-box transparent laisse la facture intacte.
 * Deux couches, fondues en `screen` pour que la lumière s'ADDITIONNE au givré
 * (caustique lumineuse, pas un sticker posé) :
 * - conic-gradient : rim glow CONTINU sur tout le périmètre (bleu clair ↔ navy)
 * - radial-gradient: point chaud mobile piloté par --light-x/y, qui FUIT le
 *   curseur (coordonnées inversées par hero-glass.js)
 * Le biseau (inset box-shadow) donne l'épaisseur du verre.
 */
.hero-glass__border {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	/* Largeur de l'anneau lumineux (réduite : le liseré gris en bordure interne
	 * du conic doublait visuellement l'épaisseur) */
	padding: 3px;
	background:
		radial-gradient(
			ellipse 16% 16% at var(--light-x, 75%) var(--light-y, 100%),
			rgba(255, 255, 255, 1) 0%,
			rgba(255, 255, 255, 1) 14%,
			rgba(224, 242, 254, 1) 26%,
			rgba(125, 211, 252, 0.5) 42%,
			transparent 58%
		),
		conic-gradient(
			from 210deg,
			rgba(90, 130, 200, 0.5),
			rgba(20, 28, 82, 0.92),
			rgba(120, 160, 220, 0.45),
			rgba(15, 22, 70, 0.95),
			rgba(70, 110, 190, 0.55),
			rgba(90, 130, 200, 0.5)
		);
	/* Mask-ring : ne garde QUE l'anneau de 5px (exclut la zone centrale =
	 * content-box), suit les coins arrondis. Pas de backdrop-filter ici, donc
	 * l'issue Chromium #974857 (backdrop-filter ignore les masks) ne s'applique pas. */
	-webkit-mask:
		linear-gradient(#000 0 0) content-box,
		linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask:
		linear-gradient(#000 0 0) content-box,
		linear-gradient(#000 0 0);
	mask-composite: exclude;
	pointer-events: none;
	z-index: 10;
}

/*
 * Reflet spéculaire de la face — un halo blanc qui simule une lumière de fond
 * accrochant le verre. Invisible au repos (--glare-strength: 0) ; hero-glass.js
 * déplace --glare-x/y et monte --glare-strength selon l'AMPLITUDE du tilt, donc
 * le halo n'apparaît et ne glisse QUE quand la dalle s'incline. `screen` ajoute
 * la lumière sans masquer le screenshot. Au-dessus de l'image, sous l'anneau.
 */
.hero-glass__glare {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	z-index: 5;
	pointer-events: none;
	mix-blend-mode: screen;
	opacity: var(--glare-strength, 0);
	background: radial-gradient(
		ellipse 45% 45% at var(--glare-x, 50%) var(--glare-y, 50%),
		rgba(255, 255, 255, 0.85) 0%,
		rgba(224, 242, 254, 0.4) 35%,
		transparent 70%
	);
	transition: opacity 0.2s ease;
}

.hero-glass .hero-screenshot {
	display: block;
	width: 100%;
	height: auto;
	position: relative;
	z-index: 1;
	/* Coins carrés : le parent (overflow:hidden, radius 14px) les clippe et les
	 * fait passer sous l'anneau arrondi. Bords droits collés à l'anneau. */
	border-radius: 0;
}

/* État enfoncé */
.hero-glass.is-pressed {
	box-shadow:
		0 8px 24px rgba(14, 165, 233, 0.14),
		0 2px 6px rgba(0, 0, 0, 0.1);
}

/* Reduced-motion : le verre, le givré, le rim et le biseau restent ; on coupe
 * uniquement le mouvement (tilt JS non attaché côté JS, transitions off ici). */
@media (prefers-reduced-motion: reduce) {
	.hero-glass {
		transition: none;
		transform: translateZ(0);
	}
}

@media (max-width: 1024px) {
	.vitrine-fg-hero__inner {
		grid-template-columns: 1fr;
	}
	.vitrine-fg-hero__visual {
		max-width: 100%;
	}
}

@media (max-width: 480px) {
	.vitrine-fg-hero__visual {
		display: none;
	}
}

/* ---------------------------------------------------------------------------
 * §2 — Notre solution — 4 feature cards
 * ------------------------------------------------------------------------- */
.vitrine-fg-solution {
	padding-top: calc(var(--fg-section-y) - 1.375rem);
}
.vitrine-fg-solution__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	align-items: start;
}
.vitrine-fg-solution__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	text-align: center;
}
.vitrine-fg-solution__icon-holder {
	width: 100px;
	height: 100px;
	border-radius: 12px;
	background: var(--fg-blue-50);
	color: var(--fg-cta);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.vitrine-fg-solution__card-title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.4;
	color: var(--fg-space);
	margin: 0;
}
.vitrine-fg-solution__card-desc {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--fg-blue-900);
	margin: 0;
	max-width: 266px;
}

@media (max-width: 1024px) {
	.vitrine-fg-solution__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 2.5rem 1.5rem;
	}
}
@media (max-width: 640px) {
	.vitrine-fg-solution__grid {
		grid-template-columns: 1fr;
	}
}

/* ---------------------------------------------------------------------------
 * §2 — Solution card icon animations
 * ------------------------------------------------------------------------- */

/* 1. Devices — whole-icon hover (paths are structurally inseparable) */
.dv-icon {
	transition: transform 0.3s ease;
	display: block;
}
@media (hover: hover) {
	.vitrine-fg-solution__card:hover .dv-icon {
		transform: scale(1.02) translateY(-2px);
	}
}

/* 2. HardDrives — ambient LED pulse, chassis static */
@keyframes hd-led-pulse-1 {
	0%,
	100% {
		opacity: 0.4;
	}
	50% {
		opacity: 1;
	}
}
@keyframes hd-led-pulse-2 {
	0%,
	100% {
		opacity: 0.3;
	}
	50% {
		opacity: 1;
	}
}
.hd-led-1 {
	animation: hd-led-pulse-1 1.2s ease-in-out infinite;
}
.hd-led-2 {
	animation: hd-led-pulse-2 1.8s ease-in-out infinite;
}
/* a11y (WCAG 2.3.3) : couper le pulse des LED sous prefers-reduced-motion,
   les laisser allumées statiques. */
@media (prefers-reduced-motion: reduce) {
	.hd-led-1,
	.hd-led-2 {
		animation: none;
		opacity: 1;
	}
}

/* 3. CloudCheck — checkmark path-draw on hover (pointer devices only) */
.cc-check {
	transition: stroke-dashoffset 0.4s cubic-bezier(0.22, 1, 0.36, 1) 0.15s;
}
@media (hover: hover) {
	.vitrine-fg-solution__card:hover .cc-check {
		stroke-dashoffset: 0;
	}
}

/* ---------------------------------------------------------------------------
 * §3 — Clients band
 * ------------------------------------------------------------------------- */
.vitrine-fg-clients {
	background: var(--fg-blue-100);
}
.vitrine-fg-clients__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: wrap;
}
.vitrine-fg-clients__logos-wrap {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	position: relative;
	/* Marge verticale : laisse respirer l'aura des logos au survol sans qu'elle
	 * soit clippée par l'overflow:hidden (qui masque le marquee horizontalement). */
	padding-block: 26px;
}
.vitrine-fg-clients__logos-wrap::before,
.vitrine-fg-clients__logos-wrap::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100px;
	z-index: 2;
	pointer-events: none;
}
.vitrine-fg-clients__logos-wrap::before {
	left: 0;
	background: linear-gradient(to right, #dae4f8, transparent);
}
.vitrine-fg-clients__logos-wrap::after {
	right: 0;
	background: linear-gradient(to left, #dae4f8, transparent);
}
.vitrine-fg-clients__track {
	display: flex;
	align-items: center;
	width: max-content;
	animation: clients-marquee 22s linear infinite;
}
.vitrine-fg-clients__item {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	margin-right: 3rem;
}
.vitrine-fg-clients__logo {
	height: 50px;
	width: auto;
	display: block;
}
@keyframes clients-marquee {
	from {
		transform: translateX(0);
	}
	to {
		transform: translateX(calc(-100% / 3));
	}
}
@media (prefers-reduced-motion: reduce) {
	.vitrine-fg-clients__track {
		animation: none;
	}
}

/* Logos cliquables : lien wrapper + pause du défilement au survol souris. */
.vitrine-fg-clients__link {
	display: inline-flex;
	align-items: center;
}
.vitrine-fg-clients__logos-wrap:hover .vitrine-fg-clients__track {
	animation-play-state: paused;
}

/* Le marquee se met en pause au survol : on met en valeur le logo visé avec
 * une aura blanchâtre douce en ellipse derrière lui (aussi au focus clavier). */
.vitrine-fg-clients__link {
	position: relative;
}
.vitrine-fg-clients__link::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 50%;
	width: 150%;
	height: 190%;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background: radial-gradient(
		ellipse at center,
		rgba(255, 255, 255, 0.5),
		rgba(255, 255, 255, 0) 68%
	);
	opacity: 0;
	transition: opacity 220ms ease;
	pointer-events: none;
	z-index: 0;
}
.vitrine-fg-clients__logo {
	position: relative;
	z-index: 1;
	transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}
.vitrine-fg-clients__link:hover::before,
.vitrine-fg-clients__link:focus-visible::before {
	opacity: 1;
}
.vitrine-fg-clients__link:hover .vitrine-fg-clients__logo,
.vitrine-fg-clients__link:focus-visible .vitrine-fg-clients__logo {
	transform: scale(1.06);
}
@media (prefers-reduced-motion: reduce) {
	.vitrine-fg-clients__link::before,
	.vitrine-fg-clients__logo {
		transition: none;
	}
	.vitrine-fg-clients__link:hover .vitrine-fg-clients__logo,
	.vitrine-fg-clients__link:focus-visible .vitrine-fg-clients__logo {
		transform: none;
	}
}

/* Tailles individuelles des logos (ajustables au rendu réel). */
.vitrine-fg-clients__logo--lg {
	height: 64px;
}
.vitrine-fg-clients__logo--sm {
	height: 38px;
}

/* Texte au-dessus du carrousel sur tablette et mobile. */
@media (max-width: 1024px) {
	.vitrine-fg-clients__inner {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 3rem;
	}
	.vitrine-fg-clients__inner .vitrine-fg-badge {
		flex-shrink: 0;
	}
	.vitrine-fg-clients__logos-wrap {
		width: 100%;
		flex: none;
	}
}

/* ---------------------------------------------------------------------------
 * §4 — Nos points forts — navy 3×2 grid
 * ------------------------------------------------------------------------- */
.vitrine-fg-strong {
	background: var(--fg-bg-navy);
	padding-bottom: 1.5rem;
}
.vitrine-fg-strong__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
}
.vitrine-fg-strong__card {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	padding: 20px;
	min-height: 420px;
	background: var(--fg-blue-800);
	border-radius: var(--fg-radius-card);
	border-bottom: 3px solid var(--fg-blue-300);
	color: #fff;
}
.vitrine-fg-strong__card--media {
	padding: 0;
	overflow: hidden;
	border-bottom: none;
}
.vitrine-fg-strong__card--media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: var(--fg-radius-card);
}
.vitrine-fg-strong__icon {
	color: var(--fg-blue-300);
	display: inline-flex;
}
.vitrine-fg-strong__card-title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.4;
	margin: 0;
	color: #fff;
}
.vitrine-fg-strong__card-desc {
	font-size: 1rem;
	line-height: 1.5;
	margin: 0;
	color: #fff;
}

@media (max-width: 1024px) {
	.vitrine-fg-strong__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.vitrine-fg-strong__card {
		min-height: auto;
	}
	.vitrine-fg-strong__card--media {
		aspect-ratio: 4 / 3;
	}
}
@media (max-width: 640px) {
	.vitrine-fg-strong__grid {
		grid-template-columns: 1fr;
	}
	/* Card image décorative (aria-hidden) masquée en mobile : sur 1 colonne
	 * elle déséquilibre la grille (image cover != cards texte), aucune
	 * info perdue puisqu'elle est purement esthétique. */
	.vitrine-fg-strong__card--media {
		display: none;
	}
}

/* ---------------------------------------------------------------------------
 * §5 — Comment ça fonctionne — 3 numbered steps with connecting line
 * ------------------------------------------------------------------------- */
.vitrine-fg-how__grid {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
	align-items: start;
	/* Reset des défauts <ol> : sans ça, le padding-inline-start:40px du
	 * navigateur décale toute la grille vers la droite (flagrant en
	 * mono-colonne mobile). */
	list-style: none;
	margin: 0;
	padding: 0;
}
/* Dashed connector line — between rows of icons */
.vitrine-fg-how__grid::before {
	content: "";
	position: absolute;
	top: 122px;
	left: 16%;
	right: 16%;
	height: 0;
	border-top: 2px dashed var(--fg-blue-300);
	z-index: 0;
}
.vitrine-fg-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px;
	text-align: center;
	position: relative;
	z-index: 1;
}
.vitrine-fg-step__number {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--fg-cta);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
}
.vitrine-fg-step__icon-holder {
	width: 100px;
	height: 100px;
	border-radius: 12px;
	background: var(--fg-blue-50);
	color: var(--fg-cta);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.vitrine-fg-step__title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.4;
	color: var(--fg-space);
	margin: 0;
	max-width: 320px;
}
.vitrine-fg-step__desc {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--fg-blue-900);
	margin: 0;
	max-width: 280px;
}

@media (max-width: 1024px) {
	.vitrine-fg-how__grid {
		grid-template-columns: 1fr;
		gap: 3rem;
	}
	.vitrine-fg-how__grid::before {
		display: none;
	}
}

/* ---------------------------------------------------------------------------
 * §6 — La documentation — 2 cards with arrow CTA
 * ------------------------------------------------------------------------- */
.vitrine-fg-doc {
	background:
		radial-gradient(ellipse 70% 60% at 90% 10%, white 0%, transparent 60%),
		radial-gradient(
			ellipse 55% 55% at 10% 90%,
			var(--fg-blue-300) 0%,
			transparent 65%
		),
		linear-gradient(
			120deg,
			transparent 30%,
			color-mix(in srgb, white 55%, var(--fg-blue-100) 45%) 50%,
			transparent 70%
		),
		linear-gradient(135deg, var(--fg-blue-100) 0%, var(--fg-blue-300) 100%);
}
.vitrine-fg-doc__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 80px;
	max-width: 880px;
	margin: 0 auto;
}
.vitrine-fg-doc__card {
	display: flex;
	gap: 20px;
	padding: 20px;
	background: #fff;
	border: 1px solid var(--fg-blue-300);
	border-radius: var(--fg-radius-card);
	text-decoration: none;
	color: inherit;
	transition:
		transform 220ms ease,
		box-shadow 220ms ease;
}
.vitrine-fg-doc__card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 32px -8px rgba(20, 28, 82, 0.15);
}
.vitrine-fg-doc__icon {
	color: var(--fg-cta);
	display: inline-flex;
	flex-shrink: 0;
}
.vitrine-fg-doc__body {
	display: flex;
	flex-direction: column;
	gap: 20px;
	flex: 1;
}
.vitrine-fg-doc__card-title {
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.4;
	color: var(--fg-space);
	margin: 0;
}
.vitrine-fg-doc__card-desc {
	font-size: 1rem;
	line-height: 1.5;
	color: var(--fg-blue-900);
	margin: 0;
}
.vitrine-fg-doc__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 1rem;
	font-weight: 500;
	color: var(--fg-cta);
	margin-top: auto;
}
.vitrine-fg-doc__cta-arrow {
	display: inline-flex;
	transition: transform 200ms ease;
}
.vitrine-fg-doc__card:hover .vitrine-fg-doc__cta-arrow {
	transform: translateX(4px);
}

@media (max-width: 768px) {
	.vitrine-fg-doc__grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

/* ---------------------------------------------------------------------------
 * §7 — L'alliance — navy + perspective image
 * ------------------------------------------------------------------------- */
.vitrine-fg-alliance {
	background: var(--fg-bg-navy);
	position: relative;
	overflow: hidden;
	min-height: 832px;
}
.vitrine-fg-alliance__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
	text-align: center;
	position: relative;
	z-index: 1;
}
.vitrine-fg-alliance__brand {
	margin-bottom: 1rem;
	color: #fff;
}
.vitrine-fg-alliance__brand-text {
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: #fff;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
}
.vitrine-fg-alliance__brand-logo {
	height: 40px;
	width: auto;
	display: block;
}
.vitrine-fg-alliance__brand-sub {
	font-size: 1rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.7);
	margin-top: 4px;
}
.vitrine-fg-alliance__lead {
	font-size: 1rem;
	line-height: 1.5;
	color: #fff;
	max-width: 720px;
	margin: 0;
}
.vitrine-fg-alliance__visual {
	position: absolute;
	left: 50%;
	bottom: -80px;
	width: 960px;
	max-width: 90%;
	transform: translateX(-50%) rotate(7.88deg);
	pointer-events: none;
	opacity: 0.75;
}
.vitrine-fg-alliance__visual img {
	width: 100%;
	height: auto;
	display: block;
}

@media (prefers-reduced-motion: reduce) {
	.vitrine-fg-alliance__visual {
		transform: translateX(-50%);
	}
}

/* ---------------------------------------------------------------------------
 * §8 — Contact form card
 * ------------------------------------------------------------------------- */
.vitrine-fg-contact-section {
	background: #fff;
}
.vitrine-fg-contact {
	background: var(--fg-blue-100);
	border-radius: 16px;
	border-bottom: 12px solid var(--fg-blue-700);
	padding: clamp(32px, 5vw, 60px);
	max-width: 952px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 32px;
}
.vitrine-fg-contact__row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
}
.vitrine-fg-contact__field {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.vitrine-fg-contact__label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.vitrine-fg-contact input,
.vitrine-fg-contact select,
.vitrine-fg-contact textarea {
	height: 40px;
	padding: 0 12px;
	background: #fff;
	border: 1px solid var(--fg-border-soft);
	border-radius: var(--fg-radius-input);
	font-size: 0.875rem;
	font-family: inherit;
	color: var(--fg-blue-900);
	width: 100%;
	transition:
		border-color 200ms ease,
		box-shadow 200ms ease;
}
.vitrine-fg-contact textarea {
	height: auto;
	min-height: 120px;
	padding: 12px;
	resize: vertical;
	line-height: 1.5;
}
.vitrine-fg-contact input::placeholder,
.vitrine-fg-contact textarea::placeholder,
.vitrine-fg-contact select:invalid {
	color: var(--fg-text-muted);
}
.vitrine-fg-contact input:focus,
.vitrine-fg-contact select:focus,
.vitrine-fg-contact textarea:focus {
	outline: none;
	border-color: var(--fg-cta);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.15);
}
.vitrine-fg-contact__submit {
	align-self: center;
	min-width: 120px;
	justify-content: center;
}
.vitrine-fg-contact input[aria-invalid="true"],
.vitrine-fg-contact select[aria-invalid="true"],
.vitrine-fg-contact textarea[aria-invalid="true"] {
	border-color: #d92d20;
	box-shadow: 0 0 0 3px rgba(217, 45, 32, 0.12);
}
.vitrine-fg-contact__error {
	color: #d92d20;
	font-size: 0.8125rem;
	line-height: 1.4;
}
.vitrine-fg-contact__error[hidden] {
	display: none;
}

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

/* ---------------------------------------------------------------------------
 * Toast — notification in-page (succès/erreur formulaire contact).
 * ------------------------------------------------------------------------- */
.vitrine-toast-container {
	position: fixed;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1000;
	display: flex;
	flex-direction: column;
	gap: 8px;
	max-width: min(90vw, 420px);
}
.vitrine-toast {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 16px;
	border-radius: 10px;
	background: var(--fg-blue-900, #141c52);
	color: #fff;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
	font-size: 0.9375rem;
	animation: vitrine-toast-in 220ms ease;
}
.vitrine-toast--error {
	background: #d92d20;
}
.vitrine-toast__text {
	flex: 1;
}
.vitrine-toast__close {
	background: transparent;
	border: none;
	color: inherit;
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	padding: 4px;
}

@keyframes vitrine-toast-in {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.vitrine-toast {
		animation: none;
	}
}

/* ---------------------------------------------------------------------------
 * Footer Figma redesign
 * ------------------------------------------------------------------------- */
.mk-footer--figma {
	background: var(--fg-bg-navy);
	color: #fff;
	padding: 20px clamp(20px, 5vw, 140px);
}
.mk-footer--figma .mk-footer__inner {
	max-width: var(--fg-max-width);
	margin: 0 auto;
	/* Override DS marketing-footer.css qui impose display:grid 5-col +
	 * padding lourd — incompatible avec notre layout 2 blocs (__top + legal-band). */
	display: block;
	grid-template-columns: none;
	gap: 0;
	padding: 0;
}
.mk-footer--figma .mk-footer__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: clamp(2rem, 6vw, 4rem);
	padding: 16px 0;
}
.mk-footer--figma .mk-footer__brand {
	/* WCAG 2.5.5 AAA touch target : padding-block 12 ajoute hit area
     (logo 24px + 12+12 = 48px hauteur). */
	display: inline-flex;
	flex-direction: column;
	padding: 12px 0;
	text-decoration: none;
	color: #fff;
}
.mk-footer--figma .mk-footer__brand-name {
	font-weight: 700;
	font-size: 1.5rem;
}
.mk-footer--figma .mk-footer__brand-logo {
	height: 48px;
	width: auto;
	display: block;
}
.mk-footer--figma .mk-footer__brand-sub {
	font-weight: 500;
	font-size: 0.75rem;
	opacity: 0.85;
}
.mk-footer--figma .mk-footer__cols {
	display: flex;
	gap: 48px;
}
.mk-footer--figma .mk-footer__col {
	display: flex;
	flex-direction: column;
	gap: 8px;
	color: #fff;
}
.mk-footer--figma .mk-footer__heading {
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.4;
	margin: 0;
	color: #fff;
	/* Override DS marketing-footer.css qui force uppercase + letter-spacing */
	text-transform: none;
	letter-spacing: 0;
}
.mk-footer--figma .mk-footer__address {
	font-style: normal;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #fff;
	font-weight: 400;
}
.mk-footer--figma .mk-footer__col nav {
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.mk-footer--figma .mk-footer__col nav a {
	/* Padding réduit pour matcher la compacité Figma. Touch target reste
	 * ≥24×24 (WCAG AA conformité légale), sous AAA mais cohérent avec le
	 * design plus dense du footer. */
	display: inline-block;
	padding: 4px 0;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #fff;
	text-decoration: none;
	font-weight: 400;
}
.mk-footer--figma .mk-footer__col nav a:hover {
	text-decoration: underline;
}
/* Compense le padding ajouté pour préserver la spacing visuelle existante */
.mk-footer--figma .mk-footer__col nav {
	gap: 0;
}
.mk-footer__social-link {
	/* WCAG 2.5.5 AAA touch target ≥44×44. Icône SVG 32×32 centrée dans la zone de tap. */
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 8px;
	transition: opacity 200ms ease;
}
.mk-footer__social-link:hover {
	opacity: 0.85;
}
.mk-footer__social-link svg {
	width: 32px;
	height: 32px;
	display: block;
}
.mk-footer--figma .mk-footer__legal-band {
	padding: 20px 0;
	text-align: center;
	font-size: 0.75rem;
	color: #fff;
	border-top: 1px solid color-mix(in srgb, white 15%, transparent);
	margin-top: clamp(1.5rem, 4vw, 2.5rem);
}
.mk-footer--figma .mk-footer__legal-band p {
	margin: 0;
}

@media (max-width: 1024px) {
	.mk-footer--figma .mk-footer__top {
		flex-direction: column;
		gap: 32px;
	}
	.mk-footer--figma .mk-footer__cols {
		flex-wrap: wrap;
		gap: 32px;
	}
}

/* Newsletter col — small form in footer */
.mk-footer--figma .mk-footer__col--newsletter {
	max-width: 280px;
}
.mk-footer__newsletter-lead {
	font-size: 0.875rem;
	line-height: 1.4;
	margin: 0;
}
.mk-footer__newsletter-form {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 8px 0;
}
.mk-footer__newsletter-form input[type="email"] {
	height: 40px;
	padding: 0 12px;
	background: #fff;
	border: 1px solid var(--fg-border-soft);
	border-radius: var(--fg-radius-input);
	font-size: 0.875rem;
	color: var(--fg-blue-900);
	font-family: inherit;
}
.mk-footer__newsletter-form input[type="email"]::placeholder {
	color: var(--fg-text-muted);
}
.mk-footer__newsletter-form input[type="email"]:focus {
	outline: 2px solid var(--fg-cta);
	outline-offset: 2px;
}
.mk-footer__newsletter-form .btn--cta {
	align-self: flex-start;
}
.mk-footer__newsletter-note {
	font-size: 0.75rem;
	line-height: 1.4;
	margin: 0;
	color: #fff;
	opacity: 0.7;
}
.mk-footer__newsletter-note a {
	color: #fff;
	text-decoration: underline;
}

/* Vitrine breadcrumb (B.2) — visible HTML next to JSON-LD BreadcrumbList */
.vitrine-breadcrumb {
	max-width: var(--fg-max-width, 1160px);
	margin: 0 auto;
	padding: 16px clamp(20px, 5vw, 140px) 0;
	font-size: 0.875rem;
	color: var(--fg-text-muted, #666);
}
.vitrine-breadcrumb ol {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.vitrine-breadcrumb li {
	display: inline-flex;
	align-items: center;
}
.vitrine-breadcrumb li:not(:last-child)::after {
	content: "›";
	margin-left: 0.5rem;
	color: var(--fg-text-muted, #666);
}
.vitrine-breadcrumb a {
	color: var(--fg-cta, #2563eb);
	text-decoration: none;
}
.vitrine-breadcrumb a:hover {
	text-decoration: underline;
}
.vitrine-breadcrumb li[aria-current="page"] {
	color: var(--fg-space, #141c52);
	font-weight: 500;
}

/* Glossary — DefinedTermSet Schema.org markup (C.6) */
.vitrine-glossary {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin: 0;
	padding: 0;
}
.vitrine-glossary__item {
	padding: 1.25rem 1.5rem;
	background: var(--fg-blue-50, #ecf1fb);
	border-left: 4px solid var(--fg-cta, #2563eb);
	border-radius: 8px;
	scroll-margin-top: 130px;
}
.vitrine-glossary__item:target {
	background: var(--fg-blue-100, #dae4f8);
	outline: 2px solid var(--fg-cta, #2563eb);
}
.vitrine-glossary__term {
	margin: 0 0 0.5rem;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--fg-space, #141c52);
}
.vitrine-glossary__term dfn {
	font-style: normal;
}
.vitrine-glossary__def {
	margin: 0;
	font-size: 1rem;
	line-height: 1.55;
	color: var(--fg-blue-900, #0e182c);
}
@media (min-width: 768px) {
	.vitrine-glossary {
		grid-template-columns: 1fr 1fr;
	}
}

/* WCAG 2.2 — 2.5.8 Target Size (Minimum) AA : tous les targets ≥ 24×24px.
   .vitrine-anchor-dots__dot du design system fait 10×10. On expand le hit
   area via padding sans toucher au visuel (box-sizing: content-box garde
   width:10 pour le dot, le padding 7 ajoute 14 → 24 total). Le gap entre
   dots est de var(--s-3, 12px) ce qui laisse marge pour les paddings. */
.vitrine-anchor-dots__dot {
	box-sizing: content-box;
	padding: 7px;
	/* Centre le hit area sur le dot existant (sinon il décale visuellement). */
	background-clip: content-box;
	position: relative;
}

/* Label section au survol — frosted glass pill à gauche du dot.
   Lit attr(data-label) posé par public/js/anchor-dots.js. */
.vitrine-anchor-dots__dot::before {
	content: attr(data-label);
	position: absolute;
	right: calc(100% + var(--s-3));
	top: 50%;
	transform: translateY(-50%) translateX(4px);
	white-space: nowrap;
	padding: var(--s-1) var(--s-3);
	border-radius: var(--radius-full);
	background: rgba(255, 255, 255, 0.82);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	color: var(--color-brand);
	font-size: var(--text-xs);
	font-weight: 500;
	box-shadow: var(--shadow-sm);
	opacity: 0;
	pointer-events: none;
	transition:
		opacity 180ms ease,
		transform 180ms ease;
}

.vitrine-anchor-dots__dot:hover::before {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}

.vitrine-anchor-dots__dot:focus-visible::before {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}

@media (prefers-reduced-motion: reduce) {
	.vitrine-anchor-dots__dot::before {
		transition: none;
	}
}

/* Inversion fond sombre — quand [data-dark-section] est posé par anchor-dots.js
   (section avec data-bg-dark="true"), les dots passent en blanc sur fond navy. */
.vitrine-anchor-dots[data-dark-section] .vitrine-anchor-dots__dot {
	border-color: rgba(255, 255, 255, 0.45);
}
.vitrine-anchor-dots[data-dark-section]
	.vitrine-anchor-dots__dot[data-active="true"] {
	background: #fff;
	border-color: #fff;
}
.vitrine-anchor-dots[data-dark-section] .vitrine-anchor-dots__dot:hover {
	border-color: #fff;
}
.vitrine-anchor-dots[data-dark-section]
	.vitrine-anchor-dots__dot:focus-visible::before {
	opacity: 1;
	transform: translateY(-50%) translateX(0);
}
.vitrine-anchor-dots[data-dark-section] .vitrine-anchor-dots__dot::before {
	background: rgba(11, 31, 58, 0.88);
	color: #fff;
}

/* WCAG 2.5.5 + iOS HIG + Material — touch target 48px (au-dessus du minimum
   24/44 WCAG, conformité multi-OS optimale). Variable réutilisable. */
:root {
	--touch-min: 48px;
}

/* CTA "Contacter un expert" : sur mobile étroit, le bouton .btn--cta peut
   tomber sous 44 de width quand placé dans un flex container — min-width
   force une hit area respectueuse. */
.btn--cta {
	min-width: var(--touch-min);
	/* height 44 existant + min-width 48 = hit area garantie even en flex shrink */
}

/* "En savoir plus" footer newsletter-note <a> : default inline link = 17px
   de hauteur. Padding-block ajoute hit area sans casser le flow texte. */
.mk-footer--figma .mk-footer__newsletter-note a {
	display: inline-block;
	padding: 8px 4px;
	/* Compense le margin pour éviter le décalage visuel inattendu */
	margin: -8px -4px;
}

/* Footer brand: déjà à 144×48 via padding 12 0 (commit chore a11y précédent),
   on bump pour atteindre --touch-min consistant sur tous OS. */
.mk-footer--figma .mk-footer__brand {
	min-height: var(--touch-min);
}

/* Heading clamp mobile — display-xl du design system est clamp(3.5rem, ...) =
   56px minimum, trop large sur 320px width. Lower bound réduit à 2.5rem (40px)
   pour respecter le content sans coupure horizontale. Upper bound 96px conservé. */
:root {
	--display-xl: clamp(2.5rem, 6vw + 1rem, 6rem);
}

/* Scroll-to-top button — apparaît après 1 viewport scroll (cf. scroll-to-top.js).
   Fixed bottom-right, hit area 48×48, focus visible distinct. */
.vitrine-scroll-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	width: var(--touch-min, 48px);
	height: var(--touch-min, 48px);
	display: none;
	align-items: center;
	justify-content: center;
	background: var(--fg-cta, #2563eb);
	color: #fff;
	border: none;
	border-radius: 50%;
	cursor: pointer;
	z-index: 950;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	transition:
		transform 200ms cubic-bezier(0.22, 1, 0.36, 1),
		opacity 200ms ease,
		background 200ms ease;
}
.vitrine-scroll-top.is-visible {
	display: inline-flex;
}
.vitrine-scroll-top:hover {
	transform: translateY(-2px);
	background: var(--fg-cta-hover, #1e40af);
}
.vitrine-scroll-top:focus-visible {
	outline: 3px solid var(--fg-cta, #2563eb);
	outline-offset: 3px;
}
@media (prefers-reduced-motion: reduce) {
	.vitrine-scroll-top {
		transition: none;
	}
	.vitrine-scroll-top:hover {
		transform: none;
	}
}

/* Footer enrichissement : SIREN + emails contact (RGAA 8.9 information
   identification de l'éditeur + facilité de contact pour signaler problèmes). */
.mk-footer--figma .mk-footer__siren {
	display: inline-block;
	margin-top: 8px;
	font-size: 0.75rem;
	font-variant-numeric: tabular-nums;
	opacity: 0.75;
}
.mk-footer--figma .mk-footer__contact-emails {
	margin: 12px 0 0 0;
	font-size: 0.875rem;
	line-height: 1.8;
}
.mk-footer--figma .mk-footer__contact-emails a {
	color: #fff;
	text-decoration: underline;
	text-decoration-color: rgba(255, 255, 255, 0.4);
	text-underline-offset: 2px;
	display: inline-block;
	padding: 4px 0;
}
.mk-footer--figma .mk-footer__contact-emails a:hover,
.mk-footer--figma .mk-footer__contact-emails a:focus-visible {
	text-decoration-color: #fff;
}

/* Newsletter consent checkbox (RGPD double opt-in explicite). */
.mk-footer--figma .mk-footer__newsletter-consent {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 0.75rem;
	line-height: 1.4;
	cursor: pointer;
	padding: 4px 0;
}
.mk-footer--figma .mk-footer__newsletter-consent input[type="checkbox"] {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	margin-top: 2px;
	cursor: pointer;
}
.mk-footer--figma .mk-footer__newsletter-consent span {
	color: rgba(255, 255, 255, 0.85);
}

/* Plan du site (/plan-du-site) — RGAA 12.2 (plan du site). Layout simple
   à 2 colonnes sur desktop, 1 sur mobile. Bullets retirées (nav-like). */
.vitrine-plan {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}
@media (min-width: 768px) {
	.vitrine-plan {
		grid-template-columns: 1fr 1fr;
	}
}
.vitrine-plan__heading {
	font-size: 1.25rem;
	margin: 0 0 1rem 0;
	color: var(--fg-space, #141c52);
}
.vitrine-plan__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}
.vitrine-plan__item {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.vitrine-plan__link {
	font-weight: 600;
	color: var(--color-brand, #2563eb);
	text-decoration: none;
	padding: 6px 0;
	min-height: var(--touch-min, 48px);
	display: inline-flex;
	align-items: center;
}
.vitrine-plan__link:hover,
.vitrine-plan__link:focus-visible {
	text-decoration: underline;
}
.vitrine-plan__desc {
	font-size: 0.875rem;
	color: var(--fg-blue-900, #0e182c);
	opacity: 0.8;
}

/* Trust signals legal band — sobre texte avec bullets décoratives.
   Pas de claim certif non détenue (immatriculation PA dit "en cours"). */
.mk-footer--figma .mk-footer__trust {
	list-style: none;
	padding: 0;
	margin: 0 0 12px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px 20px;
	font-size: 0.75rem;
}
.mk-footer--figma .mk-footer__trust li {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.mk-footer--figma .mk-footer__trust span[aria-hidden] {
	color: var(--color-brand-mid, #5a8dee);
	font-size: 0.625rem;
}
.mk-footer--figma .mk-footer__trust-note {
	opacity: 0.7;
	font-style: italic;
}
