/* ============================================================
   STUDIO ORBE — Composants & Layout
   Mobile-first (min-width queries), container queries, glassmorphism,
   bento grids, kinetic typography, scroll-driven animations.
   ============================================================ */

/* ---------- Layout helpers ---------- */
.container {
  width: 100%;
  max-width: var(--content-wide);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.container--default { max-width: var(--content-default); }
.container--narrow  { max-width: var(--content-narrow); }

.section {
  padding-block: clamp(var(--space-16), 9vw, var(--space-32));
  position: relative;
}
.section--tight { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); }

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-body);
  font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-primary);
}
.eyebrow::before {
  content: ''; width: 1.75rem; height: 1px;
  background: currentColor; opacity: 0.6;
}

.section-head { max-width: 46rem; margin-bottom: clamp(var(--space-8), 4vw, var(--space-12)); }
.section-head h2 { font-size: var(--text-2xl); margin-block: var(--space-4) var(--space-3); }
.section-head p { color: var(--color-text-muted); font-size: var(--text-lg); }
.text-center { text-align: center; }
.section-head.text-center { margin-inline: auto; }
.section-head.text-center p { margin-inline: auto; }

/* ---------- Boutons (zones de clic ≥ 48px) ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  min-height: 48px; padding: var(--space-3) var(--space-6);
  font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600;
  border-radius: var(--radius-full);
  border: 1px solid transparent;
  white-space: nowrap;
  will-change: transform;
}
.btn svg { width: 1.1em; height: 1.1em; }
.btn--primary {
  background: var(--color-primary); color: var(--color-primary-contrast);
  box-shadow: var(--shadow-glow);
}
.btn--primary:hover { background: var(--color-primary-hover); transform: translateY(-2px); }
.btn--primary:active { background: var(--color-primary-active); transform: translateY(0); }
.btn--ghost {
  background: transparent; color: var(--color-text);
  border-color: var(--color-border);
}
.btn--ghost:hover { border-color: var(--color-primary); color: var(--color-primary); transform: translateY(-2px); }
.btn--light {
  background: var(--color-surface-2); color: var(--color-text);
  border-color: var(--color-border);
}
.btn--light:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

.arrow-link {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-weight: 600; font-size: var(--text-sm); color: var(--color-primary);
}
.arrow-link svg { transition: transform var(--transition-interactive); }
.arrow-link:hover svg { transform: translateX(4px); }

/* ============================================================
   HEADER / NAVIGATION — mobile-first, thumb-friendly
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 100;
  padding-block: var(--space-3);
  background: var(--color-surface-glass);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  backdrop-filter: blur(18px) saturate(160%);
  border-bottom: 1px solid var(--color-divider);
  transition: background var(--transition-slow), border-color var(--transition-slow);
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
}
.brand {
  display: inline-flex; align-items: center; gap: var(--space-3);
  font-family: var(--font-display); font-weight: 600;
  font-size: var(--text-lg); letter-spacing: -0.02em;
  color: var(--color-text);
}
.brand__mark { width: 34px; height: 34px; color: var(--color-primary); flex: none; }
.brand__mark svg { width: 100%; height: 100%; }

.nav__links {
  display: none;
  list-style: none;
  align-items: center; gap: var(--space-1);
}
.nav__links a {
  display: inline-flex; align-items: center;
  min-height: 44px; padding-inline: var(--space-4);
  font-size: var(--text-sm); font-weight: 500;
  color: var(--color-text-muted); border-radius: var(--radius-full);
}
.nav__links a:hover { color: var(--color-text); background: var(--color-surface-offset); }
.nav__links a[aria-current='page'] { color: var(--color-primary); font-weight: 600; }

.nav__actions { display: flex; align-items: center; gap: var(--space-2); }

/* Boutons icône (langue / thème) */
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 44px; min-height: 44px; padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-full); color: var(--color-text-muted);
  border: 1px solid var(--color-border); background: var(--color-surface);
  font-size: var(--text-sm); font-weight: 600;
}
.icon-btn:hover { color: var(--color-primary); border-color: var(--color-primary); }
.lang-btn { letter-spacing: 0.04em; }

