/* ==========================================================================
   ASTRIONI — site.css
   Système de PAGE MARKETING front-office partagé par les 8 sites.
   S'appuie sur tokens.css + components.css. La marque est portée par la
   classe .brand-* sur <html>. Motifs signature animés + reveals au scroll.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Base page
   -------------------------------------------------------------------------- */
html { scroll-behavior: smooth; }
body.site { background: var(--surface-bg); color: var(--text-primary); }
.site-main { overflow-x: clip; }
.wrap { width: 100%; max-width: var(--container-xl); margin-inline: auto; padding-inline: var(--space-6); }
@media (min-width: 768px) { .wrap { padding-inline: var(--space-8); } }
.section { padding-block: var(--space-20); }
.section-sm { padding-block: var(--space-12); }
.section-head { max-width: 60ch; margin-bottom: var(--space-10); }
.section-head .overline { margin-bottom: var(--space-3); display: block; }
.section-head h2 { font-family: var(--font-display); font-weight: var(--brand-display-weight); font-size: clamp(2rem, 4vw, var(--text-4xl)); line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); margin: 0; text-wrap: balance; }
.section-head p { margin: var(--space-4) 0 0; color: var(--text-secondary); font-size: var(--text-lg); line-height: var(--leading-relaxed); text-wrap: pretty; }
.center { text-align: center; margin-inline: auto; }

/* Stat / chiffre-clé — police pilotée par la marque */
.stat-num { font-family: var(--brand-num-font, var(--font-mono)); font-weight: 700; font-feature-settings: "tnum" 1; letter-spacing: -0.01em; }

/* --------------------------------------------------------------------------
   Bandeau d'annonce
   -------------------------------------------------------------------------- */
.topbar {
  background: var(--surface-inverse); color: var(--text-inverse-soft);
  font-size: var(--text-sm); text-align: center; padding: var(--space-2) var(--space-4);
}
.topbar strong { color: var(--text-inverse); font-weight: var(--weight-semibold); }
.topbar .accent { color: color-mix(in oklab, var(--brand-accent), #fff 22%); }

/* --------------------------------------------------------------------------
   Navbar de site (étend .navbar)
   -------------------------------------------------------------------------- */
.site-nav { position: sticky; top: 0; z-index: var(--z-sticky); background: color-mix(in srgb, var(--surface-bg-soft), transparent 12%); backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--border-subtle); }
.site-nav .wrap { display: flex; align-items: center; gap: var(--space-6); min-height: 70px; }
.site-nav .nav-mid { display: none; flex: 1; }
.site-nav .nav-cta { display: flex; align-items: center; gap: var(--space-2); margin-left: auto; }
@media (min-width: 1024px) { .site-nav .nav-mid { display: flex; justify-content: center; gap: var(--space-1); } .site-nav .nav-cta { margin-left: 0; } }
.nav-toggle { display: inline-grid; place-items: center; width: 44px; height: 44px; border: 1px solid var(--border-default); border-radius: var(--radius-sm); background: var(--surface-card); cursor: pointer; }
@media (min-width: 1024px) { .nav-toggle { display: none; } }
.nav-drawer { display: none; flex-direction: column; gap: var(--space-1); padding: var(--space-4) var(--space-6) var(--space-5); border-top: 1px solid var(--border-subtle); }
.nav-drawer.open { display: flex; }
@media (min-width: 1024px) { .nav-drawer { display: none !important; } }

/* --------------------------------------------------------------------------
   HERO + MOTIF SIGNATURE
   -------------------------------------------------------------------------- */
.hero-site { position: relative; overflow: hidden; isolation: isolate; }
.hero-site .wrap { position: relative; z-index: 2; }
.hero-inner { padding-block: clamp(3rem, 8vw, var(--space-24)); }
.hero-eyebrow { display: inline-flex; align-items: center; gap: var(--space-2); padding: 6px var(--space-3); border-radius: var(--radius-pill); background: var(--brand-accent-soft); color: var(--brand-accent-text); font-size: var(--text-sm); font-weight: var(--weight-semibold); margin-bottom: var(--space-5); }
.hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--brand-accent); box-shadow: 0 0 0 4px var(--brand-accent-soft); }
.hero-h1 { font-family: var(--font-display); font-weight: var(--brand-display-weight); font-size: clamp(2.6rem, 6.5vw, 5rem); line-height: 1.04; letter-spacing: var(--tracking-tight); margin: 0; max-width: 16ch; text-wrap: balance; }
.hero-h1 .accent { color: var(--brand-accent-text); }
.hero-sub { margin: var(--space-6) 0 0; font-size: var(--text-lg); line-height: var(--leading-relaxed); color: var(--text-secondary); max-width: 52ch; text-wrap: pretty; }
.hero-cta { margin-top: var(--space-8); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hero-trust { margin-top: var(--space-6); display: flex; flex-wrap: wrap; gap: var(--space-4); color: var(--text-muted); font-size: var(--text-sm); }
.hero-trust span { display: inline-flex; align-items: center; gap: var(--space-2); }
.hero-trust .tick { color: var(--brand-accent-text); font-weight: 700; }

/* Layout variants */
.hero--split .hero-inner { display: grid; gap: var(--space-12); align-items: center; }
@media (min-width: 1024px) { .hero--split .hero-inner { grid-template-columns: 1.05fr 0.95fr; } }
.hero--center .hero-inner { text-align: center; display: flex; flex-direction: column; align-items: center; }
.hero--center .hero-h1, .hero--center .hero-sub { max-width: none; }
.hero--center .hero-cta, .hero--center .hero-trust { justify-content: center; }

/* Visuel hero (carte de démo brandée) */
.hero-card { position: relative; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); padding: var(--space-6); }

