/* =====================================================================
   1% pour les Enfants — site layout
   Depends on tokens.css + components.css. Layout-only — no new tokens.
   ===================================================================== */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--paper);
  color: var(--ink-700);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; margin: 0; }
button { font-family: inherit; }
img { display: block; max-width: 100%; }

/* Visually-hidden but screen-reader-accessible (page h1 on visual-only heroes). */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* Skip-to-content link — first focusable element; visible only on keyboard focus. */
.skip-link {
  position: absolute; left: 12px; top: -56px; z-index: 1000;
  background: var(--deep-500); color: #fff;
  padding: 10px 16px; border-radius: var(--radius-sm);
  font: 600 14px/1 var(--font-body, sans-serif);
  transition: top var(--dur-fast) var(--ease);
}
.skip-link:focus { top: 12px; }
/* The skip target is a layout wrapper; don't draw a focus ring around all content. */
#main:focus { outline: none; }

/* =====================================================================
   BACKGROUND SYSTEM — paper grain + ambient radial washes.
   Matches the UI Kit's marketing-site treatment: fixed in place, content
   glides over. The Paper page is the substrate; large soft radials in
   Sky / Sun / Brand Pink (very low alpha) sit on top as faint colour
   washes. No SVG blobs, no toy-like shapes — institutional warmth.
   ===================================================================== */
body::before {
  content: ""; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: var(--paper-grain-url);
  opacity: 0.55; mix-blend-mode: multiply;
}
/* Animated "liquid bubble" layer. js/bg.js fills .bg-shapes with .blob
   spans (soft brand-coloured radial gradients) and drives their motion.
   The #goofilter (defined in the page markup) blurs the whole layer then
   sharpens its alpha so blobs that drift near each other fuse, with an
   extra blur to keep everything as a soft colour wash. Low opacity keeps
   type readable. overflow:hidden clips blobs at the viewport edge;
   isolation:isolate so the blobs' blend-mode mixes their colours with one
   another, not with the page content. */
.bg-shapes {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; overflow: hidden;
  isolation: isolate;
  filter: url(#goofilter) blur(60px);
  opacity: 0.20;
  will-change: transform;
}
.bg-shapes .blob {
  position: absolute; top: 0; left: 0;
  border-radius: 50%;
  mix-blend-mode: multiply;   /* overlapping bubbles blend into new hues */
  will-change: transform;
}
/* Lighter touch on small screens (the goo + blur is GPU-heavy). */
@media (max-width: 768px) {
  .bg-shapes { filter: url(#goofilter) blur(40px); }
}
/* bg.js renders a single calm static frame when this is set. */
@media (prefers-reduced-motion: reduce) {
  .bg-shapes { filter: url(#goofilter) blur(60px); }
}

.page { position: relative; z-index: 1; }

/* =====================================================================
   BUTTON SIZE OVERRIDES — site uses tighter buttons than the kit default.
   Reduces sm/md/lg sizes to ~50–60% of their original visual mass.
   ===================================================================== */
.btn.btn-sm { font-size: 11px; padding: 4px 10px; min-height: 22px; gap: 6px; }
.btn.btn-md { font-size: 12px; padding: 5px 12px; min-height: 26px; gap: 6px; }
.btn.btn-lg { font-size: 13px; padding: 6px 14px; min-height: 30px; gap: 6px; }
.btn .btn-arrow { width: 12px; height: 12px; }
.btn .btn-arrow i { width: 12px; height: 12px; }
/* Buttons are usually <a> tags; the default `a:hover { color: deep }`
   from tokens.css was leaking into pink-filled buttons. Lock the text
   colour back to the button's intended text token on all interactions. */
.btn-primary, .btn-primary:hover, .btn-primary:active, .btn-primary:focus, .btn-primary:visited { color: var(--btn-text); }
.btn-ghost.btn-sm::after { bottom: 2px; }
.btn-ghost.btn-md::after { bottom: 3px; }
.btn-ghost.btn-lg::after { bottom: 4px; }

/* =====================================================================
   STICKY AUTO-HIDE NAV + LAUNCH RIBBON
   Nav is the sticky element. Ribbon scrolls with the page.
   .nav-hidden translates the nav off-screen.
   ===================================================================== */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(250, 250, 247, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base) var(--ease);
}
.site-nav.nav-hidden { transform: translateY(-100%); }

.nav-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 14px 24px;
}
.nav-brand { display: inline-flex; align-items: center; gap: 10px; }
.nav-brand img { width: 32px; height: 32px; }
/* Wordmark text is hidden — the head mark IS the brand on the nav bar. */
.nav-brand .wordmark { display: none; }

.nav-links {
  display: flex; align-items: center; gap: 28px;
  font-family: var(--font-display);
}
.nav-link, .nav-trigger {
  font: 600 14px/1 var(--font-display);
  color: var(--ink-700);
  letter-spacing: -0.005em;
  display: inline-flex; align-items: center; gap: 6px;
  background: none; border: 0; cursor: pointer;
  padding: 8px 0;
  transition: color var(--dur-fast) var(--ease);
}
.nav-link:hover, .nav-link.active, .nav-trigger:hover { color: var(--ink-900); }

/* Dropdown */
.nav-item-dropdown { position: relative; }
.nav-trigger .caret { width: 12px; height: 12px; transition: transform var(--dur-fast) var(--ease); }
.nav-item-dropdown:hover .nav-trigger .caret,
.nav-item-dropdown:focus-within .nav-trigger .caret,
.nav-item-dropdown.is-open .nav-trigger .caret { transform: rotate(180deg); }
.nav-dropdown {
  position: absolute; top: 100%; left: -16px;
  background: var(--snow);
  min-width: 220px;
  padding: 8px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--ink-200);
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease), visibility var(--dur-base);
}
.nav-item-dropdown:hover .nav-dropdown,
.nav-item-dropdown:focus-within .nav-dropdown,
.nav-item-dropdown.is-open .nav-dropdown {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.nav-dropdown a {
  display: block;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  font: 500 14px/1.3 var(--font-body);
  color: var(--ink-700);
  transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.nav-dropdown a:hover { background: var(--sky-50); color: var(--ink-900); }
.nav-dropdown a .sub {
  display: block;
  font: 400 12px/1.4 var(--font-body);
  color: var(--ink-500);
  margin-top: 2px;
}

.nav-cta { display: inline-flex; align-items: center; gap: 12px; }

/* Mobile menu trigger */
.nav-burger {
  display: none;
  width: 40px; height: 40px;
  background: transparent;
  border: 0; cursor: pointer;
  border-radius: var(--radius-sm);
  align-items: center; justify-content: center;
  color: var(--ink-900);
}
.nav-burger:hover { background: var(--ink-100); }

/* Mobile sheet */
.nav-sheet {
  position: fixed; inset: 64px 0 0 0;
  background: var(--paper);
  z-index: 55;
  padding: 24px;
  display: none;
  overflow-y: auto;
  flex-direction: column; gap: 8px;
}
.nav-sheet.open { display: flex; }
.nav-sheet .sheet-group { border-bottom: 1px solid var(--ink-200); padding: 14px 0; }
.nav-sheet .sheet-group > a:not(.btn), .nav-sheet .sheet-group > .grp-label {
  font: 700 18px/1.2 var(--font-display); color: var(--ink-900);
  display: block; padding: 6px 0;
}
.nav-sheet .sheet-sub { display: flex; flex-direction: column; gap: 4px; padding: 8px 0 0; }
.nav-sheet .sheet-sub a { font: 500 15px/1.3 var(--font-body); color: var(--ink-700); padding: 8px 0; }

/* Launch-offer ribbon */
.ribbon {
  position: relative;
  background: var(--pink-500);
  color: var(--snow);
  padding: 12px 24px;
  font: 600 14px/1.3 var(--font-body);
  text-align: center;
  display: flex; align-items: center; justify-content: center;
}
.ribbon strong { font-weight: 700; }
.ribbon .ribbon-close {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  width: 32px; height: 32px;
  background: transparent; color: var(--snow);
  border: 0; cursor: pointer;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--dur-fast) var(--ease);
}
.ribbon .ribbon-close:hover { background: rgba(255,255,255,0.15); }
.ribbon.hidden { display: none; }

/* =====================================================================
   PAGE SHELL
   ===================================================================== */
main { display: block; }
.section { padding: var(--section-y-desktop) 24px; }
.section-inner { max-width: 1180px; margin: 0 auto; }
.section-head { display: flex; flex-direction: column; gap: 14px; max-width: 740px; margin-bottom: 56px; }
.section-head .eyebrow {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--deep-500);
}
.section-head h2 {
  font: 800 44px/1.05 var(--font-display);
  letter-spacing: -0.02em; color: var(--ink-900);
  text-wrap: balance;
}
.section-head h1 {
  font: 800 56px/1.05 var(--font-display);
  letter-spacing: -0.025em; color: var(--ink-900);
  text-wrap: balance;
}
.section-head p {
  font: 500 18px/1.55 var(--font-body); color: var(--ink-700);
  max-width: 620px;
}

.section.deep-band {
  background: var(--deep-500); color: var(--snow);
  position: relative; overflow: hidden;
}
.section.deep-band::before {
  content: ""; position: absolute; inset: 0;
  background-image: var(--paper-grain-url);
  opacity: 0.45; mix-blend-mode: overlay;
  pointer-events: none;
}
.section.deep-band > * { position: relative; }
.section.deep-band h2, .section.deep-band h1 { color: var(--snow); }
.section.deep-band p { color: var(--sky-100); }

/* Sky band — light-blue full-width band. Text is Ink-900 on Sky (per the
   contrast matrix). Used for the homepage final CTA. */
.section.sky-band { background: var(--sky-500); color: var(--ink-900); position: relative; overflow: hidden; }
.section.sky-band::before {
  content: ""; position: absolute; inset: 0;
  background-image: var(--paper-grain-url);
  opacity: 0.30; mix-blend-mode: multiply; pointer-events: none;
}
.section.sky-band > * { position: relative; }
.section.sky-band h2, .section.sky-band h1 { color: var(--ink-900); }
.section.sky-band .cta-banner h2 { color: var(--ink-900); }
.section.sky-band .cta-banner p { color: var(--ink-900); opacity: 0.72; }

/* A band that sits flush against the footer. The Paper gap is gone (footer
   has no top margin); the band keeps its own padding for breathing room, so
   the Sky band runs straight into the Deep footer with no Paper strip. */
.section.flush-footer { margin-bottom: 0; }

/* =====================================================================
   HERO
   ===================================================================== */
.hero {
  padding: 64px 24px 80px;
}
.hero-inner {
  max-width: 1180px; margin: 0 auto;
}
.hero-text { display: flex; flex-direction: column; gap: 24px; max-width: 760px; }
.hero-text .eyebrow {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--deep-500);
}
.hero-text h1 {
  font: 800 60px/1.02 var(--font-display);
  letter-spacing: -0.025em;
  color: var(--ink-900);
  text-wrap: balance;
}
.hero-text .lede {
  font: 400 20px/1.5 var(--font-body); color: var(--ink-700);
  max-width: 540px;
}
.hero-cta-row {
  display: flex; gap: 14px; align-items: center; flex-wrap: wrap;
  margin-top: 8px;
}
.hero-aside { display: flex; justify-content: center; }