.menu-toggle { display: inline-flex; }
.menu-toggle svg { width: 22px; height: 22px; }

/* Menu mobile déroulant */
.mobile-menu {
  display: grid; grid-template-rows: 0fr;
  transition: grid-template-rows var(--transition-slow);
  overflow: hidden;
}
.mobile-menu[data-open='true'] { grid-template-rows: 1fr; }
.mobile-menu__inner { min-height: 0; }
.mobile-menu ul { list-style: none; padding-block: var(--space-4); display: grid; gap: var(--space-1); }
.mobile-menu a {
  display: flex; align-items: center; min-height: 52px;
  padding-inline: var(--space-4); border-radius: var(--radius-md);
  font-size: var(--text-lg); font-weight: 500; color: var(--color-text);
}
.mobile-menu a:hover, .mobile-menu a[aria-current='page'] {
  background: var(--color-surface-offset); color: var(--color-primary);
}

@media (min-width: 900px) {
  .nav__links { display: flex; }
  .menu-toggle { display: none; }
  .mobile-menu { display: none; }
}

/* ============================================================
   HERO — kinetic typography + glassmorphism + spatial depth
   ============================================================ */
.hero {
  position: relative;
  padding-block: clamp(var(--space-20), 12vw, var(--space-32));
  background: var(--hero-gradient);
  overflow: hidden;
  isolation: isolate;
}
/* Halos flottants (spatial design / profondeur) */
.hero::before, .hero::after {
  content: ''; position: absolute; border-radius: 50%; z-index: -1;
  filter: blur(70px); opacity: 0.9;
  animation: float 14s ease-in-out infinite;
}
.hero::before {
  width: 42vw; height: 42vw; max-width: 560px; max-height: 560px;
  top: -10%; right: -6%; background: var(--glow-1);
}
.hero::after {
  width: 36vw; height: 36vw; max-width: 460px; max-height: 460px;
  bottom: -14%; left: -8%; background: var(--glow-2);
  animation-delay: -7s;
}
@keyframes float {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(2%, 4%) scale(1.06); }
}

.hero__inner { display: block; }

.hero__title {
  font-size: clamp(3rem, 8vw, 7rem);
  font-weight: 600; line-height: 0.98;
  letter-spacing: -0.03em;
  max-width: 16ch;
  margin-block: var(--space-5) var(--space-6);
}
/* Kinetic typography — « vivantes » : dégradé vivant qui coule en continu (ambiant).
   background-position animé → zéro reflow / zéro CLS. Pas de survol, pas de lien (décision F. 2026-06-10). */
.hero__title .kinetic {
  display: inline;
  font-weight: 700;
  background: linear-gradient(100deg, var(--color-primary), var(--color-support) 40%, var(--color-accent) 70%, var(--color-primary));
  background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: kinetic-flow 5.5s ease-in-out infinite alternate;
}
@keyframes kinetic-flow {
  from { background-position: 0% 50%; }
  to   { background-position: 100% 50%; }
}
.hero__lead {
  font-size: var(--text-lg); color: var(--color-text-muted);
  max-width: 38ch; margin-bottom: var(--space-8);
}
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero__stats {
  display: flex; flex-wrap: wrap; gap: clamp(var(--space-6), 4vw, var(--space-12));
  margin-top: clamp(var(--space-10), 5vw, var(--space-16));
  padding-top: var(--space-8); border-top: 1px solid var(--color-divider);
}
.hero__stat .num {
  font-family: var(--font-display); font-size: var(--text-xl);
  font-weight: 600; color: var(--color-text); letter-spacing: -0.02em;
}
/* v2.0.29 — accent unique de la rangée (décision F.) : « <1 s » au centre en teal —
   compense la maigreur du glyphe « <1 » et colore LA stat de marque (vitesse).
   (La réduction des unités v2.0.28 a été RETIRÉE — proposition A non acceptée par F.) */
