/* ============================================================
   ClickToClub — Landing 2026
   Tokens + base + composants. Vanilla CSS, aucune dépendance.
   ============================================================ */

/* ---------- 1. Design tokens ---------- */
:root {
  /* Couleurs de marque (bleu marine du logo) */
  --c2c-primary: #0F2A57;
  --c2c-primary-600: #0B2147;
  --c2c-primary-700: #1976D2;   /* Material Blue 700 — pour les accents text (eyebrows, kickers) */
  --c2c-primary-50: #EDF0F7;
  --c2c-primary-100: #CFD6E6;

  /* Accent bleu vif du logo (barre colorée — 4ème segment Material Blue) */
  --c2c-blue-accent: #2196F3;
  --c2c-blue-accent-light: #64B5F6;

  --c2c-accent: #ff8c42;
  --c2c-accent-600: #e57233;

  --c2c-success: #10b981;
  --c2c-warning: #f59e0b;
  --c2c-danger: #ef4444;

  /* Neutres — teintés navy pour aucun "vrai noir" dans les textes */
  --c2c-ink: #0F2A57;       /* Navy du logo — pour tous les headings */
  --c2c-ink-2: #273F6C;     /* Navy slate — pour le corps de texte */
  --c2c-muted: #475569;
  --c2c-muted-2: #64748b;
  --c2c-line: #e2e8f0;
  --c2c-line-2: #f1f5f9;
  --c2c-bg: #ffffff;
  --c2c-bg-soft: #f8fafc;
  --c2c-bg-tint: #EEF1F8;

  /* Dégradés */
  --c2c-gradient-hero: radial-gradient(1200px 600px at 85% -10%, rgba(15, 42, 87, 0.14), transparent 60%),
    radial-gradient(800px 400px at 10% 20%, rgba(255, 140, 66, 0.12), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f4f6fb 100%);
  --c2c-gradient-brand: linear-gradient(135deg, #0F2A57 0%, #1E3A6F 100%);
  --c2c-gradient-accent: linear-gradient(135deg, #ff8c42 0%, #ff6b35 100%);
  --c2c-gradient-cta: linear-gradient(135deg, #0F2A57 0%, #1A3A6F 60%, #2A4B80 120%);

  /* Gradient pour emphase texte (sur fond clair — titre hero) */
  --c2c-gradient-text: linear-gradient(135deg, #2196F3 0%, #0F2A57 100%);
  /* Gradient pour chiffres sur fond sombre (stats band) */
  --c2c-gradient-text-bright: linear-gradient(135deg, #64B5F6 0%, #2196F3 100%);

  /* Typo */
  --c2c-font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --c2c-font-display: "Manrope", var(--c2c-font-sans);

  /* Espacements (échelle 4px) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;
  --s-10: 128px;

  /* Rayons */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* Ombres */
  --sh-xs: 0 1px 2px rgba(11, 18, 32, 0.06);
  --sh-sm: 0 2px 8px rgba(11, 18, 32, 0.06), 0 1px 2px rgba(11, 18, 32, 0.04);
  --sh-md: 0 8px 24px rgba(11, 18, 32, 0.08), 0 2px 4px rgba(11, 18, 32, 0.04);
  --sh-lg: 0 20px 50px rgba(11, 18, 32, 0.12), 0 4px 12px rgba(11, 18, 32, 0.05);
  --sh-brand: 0 12px 30px rgba(15, 42, 87, 0.3);
  --sh-accent: 0 12px 30px rgba(255, 140, 66, 0.3);

  /* Layout */
  --container: 1200px;
  --container-narrow: 880px;

  /* Transitions */
  --t-fast: 150ms cubic-bezier(0.2, 0, 0.2, 1);
  --t-base: 250ms cubic-bezier(0.2, 0, 0.2, 1);
  --t-slow: 400ms cubic-bezier(0.2, 0, 0.2, 1);
}

/* ---------- 2. Reset + base ---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
  -webkit-text-size-adjust: 100%;
}

body.c2c-2026 {
  margin: 0;
  font-family: var(--c2c-font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--c2c-ink-2);
  background: var(--c2c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body.c2c-2026 img,
body.c2c-2026 svg {
  max-width: 100%;
  height: auto;
  display: block;
}

body.c2c-2026 a {
  color: var(--c2c-primary-700);
  text-decoration: none;
  transition: color var(--t-fast);
}

body.c2c-2026 a:hover {
  color: var(--c2c-primary);
}

body.c2c-2026 h1,
body.c2c-2026 h2,
body.c2c-2026 h3,
body.c2c-2026 h4 {
  font-family: var(--c2c-font-display);
  color: var(--c2c-ink);
  line-height: 1.2;
  margin: 0 0 var(--s-4) 0;
  font-weight: 800;
  letter-spacing: -0.01em;
}

body.c2c-2026 h1 { font-size: clamp(2rem, 4.5vw + 0.5rem, 3.75rem); letter-spacing: -0.02em; }
body.c2c-2026 h2 { font-size: clamp(1.75rem, 2.5vw + 0.5rem, 2.5rem); }
body.c2c-2026 h3 { font-size: clamp(1.25rem, 1vw + 0.75rem, 1.5rem); }
body.c2c-2026 h4 { font-size: 1.125rem; font-weight: 700; }

body.c2c-2026 p {
  margin: 0 0 var(--s-4) 0;
}

body.c2c-2026 ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

body.c2c-2026 button {
  font-family: inherit;
  cursor: pointer;
}

body.c2c-2026 :focus-visible {
  outline: 3px solid var(--c2c-primary);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}

/* ---------- 3. Layout utilitaires ---------- */
.c2c-container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--s-5);
}

.c2c-container--narrow {
  max-width: var(--container-narrow);
}

.c2c-section {
  padding: clamp(var(--s-8), 8vw, var(--s-10)) 0;
  position: relative;
}

.c2c-section--tint {
  background: var(--c2c-bg-soft);
}

.c2c-section--brand {
  background: var(--c2c-gradient-cta);
  color: #e2e8f0;
}

.c2c-section--brand h2,
.c2c-section--brand h3 {
  color: #ffffff;
}

.c2c-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 6px 14px;
  background: var(--c2c-primary-50);
  color: var(--c2c-primary-700);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  margin-bottom: var(--s-4);
}

.c2c-section-header {
  max-width: 720px;
  margin: 0 auto var(--s-7);
  text-align: center;
}

.c2c-section-header--left {
  margin-left: 0;
  text-align: left;
}

.c2c-section-lead {
  font-size: 1.125rem;
  color: var(--c2c-muted);
  margin: 0;
}

/* ---------- 4. Boutons ---------- */
.c2c-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 14px 26px;
  border-radius: var(--r-pill);
  font-family: inherit;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1;
  border: 1.5px solid transparent;
  transition: transform var(--t-fast), box-shadow var(--t-base), background var(--t-base), color var(--t-base);
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
}

.c2c-btn:hover {
  transform: translateY(-1px);
}

.c2c-btn--primary {
  background: var(--c2c-gradient-accent);
  color: #ffffff;
  box-shadow: var(--sh-accent);
}

.c2c-btn--primary:hover {
  color: #ffffff;
  box-shadow: 0 16px 40px rgba(255, 140, 66, 0.4);
}

.c2c-btn--brand {
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  box-shadow: var(--sh-brand);
}

.c2c-btn--brand:hover {
  color: #ffffff;
  box-shadow: 0 16px 40px rgba(15, 42, 87, 0.4);
}

.c2c-btn--ghost {
  background: transparent;
  color: var(--c2c-ink);
  border-color: var(--c2c-line);
}

.c2c-btn--ghost:hover {
  background: var(--c2c-bg-soft);
  border-color: var(--c2c-primary);
  color: var(--c2c-primary-700);
}

.c2c-btn--light {
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(6px);
}

.c2c-btn--light:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #ffffff;
}