/* =====================================================================
   HOMEPAGE HERO — falling counter (matches UI Kit)
   ===================================================================== */
.hero-counter {
  min-height: calc(100vh - 110px);
  padding: 48px 24px 96px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center;
  gap: 28px;
}
.hero-eyebrow {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--deep-500);
  opacity: 0;
  animation: fadeUp 600ms var(--ease) 1.6s forwards;
}
.counter-stage {
  perspective: 1200px;
  display: flex; flex-direction: column; align-items: center;
  margin: 8px 0 0;
}
.counter {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(72px, 13vw, 200px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  display: inline-flex;
  gap: 2px;
}
/* Entrance: a calm fade-in (reverted from the "slam down" drop). */
.counter.dropped { animation: fadeUp 600ms var(--ease) 0.15s both; }
.counter-digit { display: inline-block; transition: transform 400ms var(--ease); }
.counter-digit.tick { animation: flip 380ms var(--ease); }
@keyframes flip {
  0%   { transform: translateY(0); opacity: 1; }
  35%  { transform: translateY(-30%); opacity: 0; }
  36%  { transform: translateY(30%); }
  100% { transform: translateY(0); opacity: 1; }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.counter-caption {
  font: 500 16px/1.5 var(--font-body);
  color: var(--ink-700);
  max-width: 560px;
  opacity: 0;
  animation: fadeUp 600ms var(--ease) 1.8s forwards;
}
.counter-caption strong { color: var(--ink-900); font-weight: 700; }
.counter-caption .src { font: 500 12px/1.4 var(--font-body); color: var(--ink-500); display: block; margin-top: 6px; }
.hero-help {
  font: 700 22px/1.3 var(--font-display);
  letter-spacing: -0.01em;
  color: var(--ink-900);
  opacity: 0;
  animation: fadeUp 600ms var(--ease) 2.2s forwards;
}
.hero-counter .hero-cta-row {
  margin-top: 0;
  justify-content: center;
  opacity: 0;
  animation: fadeUp 600ms var(--ease) 2.6s forwards;
}

/* =====================================================================
   MISSION — engagement model (matches UI Kit)
   ===================================================================== */
.mission-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.mission-narrative { display: flex; flex-direction: column; gap: 16px; }
.mission-steps { display: flex; flex-direction: column; gap: 14px; margin: 4px 0 18px; }
.mission-step { display: flex; gap: 14px; align-items: flex-start; }
.mission-step .n {
  width: 32px; height: 32px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--sun-100);
  color: var(--sun-900);
  display: grid; place-items: center;
  font: 800 14px/1 var(--font-display);
}
.mission-step .body strong { font: 700 15px/1.3 var(--font-display); color: var(--ink-900); display: block; margin-bottom: 2px; }
.mission-step .body span  { font: 400 14px/1.5 var(--font-body); color: var(--ink-700); }
.mission-badges { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 4px 0 20px; }
.mission-badge {
  display: flex; gap: 10px; align-items: flex-start;
  background: var(--success-bg);
  border: 1px solid rgba(27, 127, 58, 0.22);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}
.mission-badge > i { color: var(--success); width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; }
.mission-badge > span { display: flex; flex-direction: column; font: 400 12px/1.4 var(--font-body); color: var(--ink-600); }
.mission-badge strong { font: 700 13px/1.3 var(--font-display); color: var(--success); margin-bottom: 1px; }
@media (max-width: 720px) { .mission-badges { grid-template-columns: 1fr; } }
.mission-cta-row { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.model-card {
  background: var(--snow);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 32px;
  display: flex; flex-direction: column; gap: 22px;
}
.model-card .formula {
  display: flex; align-items: stretch; gap: 14px;
  padding: 20px;
  border-radius: var(--radius-md);
  background: var(--paper);
  border: 1.5px solid var(--ink-200);
}
.model-card .cell { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.model-card .cell .lbl { font: 700 10px/1.3 var(--font-body); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-500); }
.model-card .cell .amt { font: 800 36px/1 var(--font-display); letter-spacing: -0.025em; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.model-card .cell .amt.amt-sm { font-size: 18px; line-height: 1.2; letter-spacing: -0.01em; }
.model-card .cell .sub { font: 400 12px/1.4 var(--font-body); color: var(--ink-700); }
.model-card .plus { width: 28px; display: flex; align-items: center; justify-content: center; font: 700 28px/1 var(--font-display); color: var(--ink-300); }
.early-bird {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  background: var(--sun-50);
  border-left: 3px solid var(--sun-500);
  padding: 10px 14px;
  font: 600 13px/1.4 var(--font-body);
  color: var(--ink-900);
  border-radius: var(--radius-sm);
}
.early-bird strong { font: 800 14px/1 var(--font-display); }
.modes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mode {
  border-radius: var(--radius-md);
  border: 1.5px solid var(--ink-200);
  padding: 18px;
  display: flex; flex-direction: column; gap: 6px;
  background: var(--snow);
}
.mode .pill { font: 700 10px/1 var(--font-body); letter-spacing: 0.08em; text-transform: uppercase; color: var(--deep-500); }
.mode .what { font: 700 16px/1.3 var(--font-display); color: var(--ink-900); letter-spacing: -0.005em; }
.mode .how  { font: 400 13px/1.5 var(--font-body); color: var(--ink-700); }
.mode.targeted { border-color: var(--sky-500); background: var(--sky-50); }
.mode.targeted .pill { color: var(--sky-700); }

/* =====================================================================
   ACTORS — UI-Kit-style marquee items (logo + name/sub side by side)
   ===================================================================== */
.actors-marquees { display: flex; flex-direction: column; gap: 28px; }
.marquee-item {
  flex-shrink: 0;
  background: var(--snow);
  border: 1px solid var(--ink-200);
  border-radius: var(--radius-md);
  padding: 14px 20px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.marquee-item:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.marquee-item .logo {
  width: 40px; height: 40px;
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  font: 800 14px/1 var(--font-display);
  flex-shrink: 0;
}
.marquee-item.assoc .logo { background: var(--sky-50); color: var(--sky-700); }
.marquee-item.firm  .logo { background: var(--sun-50); color: var(--sun-900); }
.marquee-item .name { font: 700 14px/1.2 var(--font-display); color: var(--ink-900); letter-spacing: -0.005em; white-space: nowrap; }
.marquee-item .sub  { font: 500 12px/1.3 var(--font-body); color: var(--ink-500); white-space: nowrap; }
.marquee-item.person { padding: 12px 18px 12px 12px; }
.marquee-item.person .avatar {
  width: 44px; height: 44px; border-radius: 50%;
  display: grid; place-items: center;
  font: 700 15px/1 var(--font-display);
  flex-shrink: 0;
}
.person-info { display: flex; flex-direction: column; gap: 2px; }

/* Homepage ticker hero — legacy, kept for compat. */
.ticker-hero { padding: 88px 24px 96px; text-align: center; }
.ticker-hero .eyebrow {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--deep-500);
}
.ticker-display {
  margin: 18px auto 0;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(72px, 13vw, 180px);
  line-height: 1; letter-spacing: -0.04em;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  display: inline-flex; gap: 2px;
}
.ticker-display .d { display: inline-block; transition: transform 300ms var(--ease), color 300ms var(--ease); }
.ticker-display .d.pulse { color: var(--pink-500); transform: translateY(-4px); }
.ticker-label {
  margin: 22px auto 0; max-width: 620px;
  font: 500 16px/1.5 var(--font-body); color: var(--ink-700);
}
.ticker-label .src { display: block; font: 400 12px/1.4 var(--font-body); color: var(--ink-500); margin-top: 8px; }
.ticker-line {
  margin: 32px auto 0;
  font: 700 24px/1.35 var(--font-display);
  letter-spacing: -0.01em;
  color: var(--ink-900);
  max-width: 720px;
  text-wrap: balance;
}
.ticker-cta-row {
  display: flex; gap: 14px; align-items: center; justify-content: center;
  flex-wrap: wrap;
  margin: 32px auto 0;
}
.ticker-illu {
  margin: 48px auto 0;
  width: min(420px, 80%);
}

/* =====================================================================
   CARDS / GRIDS
   ===================================================================== */
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }

.icon-card {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 12px;
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.icon-card .pictogram {
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  background: var(--sky-50);
  color: var(--deep-500);
}
.icon-card.sun .pictogram { background: var(--sun-50); color: var(--sun-900); }
.icon-card.pink .pictogram { background: var(--pink-50); color: var(--pink-700); }
.icon-card.deep .pictogram { background: var(--deep-50); color: var(--deep-500); }
.icon-card h3 {
  font: 700 18px/1.3 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-900);
}
.icon-card p {
  font: 400 14px/1.55 var(--font-body); color: var(--ink-700);
}

/* =====================================================================
   PROCESS STEPS (3-step)
   ===================================================================== */
.process { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; position: relative; }
.process::before {
  content: ""; position: absolute;
  top: 38px; left: 8%; right: 8%; height: 2px;
  background: repeating-linear-gradient(90deg, var(--ink-200) 0 8px, transparent 8px 16px);
  z-index: 0;
}
.process-step {
  position: relative; z-index: 1;
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 12px;
}
.process-step .num {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--sun-500); color: var(--ink-900);
  display: grid; place-items: center;
  font: 800 16px/1 var(--font-display);
}
.process-step h3 {
  font: 700 20px/1.25 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-900);
}
.process-step p {
  font: 400 15px/1.55 var(--font-body); color: var(--ink-700);
}
.process-step .ico {
  margin-top: auto;
  width: 32px; height: 32px;
  color: var(--deep-500);
}