.hero__stat--accent .num { color: var(--color-primary); }
.hero__stat .lbl { font-size: var(--text-sm); color: var(--color-text-muted); }

/* Révélation douce à l'arrivée (hero plein typographique).
   v2.2.2 perf CWV : MONTÉE SEULE (transform), sans fondu — un texte à opacity:0
   n'est pas « peint » pour le LCP, le fondu ajoutait ~0,8 s au mobile. Le
   mouvement doux demeure ; les sections sous le pli gardent leur fondu (.reveal). */
@keyframes hero-reveal { from { transform: translateY(18px); } to { transform: none; } }
.hero__text, .hero__stats { animation: hero-reveal .8s cubic-bezier(.2,.7,.2,1) both; }
.hero__stats { animation-delay: .12s; }
@media (prefers-reduced-motion: reduce) {
  .hero__title .kinetic, .hero__text, .hero__stats { animation: none; }
}

/* (Hero plein typographique v2.0.23 — colonne unique, visuel/vidéo/badge retirés.
   Le H1 géant + le dégradé vivant sur « vivantes » portent le hero ; les stats portent la preuve.) */

/* ============================================================
   GLASS CARD (Liquid Glass raffiné) — utilisé avec parcimonie
   ============================================================ */
.glass {
  background: var(--color-surface-glass);
  -webkit-backdrop-filter: blur(20px) saturate(170%);
  backdrop-filter: blur(20px) saturate(170%);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

/* ============================================================
   BENTO GRID — CSS Grid + container queries
   ============================================================ */
.bento {
  display: grid; gap: var(--space-4);
  grid-template-columns: 1fr;
}
.bento-item {
  position: relative;
  padding: clamp(var(--space-5), 3vw, var(--space-8));
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  container-type: inline-size;
  transition: border-color var(--transition-interactive), transform var(--transition-interactive), box-shadow var(--transition-interactive);
}
.bento-item:hover { border-color: var(--color-primary); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.bento-item__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: var(--radius-md);
  background: var(--color-primary-soft); color: var(--color-primary);
  margin-bottom: var(--space-5);
}
.bento-item__icon svg { width: 26px; height: 26px; }
.bento-item h3 { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.bento-item p { color: var(--color-text-muted); font-size: var(--text-base); }

/* Item large + accent */
.bento-item--feature {
  background: linear-gradient(155deg, var(--color-surface-2), var(--color-surface-offset));
}
.bento-item--accent {
  background: linear-gradient(155deg, color-mix(in oklab, var(--color-primary) 14%, var(--color-surface)), var(--color-surface));
}
/* Adaptation au conteneur (container query) : passe en 2 colonnes si l'item est large */
@container (min-width: 460px) {
  .bento-item--feature .bento-item__body { max-width: 80%; }
}

@media (min-width: 640px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento-item--feature { grid-column: span 2; }
}
@media (min-width: 960px) {
  .bento { grid-template-columns: repeat(3, 1fr); }
  .bento-item--feature { grid-column: span 2; grid-row: span 1; }
  .bento-item--tall { grid-row: span 2; }
}

/* ============================================================
   CARTES PRODUITS / SERVICES (container queries)
   ============================================================ */
.card-grid {
  display: grid; gap: clamp(var(--space-5), 3vw, var(--space-8));
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .card-grid--2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .card-grid--3 { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 600px) { .card-grid--auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); } }

.product-card {
  display: flex; flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive), border-color var(--transition-interactive);
}
.product-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--color-primary); }
.product-card__media { aspect-ratio: 3 / 2; overflow: hidden; background: var(--color-surface-offset); }
.product-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.product-card:hover .product-card__media img { transform: scale(1.04); }
.product-card__body { padding: clamp(var(--space-5), 3vw, var(--space-6)); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.tag {
  align-self: flex-start; font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: var(--space-1) var(--space-3); border-radius: var(--radius-full);
  background: var(--color-primary-soft); color: var(--color-primary);
}
.product-card h2, .product-card h3 { font-size: var(--text-lg); }
.product-card p { color: var(--color-text-muted); font-size: var(--text-sm); flex: 1; }
.meta-list { display: flex; flex-wrap: wrap; gap: var(--space-5); margin-top: var(--space-2); padding-top: var(--space-4); border-top: 1px solid var(--color-border); }
.meta-list li { display: flex; flex-direction: column; gap: 2px; }
.meta-list strong { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); color: var(--color-primary); letter-spacing: -0.01em; }
.meta-list span { font-size: var(--text-xs); color: var(--color-text-muted); }
.product-card__foot { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-2); }
.price { font-family: var(--font-display); font-weight: 600; font-size: var(--text-lg); }
.price small { font-weight: 400; font-size: var(--text-xs); color: var(--color-text-muted); }