/* ---- Couche MOTIF (signature animée, derrière le contenu) ---- */
.hero-motif { position: absolute; inset: -20%; z-index: 1; pointer-events: none; opacity: 0.9; }
.hero-motif::after { content: ""; position: absolute; inset: 0; background: radial-gradient(80% 70% at 50% 0%, transparent 40%, var(--surface-bg) 92%); }

/* arkhoni — rayons concentriques (radar) */
.brand-arkhoni .hero-motif { background: repeating-radial-gradient(circle at 78% 26%, transparent 0 46px, color-mix(in oklab, var(--brand-accent), transparent 86%) 46px 48px); animation: motifZoom 18s ease-in-out infinite; }
/* astrioni — nœuds en orbite (grille de points) */
.brand-astrioni .hero-motif { background-image: radial-gradient(color-mix(in oklab, var(--brand-accent), transparent 78%) 2.5px, transparent 2.6px); background-size: 38px 38px; animation: motifDrift 26s linear infinite; }
/* athenori — grille de scan technique */
.brand-athenori .hero-motif { background-image: linear-gradient(color-mix(in oklab,var(--brand-accent),transparent 90%) 1px, transparent 1px), linear-gradient(90deg, color-mix(in oklab,var(--brand-accent),transparent 90%) 1px, transparent 1px); background-size: 46px 46px; }
.brand-athenori .hero-motif::before { content: ""; position: absolute; left: 0; right: 0; height: 2px; background: color-mix(in oklab, var(--brand-accent), transparent 40%); box-shadow: 0 0 18px var(--brand-accent); animation: scanDown 6s var(--ease-in-out) infinite; }
/* aedironi — blueprint */
.brand-aedironi .hero-motif { background-image: linear-gradient(color-mix(in oklab,var(--brand-accent),transparent 88%) 1px, transparent 1px), linear-gradient(90deg, color-mix(in oklab,var(--brand-accent),transparent 88%) 1px, transparent 1px); background-size: 30px 30px; animation: motifDrift 30s linear infinite; }
/* argyroni — lignes de registre */
.brand-argyroni .hero-motif { background-image: repeating-linear-gradient(0deg, transparent 0 27px, color-mix(in oklab,var(--brand-accent),transparent 88%) 27px 28px); animation: ledgerUp 20s linear infinite; }
/* actaoni — colonnes de document */
.brand-actaoni .hero-motif { background-image: repeating-linear-gradient(90deg, transparent 0 60px, color-mix(in oklab,var(--brand-accent),transparent 90%) 60px 61px); }
/* asteroni — éclats d'étoiles */
.brand-asteroni .hero-motif { background-image: radial-gradient(color-mix(in oklab,var(--brand-accent),transparent 72%) 1.6px, transparent 2px), radial-gradient(color-mix(in oklab,var(--brand-accent),transparent 80%) 1.2px, transparent 1.6px); background-size: 90px 90px, 54px 54px; background-position: 0 0, 27px 27px; animation: twinkleBg 5s ease-in-out infinite; }
/* alearoni — confettis joueurs */
.brand-alearoni .hero-motif { background-image: radial-gradient(color-mix(in oklab,var(--brand-accent),transparent 70%) 4px, transparent 5px), radial-gradient(color-mix(in oklab,#ff8c00,transparent 78%) 3px, transparent 4px), radial-gradient(color-mix(in oklab,#3a6ea5,transparent 78%) 3px, transparent 4px); background-size: 120px 120px, 80px 80px, 100px 100px; background-position: 0 0, 40px 60px, 70px 20px; animation: motifDrift 24s linear infinite; }

/* --------------------------------------------------------------------------
   Sections de contenu
   -------------------------------------------------------------------------- */
.feature-row { display: grid; gap: var(--space-10); align-items: center; }
@media (min-width: 900px) { .feature-row { grid-template-columns: 1fr 1fr; } .feature-row.flip > .feature-visual { order: -1; } }
.feature-text h3 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-3xl); line-height: var(--leading-snug); margin: var(--space-3) 0 var(--space-4); }
.feature-text p { color: var(--text-secondary); font-size: var(--text-md); line-height: var(--leading-relaxed); margin: 0; }
.feature-visual { position: relative; }

.grid-3 { display: grid; gap: var(--space-6); grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.grid-4 { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
.f-card { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); transition: transform var(--duration-base) var(--ease-standard), box-shadow 0.45s var(--ease-standard); }
.f-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.f-card .f-ic { font-size: var(--text-2xl); width: 52px; height: 52px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--brand-accent-soft); color: var(--brand-accent-text); margin-bottom: var(--space-4); position: relative; overflow: hidden; }
.f-card h4 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-xl); margin: 0 0 var(--space-2); }
.f-card p { color: var(--text-secondary); font-size: var(--text-sm); margin: 0; line-height: var(--leading-normal); }