/* =====================================================================
   MARQUEE ROWS
   ===================================================================== */
.marquee-stack { display: flex; flex-direction: column; gap: 36px; }
.marquee-row {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 24px; align-items: center;
}
.marquee-label .pill {
  font: 700 11px/1 var(--font-display);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--deep-500);
}
.marquee-label h3 {
  margin-top: 6px;
  font: 800 22px/1.15 var(--font-display);
  letter-spacing: -0.01em; color: var(--ink-900);
}
.marquee-label p {
  margin-top: 4px;
  font: 400 13px/1.4 var(--font-body); color: var(--ink-700);
}

.marquee {
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track { display: flex; width: max-content; gap: 18px; will-change: transform; }
.marquee-track.ltr { animation: marqueeLtr 30s linear infinite; }
.marquee-track.rtl { animation: marqueeRtl 30s linear infinite; }
@keyframes marqueeRtl { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes marqueeLtr { from { transform: translateX(-50%); } to { transform: translateX(0); } }

.assoc-card {
  flex-shrink: 0;
  width: 200px; height: 200px;
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--ink-200);
  display: flex; flex-direction: column; gap: 10px;
  position: relative; overflow: hidden;
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.assoc-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.assoc-card .logo {
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  background: var(--sky-50); color: var(--deep-500);
  display: grid; place-items: center;
  font: 800 18px/1 var(--font-display);
}
.assoc-card .name {
  font: 700 15px/1.3 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-900);
}
.assoc-card .reveal {
  margin-top: auto;
  font: 400 12px/1.45 var(--font-body); color: var(--ink-700);
  display: flex; gap: 6px; align-items: center;
  opacity: 0; transform: translateY(6px);
  transition: opacity var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.assoc-card:hover .reveal { opacity: 1; transform: translateY(0); }

/* ----- Grid toolbar (search + facet chips) ------------------------- */
.grid-toolbar {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 24px;
}
.grid-search {
  position: relative;
  max-width: 480px;
}
.grid-search i {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  width: 18px; height: 18px; color: var(--ink-500); pointer-events: none;
}
.grid-search input {
  width: 100%; padding: 12px 14px 12px 44px;
  border: 1px solid var(--ink-200); border-radius: var(--radius-md);
  background: var(--snow); color: var(--ink-900);
  font: 400 15px/1.4 var(--font-body);
  transition: border-color var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease);
}
.grid-search input:focus {
  outline: none; border-color: var(--deep-500);
  box-shadow: 0 0 0 3px rgba(0,0,0,0.06);
}
.grid-facets { display: flex; flex-direction: column; gap: 10px; }
.facet-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.facet-label {
  font: 600 12px/1 var(--font-body); letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--ink-500);
  min-width: 80px;
}
.filter-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.filter-chip {
  border: 1px solid var(--ink-200); background: var(--snow);
  color: var(--ink-700);
  padding: 6px 12px; border-radius: 999px;
  font: 500 13px/1 var(--font-body);
  cursor: pointer;
  transition: background var(--dur-base) var(--ease),
              border-color var(--dur-base) var(--ease),
              color var(--dur-base) var(--ease);
}
.filter-chip:hover { border-color: var(--ink-500); }
.filter-chip.is-active {
  background: var(--ink-900); border-color: var(--ink-900); color: var(--snow);
}
.grid-count { color: var(--ink-500); margin: 0; }
.grid-empty {
  grid-column: 1 / -1;
  padding: 32px; text-align: center;
  border: 1px dashed var(--ink-200); border-radius: var(--radius-md);
  color: var(--ink-500);
}

.firm-card {
  flex-shrink: 0;
  width: 180px; height: 100px;
  background: var(--snow);
  border-radius: var(--radius-md);
  border: 1px solid var(--ink-200);
  box-shadow: var(--shadow-sm);
  display: grid; place-items: center;
  padding: 14px;
  transition: filter var(--dur-base) var(--ease), box-shadow var(--dur-base) var(--ease);
  filter: grayscale(100%);
}
.firm-card:hover { filter: grayscale(0); box-shadow: var(--shadow-md); }
.firm-card .wordmark {
  font: 800 16px/1.1 var(--font-display);
  letter-spacing: -0.005em;
  text-align: center;
  color: var(--ink-900);
}

.person-card {
  flex-shrink: 0;
  width: 200px;
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 14px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--ink-200);
  display: flex; flex-direction: column; gap: 10px;
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.person-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.person-card .portrait {
  width: 100%; aspect-ratio: 1;
  border-radius: var(--radius-md);
  display: grid; place-items: center;
  font: 800 28px/1 var(--font-display);
}
.person-card .portrait.pink { background: var(--pink-100); color: var(--pink-700); }
.person-card .portrait.sky  { background: var(--sky-100);  color: var(--deep-500); }
.person-card .portrait.sun  { background: var(--sun-100);  color: var(--sun-900); }
.person-card .portrait.deep { background: var(--deep-500); color: var(--snow); }
.person-card .name { font: 700 14px/1.3 var(--font-display); color: var(--ink-900); }
.person-card .role { font: 400 12px/1.4 var(--font-body); color: var(--ink-500); }

/* =====================================================================
   FINAL CTA BANNER
   ===================================================================== */
.cta-banner {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  max-width: 720px; margin: 0 auto;
}
.cta-banner h2 {
  font: 800 44px/1.1 var(--font-display);
  letter-spacing: -0.02em; color: var(--snow);
  text-wrap: balance;
}
.cta-banner p {
  font: 400 18px/1.55 var(--font-body); color: var(--sky-100);
  max-width: 520px;
}

/* =====================================================================
   STATS / CALLOUTS
   ===================================================================== */