/* ============================================================
   ÉQUIPE
   ============================================================ */
.team-grid { display: grid; gap: clamp(var(--space-5), 3vw, var(--space-8)); grid-template-columns: 1fr; }
@media (min-width: 520px) { .team-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 920px) { .team-grid { grid-template-columns: repeat(4, 1fr); } }
.member { text-align: left; }
.member__photo { position: relative; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 3 / 4; box-shadow: var(--shadow-sm); }
.member__photo img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.member:hover .member__photo img { transform: scale(1.05); }
.member__socials {
  position: absolute; inset-inline: 0; bottom: 0;
  display: flex; gap: var(--space-2); padding: var(--space-3);
  background: linear-gradient(to top, rgba(11,16,31,0.7), transparent);
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--transition-interactive), transform var(--transition-interactive);
}
.member:hover .member__socials, .member:focus-within .member__socials { opacity: 1; transform: translateY(0); }
.member__socials a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--radius-full);
  background: rgba(255,255,255,0.14); color: #fff; backdrop-filter: blur(6px);
}
.member__socials a:hover { background: var(--color-primary); }
.member__socials svg { width: 16px; height: 16px; }
.member h3 { font-size: var(--text-lg); margin-top: var(--space-4); }
.member .role { color: var(--color-primary); font-size: var(--text-sm); font-weight: 600; }
.member .bio { color: var(--color-text-muted); font-size: var(--text-sm); margin-top: var(--space-2); }

/* ============================================================
   STATS / VALEURS (À propos)
   ============================================================ */