/* Étapes */
.steps { display: grid; gap: var(--space-6); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); counter-reset: step; }
.step { position: relative; padding-top: var(--space-8); }
.step::before { counter-increment: step; content: counter(step, decimal-leading-zero); position: absolute; top: 0; left: 0; font-family: var(--brand-num-font, var(--font-mono)); font-size: var(--text-2xl); font-weight: 700; color: var(--brand-accent-text); }
.step h4 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-xl); margin: 0 0 var(--space-2); }
.step p { color: var(--text-secondary); font-size: var(--text-sm); margin: 0; }

/* Stats bandeau */
.stats { display: grid; gap: var(--space-6); grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); text-align: center; }
.stats .stat-num { font-size: clamp(2.4rem, 5vw, 3.4rem); color: var(--brand-accent-text); line-height: 1; }
.stats .stat-lbl { margin-top: var(--space-2); color: var(--text-secondary); font-size: var(--text-sm); }

/* FAQ accordéon */
.faq { max-width: 820px; margin-inline: auto; border-top: 1px solid var(--border-default); }
.faq-item { border-bottom: 1px solid var(--border-default); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-5) 0; background: none; border: none; cursor: pointer; text-align: left; font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-lg); color: var(--text-primary); }
.faq-q .chev { flex: none; width: 28px; height: 28px; display: grid; place-items: center; color: var(--brand-accent-text); transition: transform var(--duration-base) var(--ease-standard); font-size: var(--text-xl); }
.faq-item.open .chev { transform: none; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height var(--duration-slow) var(--ease-standard); }
.faq-a p { margin: 0 0 var(--space-5); color: var(--text-secondary); line-height: var(--leading-relaxed); }

/* Bandeau écosystème (cross-sell) */
.eco-strip { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }
.eco-chip { display: inline-flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-4); border-radius: var(--radius-pill); border: 1px solid var(--border-default); background: var(--surface-card); color: var(--text-secondary); text-decoration: none; font-size: var(--text-sm); font-weight: var(--weight-medium); transition: border-color var(--duration-fast), color var(--duration-fast), transform var(--duration-fast); }
.eco-chip:hover { transform: translateY(-2px); color: var(--text-primary); border-color: var(--border-strong); }
.eco-chip .swatch { width: 12px; height: 12px; border-radius: 50%; }

/* Cartes service (index du hub) */
.svc { display: flex; flex-direction: column; gap: var(--space-3); text-decoration: none; color: inherit; }
.svc-top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.svc .swatch { width: 34px; height: 34px; border-radius: var(--radius-sm); background: var(--brand-accent); display: grid; place-items: center; color: var(--brand-accent-contrast); font-family: var(--font-display); font-weight: 600; box-shadow: 0 0 0 4px var(--brand-accent-soft); }
.svc-go { margin-top: auto; color: var(--brand-accent-text); font-weight: var(--weight-semibold); font-size: var(--text-sm); }

/* --------------------------------------------------------------------------
   Reveals au scroll
   -------------------------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .hero-motif, .brand-athenori .hero-motif::before { animation: none !important; }
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* --------------------------------------------------------------------------
   Keyframes motifs
   -------------------------------------------------------------------------- */
@keyframes motifDrift { to { background-position: 200px 120px; } }
@keyframes motifZoom { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.12); } }
@keyframes ledgerUp { to { background-position: 0 -280px; } }
@keyframes scanDown { 0% { top: 6%; opacity: 0; } 10% { opacity: 1; } 90% { opacity: 1; } 100% { top: 94%; opacity: 0; } }
@keyframes twinkleBg { 0%, 100% { opacity: 0.6; } 50% { opacity: 1; } }