.stat-card {
  background: var(--sun-50);
  border-radius: var(--radius-lg);
  padding: 28px;
  border-left: 4px solid var(--sun-500);
}
.stat-card .num {
  font: 800 44px/1 var(--font-display);
  letter-spacing: -0.025em; color: var(--ink-900);
  font-variant-numeric: tabular-nums;
}
.stat-card .lbl {
  margin-top: 8px;
  font: 500 14px/1.45 var(--font-body); color: var(--ink-700);
}
.stat-card.sky  { background: var(--sky-50);  border-left-color: var(--sky-500); }
.stat-card.pink { background: var(--pink-50); border-left-color: var(--pink-500); }
.stat-card.deep { background: var(--deep-500); border-left-color: var(--sun-500); color: var(--snow); }
.stat-card.deep .num, .stat-card.deep .lbl { color: var(--snow); }
/* Rotating stats: keep a stable height and crossfade content */
.stats-rotate .stat-card { min-height: 200px; }
.stats-rotate .stat-card .num,
.stats-rotate .stat-card .lbl { transition: opacity .35s ease; }
.stats-rotate .stat-card.is-swapping .num,
.stats-rotate .stat-card.is-swapping .lbl { opacity: 0; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer {
  background: var(--deep-500); color: var(--snow);
  padding: 80px 24px 32px;
  position: relative; overflow: hidden;
  margin-top: var(--section-y-desktop);
}
.site-footer::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(700px 500px at 90% 100%, rgba(255, 199, 60, 0.10), transparent 65%),
    radial-gradient(500px 400px at 0% 0%,   rgba(125, 167, 255, 0.16), transparent 70%);
}
.footer-inner {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr 1.2fr;
  gap: 56px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.14);
  position: relative;
}
.footer-brand img { width: 48px; height: 48px; }
.footer-brand h3 {
  font: 800 22px/1.2 var(--font-display);
  letter-spacing: -0.01em; color: var(--snow);
  margin-top: 18px; text-wrap: balance;
}
.footer-brand p {
  font: 400 13px/1.55 var(--font-body); color: var(--sky-100);
  margin-top: 10px; max-width: 280px;
}
.footer-brand .linkedin {
  margin-top: 18px;
  display: inline-flex; align-items: center; gap: 8px;
  font: 600 13px/1 var(--font-body); color: var(--sky-100);
}
.footer-brand .linkedin:hover { color: var(--snow); }

.footer-map h4 {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--sun-500);
  margin-bottom: 16px;
}
.footer-map .col {
  display: flex; flex-direction: column; gap: 10px;
}
.footer-map a {
  font: 500 14px/1.3 var(--font-body); color: var(--sky-100);
  transition: color var(--dur-fast) var(--ease);
}
.footer-map a:hover { color: var(--snow); }

.footer-form h4 {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--sun-500);
  margin-bottom: 16px;
}
.footer-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.footer-form .row.single { grid-template-columns: 1fr; }
.footer-form label {
  display: block;
  font: 700 10px/1 var(--font-display);
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--sky-100); margin-bottom: 6px;
}
.footer-form .input, .footer-form .textarea {
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.18);
  color: var(--snow);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  font: 500 14px/1.4 var(--font-body);
  width: 100%; box-sizing: border-box;
}
.footer-form .input::placeholder, .footer-form .textarea::placeholder { color: rgba(255,255,255,0.45); }
.footer-form .input:focus, .footer-form .textarea:focus {
  outline: none;
  border-color: var(--sun-500);
  box-shadow: 0 0 0 4px rgba(255, 199, 60, 0.18);
}
.footer-form .textarea { min-height: 88px; resize: vertical; }
.footer-form .intents { display: flex; flex-wrap: wrap; gap: 8px; }
.footer-form .intent {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  border: 1.5px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-pill);
  cursor: pointer;
  font: 500 13px/1 var(--font-body); color: var(--sky-100);
  transition: all var(--dur-fast) var(--ease);
}
.footer-form .intent input { appearance: none; width: 12px; height: 12px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.4); margin: 0; }
.footer-form .intent input:checked { background: var(--sun-500); border-color: var(--sun-500); }
.footer-form .intent:has(input:checked) { background: rgba(255, 199, 60, 0.14); border-color: var(--sun-500); color: var(--snow); }
.footer-form .submit-row { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; gap: 12px; }
.footer-form .submit-row small { font: 400 11px/1.4 var(--font-body); color: rgba(255,255,255,0.6); }

.footer-legal {
  max-width: 1180px; margin: 24px auto 0;
  display: flex; justify-content: space-between; gap: 24px;
  font: 400 12px/1.4 var(--font-body); color: rgba(255,255,255,0.55);
  flex-wrap: wrap;
  position: relative;
}

/* =====================================================================
   STICKY RIGHT-RAIL CTA
   ===================================================================== */
.rail-cta {
  position: fixed;
  right: 24px; bottom: 28px;
  z-index: 50;
}

/* =====================================================================
   PROFILE / EDITORIAL / FAQ / BLOG
   ===================================================================== */
.profile-hero {
  padding: 72px 24px 48px;
}
.profile-hero-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; gap: 32px; align-items: flex-start;
}
.profile-hero .badge-logo {
  width: 96px; height: 96px;
  border-radius: var(--radius-lg);
  display: grid; place-items: center;
  font: 800 28px/1 var(--font-display);
  background: var(--sky-50); color: var(--deep-500);
  flex-shrink: 0;
}
.badge-logo-img {
  width: 96px; height: 96px;
  border-radius: var(--radius-lg);
  object-fit: cover; flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}
.profile-slogan {
  font: 600 18px/1.4 var(--font-display);
  color: var(--ink-500); letter-spacing: -0.005em;
  max-width: 560px;
}
.profile-gallery {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px;
  margin-top: 4px;
}
.profile-gallery img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover;
  border-radius: var(--radius-md); display: block;
}
.profile-hero .portrait {
  width: 160px; height: 160px;
  border-radius: var(--radius-lg);
  background: var(--sky-100); color: var(--deep-500);
  display: grid; place-items: center;
  font: 800 48px/1 var(--font-display);
  flex-shrink: 0;
}
.profile-hero .meta { display: flex; flex-direction: column; gap: 12px; }
.profile-hero .meta .tags { display: flex; gap: 8px; flex-wrap: wrap; }
.profile-hero h1 {
  font: 800 36px/1.1 var(--font-display);
  letter-spacing: -0.015em; color: var(--ink-900);
}
.profile-hero h2 {
  font: 600 22px/1.35 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-700);
  max-width: 640px; text-wrap: balance;
}