.c2c-btn--sm {
  padding: 10px 18px;
  font-size: 0.875rem;
}

.c2c-btn--lg {
  padding: 17px 32px;
  font-size: 1rem;
}

/* ---------- 5. Navigation ---------- */
.c2c-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: var(--s-3) 0;
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: background var(--t-base), box-shadow var(--t-base), padding var(--t-base);
}

.c2c-nav.is-scrolled {
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--sh-sm);
  padding: var(--s-2) 0;
}

.c2c-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
}

.c2c-nav__brand {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--c2c-font-display);
  font-weight: 800;
  font-size: 1.25rem;
  color: var(--c2c-ink);
  text-decoration: none;
}

.c2c-nav__brand:hover {
  color: var(--c2c-primary-700);
}

.c2c-nav__brand img {
  width: 38px;
  height: 38px;
  border-radius: var(--r-sm);
}

.c2c-nav__links {
  display: flex;
  align-items: center;
  gap: var(--s-5);
}

.c2c-nav__links a {
  color: var(--c2c-ink-2);
  font-size: 0.9375rem;
  font-weight: 500;
  padding: 8px 4px;
  position: relative;
  transition: color var(--t-fast);
}

.c2c-nav__links a::after {
  content: "";
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: 2px;
  height: 2px;
  background: var(--c2c-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t-base);
}

.c2c-nav__links a:hover,
.c2c-nav__links a.is-active {
  color: var(--c2c-primary-700);
}

.c2c-nav__links a:hover::after,
.c2c-nav__links a.is-active::after {
  transform: scaleX(1);
}

.c2c-nav__cta {
  display: flex;
  align-items: center;
  gap: var(--s-3);
}

.c2c-nav__toggle {
  display: none;
  background: transparent;
  border: none;
  width: 40px;
  height: 40px;
  padding: 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
}

.c2c-nav__mobile {
  display: none;
}

.c2c-nav__toggle span {
  width: 22px;
  height: 2px;
  background: var(--c2c-ink);
  border-radius: 2px;
  transition: transform var(--t-base), opacity var(--t-fast);
}

.c2c-nav__toggle.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.c2c-nav__toggle.is-open span:nth-child(2) {
  opacity: 0;
}

.c2c-nav__toggle.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ---------- 6. Hero ---------- */
.c2c-hero {
  position: relative;
  padding: clamp(88px, 8vw, 108px) 0 clamp(var(--s-7), 7vw, var(--s-9));
  background: var(--c2c-gradient-hero);
  overflow: hidden;
}

.c2c-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(15, 42, 87, 0.09) 1px, transparent 0);
  background-size: 32px 32px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.5), transparent 70%);
  -webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.5), transparent 70%);
  pointer-events: none;
}

.c2c-hero__inner {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  align-items: start;
  gap: clamp(var(--s-6), 5vw, var(--s-8));
  position: relative;
  z-index: 1;
}

.c2c-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 6px 14px 6px 6px;
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-pill);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--c2c-muted);
  margin-bottom: var(--s-5);
  box-shadow: var(--sh-xs);
}

.c2c-hero__badge strong {
  background: var(--c2c-primary-50);
  color: var(--c2c-primary-700);
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-weight: 700;
  font-size: 0.75rem;
}

.c2c-hero__title {
  margin: 0 0 var(--s-5) 0;
}

.c2c-hero__title em {
  font-style: normal;
  background: var(--c2c-gradient-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.c2c-hero__lead {
  font-size: clamp(1rem, 0.5vw + 0.9rem, 1.1875rem);
  color: var(--c2c-muted);
  margin: 0 0 var(--s-6) 0;
  max-width: 540px;
}

.c2c-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
}

.c2c-hero__proof {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--s-2) var(--s-5);
  color: var(--c2c-muted-2);
  font-size: 0.875rem;
}

.c2c-hero__proof span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.c2c-hero__proof svg {
  width: 16px;
  height: 16px;
  color: var(--c2c-success);
  flex-shrink: 0;
}

.c2c-hero__visual {
  position: relative;
}

.c2c-hero__visual::before {
  content: "";
  position: absolute;
  inset: -40px;
  background: radial-gradient(circle at 50% 50%, rgba(15, 42, 87, 0.18), transparent 65%);
  z-index: -1;
}

/* ---------- 6b. LicenceFacile demo (hero animation — cycle 10s) ---------- */
.lf-demo {
  position: relative;
  display: grid;
  grid-template-rows: auto 70px auto;
  gap: var(--s-3);
  max-width: 460px;
  margin: 0 auto;
  font-size: 0.875rem;
  color: var(--c2c-ink-2);
}

.lf-demo--wide {
  max-width: 520px;
}

.lf-card {
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-md);
  box-shadow: var(--sh-md);
  overflow: hidden;
}

.lf-card--ctc { border-top: 3px solid var(--c2c-primary); }
.lf-card--fede { border-top: 3px solid var(--c2c-blue-accent); }

.lf-card__head {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  padding: 10px 14px;
  background: var(--c2c-bg-soft);
  border-bottom: 1px solid var(--c2c-line);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--c2c-muted);
}

.lf-card__head > span {
  flex-grow: 1;
  min-width: 0;
}

.lf-card__head em {
  font-style: normal;
  color: var(--c2c-ink);
}

.lf-card__head img {
  width: 20px;
  height: 20px;
  border-radius: 4px;
  flex-shrink: 0;
}

.lf-card__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--c2c-success);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.2);
  flex-shrink: 0;
}

.lf-card__dot--red {
  background: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.2);
}

.lf-card__body { padding: 14px; }

.lf-fede-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 3px 8px;
  font-size: 0.75rem;
  font-weight: 800;
  color: #ffffff;
  background: var(--c2c-blue-accent);
  border-radius: 6px;
  letter-spacing: 0.06em;
  flex-shrink: 0;
}

/* -- Profile CTC -- */
.lf-profile {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px dashed var(--c2c-line);
  margin-bottom: 12px;
}