/* ==========================================================================
   ÉLÉVATION v2 — langage visuel aligné sur le site en ligne
   (navbar flottante sombre STICKY, hero sombre, cartes-confiance, en-têtes
   illustrés, lignes 22 points, carrousel, retour-haut, footer enrichi).
   Partagé par les 8 sites.
   ========================================================================== */

/* ---- Navbar flottante sombre — reste STICKY au scroll ---- */
.site-nav { position: sticky; top: var(--space-3); background: transparent; backdrop-filter: none; border: none; padding-top: var(--space-3); transition: top var(--duration-base) var(--ease-standard); }
/* La première section glisse SOUS la navbar : la bande derrière le menu prend la couleur
   de la section (et plus celle du body). Hauteur de flux de la nav ≈ padding-top + pilule 66px. */
.site-nav { margin-bottom: calc(-1 * (var(--space-3) + 66px)); }
.site-main > :first-child { padding-top: calc(var(--space-3) + 66px); }
/* Sections qui avaient déjà leur propre padding-top : compensation ADDITIVE */
.site-main > .bp-hero:first-child,
.site-main > .legal-hero:first-child { padding-top: calc(var(--space-3) + 66px + var(--space-16)); }
.site-main > .soon:first-child { padding-top: calc(var(--space-3) + 66px + clamp(110px, 16vh, 200px)); }
.site-main > .eb-hero:first-child { padding-top: calc(var(--space-3) + 66px + var(--space-12)); }
.site-nav .wrap { min-height: 64px; padding-inline: var(--space-5);
  background: linear-gradient(180deg, #1b3c5c, #102740);
  border: 1px solid rgba(255,255,255,0.10); border-radius: 20px;
  box-shadow: 0 16px 44px rgba(11,27,44,0.30); transition: box-shadow var(--duration-base) var(--ease-standard); }
.site-nav.scrolled .wrap { box-shadow: 0 10px 30px rgba(11,27,44,0.45); }
.site-nav .logo { color: #fff; display: inline-flex; align-items: center; gap: 0; font-family: var(--font-body); font-weight: 700; letter-spacing: -0.01em; font-size: var(--text-xl); }
.site-nav .logo .nav-mark { margin-right: 11px; }
.site-nav .logo .a, .site-nav .logo .i { color: var(--brand-accent); }
.footer .logo { font-family: var(--font-body); font-weight: 700; letter-spacing: -0.01em; }
.nav-mark { position: relative; width: 40px; height: 40px; border-radius: 11px; flex: none;
  background: var(--brand-accent); display: inline-block;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='10' cy='10' r='7'/%3E%3Cline x1='15.2' y1='15.2' x2='21' y2='21'/%3E%3Cpath d='M10 6.4c-1.7 0-3 1.3-3 3 0 2.2 3 4.3 3 4.3s3-2.1 3-4.3c0-1.7-1.3-3-3-3z' fill='%23ffffff' stroke='none'/%3E%3Ccircle cx='10' cy='9.4' r='1' fill='%23102740' stroke='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center; background-size: 26px 26px;
  box-shadow: 0 6px 16px color-mix(in oklab, var(--brand-accent), transparent 52%); }
.site-nav .nav-link { color: rgba(255,255,255,0.80); }
.site-nav .nav-link:hover { color: #fff; background: rgba(255,255,255,0.10); }
.site-nav .nav-link[aria-current="page"] { color: #fff; }
.site-nav .nav-link[aria-current="page"]::after { background: var(--brand-accent); }
.footer .logo .a, .footer .logo .i { color: var(--brand-accent); }
.site-nav .btn-ghost { color: #fff; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.16); }
.site-nav .btn-ghost:hover { background: rgba(255,255,255,0.14); }
.site-nav .nav-toggle { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.20); color: #fff; }
.nav-drawer { background: #102740; border: 1px solid rgba(255,255,255,0.10); border-radius: 18px; margin-top: var(--space-2); }
.nav-drawer .nav-link { color: rgba(255,255,255,0.85); }
.nav-drawer .nav-link:hover { color: #fff; background: rgba(255,255,255,0.10); }

/* ---- Hero sombre ---- */
.hero--dark { color: #e9eff5; isolation: isolate;
  background: radial-gradient(110% 80% at 82% -8%, color-mix(in oklab, var(--brand-accent), transparent 78%), transparent 52%), linear-gradient(180deg, #133049, #0e2236);
  border-bottom-left-radius: 40px; border-bottom-right-radius: 40px; margin-top: calc(-1 * (64px + var(--space-6))); padding-top: calc(64px + var(--space-6)); }
.hero--dark::before { content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 46px 46px; -webkit-mask-image: radial-gradient(80% 80% at 70% 20%, #000, transparent 80%); mask-image: radial-gradient(80% 80% at 70% 20%, #000, transparent 80%); }
.hero--dark .hero-h1 { color: #fff; }
.hero--dark .hero-h1 .accent { color: var(--brand-accent); }
.hero--dark .hero-sub { color: rgba(233,239,245,0.74); }
.hero--dark .hero-eyebrow { background: rgba(255,255,255,0.08); color: #fff; border: 1px solid rgba(255,255,255,0.14); }
.hero--dark .hero-foot { color: rgba(233,239,245,0.6); border-top-color: rgba(255,255,255,0.14); }
.hero--dark .hero-foot .price { color: #fff; }
.hero--dark .hero-foot .price strong { color: var(--brand-accent); }
.hero--dark .btn-secondary { background: rgba(255,255,255,0.06); color: #fff; border-color: rgba(255,255,255,0.20); }
.hero--dark .btn-secondary:hover { background: rgba(255,255,255,0.14); }
.hero--dark .hero-motif::after { background: radial-gradient(80% 70% at 50% 0%, transparent 45%, #0e2236 94%); }
.hero--dark .hero-card { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.12); box-shadow: 0 24px 60px rgba(0,0,0,0.35); color: #e9eff5; }
.hero--dark .hero-card .small.muted, .hero--dark .hero-card .muted { color: rgba(233,239,245,0.6); }

/* ---- Cartes-confiance (rangée flottante) ---- */
.trust-wrap { position: relative; z-index: 3; margin-top: calc(-1 * var(--space-10)); }
.trust-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: var(--space-4); }
.trust-cards .tc { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5); text-align: center; font-weight: var(--weight-semibold); font-size: var(--text-sm); box-shadow: var(--shadow-md); }
.trust-cards .tc .n { display: block; font-family: var(--brand-num-font); font-size: var(--text-2xl); color: var(--brand-accent-text); margin-bottom: 4px; }
.trust-cards .tc .n .pre { display: block; font-family: var(--font-body); font-size: var(--text-xs); font-weight: var(--weight-semibold); color: var(--text-muted); letter-spacing: 0.02em; margin-bottom: 1px; }

/* ---- En-têtes illustrés en dégradé (line-art géométrique) ---- */
.illus { position: relative; height: 150px; border-radius: var(--radius-md); overflow: hidden; margin-bottom: var(--space-5);
  background: linear-gradient(140deg, #1d4f72, #102841); }
.illus.is-accent { background: linear-gradient(140deg, color-mix(in oklab, var(--brand-accent), #000 6%), color-mix(in oklab, var(--brand-accent), #000 42%)); }
.illus.is-green { background: linear-gradient(140deg, #1f5a4a, #123726); }
.illus::before { content: ""; position: absolute; inset: 0;
  background: repeating-radial-gradient(circle at 70% 52%, transparent 0 16px, rgba(255,255,255,0.16) 16px 17px, transparent 17px 30px); opacity: 0.9; }
.illus::after { content: ""; position: absolute; width: 10px; height: 10px; border-radius: 50%; right: 28%; top: 46%; background: var(--brand-accent); box-shadow: 0 0 14px var(--brand-accent), -34px 22px 0 -2px rgba(255,255,255,0.7), 26px -18px 0 -3px rgba(255,255,255,0.6); }
.illus.is-accent::after { background: #fff; box-shadow: 0 0 14px rgba(255,255,255,0.8), -34px 22px 0 -2px rgba(255,255,255,0.7), 26px -18px 0 -3px rgba(255,255,255,0.6); }
.illus .fold { position: absolute; left: 16%; top: 26%; width: 38%; height: 48%; border: 1.5px solid rgba(255,255,255,0.45); border-radius: 4px; transform: skewY(-6deg); background: linear-gradient(120deg, rgba(255,255,255,0.06), transparent); }
.illus .fold::before { content: ""; position: absolute; left: 50%; top: -1px; bottom: -1px; border-left: 1.5px solid rgba(255,255,255,0.35); }

/* ---- Lignes "22 points" ---- */
.points-list { display: flex; flex-direction: column; gap: var(--space-3); }
.point-row { display: flex; align-items: center; gap: var(--space-4); background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5); box-shadow: var(--shadow-sm); }
.point-row .ic { flex: none; width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--surface-sunken); display: grid; place-items: center; font-size: 20px; color: var(--brand-accent-text); }
.point-row .bd { flex: 1; }
.point-row .bd h4 { margin: 0 0 2px; font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-lg); }
.point-row .bd p { margin: 0; color: var(--text-secondary); font-size: var(--text-sm); }
.point-row .pts { flex: none; background: var(--brand-accent); color: var(--brand-accent-contrast); font-family: var(--brand-num-font); font-weight: 700; font-size: var(--text-sm); padding: 6px 14px; border-radius: var(--radius-pill); }

/* ---- Carrousel (témoignages) ---- */
.carousel { position: relative; }
.carousel-track { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(300px, 1fr); gap: var(--space-6); overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; padding-bottom: var(--space-3); scrollbar-width: none; }
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-track > * { scroll-snap-align: start; }
@media (min-width: 900px) { .carousel-track { grid-auto-flow: row; grid-template-columns: repeat(3, 1fr); overflow: visible; } }
.carousel-nav { display: flex; gap: var(--space-3); justify-content: center; margin-top: var(--space-6); }
.carousel-nav button { width: 48px; height: 48px; border-radius: 50%; border: none; cursor: pointer; background: var(--brand-accent); color: var(--brand-accent-contrast); font-size: 20px; display: grid; place-items: center; box-shadow: var(--shadow-sm); transition: transform var(--duration-fast), background var(--duration-fast); }
.carousel-nav button:hover { transform: translateY(-2px); background: var(--brand-accent-strong); }
@media (min-width: 900px) { .carousel-nav { display: none; } }

/* ---- Retour en haut ---- */
.to-top { position: fixed; right: var(--space-6); bottom: var(--space-6); z-index: var(--z-sticky); width: 52px; height: 52px; border-radius: 50%; border: none; cursor: pointer; background: var(--brand-accent); color: #fff; font-size: 22px; box-shadow: var(--shadow-lg); opacity: 0; transform: translateY(12px); pointer-events: none; transition: opacity var(--duration-base), transform var(--duration-base); }
.to-top.show { opacity: 1; transform: none; pointer-events: auto; }

/* ---- Footer enrichi : langues + réseaux ---- */
.footer-extra { margin-top: var(--space-10); display: flex; flex-wrap: wrap; gap: var(--space-8); align-items: flex-start; justify-content: space-between; }
.lang-switch, .social-row { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.lang-switch a, .social-row a { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,0.06); border: 1px solid var(--border-inverse); color: var(--text-inverse-soft); text-decoration: none; font-size: var(--text-xs); font-weight: 600; }
.lang-switch a:hover, .social-row a:hover { color: var(--text-inverse); background: rgba(255,255,255,0.12); }
.lang-switch a.on { background: var(--brand-accent); color: var(--brand-accent-contrast); border-color: transparent; }
.social-row a svg { width: 18px; height: 18px; display: block; }
.footer-bottom .social-row { gap: var(--space-2); }
.lang-block { width: 100%; }
.lang-note { margin: 0 0 var(--space-3); font-size: var(--text-xs); color: var(--text-inverse-soft); max-width: 66ch; line-height: var(--leading-normal); }
.footer .wrap { padding-inline: clamp(var(--space-8), 5vw, var(--space-20)); }
.footer-news { margin-inline: 0; }

/* ---- Newsletter (footer, partagé écosystème) ---- */
.footer-news { margin: 0 0 var(--space-12); padding: clamp(var(--space-8), 4vw, var(--space-10)) clamp(var(--space-8), 4vw, var(--space-12)); border-radius: var(--radius-xl); background: var(--surface-bg); border: 1px solid var(--border-subtle); display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--space-8) var(--space-12); align-items: center; }
.footer-news .news-eyebrow { display: inline-block; font-family: var(--font-mono); font-size: var(--text-2xs); font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--brand-accent-text, var(--brand-accent)); margin-bottom: var(--space-2); }
@media (max-width: 760px) { .footer-news { grid-template-columns: 1fr; padding: var(--space-6); } }
.footer-news .news-txt h4 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-lg); color: var(--text-primary); margin: 0 0 var(--space-2); }
.footer-news .news-txt p { margin: 0; font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-normal); max-width: 50ch; }
.news-form { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.news-form .input { flex: 1 1 220px; background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-pill); padding: var(--space-3) var(--space-5); font: inherit; color: var(--text-primary); }
.news-form .input::placeholder { color: var(--text-muted); }
.news-form .input:focus-visible { outline: 3px solid color-mix(in oklab, var(--brand-accent), transparent 45%); outline-offset: 2px; }
.news-form .btn { flex: none; }
.news-consent { margin-top: var(--space-3); font-size: var(--text-2xs); color: var(--text-muted); }
.news-consent a { color: var(--brand-accent-text); text-decoration: underline; text-underline-offset: 2px; }
.news-done { display: none; align-items: center; gap: var(--space-3); font-size: var(--text-sm); color: var(--text-primary); font-weight: var(--weight-semibold); }
.news-done.show { display: flex; }
.news-done .ic { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; background: var(--brand-accent); color: #fff; flex: none; }
.footer-col .soon-tag { font-size: var(--text-xs); color: var(--text-inverse-soft); font-style: italic; opacity: 0.75; }
.footer-col .eco-here { color: var(--text-inverse); font-weight: var(--weight-semibold); opacity: 0.65; }
.footer-col .eco-soon { color: var(--text-inverse-soft); }
.footer-col .eco-soon em { font-style: normal; font-size: var(--text-2xs); opacity: 0.7; }

@media (prefers-reduced-motion: reduce) { .carousel-track { scroll-behavior: auto; } }

/* ---- Bandeau consentement cookies (partagé écosystème) ---- */
.cookie-bar { position: fixed; left: 50%; bottom: var(--space-5); transform: translate(-50%, 140%); z-index: var(--z-toast, 1200); width: min(940px, calc(100vw - 2rem));
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-5) var(--space-6); justify-content: space-between;
  background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl, var(--shadow-lg)); padding: var(--space-5) var(--space-6);
  transition: transform var(--duration-slow, 360ms) var(--ease-standard, ease); }
.cookie-bar.show { transform: translate(-50%, 0); }
.cookie-bar .cookie-txt { flex: 1 1 360px; }
.cookie-bar p { margin: 0; color: var(--text-secondary); font-size: var(--text-sm); line-height: var(--leading-normal); }
.cookie-bar strong { color: var(--text-primary); font-weight: var(--weight-semibold); font-size: var(--text-base); }
.cookie-bar .cookie-link { color: var(--brand-accent-text); text-decoration: underline; text-underline-offset: 2px; font-weight: var(--weight-semibold); }
.cookie-bar .cookie-acts { display: flex; gap: var(--space-3); flex: none; }
@media (max-width: 560px) { .cookie-bar { bottom: 0; border-radius: var(--radius-xl) var(--radius-xl) 0 0; } .cookie-bar .cookie-acts { width: 100%; } .cookie-bar .cookie-acts .btn { flex: 1; } }
.cookie-prefs { display: none; flex-basis: 100%; width: 100%; margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--border-default); flex-direction: column; gap: var(--space-3); }
.cookie-bar.show-prefs .cookie-prefs { display: flex; }
.cookie-pref-row { display: flex; gap: var(--space-3); align-items: flex-start; cursor: pointer; }
.cookie-pref-row input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--brand-accent); flex: none; }
.cookie-pref-row strong { display: block; font-size: var(--text-sm); color: var(--text-primary); }
.cookie-pref-row span { font-size: var(--text-xs); color: var(--text-muted); }
.cookie-prefs .btn { align-self: flex-start; }

/* ---- Pages légales ---- */
.legal-hero { background: linear-gradient(180deg, var(--surface-bg-soft), var(--surface-bg)); padding-block: var(--space-16) var(--space-10); border-bottom: 1px solid var(--border-subtle); }
.legal-hero .eyebrow-pill { display: inline-flex; align-items: center; gap: var(--space-2); background: var(--brand-accent-soft); color: var(--brand-accent-text); font-weight: var(--weight-semibold); font-size: var(--text-sm); padding: 6px var(--space-4); border-radius: var(--radius-pill); }
.legal-hero h1 { font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: clamp(2.2rem, 5vw, 3.2rem); margin: var(--space-5) 0 var(--space-3); letter-spacing: var(--tracking-tight); }
.legal-hero .updated { color: var(--text-muted); font-family: var(--font-mono); font-size: var(--text-sm); }
.legal-wrap { display: grid; grid-template-columns: 260px 1fr; gap: var(--space-12); align-items: start; }
@media (max-width: 900px) { .legal-wrap { grid-template-columns: 1fr; gap: var(--space-8); } }
.legal-toc { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 2px; border-left: 2px solid var(--border-subtle); padding-left: var(--space-4); }
@media (max-width: 900px) { .legal-toc { position: static; } }
.legal-toc a { color: var(--text-secondary); text-decoration: none; font-size: var(--text-sm); padding: 6px 0; transition: color var(--duration-fast); }
.legal-toc a:hover { color: var(--brand-accent-text); }
.legal-body { max-width: 760px; }
.legal-body section { margin-bottom: var(--space-10); scroll-margin-top: 100px; }
.legal-body h2 { font-family: var(--font-display); font-weight: var(--weight-medium); font-size: var(--text-2xl); margin: 0 0 var(--space-3); display: flex; align-items: baseline; gap: var(--space-3); }
.legal-body h2 .num { font-family: var(--font-mono); font-size: var(--text-base); color: var(--brand-accent-text); }
.legal-body h3 { font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-lg); margin: var(--space-6) 0 var(--space-2); }
.legal-body p, .legal-body li { color: var(--text-secondary); line-height: var(--leading-relaxed); }
.legal-body p { margin: 0 0 var(--space-3); }
.legal-body ul, .legal-body ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); }
.legal-body a { color: var(--brand-accent-text); text-decoration: underline; text-underline-offset: 2px; }
.legal-body .ldl { margin: 0 0 var(--space-4); display: grid; grid-template-columns: max-content 1fr; gap: var(--space-2) var(--space-6); }
.legal-body .ldl dt { font-weight: var(--weight-semibold); color: var(--text-primary); }
.legal-body .ldl dd { margin: 0; color: var(--text-secondary); }
.legal-note { background: var(--surface-bg-soft); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: var(--space-4) var(--space-5); margin: var(--space-4) 0; }
.legal-note p { margin: 0; }
.legal-table { width: 100%; border-collapse: collapse; margin: 0 0 var(--space-4); font-size: var(--text-sm); }
.legal-table th, .legal-table td { text-align: left; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border-subtle); vertical-align: top; }
.legal-table th { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); }
.cookie-choice { display: inline-flex; gap: var(--space-3); margin-top: var(--space-3); }

/* ---- Formulaire de contact (partagé écosystème) ---- */
.contact-panel { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: clamp(var(--space-8), 5vw, var(--space-16)); align-items: start; background: linear-gradient(160deg, var(--navy-700, #1b3c5c), var(--navy-900, #0e2236)); border-radius: var(--radius-2xl); padding: clamp(var(--space-8), 4vw, var(--space-12)); box-shadow: var(--shadow-lg); color: #fff; position: relative; overflow: hidden; }
.contact-panel::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.05) 1px, transparent 1px); background-size: 40px 40px; -webkit-mask-image: radial-gradient(80% 80% at 100% 0%, #000, transparent 70%); mask-image: radial-gradient(80% 80% at 100% 0%, #000, transparent 70%); pointer-events: none; }
@media (max-width: 860px) { .contact-panel { grid-template-columns: 1fr; gap: var(--space-8); } }
.contact-intro { position: relative; z-index: 1; }
.contact-intro .pill { display: inline-flex; align-items: center; gap: var(--space-2); background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.18); color: #fff; font-family: var(--font-mono); font-size: var(--text-2xs); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; padding: 6px 14px; border-radius: var(--radius-pill); }
.contact-intro h2 { font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: clamp(1.9rem, 3.6vw, var(--text-4xl)); line-height: 1.12; margin: var(--space-5) 0 var(--space-4); color: #fff; }
.contact-intro p { color: rgba(233,239,245,0.80); line-height: var(--leading-relaxed); margin: 0 0 var(--space-3); max-width: 46ch; }
.contact-form { position: relative; z-index: 1; display: flex; flex-direction: column; gap: var(--space-4); }
.contact-form .field { display: flex; flex-direction: column; gap: var(--space-2); }
.contact-form label { font-weight: var(--weight-semibold); font-size: var(--text-sm); color: #fff; }
.contact-form .input, .contact-form .select, .contact-form .textarea { width: 100%; background: var(--surface-card); border: 1px solid transparent; border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); font: inherit; color: var(--text-primary); box-shadow: var(--shadow-sm); }
.contact-form .textarea { min-height: 132px; resize: vertical; }
.contact-form .input::placeholder, .contact-form .textarea::placeholder { color: var(--text-muted); }
.contact-form .input:focus-visible, .contact-form .select:focus-visible, .contact-form .textarea:focus-visible { outline: 3px solid color-mix(in oklab, var(--brand-accent), transparent 45%); outline-offset: 2px; border-color: var(--brand-accent); }
.contact-consent { display: flex; gap: var(--space-3); align-items: flex-start; }
.contact-consent input { margin-top: 3px; width: 20px; height: 20px; accent-color: var(--brand-accent); flex: none; }
.contact-consent label { font-weight: var(--weight-regular); font-size: var(--text-sm); color: rgba(233,239,245,0.82); line-height: var(--leading-normal); }
.contact-consent a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
.contact-form .btn-submit { background: linear-gradient(180deg, color-mix(in oklab, var(--brand-accent), #fff 4%), var(--brand-accent)); color: #fff; border: none; box-shadow: 0 10px 26px color-mix(in oklab, var(--brand-accent), transparent 55%); }
.contact-form .btn-submit:hover { box-shadow: 0 14px 32px color-mix(in oklab, var(--brand-accent), transparent 46%); }
.contact-error { display: none; color: #ffd9cf; font-size: var(--text-sm); }
.contact-error.show { display: block; }
.contact-success { display: none; position: relative; z-index: 1; flex-direction: column; gap: var(--space-3); justify-content: center; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.16); border-radius: var(--radius-lg); padding: var(--space-8); text-align: center; }
.contact-success.show { display: flex; }
.contact-success .ic { width: 56px; height: 56px; margin: 0 auto; border-radius: 50%; display: grid; place-items: center; background: var(--brand-accent); color: #fff; font-size: 26px; }
.contact-success h3 { font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: var(--text-2xl); margin: 0; color: #fff; }
.contact-success p { color: rgba(233,239,245,0.82); margin: 0; }