.profile-body {
  max-width: 1180px; margin: 0 auto;
  padding: 32px 24px 80px;
  display: grid; grid-template-columns: 1fr 320px; gap: 48px;
  align-items: start;
}
.profile-body .main { display: flex; flex-direction: column; gap: 32px; }
.profile-section { display: flex; flex-direction: column; gap: 16px; padding-top: 32px; border-top: 1px solid var(--ink-100); }
.profile-section:first-child { padding-top: 0; border-top: 0; }
.profile-produit { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.profile-produit strong { font: 700 16px/1.3 var(--font-display); color: var(--ink-900); display: block; margin-bottom: 2px; }
.profile-produit .t-body-sm { color: var(--ink-500); }
/* Produit engagé showcase card — image + promo + link to the company's shop */
.produit-showcase {
  display: flex; gap: 20px; align-items: stretch;
  border: 1px solid var(--ink-200); border-radius: var(--radius-lg);
  background: var(--snow); padding: 18px;
  transition: border-color .15s var(--ease), transform .15s var(--ease), box-shadow .15s var(--ease);
}
a.produit-showcase:hover { border-color: var(--deep-500); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.produit-showcase-img {
  width: 132px; height: 132px; object-fit: cover;
  border-radius: var(--radius-md); flex-shrink: 0;
}
.produit-showcase-body { display: flex; flex-direction: column; gap: 8px; min-width: 0; }
.produit-showcase-head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.produit-showcase-head strong { font: 700 17px/1.3 var(--font-display); color: var(--ink-900); }
.produit-showcase-body .t-body-sm { color: var(--ink-600); }
.produit-showcase-cta {
  margin-top: auto; padding-top: 6px;
  display: inline-flex; align-items: center; gap: 6px;
  font: 700 14px/1 var(--font-display); color: var(--deep-500);
}
.produit-showcase-cta i { width: 16px; height: 16px; }
.assoc-soutien-list { display: flex; flex-direction: column; gap: 10px; }
.assoc-soutien { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 18px; border: 1px solid var(--ink-200); border-radius: var(--radius-md); background: var(--snow); font: 700 15px/1.2 var(--font-display); color: var(--ink-900); transition: border-color .15s var(--ease), transform .15s var(--ease); }
a.assoc-soutien:hover { border-color: var(--deep-500); transform: translateX(2px); }
.assoc-soutien i { color: var(--deep-500); width: 18px; height: 18px; flex-shrink: 0; }
.assoc-soutien.is-static { color: var(--ink-700); }
.profile-body .main h3 {
  font: 700 22px/1.25 var(--font-display); letter-spacing: -0.005em;
  color: var(--ink-900);
}
.profile-body .main p {
  font: 400 17px/1.6 var(--font-body); color: var(--ink-700);
  max-width: 680px;
}
.profile-body .side, .profile-layout > .side {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 14px;
  position: sticky; top: 88px;
}
/* Association profile: a full-page two-column grid so the support card starts
   level with the title AND stays pinned (sticky) while the page scrolls. */
.profile-layout {
  max-width: 1180px; margin: 0 auto;
  padding: 0 24px 80px;
  display: grid; grid-template-columns: 1fr 320px; gap: 48px;
  align-items: start;
}
.profile-layout .profile-hero { padding: 72px 0 48px; }
.profile-layout .profile-hero-inner { max-width: none; }
.profile-layout .profile-body { max-width: none; padding: 32px 0 0; display: block; }
.profile-layout > .side { margin-top: 88px; }
.profile-hero .badge-logo-xl {
  width: 140px; height: 140px; font-size: 40px;
}
.profile-body .side h4, .profile-layout > .side h4 {
  font: 700 14px/1.3 var(--font-display); color: var(--ink-900);
}
.profile-body .side p, .profile-layout > .side p {
  font: 400 13px/1.5 var(--font-body); color: var(--ink-700);
}

.editorial {
  max-width: 720px; margin: 0 auto;
  padding: 24px 24px 64px;
  display: flex; flex-direction: column; gap: 20px;
}
.editorial p { font: 400 18px/1.65 var(--font-body); color: var(--ink-700); }
.editorial h2 { margin-top: 16px; font: 800 32px/1.15 var(--font-display); letter-spacing: -0.015em; color: var(--ink-900); }
.editorial h3 { margin-top: 12px; font: 700 22px/1.25 var(--font-display); color: var(--ink-900); }
.editorial ul, .editorial ol { margin: 16px 0; padding-left: 1.4em; }
.editorial ul { list-style: disc; }
.editorial ol { list-style: decimal; }
.editorial li { font: 400 18px/1.65 var(--font-body); color: var(--ink-700); margin: 6px 0; }
.editorial a { color: var(--pink-700); text-decoration: underline; }
.editorial blockquote {
  margin: 12px 0; padding: 18px 22px;
  border-left: 4px solid var(--sun-500);
  background: var(--snow); border-radius: var(--radius-md);
  font: 500 18px/1.55 var(--font-display); color: var(--ink-900);
  letter-spacing: -0.005em;
}
.editorial blockquote cite {
  display: block; margin-top: 8px;
  font: 400 13px/1.4 var(--font-body); color: var(--ink-500);
  font-style: normal;
}
.pull-quote {
  font: 700 28px/1.25 var(--font-display);
  letter-spacing: -0.01em; color: var(--ink-900);
  margin: 24px 0; max-width: 620px;
  text-wrap: balance;
}
.pull-quote .accent { color: var(--pink-500); }

.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }

/* FAQ accordion */
.faq-search { max-width: 540px; margin: 0 0 24px; }
.faq-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 32px; }
.faq-group .group-head {
  font: 700 12px/1 var(--font-display);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--deep-500); margin-bottom: 8px;
}
.faq-item {
  background: var(--snow);
  border-radius: var(--radius-md);
  border: 1px solid var(--ink-200);
  overflow: hidden;
}
.faq-item summary {
  list-style: none;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  cursor: pointer;
  font: 600 16px/1.4 var(--font-display);
  letter-spacing: -0.005em;
  color: var(--ink-900);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .chev {
  width: 18px; height: 18px;
  color: var(--ink-500);
  transition: transform var(--dur-base) var(--ease);
}
.faq-item[open] summary .chev { transform: rotate(180deg); }
.faq-item .answer {
  padding: 0 22px 20px;
  font: 400 15px/1.6 var(--font-body); color: var(--ink-700);
}

/* Blog */
.blog-filter {
  display: flex; gap: 10px; margin-bottom: 32px; flex-wrap: wrap;
}
.blog-chip {
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--ink-200);
  background: var(--snow);
  font: 600 13px/1 var(--font-body); color: var(--ink-700);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
}
.blog-chip.active, .blog-chip:hover { border-color: var(--deep-500); background: var(--deep-500); color: var(--snow); }

.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.blog-card {
  background: var(--snow); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
  cursor: pointer;
}
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.blog-img { aspect-ratio: 16/10; position: relative; background: var(--sky-100); }
.blog-img.sun { background: var(--sun-100); }
.blog-img.pink { background: var(--pink-50); }
.blog-img.deep { background: var(--deep-100); }
.blog-img::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(600px 400px at 20% 20%, rgba(255,255,255,0.4), transparent 60%),
    radial-gradient(500px 300px at 80% 70%, rgba(17,17,17,0.06), transparent 65%);
}
.blog-body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.blog-eyebrow {
  font: 700 10px/1 var(--font-display); letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--deep-500);
}
.blog-card h3 {
  font: 700 18px/1.3 var(--font-display); letter-spacing: -0.005em;
  color: var(--ink-900); text-wrap: balance;
}
.blog-card p { font: 400 14px/1.5 var(--font-body); color: var(--ink-700); }
.blog-meta {
  display: flex; align-items: center; gap: 10px; margin-top: 8px;
  font: 500 12px/1 var(--font-body); color: var(--ink-500);
}

/* =====================================================================
   INSCRIPTION FLOW
   ===================================================================== */
.flow-shell {
  max-width: 820px; margin: 0 auto;
  padding: 56px 24px 80px;
}
.flow-progress {
  display: flex; gap: 8px; margin-bottom: 32px;
}
.flow-progress .seg {
  flex: 1; height: 4px; border-radius: 2px;
  background: var(--ink-200);
}
.flow-progress .seg.done { background: var(--deep-500); }
.flow-progress .seg.current { background: var(--pink-500); }

.flow-step {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 36px;
  box-shadow: var(--shadow-sm);
  display: none;
  flex-direction: column; gap: 24px;
}
.flow-step.active { display: flex; }
.flow-step .step-head { display: flex; flex-direction: column; gap: 8px; }
.flow-step .step-num {
  font: 700 11px/1 var(--font-display);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--deep-500);
}
.flow-step h2 {
  font: 800 32px/1.1 var(--font-display);
  letter-spacing: -0.015em; color: var(--ink-900);
}
.flow-step .lede {
  font: 400 16px/1.55 var(--font-body); color: var(--ink-700);
}

/* Association-referral lock banner (shown on the company step when the visitor
   arrives from an association's page via ?assoc=). */