.lf-profile__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--c2c-gradient-text);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.9375rem;
  flex-shrink: 0;
}

.lf-profile__meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.lf-profile__meta strong { color: var(--c2c-ink); font-weight: 700; }
.lf-profile__meta small { color: var(--c2c-muted); font-size: 0.75rem; }

/* -- Status row + Licence row CTC -- */
.lf-status-row,
.lf-licence-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--c2c-line-2);
}

.lf-licence-row { border-bottom: none; }

.lf-row__label {
  font-size: 0.6875rem;
  color: var(--c2c-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  flex-shrink: 0;
}

.lf-status {
  position: relative;
  min-width: 180px;
  min-height: 26px;
}

.lf-status__step {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  white-space: nowrap;
}

.lf-status__chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.lf-status__chip--neutral {
  background: var(--c2c-bg-soft);
  color: var(--c2c-muted);
  border: 1px solid var(--c2c-line);
}

.lf-status__chip--blue {
  background: var(--c2c-primary-50);
  color: var(--c2c-blue-accent);
  border: 1px solid var(--c2c-primary-100);
}

.lf-status__chip--green {
  background: rgba(16, 185, 129, 0.12);
  color: var(--c2c-success);
  border: 1px solid rgba(16, 185, 129, 0.35);
}

.lf-status__chip svg {
  width: 12px;
  height: 12px;
}

.lf-status__step--1 { animation: lfStep1 10s infinite; }
.lf-status__step--2 { animation: lfStep2 10s infinite; }
.lf-status__step--3 { animation: lfStep3 10s infinite; }

@keyframes lfStep1 {
  0%, 16% { opacity: 1; transform: translateY(-50%); }
  20%, 90% { opacity: 0; transform: translateY(calc(-50% - 4px)); }
  94%, 100% { opacity: 1; transform: translateY(-50%); }
}

@keyframes lfStep2 {
  0%, 16% { opacity: 0; transform: translateY(calc(-50% + 4px)); }
  22%, 56% { opacity: 1; transform: translateY(-50%); }
  60%, 100% { opacity: 0; transform: translateY(calc(-50% - 4px)); }
}

@keyframes lfStep3 {
  0%, 56% { opacity: 0; transform: translateY(calc(-50% + 4px)); }
  62% { opacity: 1; transform: translateY(-50%) scale(1.08); }
  66%, 90% { opacity: 1; transform: translateY(-50%) scale(1); }
  94%, 100% { opacity: 0; transform: translateY(calc(-50% - 4px)); }
}

.lf-licence-row__value {
  position: relative;
  min-width: 160px;
  min-height: 22px;
  font-family: var(--c2c-font-display);
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}

.lf-licence__pending,
.lf-licence__done {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.lf-licence__pending {
  color: var(--c2c-muted-2);
  font-weight: 500;
  animation: lfPending 10s infinite;
}

.lf-licence__done {
  color: var(--c2c-success);
  opacity: 0;
  animation: lfDone 10s infinite;
}

.lf-licence__check {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) scale(0);
  width: 16px;
  height: 16px;
  color: var(--c2c-success);
  opacity: 0;
  animation: lfCheck 10s infinite;
}

@keyframes lfPending {
  0%, 62% { opacity: 1; }
  65%, 92% { opacity: 0; }
  96%, 100% { opacity: 1; }
}

@keyframes lfDone {
  0%, 65% { opacity: 0; transform: translateY(-50%) translateX(-6px); }
  70%, 90% { opacity: 1; transform: translateY(-50%) translateX(0); }
  92%, 100% { opacity: 0; }
}

@keyframes lfCheck {
  0%, 66% { opacity: 0; transform: translateY(-50%) scale(0); }
  72% { opacity: 1; transform: translateY(-50%) scale(1.3); }
  76%, 90% { transform: translateY(-50%) scale(1); }
  92%, 100% { opacity: 0; transform: translateY(-50%) scale(0); }
}

/* -- Flow area (particules + rail + labels) -- */
.lf-flow {
  position: relative;
  color: var(--c2c-primary-100);
}

.lf-flow__rail {
  position: absolute;
  left: 50%;
  top: 0;
  width: 6px;
  height: 100%;
  transform: translateX(-50%);
  opacity: 0.6;
}

.lf-particle {
  position: absolute;
  left: 50%;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  transform: translateX(-50%);
  opacity: 0;
}

.lf-particle--down {
  background: var(--c2c-blue-accent);
  box-shadow: 0 0 12px var(--c2c-blue-accent), 0 0 4px var(--c2c-blue-accent);
  animation: lfDown 10s infinite;
  animation-delay: calc(var(--i) * 0.15s);
}

.lf-particle--up {
  background: var(--c2c-success);
  box-shadow: 0 0 12px var(--c2c-success), 0 0 4px var(--c2c-success);
  animation: lfUp 10s infinite;
  animation-delay: calc(var(--i) * 0.15s);
}

@keyframes lfDown {
  0%, 20% { opacity: 0; top: -4px; }
  22% { opacity: 1; top: -4px; }
  33% { opacity: 1; top: calc(100% - 6px); }
  34%, 100% { opacity: 0; top: calc(100% - 6px); }
}

@keyframes lfUp {
  0%, 55% { opacity: 0; top: calc(100% - 6px); }
  57% { opacity: 1; top: calc(100% - 6px); }
  66% { opacity: 1; top: -4px; }
  67%, 100% { opacity: 0; top: -4px; }
}

.lf-flow__label {
  position: absolute;
  left: calc(50% + 18px);
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
  opacity: 0;
}

.lf-flow__label--down { color: var(--c2c-blue-accent); animation: lfLabelDown 10s infinite; }
.lf-flow__label--up { color: var(--c2c-success); animation: lfLabelUp 10s infinite; }

@keyframes lfLabelDown {
  0%, 20% { opacity: 0; transform: translateY(-50%) translateX(-4px); }
  24%, 42% { opacity: 1; transform: translateY(-50%) translateX(0); }
  45%, 100% { opacity: 0; }
}

@keyframes lfLabelUp {
  0%, 54% { opacity: 0; transform: translateY(-50%) translateX(-4px); }
  58%, 72% { opacity: 1; transform: translateY(-50%) translateX(0); }
  75%, 100% { opacity: 0; }
}

/* -- Inputs fédération -- */
.lf-input {
  display: grid;
  grid-template-columns: 90px 1fr;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border: 1px solid var(--c2c-line);
  border-radius: 6px;
  margin-bottom: 6px;
  background: #ffffff;
  animation: lfInputBg 10s infinite;
}

.lf-input label {
  font-size: 0.6875rem;
  color: var(--c2c-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.lf-input__val {
  font-family: var(--c2c-font-display);
  font-weight: 700;
  color: var(--c2c-ink);
  opacity: 0;
  font-size: 0.8125rem;
}

.lf-input--1 .lf-input__val { animation: lfFill1 10s infinite; }
.lf-input--2 .lf-input__val { animation: lfFill2 10s infinite; }
.lf-input--3 .lf-input__val { animation: lfFill3 10s infinite; }

@keyframes lfFill1 {
  0%, 26% { opacity: 0; transform: translateX(-4px); }
  30%, 88% { opacity: 1; transform: translateX(0); }
  92%, 100% { opacity: 0; transform: translateX(-4px); }
}
@keyframes lfFill2 {
  0%, 30% { opacity: 0; transform: translateX(-4px); }
  34%, 88% { opacity: 1; transform: translateX(0); }
  92%, 100% { opacity: 0; transform: translateX(-4px); }
}
@keyframes lfFill3 {
  0%, 34% { opacity: 0; transform: translateX(-4px); }
  38%, 88% { opacity: 1; transform: translateX(0); }
  92%, 100% { opacity: 0; transform: translateX(-4px); }
}

@keyframes lfInputBg {
  0%, 26% { background: #ffffff; border-color: var(--c2c-line); }
  30%, 46% { background: var(--c2c-primary-50); border-color: var(--c2c-primary-100); }
  50%, 88% { background: rgba(16, 185, 129, 0.08); border-color: var(--c2c-success); }
  92%, 100% { background: #ffffff; border-color: var(--c2c-line); }
}

/* -- Submit + success -- */
.lf-submit {
  position: relative;
  margin-top: 10px;
  height: 38px;
}

.lf-submit__btn,
.lf-submit__ok {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  font-weight: 700;
  font-size: 0.875rem;
}

.lf-submit__btn {
  background: var(--c2c-blue-accent);
  color: #ffffff;
  animation: lfBtn 10s infinite;
}

.lf-submit__ok {
  background: var(--c2c-success);
  color: #ffffff;
  gap: 6px;
  opacity: 0;
  animation: lfOk 10s infinite;
}

.lf-submit__ok svg { width: 16px; height: 16px; }

@keyframes lfBtn {
  0%, 44% { opacity: 1; transform: scale(1); background: var(--c2c-blue-accent); }
  46% { transform: scale(0.96); background: var(--c2c-blue-accent-light); }
  48%, 92% { opacity: 0; }
  96%, 100% { opacity: 1; transform: scale(1); background: var(--c2c-blue-accent); }
}

@keyframes lfOk {
  0%, 46% { opacity: 0; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.05); }
  55%, 88% { transform: scale(1); opacity: 1; }
  92%, 100% { opacity: 0; }
}

/* -- Badges fédération groupés + titre (statique) -- */
.lf-fede-badges {
  display: inline-flex;
  gap: 4px;
  flex-shrink: 0;
}

.lf-fede-badge--alt {
  background: var(--c2c-primary);
}

.lf-fede-title {
  font-weight: 700;
  color: var(--c2c-ink);
  flex-grow: 1;
  min-width: 0;
}

/* Reduced motion → état final figé */
@media (prefers-reduced-motion: reduce) {
  .lf-demo *,
  .lf-demo *::before,
  .lf-demo *::after {
    animation: none !important;
  }
  .lf-licence__pending,
  .lf-status__step--1,
  .lf-status__step--2 { display: none; }
  .lf-status__step--3,
  .lf-licence__done,
  .lf-licence__check,
  .lf-input__val,
  .lf-submit__ok { opacity: 1; transform: translateY(-50%); }
  .lf-licence__check { transform: translateY(-50%) scale(1); }
  .lf-submit__btn { opacity: 0; }
  .lf-input {
    background: rgba(16, 185, 129, 0.08);
    border-color: var(--c2c-success);
  }
  .lf-particle, .lf-flow__label { display: none; }
}

/* ---------- 7. Device frames (mockup CSS) ---------- */
.c2c-device {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: #ffffff;
  box-shadow: var(--sh-lg);
  border: 1px solid var(--c2c-line);
}

.c2c-device--browser::before {
  content: "";
  display: block;
  height: 34px;
  background: linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
  border-bottom: 1px solid var(--c2c-line);
  background-image: radial-gradient(circle at 14px 17px, #ff5f57 5px, transparent 5.5px),
    radial-gradient(circle at 34px 17px, #febc2e 5px, transparent 5.5px),
    radial-gradient(circle at 54px 17px, #28c840 5px, transparent 5.5px),
    linear-gradient(180deg, #f8fafc 0%, #f1f5f9 100%);
}

.c2c-device img {
  display: block;
  width: 100%;
  height: auto;
}

.c2c-device--phone {
  max-width: 220px;
  border-radius: 32px;
  border: 8px solid #0b1220;
  background: #0b1220;
  box-shadow: var(--sh-lg);
  flex: 0 0 auto;
}

.c2c-device--phone img {
  border-radius: 24px;
}

.c2c-product__visual--phones {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--s-4);
  flex-wrap: wrap;
}

.c2c-product__visual--phones .c2c-device--phone:nth-child(even) {
  margin-top: 32px;
}

@media (max-width: 600px) {
  .c2c-product__visual--phones .c2c-device--phone {
    max-width: 200px;
  }
  .c2c-product__visual--phones .c2c-device--phone:nth-child(even) {
    display: none;
  }
}

.c2c-hero__card-floating {
  position: absolute;
  bottom: -20px;
  left: -30px;
  background: #ffffff;
  border-radius: var(--r-md);
  padding: var(--s-4);
  box-shadow: var(--sh-lg);
  display: flex;
  align-items: center;
  gap: var(--s-3);
  max-width: 260px;
  border: 1px solid var(--c2c-line-2);
}

.c2c-hero__card-floating__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--r-sm);
  background: var(--c2c-primary-50);
  color: var(--c2c-primary-700);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.c2c-hero__card-floating__icon svg {
  width: 22px;
  height: 22px;
}

.c2c-hero__card-floating__text {
  font-size: 0.8125rem;
  color: var(--c2c-ink-2);
  line-height: 1.4;
}

.c2c-hero__card-floating__text strong {
  display: block;
  color: var(--c2c-ink);
  font-weight: 700;
  margin-bottom: 2px;
}

/* ---------- 8. Stats band ---------- */
.c2c-stats {
  background: var(--c2c-ink);
  color: #ffffff;
  padding: var(--s-7) 0;
}

.c2c-stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
}

.c2c-stat {
  text-align: center;
  padding: var(--s-3);
  border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.c2c-stat:last-child {
  border-right: none;
}

.c2c-stat__value {
  font-family: var(--c2c-font-display);
  font-size: clamp(2rem, 3vw, 2.75rem);
  font-weight: 800;
  background: var(--c2c-gradient-text-bright);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
  margin-bottom: var(--s-2);
}

.c2c-stat__label {
  font-size: 0.875rem;
  color: #94a3b8;
  letter-spacing: 0.02em;
}

/* ---------- 9. Features grid ---------- */
.c2c-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-5);
}

.c2c-feature {
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

.c2c-feature:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md);
  border-color: var(--c2c-primary-100);
}

.c2c-feature__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--r-md);
  background: var(--c2c-primary-50);
  color: var(--c2c-primary-700);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--s-4);
}