.split { display: grid; gap: clamp(var(--space-8), 5vw, var(--space-16)); align-items: center; }
@media (min-width: 860px) { .split { grid-template-columns: 1fr 1fr; } .split--reverse > :first-child { order: 2; } }
.split__media img { width: 100%; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.split h2 { font-size: var(--text-2xl); margin-block: var(--space-4); }
.split p { color: var(--color-text-muted); font-size: var(--text-lg); margin-bottom: var(--space-5); }

.values { display: grid; gap: var(--space-4); grid-template-columns: 1fr; margin-top: var(--space-6); }
@media (min-width: 560px) { .values { grid-template-columns: repeat(2, 1fr); } }
.value { padding: var(--space-5); border-radius: var(--radius-md); background: var(--color-surface); border: 1px solid var(--color-border); }
.value h4 { font-family: var(--font-body); font-weight: 600; font-size: var(--text-base); margin-bottom: var(--space-2); display:flex; gap: var(--space-2); align-items:center; }
.value h4 svg { width: 20px; height: 20px; color: var(--color-primary); }
.value p { font-size: var(--text-sm); margin: 0; }

.stat-band { display: grid; gap: var(--space-6); grid-template-columns: repeat(2, 1fr); text-align: center; }
@media (min-width: 760px) { .stat-band { grid-template-columns: repeat(4, 1fr); } }
.stat-band .num { font-family: var(--font-display); font-weight: 600; font-size: var(--text-2xl); color: var(--color-primary); letter-spacing: -0.02em; }
.stat-band .lbl { font-size: var(--text-sm); color: var(--color-text-muted); }

/* ============================================================
   PROCESSUS / TIMELINE (Services)
   ============================================================ */
.process { display: grid; gap: var(--space-6); grid-template-columns: 1fr; counter-reset: step; }
@media (min-width: 720px) { .process { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .process { grid-template-columns: repeat(4, 1fr); } }
.step { position: relative; padding: var(--space-6); border-radius: var(--radius-lg); background: var(--color-surface); border: 1px solid var(--color-border); }
.step__num {
  font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700;
  color: transparent; -webkit-text-stroke: 1.5px var(--color-primary); display: block; margin-bottom: var(--space-3);
}
.step h3 { font-size: var(--text-lg); margin-bottom: var(--space-2); }
.step p { color: var(--color-text-muted); font-size: var(--text-sm); }

/* ============================================================
   FORFAITS / TARIFS (Services)
   ============================================================ */
.pricing-card {
  position: relative; display: flex; flex-direction: column; gap: var(--space-4);
  padding: clamp(var(--space-6), 4vw, var(--space-8));
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive), border-color var(--transition-interactive);
}
.pricing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.pricing-card--featured { border-color: var(--color-primary); box-shadow: 0 0 0 1px var(--color-primary), var(--shadow-lg); }
.pricing-card__badge {
  position: absolute; top: calc(-1 * var(--space-3)); inset-inline-end: var(--space-6);
  font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  padding: var(--space-1) var(--space-3); border-radius: var(--radius-full);
  background: var(--color-primary); color: var(--color-on-primary, #fff);
}
.pricing-card h3 { font-size: var(--text-lg); }
.price-tag { font-family: var(--font-display); font-weight: 700; font-size: var(--text-2xl); letter-spacing: -0.02em; }
.price-tag span { font-family: var(--font-body); font-weight: 400; font-size: var(--text-sm); color: var(--color-text-muted); }
.check-list { display: grid; gap: var(--space-3); flex: 1; list-style: none; padding: 0; margin: 0; }
.check-list li { position: relative; padding-inline-start: 1.75rem; font-size: var(--text-sm); color: var(--color-text-muted); }
.check-list li::before {
  content: ''; position: absolute; inset-inline-start: 0; top: 2px; width: 18px; height: 18px;
  border-radius: var(--radius-full); background: var(--color-primary-soft);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a8d99' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
  background-size: 12px; background-position: center; background-repeat: no-repeat;
}
.pricing-card .btn { width: 100%; justify-content: center; }

/* Bandeau d'inclusions communes (sous les forfaits) */
.included { margin-top: clamp(var(--space-6), 4vw, var(--space-10)); padding: clamp(var(--space-5), 3vw, var(--space-8)); border-radius: var(--radius-lg); border: 1px solid var(--color-border); background: var(--color-surface); }
.included__title { font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-text-faint); text-align: left; margin-bottom: var(--space-6); }
.included__grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4) var(--space-6); }
@media (min-width: 760px) { .included__grid { grid-template-columns: repeat(3, 1fr); } }
.included__item { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-sm); font-weight: 500; color: var(--color-text); }
.included__item .ico { flex: none; width: 24px; height: 24px; border-radius: var(--radius-full); background: var(--color-primary-soft); color: var(--color-primary); display: grid; place-items: center; }
.included__item .ico svg { width: 13px; height: 13px; }
/* Forfaits récurrents : sous-prix (mensuel affiché + annuel facturé) */
.price-block { display: flex; flex-direction: column; gap: 2px; }
.price-sub { font-size: var(--text-xs); color: var(--color-text-muted); margin: 0; }
/* Socle récurrent (4 items) : une rangée en desktop, 2×2 en mobile */
@media (min-width: 760px) { .included__grid--socle { grid-template-columns: repeat(4, 1fr); } }