.referral-lock {
  margin: 16px 0 4px;
  padding: 14px 16px;
  background: var(--pink-50, #FFE9F5);
  border: 1px solid var(--pink-500, #E6007A);
  border-radius: var(--radius-md, 14px);
  font: 400 14px/1.5 var(--font-body);
  color: var(--ink-800, var(--ink-900));
}
.referral-lock strong { color: var(--pink-700, #C0006A); }
.referral-lock a {
  display: inline-block;
  margin-left: 6px;
  color: var(--deep-500);
  font-weight: 700;
  text-decoration: underline;
}

.choice-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.choice-card {
  background: var(--snow);
  border: 1.5px solid var(--ink-200);
  border-radius: var(--radius-md);
  padding: 22px;
  cursor: pointer;
  display: flex; flex-direction: column; gap: 8px;
  transition: all var(--dur-fast) var(--ease);
}
.choice-card input { position: absolute; opacity: 0; pointer-events: none; }
.choice-card .what {
  font: 700 17px/1.3 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-900);
}
.choice-card .how {
  font: 400 14px/1.5 var(--font-body); color: var(--ink-700);
}
.choice-card:has(input:checked), .choice-card.checked {
  border-color: var(--deep-500); background: var(--sky-50);
  box-shadow: 0 0 0 3px rgba(20, 46, 98, 0.10);
}

.assoc-picker {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.assoc-pill {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  border: 1.5px solid var(--ink-200);
  border-radius: var(--radius-md);
  cursor: pointer;
  font: 500 14px/1.3 var(--font-body); color: var(--ink-900);
  background: var(--snow);
  transition: all var(--dur-fast) var(--ease);
}
.assoc-pill input { appearance: none; width: 14px; height: 14px; border-radius: 3px; border: 1.5px solid var(--ink-300); margin: 0; }
.assoc-pill input:checked { background: var(--deep-500); border-color: var(--deep-500); }
.assoc-pill:has(input:checked) { border-color: var(--deep-500); background: var(--sky-50); }
.assoc-pill .mini-logo {
  width: 28px; height: 28px; border-radius: var(--radius-sm);
  background: var(--sky-100); color: var(--deep-500);
  display: grid; place-items: center;
  font: 800 11px/1 var(--font-display);
}

.repartition { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
.repartition-row {
  display: grid; grid-template-columns: 160px 1fr 56px; gap: 14px;
  align-items: center;
}
.repartition-row .name { font: 600 14px/1.3 var(--font-body); color: var(--ink-900); }
.repartition-row input[type="range"] {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 4px; border-radius: 999px;
  background: var(--ink-200); outline: none;
}
.repartition-row input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--deep-500); cursor: pointer;
  border: 2px solid var(--snow); box-shadow: var(--shadow-sm);
}
.repartition-row .pct {
  font: 700 14px/1 var(--font-display); color: var(--ink-900);
  font-variant-numeric: tabular-nums; text-align: right;
}
.repartition-sum {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 14px;
  background: var(--ink-100);
  border-radius: var(--radius-md);
  font: 600 13px/1 var(--font-body); color: var(--ink-700);
}
.repartition-sum.invalid { background: var(--error-bg); color: var(--error); }
.repartition-sum.valid { background: var(--success-bg); color: var(--success); }

.field-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
.field-grid .full { grid-column: 1 / -1; }

.recap {
  background: var(--paper);
  border-radius: var(--radius-md);
  padding: 20px;
  border: 1.5px solid var(--ink-200);
  display: flex; flex-direction: column; gap: 12px;
}
.recap-row { display: flex; justify-content: space-between; gap: 12px; }
.recap-row .k { font: 500 13px/1.4 var(--font-body); color: var(--ink-500); }
.recap-row .v { font: 600 14px/1.4 var(--font-body); color: var(--ink-900); text-align: right; }
.recap-total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 12px; border-top: 1px solid var(--ink-200);
}
.recap-total .k { font: 700 14px/1 var(--font-display); color: var(--ink-900); text-transform: uppercase; letter-spacing: 0.06em; }
.recap-total .v { font: 800 28px/1 var(--font-display); color: var(--ink-900); font-variant-numeric: tabular-nums; }
.recap-total .v small { font: 500 12px/1 var(--font-body); color: var(--ink-500); }

.flow-actions { display: flex; justify-content: space-between; align-items: center; gap: 12px; }

.flow-success {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
}
.flow-success .check {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--success-bg); color: var(--success);
  display: grid; place-items: center;
}

/* =====================================================================
   DASHBOARD (future-state mockup)
   ===================================================================== */
.dash-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: calc(100vh - 60px);
}
.dash-sidebar {
  background: var(--snow);
  border-right: 1px solid var(--ink-200);
  padding: 24px 16px;
  display: flex; flex-direction: column; gap: 24px;
  /* Pinned between the sticky site nav (60px) and the viewport bottom, so the
     panel never moves with the page scroll. */
  position: sticky; top: 60px; align-self: start; height: calc(100vh - 60px);
}
.dash-sidebar .brand-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 8px 18px;
  border-bottom: 1px solid var(--ink-200);
}
.dash-sidebar .brand-row img { width: 28px; height: 28px; }
.dash-sidebar .brand-row strong { font: 800 14px/1 var(--font-display); color: var(--ink-900); }
.dash-nav { display: flex; flex-direction: column; gap: 4px; }
.dash-nav a {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: var(--radius-sm);
  font: 500 14px/1.2 var(--font-body); color: var(--ink-700);
  transition: all var(--dur-fast) var(--ease);
}
.dash-nav a:hover { background: var(--ink-100); color: var(--ink-900); }
.dash-nav a.active { background: var(--sky-50); color: var(--deep-500); font-weight: 600; }
.dash-nav a.active::before { content: ""; width: 3px; height: 18px; background: var(--deep-500); border-radius: 2px; margin-left: -12px; margin-right: 9px; }

.dash-main { padding: 32px 40px; }
.dash-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.dash-head h1 { font: 800 28px/1.15 var(--font-display); letter-spacing: -0.015em; color: var(--ink-900); }
.dash-head .selector {
  padding: 8px 14px; border-radius: var(--radius-md);
  background: var(--snow); border: 1.5px solid var(--ink-200);
  font: 600 13px/1 var(--font-body); color: var(--ink-900);
  display: inline-flex; align-items: center; gap: 8px;
}
.dash-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 28px; }
.dash-stats .stat-card { padding: 22px; }
.dash-panel {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 28px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 18px;
}
.dash-panel h2 { font: 700 18px/1.3 var(--font-display); margin-bottom: 16px; }
.activity { display: flex; flex-direction: column; gap: 12px; }
.activity-row {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--ink-200); border-radius: var(--radius-md);
}
.activity-row .ico { width: 32px; height: 32px; border-radius: var(--radius-sm); background: var(--sky-50); color: var(--deep-500); display: grid; place-items: center; flex-shrink: 0; }
.activity-row .what { flex: 1; font: 500 14px/1.3 var(--font-body); color: var(--ink-900); }
.activity-row .what small { display: block; font: 400 12px/1.4 var(--font-body); color: var(--ink-500); margin-top: 2px; }
.activity-row .when { font: 500 12px/1 var(--font-body); color: var(--ink-500); }

/* =====================================================================
   DASHBOARD — enterprise / asso shared pieces
   ===================================================================== */
.body-dash .page { padding: 0; max-width: none; }
.body-dash .site-footer { display: none; }
.body-dash .ribbon { display: none; }

.dash-sidebar-footer { margin-top: auto; padding-top: 18px; border-top: 1px solid var(--ink-200); }

.dash-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 999px;
  font: 600 12px/1 var(--font-body);
}
.dash-badge-green   { background: var(--success-bg); color: var(--success); }
.dash-badge-sun     { background: var(--sun-50);     color: var(--sun-900); }
.dash-badge-warning { background: var(--warning-bg); color: var(--warning); }
.dash-badge-info    { background: var(--info-bg);    color: var(--info); }
.dash-badge-error   { background: var(--error-bg);   color: var(--error); }
.dash-badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.dash-info-grid { display: flex; flex-direction: column; gap: 0; }
.dash-info-row {
  display: flex; align-items: baseline; gap: 16px;
  padding: 12px 0; border-bottom: 1px solid var(--ink-200);
}
.dash-info-row:last-child { border-bottom: none; }
.dash-info-label { font: 500 13px/1.3 var(--font-body); color: var(--ink-500); width: 160px; flex-shrink: 0; }
.dash-info-value { font: 500 14px/1.3 var(--font-body); color: var(--ink-900); }

.dash-timeline { display: flex; flex-direction: column; gap: 0; }
.dash-timeline-row {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 14px 0; position: relative;
}
.dash-timeline-row:not(:last-child)::after {
  content: ""; position: absolute; left: 15px; top: 44px; bottom: -14px;
  width: 2px; background: var(--ink-200);
}
.dash-tl-dot {
  width: 32px; height: 32px; flex-shrink: 0;
  border-radius: 50%; background: var(--ink-200); color: var(--ink-500);
  display: grid; place-items: center;
}
.dash-tl-dot svg { width: 14px; height: 14px; }
.dash-timeline-row.done .dash-tl-dot { background: var(--success-bg); color: var(--success); }
.dash-tl-body { display: flex; flex-direction: column; gap: 2px; padding-top: 6px; }
.dash-tl-body strong { font: 600 14px/1.3 var(--font-body); color: var(--ink-900); }
.dash-tl-body span { font: 400 12px/1.4 var(--font-body); color: var(--ink-500); }
.dash-timeline-row.done .dash-tl-body strong { color: var(--success); }

/* Dashboard form elements */
.dash-form-grid { display: flex; flex-direction: column; gap: 20px; }
.dash-form-row { display: flex; flex-direction: column; gap: 6px; }
.dash-form-row label { font: 600 12px/1 var(--font-display); letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-700); }
.dash-char-count { font: 400 11px/1 var(--font-body); color: var(--ink-500); text-transform: none; letter-spacing: 0; }
.dash-upload-zone { border: 2px dashed var(--ink-200); border-radius: var(--radius-md); padding: 20px; cursor: pointer; text-align: center; transition: border-color var(--dur-base) var(--ease), background var(--dur-base) var(--ease); display: flex; align-items: center; justify-content: center; gap: 12px; min-height: 80px; }
.dash-upload-zone:hover { border-color: var(--deep-500); background: var(--sky-50); }
.dash-upload-zone svg { width: 20px; height: 20px; color: var(--ink-500); }
.dash-upload-zone span { font: 400 13px/1.4 var(--font-body); color: var(--ink-500); }
.dash-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px; }
.gallery-item { position: relative; border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--ink-200); }
.gallery-item img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; }
.gallery-alt-input { width: 100%; border: 0; border-top: 1px solid var(--ink-200); padding: 4px 6px; font: 400 11px/1.3 var(--font-body); color: var(--ink-700); }
.gallery-remove { position: absolute; top: 4px; right: 4px; width: 20px; height: 20px; border-radius: 50%; background: rgba(0,0,0,.5); color: #fff; border: 0; cursor: pointer; display: grid; place-items: center; }
.gallery-remove svg { width: 10px; height: 10px; }
.dash-profile-preview { border: 1.5px solid var(--ink-200); border-radius: var(--radius-lg); overflow: hidden; min-height: 80px; }
.dash-save-msg { padding: 10px 16px; border-radius: var(--radius-md); font: 500 13px/1.4 var(--font-body); }
.dash-save-msg-ok  { background: var(--success-bg); color: var(--success); }
.dash-save-msg-err { background: var(--error-bg); color: var(--error); }

.dash-doc-row { display: flex; align-items: center; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--ink-200); }
.dash-doc-row:last-child { border-bottom: none; }
.dash-doc-icon { width: 40px; height: 40px; border-radius: var(--radius-md); background: var(--sky-50); color: var(--deep-500); display: grid; place-items: center; flex-shrink: 0; }
.dash-doc-icon svg { width: 18px; height: 18px; }
.dash-doc-body { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.dash-doc-body strong { font: 600 14px/1.3 var(--font-body); color: var(--ink-900); }

/* Skeleton loading */
.dash-loading-state { padding: 32px 40px; }
.dash-skeleton-head { height: 48px; background: var(--ink-100); border-radius: var(--radius-md); width: 40%; margin-bottom: 28px; animation: dash-pulse 1.4s ease infinite; }
.dash-skeleton-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: 28px; }
.dash-skeleton-block { height: 96px; background: var(--ink-100); border-radius: var(--radius-lg); animation: dash-pulse 1.4s ease infinite; }
.dash-skeleton-panel { height: 180px; background: var(--ink-100); border-radius: var(--radius-lg); margin-bottom: 18px; animation: dash-pulse 1.4s ease infinite; }
@keyframes dash-pulse { 0%,100% { opacity: .6 } 50% { opacity: 1 } }