.c2c-feature__icon svg {
  width: 26px;
  height: 26px;
}

.c2c-feature h3 {
  margin: 0 0 var(--s-2) 0;
  font-size: 1.125rem;
}

.c2c-feature p {
  margin: 0;
  color: var(--c2c-muted);
  font-size: 0.9375rem;
}

/* ---------- 10. Product sections (alternance) ---------- */
.c2c-product {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(var(--s-6), 5vw, var(--s-8));
}

.c2c-product--reverse .c2c-product__visual {
  order: -1;
}

.c2c-product__kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--c2c-primary-700);
  text-transform: uppercase;
  margin-bottom: var(--s-3);
}

.c2c-product__kicker span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 800;
}

.c2c-product h2 {
  margin-bottom: var(--s-4);
}

.c2c-product__list {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin: 0;
}

.c2c-product__list li {
  position: relative;
  padding-left: 34px;
  color: var(--c2c-ink-2);
  font-size: 1rem;
  line-height: 1.55;
}

.c2c-product__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--c2c-success) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center center / 14px no-repeat;
}

.c2c-product__list strong {
  color: var(--c2c-ink);
  font-weight: 700;
}

.c2c-product__list .c2c-brand-word {
  color: var(--c2c-primary-700);
  font-weight: 700;
}