/* Bande « au-delà » : boutique / sur-mesure, sous les cartes de prix. */
.beyond {
  margin-top: clamp(var(--space-5), 3vw, var(--space-8));
  padding: clamp(var(--space-4), 3vw, var(--space-5)) clamp(var(--space-5), 3vw, var(--space-8));
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: var(--space-4);
}
.beyond__text {
  display: flex; align-items: center; gap: var(--space-3);
  margin: 0; font-size: var(--text-base); color: var(--color-text-muted);
}
.beyond__copy { min-width: 0; }
.beyond__text strong { color: var(--color-text); font-weight: 600; }
.beyond__price { white-space: nowrap; }
.beyond__ico {
  flex: none; width: 28px; height: 28px; border-radius: var(--radius-full);
  background: var(--color-primary-soft); color: var(--color-primary);
  display: grid; place-items: center;
}
.beyond__ico svg { width: 15px; height: 15px; }
.beyond .btn { flex: none; }
/* Mobile : empilé proprement (texte puis bouton pleine largeur), icône alignée
   sur la première ligne — évite l'icône qui flotte au milieu d'un texte sur 2-3 lignes. */
@media (max-width: 600px) {
  .beyond { flex-direction: column; align-items: stretch; gap: var(--space-4); }
  .beyond__text { align-items: flex-start; }
  .beyond__price { display: block; margin-top: 2px; }
  .beyond .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band {
  position: relative; overflow: hidden;
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-10), 6vw, var(--space-20));
  text-align: center;
  background: linear-gradient(150deg, color-mix(in oklab, var(--color-primary) 22%, var(--color-surface)), var(--color-surface));
  border: 1px solid var(--color-border);
  isolation: isolate;
}
.cta-band::before {
  content: ''; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(60% 80% at 80% 20%, var(--glow-3), transparent 70%);
}
.cta-band h2 { font-size: var(--text-2xl); margin-bottom: var(--space-4); }
.cta-band p { color: var(--color-text-muted); font-size: var(--text-lg); margin: 0 auto var(--space-8); max-width: 48ch; }
.cta-band .hero__cta { justify-content: center; }

/* ============================================================
   FORMULAIRE CONTACT (formulaires simplifiés)
   ============================================================ */
.contact-grid { display: grid; gap: clamp(var(--space-8), 5vw, var(--space-16)); }
@media (min-width: 860px) { .contact-grid { grid-template-columns: 1fr 1.1fr; align-items: start; } }
.contact-info dl { display: grid; gap: var(--space-6); margin-top: var(--space-8); }
.contact-info dt { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-muted); margin-bottom: var(--space-1); }
.contact-info dd { font-size: var(--text-lg); font-weight: 500; }
.contact-info dd a:hover { color: var(--color-primary); }

.form { display: grid; gap: var(--space-5); padding: clamp(var(--space-6), 4vw, var(--space-10)); }
.field { display: grid; gap: var(--space-2); }
.field label { font-size: var(--text-sm); font-weight: 600; }
.field input, .field textarea, .field select {
  min-height: 48px; padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  color: var(--color-text); font-size: var(--text-base);
}
.field textarea { min-height: 140px; resize: vertical; padding-top: var(--space-3); }
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--color-primary); outline: none;
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.field--row { display: grid; gap: var(--space-5); }
@media (min-width: 520px) { .field--row { grid-template-columns: 1fr 1fr; } }
.form .btn { width: 100%; }
.form-note { font-size: var(--text-xs); color: var(--color-text-faint); }
.form-success {
  display: none; align-items: center; gap: var(--space-3);
  padding: var(--space-4) var(--space-5); border-radius: var(--radius-md);
  background: var(--color-primary-soft); color: var(--color-primary); font-weight: 600;
}
.form-success[data-show='true'] { display: flex; }
/* v2.1.0 — état d'échec d'envoi (formulaire branché, Q3=A) */
.form-error {
  display: none; align-items: center; gap: var(--space-3);
  padding: var(--space-4) var(--space-5); border-radius: var(--radius-md);
  background: rgba(225, 76, 76, 0.12); color: #e98080; font-weight: 600;
}
.form-error[data-show='true'] { display: flex; }