/* repartition rows already exist on the old dashboard, but need flex */
.repartition { display: flex; flex-direction: column; gap: 16px; }
.repartition-row { display: grid; grid-template-columns: 200px 1fr 48px; align-items: center; gap: 14px; }
.repartition-row .name { font: 500 14px/1.3 var(--font-body); color: var(--ink-900); }
.repartition-row .pct { font: 700 14px/1 var(--font-display); color: var(--ink-700); text-align: right; }

/* =====================================================================
   TAX CALCULATOR
   ===================================================================== */
.calc {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  align-items: center;
}
.calc .field-block { display: flex; flex-direction: column; gap: 12px; }
.calc label { font: 700 12px/1 var(--font-display); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-900); }
.calc input[type="number"] {
  font: 800 36px/1 var(--font-display);
  border: 0; border-bottom: 2px solid var(--ink-200);
  padding: 8px 0;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  width: 100%; outline: none;
  background: transparent;
}
.calc input[type="number"]:focus { border-bottom-color: var(--deep-500); }
/* Result panel mirrors the tarifs "Coût réel" block (brand pink) so the
   "real cost after tax" reads identically on both pages. */
.calc .result {
  background: var(--pink-500, #E6007A);
  color: var(--snow);
  border-radius: var(--radius-md);
  padding: 26px 28px;
}
.calc .result .lbl { font: 700 11px/1 var(--font-display); letter-spacing: 0.08em; text-transform: uppercase; color: var(--snow); opacity: 0.9; }
.calc .result .net {
  font: 800 52px/1 var(--font-display);
  color: var(--snow); letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
  margin: 6px 0 18px;
}
.calc-break { display: flex; flex-direction: column; gap: 8px; margin: 0; }
.calc-break > div { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.calc-break dt { margin: 0; font: 500 13px/1.3 var(--font-body); color: var(--snow); opacity: 0.85; }
.calc-break dd { margin: 0; font: 800 16px/1 var(--font-display); color: var(--snow); font-variant-numeric: tabular-nums; }

/* =====================================================================
   TESTIMONIAL
   ===================================================================== */
.quote-card {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 18px;
}
.quote-card .q {
  font: 500 20px/1.5 var(--font-display);
  letter-spacing: -0.005em; color: var(--ink-900);
  text-wrap: balance;
}
.quote-card .by { display: flex; align-items: center; gap: 12px; }
.quote-card .by .avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--sky-100); color: var(--deep-500);
  display: grid; place-items: center;
  font: 700 16px/1 var(--font-display);
}
.quote-card .by .who strong { font: 700 14px/1.2 var(--font-display); color: var(--ink-900); display: block; }
.quote-card .by .who span { font: 400 12px/1.4 var(--font-body); color: var(--ink-500); }

/* =====================================================================
   MOBILE — 768 and 390
   ===================================================================== */