.c2c-product__intro {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--c2c-ink-2);
  margin: 0 0 var(--s-5) 0;
}

.c2c-product__intro .c2c-brand-word {
  color: var(--c2c-primary-700);
  font-weight: 700;
}

.c2c-product__list li.c2c-product__highlight {
  margin-top: var(--s-3);
  padding: var(--s-3) var(--s-4) var(--s-3) 56px;
  background: linear-gradient(135deg, var(--c2c-primary-50) 0%, rgba(33, 150, 243, 0.08) 100%);
  border: 1px solid var(--c2c-primary-100);
  border-radius: var(--r-md);
}

.c2c-product__list li.c2c-product__highlight::before {
  left: var(--s-4);
  top: 15px;
  background: var(--c2c-blue-accent) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='12 2 12 12 16 14'/><circle cx='12' cy='12' r='10'/></svg>") center center / 14px no-repeat;
}

.c2c-product__list li.c2c-product__highlight strong {
  color: var(--c2c-blue-accent);
  font-size: 1.0625rem;
}

/* ---------- 11. Slideshow (screenshots) ---------- */
.c2c-slideshow {
  position: relative;
}

.c2c-slideshow__track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  gap: var(--s-4);
  padding-bottom: var(--s-4);
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.c2c-slideshow__track::-webkit-scrollbar {
  display: none;
}

.c2c-slideshow__slide {
  flex: 0 0 100%;
  scroll-snap-align: start;
  min-width: 0;
}

.c2c-slideshow__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  margin-top: var(--s-3);
}

.c2c-slideshow__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--c2c-line);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background var(--t-fast), transform var(--t-fast);
}

.c2c-slideshow__dot.is-active {
  background: var(--c2c-primary);
  transform: scale(1.3);
}

.c2c-slideshow__arrow {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--c2c-ink-2);
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}

.c2c-slideshow__arrow:hover {
  background: var(--c2c-primary);
  color: #ffffff;
  border-color: var(--c2c-primary);
}

.c2c-slideshow__arrow svg {
  width: 18px;
  height: 18px;
}

/* ---------- 12. Partners marquee ---------- */
.c2c-partners {
  overflow: hidden;
  position: relative;
  padding: var(--s-5) 0;
  mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}

.c2c-partners__track {
  display: flex;
  align-items: center;
  gap: var(--s-6);
  animation: c2c-marquee 50s linear infinite;
  width: max-content;
}

.c2c-partners:hover .c2c-partners__track {
  animation-play-state: paused;
}

.c2c-partner-logo {
  height: 44px;
  width: auto;
  flex-shrink: 0;
  object-fit: contain;
  filter: grayscale(1) opacity(0.7);
  transition: filter var(--t-base);
}

.c2c-partner-logo:hover {
  filter: grayscale(0) opacity(1);
}

@keyframes c2c-marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ---------- 13. Testimonials ---------- */
.c2c-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-5);
}

.c2c-testimonial {
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  position: relative;
  transition: transform var(--t-base), box-shadow var(--t-base);
}

.c2c-testimonial:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md);
}

.c2c-testimonial__quote-mark {
  position: absolute;
  top: var(--s-4);
  right: var(--s-5);
  font-family: var(--c2c-font-display);
  font-size: 4rem;
  line-height: 1;
  color: var(--c2c-primary-100);
  font-weight: 800;
}

.c2c-testimonial__text {
  font-size: 0.9375rem;
  color: var(--c2c-ink-2);
  line-height: 1.6;
  flex-grow: 1;
  margin: 0;
  position: relative;
  z-index: 1;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.c2c-testimonial__author {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding-top: var(--s-3);
  border-top: 1px solid var(--c2c-line-2);
}

.c2c-testimonial__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--c2c-primary-50);
  flex-shrink: 0;
}

.c2c-testimonial__author-name {
  font-weight: 700;
  color: var(--c2c-ink);
  font-size: 0.9375rem;
}

.c2c-testimonial__author-role {
  font-size: 0.8125rem;
  color: var(--c2c-muted);
}

.c2c-testimonial__more {
  align-self: flex-start;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--c2c-primary-700);
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.c2c-testimonial__more:hover {
  color: var(--c2c-primary);
}

.c2c-testimonial__more svg {
  width: 14px;
  height: 14px;
  transition: transform var(--t-fast);
}

.c2c-testimonial__more:hover svg {
  transform: translateX(3px);
}

/* ---------- 14. Modal (dialog natif) ---------- */
.c2c-modal {
  max-width: 640px;
  width: calc(100% - 32px);
  padding: 0;
  border: none;
  border-radius: var(--r-lg);
  box-shadow: var(--sh-lg);
  background: #ffffff;
  color: var(--c2c-ink-2);
}

.c2c-modal::backdrop {
  background: rgba(11, 18, 32, 0.55);
  backdrop-filter: blur(4px);
}

.c2c-modal[open] {
  animation: c2c-modal-in 300ms cubic-bezier(0.2, 0, 0.2, 1);
}

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

.c2c-modal__header {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-5) var(--s-6);
  border-bottom: 1px solid var(--c2c-line);
}

.c2c-modal__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--c2c-primary-50);
  object-fit: cover;
  flex-shrink: 0;
}

.c2c-modal__title-wrap {
  flex-grow: 1;
}

.c2c-modal__title {
  font-family: var(--c2c-font-display);
  font-weight: 800;
  color: var(--c2c-ink);
  font-size: 1.125rem;
}

.c2c-modal__subtitle {
  font-size: 0.875rem;
  color: var(--c2c-muted);
}