/* ============================================================
   PAGE HEADER (pages internes)
   ============================================================ */
.page-hero {
  position: relative; overflow: hidden; isolation: isolate;
  padding-block: clamp(var(--space-16), 9vw, var(--space-24)) clamp(var(--space-10), 5vw, var(--space-16));
  background: var(--hero-gradient);
}
.page-hero::after {
  content:''; position:absolute; z-index:-1; width: 40vw; height: 40vw; max-width: 500px; max-height: 500px;
  border-radius: 50%; filter: blur(80px); background: var(--glow-1); top: -20%; right: -8%;
}
.page-hero h1 { font-size: var(--text-3xl); margin-block: var(--space-4) var(--space-5); max-width: 18ch; }
.page-hero p { font-size: var(--text-lg); color: var(--color-text-muted); max-width: 52ch; }
.breadcrumb { font-size: var(--text-sm); color: var(--color-text-muted); }
.breadcrumb a:hover { color: var(--color-primary); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--color-divider);
  background: var(--color-surface-offset);
  padding-block: clamp(var(--space-12), 6vw, var(--space-20)) var(--space-8);
}
.footer-grid { display: grid; gap: clamp(var(--space-8), 4vw, var(--space-12)); grid-template-columns: 1fr; }
@media (min-width: 640px) { .footer-grid { grid-template-columns: 1.6fr repeat(2, 1fr); } }
@media (min-width: 960px) { .footer-grid { grid-template-columns: 2fr repeat(3, 1fr); } }
.footer-brand p { color: var(--color-text-muted); font-size: var(--text-sm); margin-top: var(--space-4); max-width: 34ch; }
.footer-col h4 { font-family: var(--font-body); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-faint); margin-bottom: var(--space-4); }
.footer-col ul { list-style: none; display: grid; gap: var(--space-3); }
.footer-col a { color: var(--color-text-muted); font-size: var(--text-sm); }
.footer-col a:hover { color: var(--color-primary); }
.footer-bottom {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  align-items: center; justify-content: space-between;
  margin-top: clamp(var(--space-10), 5vw, var(--space-16));
  padding-top: var(--space-6); border-top: 1px solid var(--color-divider);
  font-size: var(--text-sm); color: var(--color-text-muted);
}
.footer-social { display: flex; gap: var(--space-2); }
.footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-full);
  border: 1px solid var(--color-border); color: var(--color-text-muted);
}
.footer-social a:hover { color: var(--color-primary); border-color: var(--color-primary); }
.footer-social svg { width: 18px; height: 18px; }

/* ============================================================
   SCROLL-DRIVEN ANIMATIONS (natif, sans JS) + fallback IntersectionObserver
   ============================================================ */