@media (max-width: 1024px) {
  .nav-links { display: none; }
  .nav-burger { display: inline-flex; }
  .nav-cta .btn { display: none; }
  .nav-brand .wordmark { display: none; }
  .nav-brand img { width: 32px; height: 32px; }
  .hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .ticker-display { font-size: clamp(64px, 18vw, 110px); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .process { grid-template-columns: 1fr; }
  .process::before { display: none; }
  .marquee-row { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr; gap: 40px; }
  .profile-body { grid-template-columns: 1fr; }
  .profile-body .side { position: static; }
  .profile-layout { grid-template-columns: 1fr; }
  .profile-layout > .side { position: static; margin-top: 0; }
  .produit-showcase { flex-direction: column; }
  .produit-showcase-img { width: 100%; height: 180px; }
  .calc { grid-template-columns: 1fr; }
  .dash-shell { grid-template-columns: minmax(0, 1fr); }
  .dash-sidebar { position: static; height: auto; min-width: 0; border-right: 0; border-bottom: 1px solid var(--ink-200); gap: 14px; }
  .dash-main { min-width: 0; overflow-x: hidden; }
  /* Dashboard nav: a horizontal scroll strip rather than a tall 8-item list
     that pushes the actual content down a full screen on every mobile visit. */
  .dash-nav { flex-direction: row; flex-wrap: nowrap; overflow-x: auto; gap: 6px; padding-bottom: 4px; -webkit-overflow-scrolling: touch; }
  .dash-nav a { white-space: nowrap; flex: 0 0 auto; }
  .dash-nav a.active::before { display: none; }
  .two-col { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .section { padding: var(--section-y-mobile) 18px; }
  .nav-inner { padding: 12px 18px; gap: 12px; }
  .hero { padding: 40px 18px 56px; }
  .ticker-hero { padding: 56px 18px 64px; }
  .hero-counter { min-height: auto; padding: 32px 18px 48px; gap: 18px; }
  .counter { font-size: clamp(56px, 16vw, 88px) !important; max-width: 100%; }
  .hero-help { font-size: 18px; }
  /* Stack CTAs centered: only the primary goes full-width; ghost buttons
     stay auto-width so their animated underline sits under the text, not
     stretched across the screen. */
  .hero-counter .hero-cta-row { flex-direction: column; align-items: center; gap: 14px; }
  .hero-counter .hero-cta-row .btn-primary { width: 100%; justify-content: center; }
  .hero-counter .hero-cta-row .btn-ghost { width: auto; }
  /* Stat-card values are sometimes words ("Vient de rejoindre", "Vérifiée"),
     not numbers — keep them readable, not giant, on small screens. */
  .stat-card { padding: 20px; }
  .stat-card .num { font-size: 30px; line-height: 1.05; text-wrap: balance; }
  .profile-body { padding: 24px 18px 56px; }
  .mission-grid { grid-template-columns: 1fr; gap: 28px; }
  .model-card { padding: 22px; }
  .model-card .formula { flex-direction: column; padding: 16px; }
  .model-card .cell .amt { font-size: 30px; }
  .model-card .plus { width: auto; padding: 6px 0; }
  .modes { grid-template-columns: 1fr; }
  .marquee-row { grid-template-columns: 1fr; gap: 14px; }
  /* On phones the cards were nearly full-width (one clipped card at a time).
     Cap their width, ellipsize long names, and soften the edge-fade so more
     fit and none look cut off. */
  .marquee { mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%); -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%); }
  .marquee-item { padding: 10px 14px; gap: 10px; }
  .marquee-item .logo, .marquee-item.person .avatar { width: 34px; height: 34px; font-size: 12px; }
  .marquee-item .name { max-width: 150px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .marquee-item .sub { max-width: 150px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .ribbon { padding: 12px 44px; }
  .ribbon .ribbon-close { right: 8px; }
  .hero-text h1 { font-size: 38px; }
  .section-head h1 { font-size: 36px; }
  .section-head h2 { font-size: 30px; }
  .ticker-line { font-size: 18px; }
  .blog-grid { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }
  .field-grid { grid-template-columns: 1fr; }
  .choice-row { grid-template-columns: 1fr; }
  .assoc-picker { grid-template-columns: 1fr; }
  .repartition-row { grid-template-columns: 100px 1fr 48px; }
  .flow-step { padding: 24px; }
  .footer-form .row { grid-template-columns: 1fr; }
  .ribbon { font-size: 13px; padding: 12px 40px; text-align: center; }
  .profile-hero-inner { flex-direction: column; gap: 18px; }
  .dash-main { padding: 24px 18px; }
  .dash-stats { grid-template-columns: 1fr; }
  .cta-banner h2 { font-size: 30px; }
  .rail-cta { display: none; }
  /* Touch targets: the desktop buttons are deliberately compact (22–30px tall);
     bump them to a tappable size (~44px) on phones, where they're used across
     the dashboard and profile pages. */
  .btn.btn-sm { min-height: 40px; padding: 8px 14px; font-size: 12px; }
  .btn.btn-md { min-height: 44px; padding: 10px 16px; font-size: 13px; }
  .btn.btn-lg { min-height: 48px; padding: 12px 18px; font-size: 14px; }
}

/* Reduced-motion: calm the incidental animations (nav slide, counter tick,
   the one-time hero drop). The partner marquees are a core brand feature
   (the "three sliding rows"), so they keep their gentle continuous scroll. */
@media (prefers-reduced-motion: reduce) {
  .site-nav { transition: none; }
  .ticker-display .d { transition: none; }
  .counter.dropped { animation: none; }
}

/* Honeypot field — invisible to humans, irresistible to bots. */
.hp-field { position:absolute !important; left:-10000px !important; top:auto !important; width:1px !important; height:1px !important; overflow:hidden !important; }

/* RGPD info notice under forms. */
.form-notice { color: var(--c-ink-2, #475569); background: rgba(15,23,42,0.03); border-radius: 12px; padding: 10px 14px; line-height: 1.5; }
.form-notice a { color: inherit; text-decoration: underline; }

/* =====================================================================
   GRILLE TARIFAIRE — pricing tier cards (page /tarifs.html)
   ===================================================================== */
.ink-success { color: var(--success); font-style: normal; }
.ink-error   { color: var(--error); }
.ink-accent  { color: var(--pink-700, var(--pink-500, #E6007A)); font-style: normal; }

.tarifs-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 20px;
  margin-top: 24px;
}
.tarif-card {
  background: var(--snow);
  border: 1px solid var(--ink-100, rgba(15,23,42,0.08));
  border-radius: var(--radius-lg, 18px);
  padding: 60px 20px 22px;
  display: flex; flex-direction: column;
  position: relative;
  box-shadow: var(--shadow-sm);
}
/* Rainbow by size — pink → gold → green → blue → navy */
.tarif-card.t-pink .tarif-badge { border-color: var(--pink-500); color: var(--pink-700); }
.tarif-card.t-pink .tarif-real  { background: var(--pink-500); }
.tarif-card.t-sun  .tarif-badge { border-color: var(--sun-700);  color: var(--sun-700); }
.tarif-card.t-sun  .tarif-real  { background: var(--sun-700); }
.tarif-card.t-mint .tarif-badge { border-color: var(--success);  color: var(--success); }
.tarif-card.t-mint .tarif-real  { background: var(--success); }
.tarif-card.t-sky  .tarif-badge { border-color: var(--sky-700);  color: var(--sky-700); }
.tarif-card.t-sky  .tarif-real  { background: var(--sky-700); }
.tarif-card.t-deep .tarif-badge { border-color: var(--deep-500); color: var(--deep-500); }
.tarif-card.t-deep .tarif-real  { background: var(--deep-500); }
.tarif-badge {
  position: absolute;
  top: 16px; left: 50%; transform: translateX(-50%);
  background: var(--snow);
  border: 2px solid var(--pink-700, var(--pink-500, #E6007A));
  color: var(--pink-700, #E6007A);
  font: 700 11px/1.2 var(--font-display);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 8px 14px;
  border-radius: 999px;
  white-space: nowrap;
  text-align: center;
  min-width: 80%;
}
/* Grid with a FIXED value column so figures line up both vertically (within a
   card) and horizontally (across all 5 equal-width cards, and between the two
   row-blocks of a card). A fixed track = identical layout everywhere; labels
   wrap if needed but do so identically since they're the same in every card.
   display:contents lets each dt/dd join the grid. */
.tarif-rows { display: grid; grid-template-columns: minmax(0, 1fr) 4.75rem; column-gap: 8px; row-gap: 12px; margin: 0; align-items: baseline; }
.tarif-rows > div { display: contents; }
.tarif-rows dt {
  font: 500 12px/1.3 var(--font-body);
  color: var(--ink-700);
  margin: 0;
}
.tarif-rows dt sup { font-size: 9px; vertical-align: super; }
.tarif-rows dd {
  margin: 0;
  justify-self: end;
  text-align: right;
  font: 800 16px/1 var(--font-display);
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.tarif-sep { border: 0; border-top: 1px solid var(--ink-100, rgba(15,23,42,0.1)); margin: 14px 0; }
.tarif-real {
  margin-top: auto;
  margin-top: 18px;
  background: var(--pink-500, #E6007A);
  color: var(--snow);
  border-radius: var(--radius-md, 14px);
  padding: 14px 16px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center;
}
.tarif-real span {
  font: 700 11px/1 var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.9;
}
.tarif-real strong {
  font: 800 24px/1 var(--font-display);
  letter-spacing: -0.02em;
}
@media (max-width: 1024px) {
  .tarifs-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .tarifs-grid { grid-template-columns: 1fr; }
}

/* Tarifs — SIRET calculator */
.calc {
  background: var(--snow);
  border-radius: var(--radius-lg);
  padding: 32px;
  box-shadow: var(--shadow-sm);
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  align-items: center;
}
.calc .field-block { display: flex; flex-direction: column; gap: 12px; }
.calc label { font: 700 12px/1 var(--font-display); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-900); }
.calc input[type="number"],
.calc input[type="text"] {
  font: 800 32px/1 var(--font-display);
  border: 0; border-bottom: 2px solid var(--ink-200);
  padding: 8px 0;
  color: var(--ink-900);
  font-variant-numeric: tabular-nums;
  width: 100%; outline: none;
  background: transparent;
}
.calc input:focus { border-bottom-color: var(--deep-500); }
.calc .result {
  background: var(--sun-50);
  border: 1px solid var(--sun-100);
  border-radius: var(--radius-md);
  padding: 24px 26px;
}
.calc .result .lbl { font: 700 11px/1 var(--font-display); letter-spacing: 0.08em; text-transform: uppercase; color: var(--sun-900); }
.calc .result .net {
  font: 800 44px/1 var(--font-display);
  color: var(--ink-900); letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
  margin: 6px 0 14px;
}
.calc-break { display: flex; flex-direction: column; gap: 8px; margin: 0 0 4px; }
.calc-break > div { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.calc-break dt { margin: 0; font: 500 13px/1.3 var(--font-body); color: var(--ink-700); }
.calc-break dd { margin: 0; font: 800 16px/1 var(--font-display); color: var(--ink-900); font-variant-numeric: tabular-nums; text-align: right; }
@media (max-width: 720px) { .calc { grid-template-columns: 1fr; gap: 24px; } }

/* =====================================================================
   MISSION CARD — refreshed (single mode, variable inscription pricing)
   ===================================================================== */
.engagement-card {
  background: var(--snow);
  border-radius: var(--radius-lg, 18px);
  padding: 28px;
  box-shadow: var(--shadow-md, var(--shadow-sm));
  display: flex; flex-direction: column; gap: 20px;
}
.engagement-headline {
  display: flex; flex-direction: column; gap: 6px;
}
.engagement-headline .lbl {
  font: 700 10px/1.3 var(--font-body);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-500);
}
.engagement-headline .amt {
  font: 800 48px/1 var(--font-display);
  letter-spacing: -0.025em;
  color: var(--ink-900);
}
.engagement-headline .sub { font: 400 14px/1.5 var(--font-body); color: var(--ink-700); }
.engagement-divider { height: 1px; background: var(--ink-100, rgba(15,23,42,0.08)); }
.engagement-inscription {
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
}
.engagement-inscription .lbl {
  font: 700 11px/1.3 var(--font-body);
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--ink-500);
}
.engagement-inscription .val {
  font: 700 16px/1.2 var(--font-display);
  color: var(--ink-900);
  text-align: right;
}
.engagement-inscription .val small {
  display: block;
  font: 400 12px/1.4 var(--font-body);
  color: var(--ink-700);
  margin-top: 2px;
}
.engagement-includes { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; }
.engagement-includes li {
  display: flex; align-items: center; gap: 8px;
  font: 500 13px/1.35 var(--font-body);
  color: var(--ink-700);
  list-style: none;
}
.engagement-includes li::before {
  content: "";
  width: 14px; height: 14px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--success-bg);
  background-image: linear-gradient(135deg, var(--success-bg), var(--success-bg));
  position: relative;
  display: inline-block;
}
.engagement-includes li svg { width: 14px; height: 14px; color: var(--success); flex-shrink: 0; }
.engagement-tarif-link {
  display: inline-flex; align-items: center; gap: 6px;
  font: 700 13px/1.2 var(--font-display);
  color: var(--pink-700, #E6007A);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  align-self: flex-start;
}
.engagement-tarif-link:hover { color: var(--pink-900, var(--pink-500)); }
@media (max-width: 720px) {
  .engagement-includes { grid-template-columns: 1fr; }
  .engagement-headline .amt { font-size: 40px; }
}