.c2c-modal__close {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--c2c-line);
  background: #ffffff;
  color: var(--c2c-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast);
  flex-shrink: 0;
}

.c2c-modal__close:hover {
  color: var(--c2c-danger);
  border-color: var(--c2c-danger);
}

.c2c-modal__body {
  padding: var(--s-5) var(--s-6) var(--s-6);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--c2c-ink-2);
  max-height: 70vh;
  overflow-y: auto;
}

.c2c-modal__body p {
  margin: 0 0 var(--s-4) 0;
}

.c2c-modal__body p:last-child {
  margin-bottom: 0;
}

/* ---------- 15. Pricing ---------- */
.c2c-pricing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  align-items: stretch;
}

.c2c-plan {
  position: relative;
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  transition: transform var(--t-base), box-shadow var(--t-base);
}

.c2c-plan:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md);
}

.c2c-plan--featured {
  border: 2px solid var(--c2c-primary);
  box-shadow: var(--sh-brand);
  background: linear-gradient(180deg, #ffffff 0%, #EEF1F8 100%);
}

.c2c-plan--featured::before {
  content: "Le plus choisi";
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--c2c-gradient-accent);
  color: #ffffff;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  box-shadow: var(--sh-accent);
}

.c2c-plan__name {
  font-family: var(--c2c-font-display);
  font-weight: 800;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c2c-primary-700);
  margin-bottom: var(--s-2);
}

.c2c-plan__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin-bottom: var(--s-2);
}

.c2c-plan__price-value {
  font-family: var(--c2c-font-display);
  font-size: 3rem;
  font-weight: 800;
  color: var(--c2c-ink);
  line-height: 1;
}

.c2c-plan__price-period {
  font-size: 1rem;
  color: var(--c2c-muted);
  font-weight: 500;
}

.c2c-plan__scale {
  font-size: 0.9375rem;
  color: var(--c2c-muted);
  margin-bottom: var(--s-5);
}

.c2c-plan__features {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
  flex-grow: 1;
}

.c2c-plan__features li {
  position: relative;
  padding-left: 28px;
  color: var(--c2c-ink-2);
  font-size: 0.9375rem;
  line-height: 1.55;
}

.c2c-plan__features li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--c2c-success) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center center / 12px no-repeat;
}

.c2c-plan__cta {
  width: 100%;
}

/* Bloc « toutes les formules incluent » */
.c2c-all-features {
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-xl);
  padding: clamp(var(--s-5), 4vw, var(--s-7));
  box-shadow: var(--sh-sm);
  position: relative;
  overflow: hidden;
}

.c2c-all-features::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--c2c-gradient-brand);
}

.c2c-all-features__header {
  display: flex;
  gap: var(--s-4);
  align-items: flex-start;
  margin-bottom: var(--s-6);
}

.c2c-all-features__icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: var(--r-md);
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--sh-brand);
}

.c2c-all-features__icon svg {
  width: 26px;
  height: 26px;
}

.c2c-all-features__header h3 {
  font-size: 1.375rem;
  margin: 0 0 var(--s-2) 0;
}

.c2c-all-features__header p {
  margin: 0;
  color: var(--c2c-muted);
  font-size: 0.9375rem;
}

.c2c-all-features__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-3) var(--s-5);
  padding: 0;
  margin: 0;
}

.c2c-all-features__list li {
  position: relative;
  padding-left: 30px;
  color: var(--c2c-ink-2);
  font-size: 0.9375rem;
  line-height: 1.55;
}

.c2c-all-features__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--c2c-success) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center center / 13px no-repeat;
}

/* Cartes de prix mini (3 paliers par taille de club) */
.c2c-pricing--mini {
  grid-template-columns: repeat(3, 1fr);
}

.c2c-plan-mini {
  position: relative;
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--s-3);
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

.c2c-plan-mini:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-md);
  border-color: var(--c2c-primary-100);
}

.c2c-plan-mini .c2c-plan__name {
  font-family: var(--c2c-font-display);
  font-weight: 800;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c2c-primary-700);
}

.c2c-plan-mini .c2c-plan__scale {
  font-size: 0.9375rem;
  color: var(--c2c-muted);
  margin: 0;
}

.c2c-plan-mini .c2c-plan__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin: var(--s-2) 0 var(--s-3);
}

.c2c-plan-mini .c2c-plan__price-value {
  font-family: var(--c2c-font-display);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--c2c-ink);
  line-height: 1;
}

.c2c-plan-mini .c2c-plan__price-period {
  font-size: 0.9375rem;
  color: var(--c2c-muted);
  font-weight: 500;
}

.c2c-plan-mini .c2c-plan__cta {
  width: 100%;
  margin-top: auto;
}

/* Option paiement en ligne — note en bas */
.c2c-option-note {
  display: flex;
  gap: var(--s-4);
  align-items: flex-start;
  margin-top: var(--s-7);
  padding: var(--s-5);
  background: linear-gradient(135deg, var(--c2c-primary-50) 0%, #fff 100%);
  border: 1px solid var(--c2c-primary-100);
  border-radius: var(--r-lg);
}

.c2c-option-note__icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: var(--r-sm);
  background: var(--c2c-primary-700);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.c2c-option-note__icon svg {
  width: 20px;
  height: 20px;
}

.c2c-option-note strong {
  display: block;
  color: var(--c2c-ink);
  font-family: var(--c2c-font-display);
  font-weight: 700;
  font-size: 1.0625rem;
  margin-bottom: 4px;
}

.c2c-option-note span {
  color: var(--c2c-muted);
  font-size: 0.9375rem;
  line-height: 1.6;
}

@media (max-width: 820px) {
  .c2c-pricing--mini {
    grid-template-columns: 1fr;
  }
  .c2c-option-note {
    flex-direction: column;
  }
}

/* Proposition commerciale — callout */
.c2c-offer {
  background: linear-gradient(135deg, var(--c2c-primary-50) 0%, #fff 100%);
  border: 1px solid var(--c2c-primary-100);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  margin-bottom: var(--s-7);
  display: flex;
  gap: var(--s-5);
  align-items: flex-start;
}

.c2c-offer__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--r-md);
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: var(--sh-brand);
}

.c2c-offer__icon svg {
  width: 24px;
  height: 24px;
}

.c2c-offer__title {
  font-family: var(--c2c-font-display);
  font-weight: 800;
  color: var(--c2c-ink);
  font-size: 1.25rem;
  margin: 0 0 var(--s-3) 0;
}

.c2c-offer__text {
  margin: 0;
  color: var(--c2c-ink-2);
  font-size: 0.9375rem;
  line-height: 1.7;
}

/* ---------- 16. FAQ ---------- */
.c2c-faq {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5) var(--s-6);
}

.c2c-faq details {
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-md);
  padding: 0;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}

.c2c-faq details[open] {
  border-color: var(--c2c-primary-100);
  box-shadow: var(--sh-sm);
}