@keyframes reveal {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Stratégie : on n'applique l'état caché QUE si JS est actif (classe .js sur <html>),
   ce qui garantit que le contenu reste visible si JS échoue (progressive enhancement). */
.js .reveal { opacity: 0; }
.js .reveal.is-visible { animation: reveal 0.7s cubic-bezier(0.16,1,0.3,1) forwards; }

/* Si scroll-driven animations supportées : version 100% CSS native.
   animation-range borné de façon à ce qu'un élément déjà dans le viewport
   au chargement soit immédiatement à opacity 1 (cover 30%). */
@supports (animation-timeline: view()) {
  .js .reveal {
    opacity: 1;
    animation: reveal linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 30%;
  }
}
@media (prefers-reduced-motion: reduce) {
  .reveal, .js .reveal, .reveal.is-visible { opacity: 1 !important; animation: none !important; transform: none !important; }
}

/* Décalage léger pour effet en cascade (sans JS, juste delays) */
.js .reveal[data-delay='1'] { animation-delay: 0.06s; }
.js .reveal[data-delay='2'] { animation-delay: 0.12s; }
.js .reveal[data-delay='3'] { animation-delay: 0.18s; }

/* ---------- Utilitaires ---------- */
.mt-0 { margin-top: 0; }
.muted { color: var(--color-text-muted); }
.lead { font-size: var(--text-lg); color: var(--color-text-muted); }
hr.rule { border: none; border-top: 1px solid var(--color-divider); margin-block: var(--space-12); }
[hidden] { display: none !important; }


/* ============================================================
   FAQ (v2.1.0 jet 1 — reprise du contenu prod, Q2=A)
   ============================================================ */
.faq-list {
  display: grid;
  gap: var(--space-4);
  max-width: 46rem;
}
.faq-item {
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  background: var(--color-surface-offset);
}
.faq-item h3 { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.faq-item p { color: var(--color-text-muted); }
.faq-item a { color: var(--color-primary); }

/* ============================================================
   Page legale (v2.1.0 jet 1 — politique de confidentialite, Q4=A)
   ============================================================ */
.legal { max-width: 44rem; }
.legal h2 { font-size: var(--text-xl); margin: var(--space-10) 0 var(--space-4); }
.legal p, .legal li { color: var(--color-text-muted); margin-bottom: var(--space-3); }
.legal ul { padding-left: 1.25em; margin-bottom: var(--space-4); }
.legal a { color: var(--color-primary); }
.legal .legal-date { font-size: var(--text-sm); color: var(--color-text-faint, var(--color-text-muted)); }


/* ============================================================
   Page contact — visuel + carte coordonnées iconifiée
   (v2.1.5 jet 1 — arbitrage F. « B » : reprise du pattern prod)
   ============================================================ */
.contact-card {
  list-style: none;
  /* v2.1.12 — marge portée par la carte elle-même (l'espacement dépendait des
     marges du visuel retiré en v2.1.11) */
  margin: var(--space-6) 0 0;
  padding: var(--space-2) var(--space-5);
  background: var(--color-surface-offset);
  border: 1px solid var(--color-divider);
  border-radius: var(--radius-lg);
}
.contact-card li {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4) 0;
}
.contact-card li + li { border-top: 1px solid var(--color-divider); }
.contact-card__ico { color: var(--color-primary); flex: none; display: inline-flex; }
.contact-card__ico svg { width: 22px; height: 22px; }
.contact-card__txt { display: grid; gap: 2px; font-size: var(--text-sm); }
.contact-card__txt .lbl {
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.contact-card__txt a { color: var(--color-text); font-weight: 600; }
.contact-card__txt a:hover { color: var(--color-primary); }


/* ============================================================
   Saisie de formulaire aux couleurs de la palette (v2.1.6 — point 3 F.)
   L'« or » constaté = jaune d'autoremplissage de Chrome (hors palette).
   #0F2832 = équivalent opaque de --color-primary-soft sur la surface.
   ============================================================ */
.field input, .field select, .field textarea { caret-color: var(--color-primary); }
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus,
.field select:-webkit-autofill,
.field textarea:-webkit-autofill {
  -webkit-box-shadow: 0 0 0 1000px #0F2832 inset;
  -webkit-text-fill-color: var(--color-text);
  border-color: var(--color-primary);
}
.field input:autofill {
  box-shadow: 0 0 0 1000px #0F2832 inset;
  border-color: var(--color-primary);
}