.c2c-faq summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-4) var(--s-5);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s-4);
  font-weight: 600;
  color: var(--c2c-ink);
  font-size: 1rem;
}

.c2c-faq summary::-webkit-details-marker {
  display: none;
}

.c2c-faq summary::after {
  content: "";
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--c2c-primary-50) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230F2A57' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") center center / 14px no-repeat;
  transition: transform var(--t-base), background-color var(--t-base);
  margin-top: 2px;
}

.c2c-faq details[open] summary::after {
  transform: rotate(180deg);
  background-color: var(--c2c-primary-100);
}

.c2c-faq__answer {
  padding: 0 var(--s-5) var(--s-5);
  color: var(--c2c-muted);
  font-size: 0.9375rem;
  line-height: 1.7;
}

/* ---------- 17. CTA final ---------- */
.c2c-final-cta {
  background: var(--c2c-gradient-cta);
  padding: clamp(var(--s-8), 10vw, var(--s-10)) 0;
  position: relative;
  overflow: hidden;
}

.c2c-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(800px 400px at 80% 120%, rgba(30, 70, 133, 0.45), transparent 60%),
    radial-gradient(600px 300px at 20% -10%, rgba(255, 140, 66, 0.18), transparent 60%);
  pointer-events: none;
}

.c2c-final-cta__inner {
  position: relative;
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

.c2c-final-cta h2 {
  color: #ffffff;
  margin-bottom: var(--s-4);
  font-size: clamp(2rem, 3vw, 2.75rem);
}

.c2c-final-cta p {
  color: #cbd5e1;
  font-size: 1.125rem;
  margin: 0 0 var(--s-6) 0;
}

.c2c-final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}

.c2c-final-cta__contact {
  margin-top: var(--s-6);
  color: #94a3b8;
  font-size: 0.9375rem;
}

.c2c-final-cta__contact a {
  color: #ffffff;
  font-weight: 600;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.4);
}

.c2c-final-cta__contact a:hover {
  color: var(--c2c-blue-accent-light);
  border-color: var(--c2c-blue-accent-light);
}

/* ---------- 17b. Contact personnel ---------- */
.c2c-personal {
  padding: clamp(var(--s-8), 10vw, var(--s-10)) 0;
  background:
    radial-gradient(900px 500px at 90% 10%, rgba(15, 42, 87, 0.14), transparent 60%),
    radial-gradient(700px 400px at 10% 110%, rgba(255, 140, 66, 0.12), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #eef1f8 100%);
  position: relative;
  overflow: hidden;
}

.c2c-personal::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(15, 42, 87, 0.07) 1px, transparent 0);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
  pointer-events: none;
}

.c2c-personal__card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap: clamp(var(--s-5), 5vw, var(--s-8));
  align-items: center;
  max-width: 1040px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-xl);
  padding: clamp(var(--s-5), 4vw, var(--s-8));
  box-shadow: var(--sh-lg);
}

.c2c-personal__card::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(15, 42, 87, 0.55), transparent 40%, rgba(255, 140, 66, 0.3));
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  pointer-events: none;
}

.c2c-personal__photo-wrap {
  position: relative;
  justify-self: center;
  width: 100%;
  max-width: 260px;
  aspect-ratio: 1;
}

.c2c-personal__photo-wrap::before {
  content: "";
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  background: var(--c2c-gradient-brand);
  opacity: 0.15;
  filter: blur(18px);
  z-index: 0;
}

.c2c-personal__photo {
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #ffffff;
  box-shadow: var(--sh-lg);
  z-index: 1;
}

.c2c-personal__status {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--c2c-success);
  border: 3px solid #ffffff;
  z-index: 2;
  box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.2);
  animation: c2c-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes c2c-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.2); }
  50% { box-shadow: 0 0 0 10px rgba(16, 185, 129, 0.05); }
}

.c2c-personal__title {
  margin: 0 0 var(--s-4) 0;
  font-size: clamp(1.5rem, 2.2vw, 2rem);
}

.c2c-personal__lead {
  font-size: 1.0625rem;
  color: var(--c2c-muted);
  margin: 0 0 var(--s-6) 0;
  line-height: 1.65;
}

.c2c-personal__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
}

.c2c-contact-card {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  column-gap: var(--s-3);
  row-gap: 2px;
  align-items: center;
  padding: var(--s-4);
  background: #ffffff;
  border: 1.5px solid var(--c2c-line);
  border-radius: var(--r-md);
  color: var(--c2c-ink) !important;
  text-decoration: none;
  transition: transform var(--t-fast), border-color var(--t-base), box-shadow var(--t-base), background var(--t-base);
}

.c2c-contact-card:hover {
  transform: translateY(-2px);
  border-color: var(--c2c-primary);
  box-shadow: var(--sh-md);
  background: var(--c2c-primary-50);
}

.c2c-contact-card__icon {
  grid-row: 1 / 3;
  width: 44px;
  height: 44px;
  border-radius: var(--r-sm);
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--sh-brand);
}

.c2c-contact-card__icon svg {
  width: 20px;
  height: 20px;
}

.c2c-contact-card__label {
  font-size: 0.75rem;
  color: var(--c2c-muted-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}

.c2c-contact-card__value {
  font-family: var(--c2c-font-display);
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--c2c-ink);
  letter-spacing: -0.01em;
}

@media (max-width: 820px) {
  .c2c-personal__card {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .c2c-personal__photo-wrap {
    max-width: 180px;
  }
  .c2c-personal__actions {
    grid-template-columns: 1fr;
  }
  .c2c-contact-card {
    text-align: left;
  }
}

/* ---------- 18. Footer ---------- */
.c2c-footer {
  background: var(--c2c-ink);
  color: #94a3b8;
  padding: var(--s-7) 0 var(--s-5);
}

.c2c-footer__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: var(--s-6);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.c2c-footer h4 {
  color: #ffffff;
  margin: 0 0 var(--s-3) 0;
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 700;
}

.c2c-footer p,
.c2c-footer li {
  font-size: 0.9375rem;
  line-height: 1.6;
  margin: 0 0 var(--s-2) 0;
}

.c2c-footer a {
  color: #cbd5e1;
}

.c2c-footer a:hover {
  color: var(--c2c-blue-accent-light);
}

.c2c-footer__brand {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}

.c2c-footer__brand img {
  width: 96px;
  height: 96px;
  border-radius: var(--r-md);
}

.c2c-footer__bottom {
  padding-top: var(--s-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  font-size: 0.8125rem;
}

/* ---------- 19. Reveal animations ---------- */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 600ms cubic-bezier(0.2, 0, 0.2, 1), transform 600ms cubic-bezier(0.2, 0, 0.2, 1);
}

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

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  .reveal {
    opacity: 1;
    transform: none;
  }
  html {
    scroll-behavior: auto;
  }
}

/* ---------- 20. Gotop button ---------- */
.c2c-gotop {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--c2c-gradient-brand);
  color: #ffffff;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--sh-brand);
  opacity: 0;
  pointer-events: none;
  transform: translateY(20px);
  transition: opacity var(--t-base), transform var(--t-base);
  z-index: 80;
}

.c2c-gotop.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.c2c-gotop:hover {
  transform: translateY(-2px);
}

.c2c-gotop svg {
  width: 20px;
  height: 20px;
}

/* ---------- 21. Responsive ---------- */
@media (max-width: 960px) {
  .c2c-hero__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .c2c-hero__lead {
    margin-left: auto;
    margin-right: auto;
  }
  .c2c-hero__actions {
    justify-content: center;
  }
  .c2c-hero__proof {
    justify-content: center;
  }
  .c2c-hero__visual {
    max-width: 560px;
    margin: 0 auto;
  }
  .c2c-hero__card-floating {
    left: 0;
  }

  .c2c-product {
    grid-template-columns: 1fr;
  }
  .c2c-product--reverse .c2c-product__visual {
    order: 0;
  }

  .c2c-stats__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--s-4);
  }
  .c2c-stat {
    border-right: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    padding-bottom: var(--s-4);
  }
  .c2c-stat:nth-last-child(-n+2) {
    border-bottom: none;
    padding-bottom: 0;
  }

  .c2c-pricing {
    grid-template-columns: 1fr;
  }

  .c2c-faq {
    grid-template-columns: 1fr;
  }

  .c2c-footer__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .c2c-nav__links,
  .c2c-nav__cta .c2c-btn--ghost {
    display: none;
  }

  .c2c-nav__toggle {
    display: inline-flex;
  }

  .c2c-nav__mobile {
    position: fixed;
    top: 64px;
    left: 16px;
    right: 16px;
    background: #ffffff;
    border-radius: var(--r-lg);
    padding: var(--s-5);
    box-shadow: var(--sh-lg);
    border: 1px solid var(--c2c-line);
    display: none;
    flex-direction: column;
    gap: var(--s-3);
  }

  .c2c-nav__mobile.is-open {
    display: flex;
  }

  .c2c-nav__mobile a {
    padding: var(--s-3);
    border-radius: var(--r-sm);
    color: var(--c2c-ink);
    font-weight: 500;
  }

  .c2c-nav__mobile a:hover {
    background: var(--c2c-bg-soft);
  }

  .c2c-nav__mobile .c2c-btn {
    margin-top: var(--s-2);
  }

  .c2c-hero__card-floating {
    display: none;
  }

  .c2c-offer {
    flex-direction: column;
  }
}

@media (max-width: 480px) {
  .c2c-container { padding: 0 var(--s-4); }
  .c2c-btn { padding: 12px 20px; }
  .c2c-hero__actions .c2c-btn { flex-grow: 1; }
}

/* ---------- 22. Legal pages (CGV, Politique de confidentialité) ---------- */
.legal-hero {
  padding: clamp(96px, 10vw, 140px) 0 var(--s-6);
  background: var(--c2c-gradient-hero);
  position: relative;
  border-bottom: 1px solid var(--c2c-line);
}

.legal-hero h1 {
  margin: 0;
}

.legal-hero__meta {
  margin: var(--s-4) 0 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--c2c-muted);
  font-size: 0.9375rem;
}

.legal-hero__meta svg {
  width: 16px;
  height: 16px;
  color: var(--c2c-primary-700);
}

.legal-body {
  padding: var(--s-7) 0 var(--s-9);
}

.legal-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(var(--s-5), 4vw, var(--s-7));
  align-items: start;
}

.legal-toc {
  position: sticky;
  top: 96px;
  align-self: start;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
  padding: var(--s-4) var(--s-4) var(--s-4) var(--s-3);
  background: var(--c2c-bg-soft);
  border: 1px solid var(--c2c-line);
  border-radius: var(--r-md);
}

.legal-toc__title {
  font-family: var(--c2c-font-display);
  font-weight: 800;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c2c-primary-700);
  margin: 0 0 var(--s-3) var(--s-2);
}

.legal-toc ol {
  margin: 0;
  padding-left: 22px;
  font-size: 0.875rem;
  list-style: decimal;
  color: var(--c2c-muted);
}

.legal-toc ol li {
  margin-bottom: 6px;
  padding-left: 4px;
}

.legal-toc ol li::marker {
  color: var(--c2c-primary-700);
  font-weight: 700;
}

.legal-toc a {
  color: var(--c2c-ink-2);
  transition: color var(--t-fast);
  line-height: 1.4;
  display: inline-block;
}

.legal-toc a:hover {
  color: var(--c2c-primary-700);
  font-weight: 600;
}

.legal-content {
  max-width: 760px;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--c2c-ink-2);
}

.legal-content section {
  padding-top: var(--s-5);
  margin-bottom: var(--s-6);
  scroll-margin-top: 96px;
}

.legal-content section:first-child {
  padding-top: 0;
}

.legal-content h2 {
  font-size: 1.375rem;
  color: var(--c2c-ink);
  margin: 0 0 var(--s-3) 0;
  padding-bottom: var(--s-2);
  border-bottom: 2px solid var(--c2c-primary-100);
  display: inline-block;
}

.legal-content h3 {
  font-size: 1.0625rem;
  color: var(--c2c-ink);
  margin: var(--s-4) 0 var(--s-2) 0;
  font-family: var(--c2c-font-display);
  font-weight: 700;
}

.legal-content p {
  margin: 0 0 var(--s-3) 0;
}

.legal-content ul {
  margin: 0 0 var(--s-3) 0;
  padding-left: 24px;
  list-style: disc;
}

.legal-content ul li::marker {
  color: var(--c2c-primary-700);
}

.legal-content ul li {
  margin-bottom: 6px;
}

.legal-content strong {
  color: var(--c2c-ink);
  font-weight: 700;
}

.legal-content a {
  color: var(--c2c-blue-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-content a:hover {
  color: var(--c2c-primary-700);
}

.legal-callout {
  margin: var(--s-5) 0;
  padding: var(--s-4) var(--s-5);
  background: var(--c2c-primary-50);
  border-left: 3px solid var(--c2c-primary);
  border-radius: var(--r-sm);
  font-size: 0.9375rem;
  color: var(--c2c-ink-2);
}

.legal-callout strong {
  display: block;
  margin-bottom: 4px;
  color: var(--c2c-primary-700);
  font-family: var(--c2c-font-display);
}

.legal-contact-card {
  margin-top: var(--s-4);
  background: #ffffff;
  border: 1px solid var(--c2c-primary-100);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--sh-sm);
}

.legal-contact-card p {
  margin: 0 0 var(--s-2) 0;
}

.legal-contact-card p:last-child {
  margin: 0;
}

@media (max-width: 900px) {
  .legal-layout {
    grid-template-columns: 1fr;
  }
  .legal-toc {
    position: static;
    max-height: none;
    margin-bottom: var(--s-5);
  }
}
