/* ════════════════════════════════════════════════════════════════
   /demarrer.css — Questionnaire d'intégration multi-étapes
   Design : La Fédé identity (marine + cyan + dégradés)
   ════════════════════════════════════════════════════════════════ */

:root {
  --dm-cyan: #209C9A;
  --dm-cyan-light: #67E8E5;
  --dm-cyan-dark: #0E7D7B;
  --dm-noir: #0F172A;
  --dm-marine: #1E293B;
  --dm-cream: #F7F5F1;
  --dm-grey: #64748B;
  --dm-border: rgba(15,23,42,0.08);
  --dm-error: #DC2626;
  --dm-success: #10B981;
}

/* CRITICAL: override author-styles for hidden — fix bug where buttons stay visible
   because .dm-btn { display: inline-flex } beats the UA stylesheet's [hidden] { display: none } */
.dm-page [hidden],
.dm-page [hidden] *,
.dm-shell [hidden],
.dm-form [hidden],
.dm-actions [hidden],
.dm-btn [hidden] {
  display: none !important;
}

.dm-page {
  font-family: 'DM Sans', system-ui, sans-serif;
  color: var(--dm-noir);
  background: var(--dm-cream);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ════════════════════════════════════════════════════════════════
   HERO MARINE
   ════════════════════════════════════════════════════════════════ */
.dm-hero {
  position: relative;
  padding: clamp(60px, 9vw, 110px) 24px clamp(50px, 7vw, 90px);
  background: linear-gradient(135deg, #051522 0%, #0F172A 45%, #1E293B 100%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}

.dm-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
}

.dm-mesh {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.6;
  animation: dmFloat 20s ease-in-out infinite;
}

.dm-mesh-1 {
  width: 580px;
  height: 580px;
  top: -180px;
  left: -120px;
  background: radial-gradient(circle, rgba(32,156,154,0.55), rgba(32,156,154,0));
  animation-delay: 0s;
}

.dm-mesh-2 {
  width: 480px;
  height: 480px;
  top: 30%;
  right: -120px;
  background: radial-gradient(circle, rgba(103,232,229,0.42), rgba(103,232,229,0));
  animation-delay: -6s;
}

.dm-mesh-3 {
  width: 380px;
  height: 380px;
  bottom: -120px;
  left: 35%;
  background: radial-gradient(circle, rgba(124,58,237,0.32), rgba(124,58,237,0));
  animation-delay: -12s;
}

@keyframes dmFloat {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(45px, -35px) scale(1.08); }
  66% { transform: translate(-30px, 30px) scale(0.94); }
}

.dm-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 50px 50px;
  mask: radial-gradient(ellipse at 50% 50%, #000 30%, transparent 80%);
  -webkit-mask: radial-gradient(ellipse at 50% 50%, #000 30%, transparent 80%);
}

.dm-hero-content {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
  position: relative;
}

.dm-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  background: rgba(103,232,229,0.12);
  border: 1px solid rgba(103,232,229,0.3);
  border-radius: 100px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dm-cyan-light);
  margin-bottom: 28px;
}

.dm-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--dm-cyan-light);
  box-shadow: 0 0 0 0 rgba(103,232,229,0.7);
  animation: dmPulse 2s infinite;
}

@keyframes dmPulse {
  0% { box-shadow: 0 0 0 0 rgba(103,232,229,0.7); }
  70% { box-shadow: 0 0 0 12px rgba(103,232,229,0); }
  100% { box-shadow: 0 0 0 0 rgba(103,232,229,0); }
}

.dm-hero-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 900;
  font-size: clamp(2rem, 5.5vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin: 0 0 22px;
  color: #fff;
}

.dm-hero-title span {
  background: linear-gradient(135deg, var(--dm-cyan-light), #34D6CF 60%, #209C9A);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  position: relative;
}

.dm-hero-sub {
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.55;
  color: #CBD5E1;
  margin: 0 0 32px;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.dm-hero-sub strong { color: #fff; font-weight: 700; }

.dm-hero-trust {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  padding: 12px 22px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 100px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.dm-trust-item {
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.85rem;
  color: #E2E8F0;
  letter-spacing: 0.02em;
}

.dm-trust-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
}

/* ════════════════════════════════════════════════════════════════
   SHELL FORM
   ════════════════════════════════════════════════════════════════ */
.dm-shell-wrap {
  padding: 0 16px;
  margin-top: clamp(-50px, -5vw, -30px);
  position: relative;
  z-index: 1;
}

.dm-shell {
  max-width: 920px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--dm-border);
  border-radius: 32px;
  box-shadow:
    0 40px 100px -30px rgba(15,23,42,0.3),
    0 16px 36px -12px rgba(32,156,154,0.18),
    0 0 0 1px rgba(255,255,255,0.6) inset;
  overflow: hidden;
  position: relative;
  transition: background 0.5s cubic-bezier(0.16,1,0.3,1);
}

/* Décoration : halo cyan en haut de la carte (premium feel) */
.dm-shell::before {
  content: '';
  position: absolute;
  top: -200px;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(103,232,229,0.18), transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.dm-shell > * { position: relative; z-index: 1; }

/* ════════════════════════════════════════════════════════════════
   CONSENT — Toggle premium "J'autorise La Fédé"
   ════════════════════════════════════════════════════════════════ */
.dm-consent {
  margin-top: 32px;
  padding: 24px 26px;
  background: linear-gradient(135deg, rgba(32,156,154,0.06), rgba(103,232,229,0.03));
  border: 1.5px solid rgba(32,156,154,0.25);
  border-radius: 18px;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.dm-consent::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, rgba(103,232,229,0.18), transparent 65%);
  pointer-events: none;
}

.dm-consent.is-checked {
  background: linear-gradient(135deg, rgba(32,156,154,0.12), rgba(103,232,229,0.06));
  border-color: var(--dm-cyan);
  box-shadow: 0 8px 24px rgba(32,156,154,0.18);
}

.dm-consent-label {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  cursor: pointer;
  position: relative;
  z-index: 1;
}

.dm-consent-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dm-consent-toggle {
  flex-shrink: 0;
  width: 52px;
  height: 30px;
  border-radius: 100px;
  background: #CBD5E1;
  position: relative;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1);
  margin-top: 2px;
}

.dm-consent-toggle::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 8px rgba(15,23,42,0.18);
  transition: left 0.3s cubic-bezier(0.16,1,0.3,1);
}

.dm-consent-input:checked + .dm-consent-toggle {
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan));
  box-shadow: 0 4px 14px rgba(32,156,154,0.35), inset 0 1px 0 rgba(255,255,255,0.3);
}

.dm-consent-input:checked + .dm-consent-toggle::after {
  left: 25px;
  background: #fff;
  box-shadow: 0 2px 10px rgba(15,23,42,0.25);
}

.dm-consent-body {
  flex: 1;
  min-width: 0;
}

.dm-consent-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1.02rem;
  color: var(--dm-noir);
  margin-bottom: 6px;
}

.dm-consent-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  background: rgba(32,156,154,0.15);
  color: var(--dm-cyan-dark);
  border-radius: 100px;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.dm-consent-text {
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--dm-grey);
}

.dm-consent-text a {
  color: var(--dm-cyan-dark);
  text-decoration: underline;
  font-weight: 600;
}

.dm-consent-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.dm-consent-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px;
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(32,156,154,0.2);
  border-radius: 100px;
  font-size: 0.74rem;
  font-weight: 600;
  color: #475569;
  backdrop-filter: blur(4px);
}

@media (max-width: 600px) {
  .dm-consent { padding: 18px 16px; }
  .dm-consent-label { gap: 14px; }
}

/* ────────────────────────────────────────────────────
   ALTERNANCE de fond par étape (clair / foncé)
   Driven by JS: shell.dataset.activeStep + classes
   ────────────────────────────────────────────────────  */
.dm-shell.is-step-tone-light {
  background: #fff;
}

.dm-shell.is-step-tone-tinted {
  background: linear-gradient(180deg, #F8FAFC 0%, #F1F5F9 60%, #E2E8F0 100%);
}

.dm-shell.is-step-tone-tinted .dm-fieldset-title {
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.dm-shell.is-step-tone-tinted .dm-progress {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(32,156,154,0.1), transparent 60%),
    linear-gradient(180deg, #F1F5F9 0%, #F8FAFC 100%);
}

.dm-shell.is-step-tone-tinted .dm-subsection {
  background: linear-gradient(135deg, rgba(32,156,154,0.08), rgba(103,232,229,0.04));
  border-color: rgba(32,156,154,0.25);
}

/* ─── Progress (premium) ─── */
.dm-progress {
  position: relative;
  padding: 36px 36px 20px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(32,156,154,0.06), transparent 60%),
    linear-gradient(180deg, #FAFBFC 0%, #fff 100%);
  border-bottom: 1px solid var(--dm-border);
}

.dm-progress-track {
  position: absolute;
  top: 36px;
  left: 76px;
  right: 76px;
  height: 5px;
  background: rgba(15,23,42,0.07);
  border-radius: 100px;
  z-index: 0;
  margin-top: 19px;
  overflow: hidden;
}

.dm-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--dm-cyan-dark) 0%, var(--dm-cyan) 50%, var(--dm-cyan-light) 100%);
  border-radius: 100px;
  width: 12.5%;
  transition: width 0.65s cubic-bezier(0.16,1,0.3,1);
  box-shadow: 0 0 20px rgba(32,156,154,0.6), inset 0 1px 0 rgba(255,255,255,0.3);
  position: relative;
}

.dm-progress-fill::after {
  /* Shimmer effect on the fill */
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 60px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
  animation: dmShimmer 2.4s ease-in-out infinite;
}

@keyframes dmShimmer {
  0% { transform: translateX(60px); opacity: 0; }
  50% { opacity: 1; }
  100% { transform: translateX(-100%); opacity: 0; }
}

.dm-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 1;
  gap: 4px;
}

.dm-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
  cursor: pointer;
}

.dm-step-dot {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #fff;
  border: 2.5px solid #E2E8F0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: #94A3B8;
  transition: all 0.35s cubic-bezier(0.16,1,0.3,1);
  position: relative;
  box-shadow: 0 2px 6px rgba(15,23,42,0.04);
}

.dm-step:hover .dm-step-dot {
  border-color: rgba(32,156,154,0.4);
  color: var(--dm-cyan-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(32,156,154,0.15);
}

.dm-step.is-active .dm-step-dot {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--dm-cyan-dark) 0%, var(--dm-cyan) 50%, var(--dm-cyan-light) 100%);
  border: 3px solid #fff;
  color: #fff;
  font-size: 1.15rem;
  transform: translateY(-4px);
  box-shadow:
    0 0 0 4px rgba(32,156,154,0.18),
    0 0 0 9px rgba(103,232,229,0.07),
    0 12px 28px rgba(32,156,154,0.45),
    inset 0 1px 0 rgba(255,255,255,0.4);
  animation: dmStepGlow 2.6s ease-in-out infinite;
}

@keyframes dmStepGlow {
  0%, 100% {
    box-shadow:
      0 0 0 4px rgba(32,156,154,0.18),
      0 0 0 9px rgba(103,232,229,0.07),
      0 12px 28px rgba(32,156,154,0.45),
      inset 0 1px 0 rgba(255,255,255,0.4);
  }
  50% {
    box-shadow:
      0 0 0 6px rgba(32,156,154,0.25),
      0 0 0 14px rgba(103,232,229,0.12),
      0 18px 38px rgba(32,156,154,0.6),
      inset 0 1px 0 rgba(255,255,255,0.4);
  }
}

.dm-step.is-done .dm-step-dot {
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan));
  border-color: var(--dm-cyan-dark);
  color: #fff;
  font-size: 0;
  box-shadow: 0 4px 12px rgba(32,156,154,0.35);
}

.dm-step.is-done .dm-step-dot::after {
  content: '';
  width: 7px;
  height: 12px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg) translate(-1px, -1px);
}

.dm-step-label {
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: #94A3B8;
  text-transform: uppercase;
  text-align: center;
  white-space: nowrap;
  transition: color 0.3s, font-weight 0.3s;
}

.dm-step.is-active .dm-step-label {
  color: var(--dm-cyan-dark);
  font-weight: 900;
}

.dm-step.is-done .dm-step-label {
  color: var(--dm-noir);
  font-weight: 800;
}

.dm-save-indicator {
  position: absolute;
  top: 28px;
  right: 28px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: rgba(16,185,129,0.1);
  color: var(--dm-success);
  border-radius: 100px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}

.dm-save-indicator.is-visible { opacity: 1; }

/* ─── Form ─── */
.dm-form {
  padding: 38px 30px 28px;
}

.dm-fieldset {
  border: none;
  padding: 0;
  margin: 0;
  display: none;
  animation: dmSlideIn 0.45s cubic-bezier(0.16,1,0.3,1);
}

.dm-fieldset.is-active { display: block; }

@keyframes dmSlideIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

.dm-fieldset-head {
  margin-bottom: 32px;
  text-align: center;
  position: relative;
  padding-bottom: 20px;
}

.dm-fieldset-head::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--dm-cyan), transparent);
  border-radius: 100px;
}

.dm-fieldset-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 900;
  font-size: clamp(1.5rem, 2.7vw, 2rem);
  letter-spacing: -0.025em;
  color: var(--dm-noir);
  margin: 0 0 10px;
  line-height: 1.15;
}

.dm-fieldset-sub {
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--dm-grey);
  margin: 0;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.dm-fieldset-sub strong { color: var(--dm-cyan-dark); font-weight: 700; }

/* ─── Rows & Fields ─── */
.dm-row {
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
}

.dm-row-2 { grid-template-columns: 1fr 1fr; }
.dm-row-3 { grid-template-columns: 1fr 1fr 1fr; }

.dm-field {
  margin-bottom: 18px;
  position: relative;
}

.dm-row .dm-field { margin-bottom: 0; }

.dm-field label {
  display: block;
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--dm-noir);
  margin-bottom: 8px;
  letter-spacing: 0.01em;
}

.dm-req {
  color: var(--dm-cyan);
  font-weight: 900;
}

.dm-hint {
  display: block;
  margin-top: 6px;
  font-size: 0.78rem;
  color: var(--dm-grey);
  line-height: 1.4;
}

.dm-hint-inline {
  font-weight: 500;
  font-size: 0.78rem;
  color: var(--dm-grey);
  text-transform: none;
  letter-spacing: 0;
  margin-left: 6px;
}

.dm-field input[type="text"],
.dm-field input[type="email"],
.dm-field input[type="tel"],
.dm-field input[type="number"],
.dm-field input[type="url"],
.dm-field select,
.dm-field textarea {
  width: 100%;
  padding: 14px 16px;
  background: #F8FAFC;
  border: 1.5px solid #CBD5E1;
  border-radius: 12px;
  font-family: inherit;
  font-size: 0.95rem;
  color: var(--dm-noir);
  transition: all 0.25s ease;
  appearance: none;
  -webkit-appearance: none;
}

.dm-field select {
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8'%3E%3Cpath fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M1 1l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 42px;
  cursor: pointer;
}

.dm-field textarea {
  resize: vertical;
  font-family: inherit;
  line-height: 1.55;
  min-height: 110px;
}

.dm-field input:focus,
.dm-field select:focus,
.dm-field textarea:focus {
  outline: none;
  border-color: var(--dm-cyan);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(32,156,154,0.12);
}

.dm-field input:invalid:not(:placeholder-shown),
.dm-field select.is-invalid,
.dm-field textarea:invalid:not(:placeholder-shown) {
  border-color: var(--dm-error);
  background: rgba(220,38,38,0.04);
}

/* Champ obligatoire non rempli (signalé par JS) — bordure rouge épaisse + shake */
.dm-field input.is-invalid,
.dm-field select.is-invalid,
.dm-field textarea.is-invalid,
.dm-radio input.is-invalid + .dm-radio-card,
.dm-radios.has-invalid {
  border-color: var(--dm-error) !important;
  background: rgba(220, 38, 38, 0.06) !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.15) !important;
  animation: dmShake 0.4s;
}

@keyframes dmShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-5px); }
  75% { transform: translateX(5px); }
}

/* Message d'erreur inline sous un champ invalide */
.dm-field-error {
  display: block;
  margin-top: 6px;
  padding: 6px 10px;
  background: rgba(220, 38, 38, 0.08);
  border-left: 3px solid var(--dm-error);
  border-radius: 6px;
  color: var(--dm-error);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.4;
}

/* Label d'un champ invalide passe en rouge */
.dm-field:has(input.is-invalid) label,
.dm-field:has(select.is-invalid) label,
.dm-field:has(textarea.is-invalid) label {
  color: var(--dm-error);
}

.dm-field:has(input.is-invalid) label .dm-req,
.dm-field:has(select.is-invalid) label .dm-req,
.dm-field:has(textarea.is-invalid) label .dm-req {
  background: var(--dm-error);
  color: #fff;
  padding: 1px 6px;
  border-radius: 100px;
  font-size: 0.75em;
}

.dm-field input::placeholder,
.dm-field textarea::placeholder {
  color: #94A3B8;
}

/* ─── Checkbox ─── */
.dm-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  padding: 14px 16px;
  background: #F8FAFC;
  border: 1.5px solid #CBD5E1;
  border-radius: 12px;
  transition: all 0.25s ease;
}

.dm-checkbox:hover { background: rgba(32,156,154,0.04); border-color: rgba(32,156,154,0.3); }

.dm-checkbox input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dm-checkbox-box {
  width: 22px;
  height: 22px;
  min-width: 22px;
  border: 2px solid var(--dm-border);
  border-radius: 6px;
  background: #fff;
  position: relative;
  transition: all 0.2s ease;
  margin-top: 1px;
}

.dm-checkbox input:checked + .dm-checkbox-box {
  background: var(--dm-cyan);
  border-color: var(--dm-cyan);
}

.dm-checkbox input:checked + .dm-checkbox-box::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 6px;
  width: 6px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2.5px 2.5px 0;
  transform: rotate(45deg);
}

.dm-checkbox-label {
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--dm-noir);
}

.dm-checkbox-label a {
  color: var(--dm-cyan-dark);
  text-decoration: underline;
  font-weight: 600;
}

/* ─── Chips multi-select ─── */
.dm-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

.dm-chip {
  position: relative;
  cursor: pointer;
}

.dm-chip input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dm-chip span {
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  background: #F1F5F9;
  border: 1.5px solid #CBD5E1;
  border-radius: 100px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 700;
  font-size: 0.88rem;
  color: #334155;
  transition: all 0.25s ease;
}

.dm-chip:hover span {
  background: rgba(32,156,154,0.06);
  border-color: rgba(32,156,154,0.4);
  transform: translateY(-1px);
}

.dm-chip input:checked + span {
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan));
  border-color: var(--dm-cyan-dark);
  color: #fff;
  box-shadow: 0 4px 14px rgba(32,156,154,0.35);
}

/* ─── Radio cards ─── */
.dm-radios {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.dm-radio {
  position: relative;
  cursor: pointer;
}

.dm-radio input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.dm-radio-card {
  display: block;
  padding: 20px 16px;
  background: #F1F5F9;
  border: 1.5px solid #CBD5E1;
  border-radius: 14px;
  text-align: center;
  transition: all 0.25s ease;
}

.dm-radio:hover .dm-radio-card {
  background: rgba(32,156,154,0.04);
  border-color: rgba(32,156,154,0.4);
  transform: translateY(-2px);
}

.dm-radio input:checked + .dm-radio-card {
  background: linear-gradient(135deg, rgba(32,156,154,0.08), rgba(103,232,229,0.05));
  border-color: var(--dm-cyan);
  box-shadow: 0 8px 22px rgba(32,156,154,0.18), inset 0 0 0 1px var(--dm-cyan);
}

.dm-radio-emoji {
  display: block;
  font-size: 1.6rem;
  margin-bottom: 6px;
}

.dm-radio-title {
  display: block;
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1rem;
  color: var(--dm-noir);
  margin-bottom: 4px;
}

.dm-radio-desc {
  display: block;
  font-size: 0.78rem;
  color: var(--dm-grey);
  line-height: 1.4;
}

/* ════════════════════════════════════════════════════════════════
   SUBSECTIONS — bloc encadré dans une étape
   ════════════════════════════════════════════════════════════════ */
.dm-subsection {
  margin: 22px 0 8px;
  padding: 22px 22px 12px;
  background: linear-gradient(135deg, rgba(32,156,154,0.04), rgba(103,232,229,0.02));
  border: 1px solid rgba(32,156,154,0.18);
  border-radius: 14px;
}

.dm-subsection-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dm-cyan-dark);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ════════════════════════════════════════════════════════════════
   TEAM TABLE — Step 3 Équipe (table dynamique de collaborateurs)
   ════════════════════════════════════════════════════════════════ */
.dm-team-table {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 14px;
}

.dm-team-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1.4fr 1fr 1fr auto;
  gap: 8px;
  align-items: end;
  padding: 14px;
  background: #F8FAFC;
  border: 1.5px solid #CBD5E1;
  border-radius: 12px;
  transition: all 0.2s ease;
}

.dm-team-row:hover {
  background: rgba(32,156,154,0.03);
  border-color: rgba(32,156,154,0.4);
}

.dm-team-row .dm-field {
  margin: 0;
}

.dm-team-row label {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--dm-grey);
  margin-bottom: 4px;
}

.dm-team-row input,
.dm-team-row select {
  padding: 9px 12px !important;
  font-size: 0.88rem !important;
  background: #fff !important;
}

.dm-team-row-remove {
  width: 38px;
  height: 38px;
  align-self: center;
  margin-top: 18px;
  border-radius: 50%;
  background: rgba(220,38,38,0.08);
  border: 1.5px solid rgba(220,38,38,0.3);
  color: var(--dm-error);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.dm-team-row-remove:hover {
  background: var(--dm-error);
  color: #fff;
  border-color: var(--dm-error);
}

.dm-btn-add-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  background: rgba(32,156,154,0.08);
  border: 1.5px dashed rgba(32,156,154,0.4);
  border-radius: 100px;
  color: var(--dm-cyan-dark);
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  cursor: pointer;
  margin-bottom: 22px;
  transition: all 0.25s ease;
}

.dm-btn-add-row:hover {
  background: rgba(32,156,154,0.15);
  border-color: var(--dm-cyan);
  border-style: solid;
  transform: translateY(-1px);
}

.dm-team-empty {
  padding: 28px 22px;
  text-align: center;
  background: #F8FAFC;
  border: 1.5px dashed #CBD5E1;
  border-radius: 12px;
  color: var(--dm-grey);
  font-size: 0.92rem;
}

@media (max-width: 800px) {
  .dm-team-row {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
  .dm-team-row-remove {
    grid-column: 1 / -1;
    width: auto;
    margin-top: 4px;
    border-radius: 8px;
    height: 32px;
  }
}

/* ════════════════════════════════════════════════════════════════
   STEP 8 — DOCUMENTS (cases à cocher + pitch marketing)
   ════════════════════════════════════════════════════════════════ */

/* Pitch banner */
.dm-speedup {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 22px;
  background: linear-gradient(135deg, rgba(32,156,154,0.08), rgba(103,232,229,0.05));
  border: 1.5px solid rgba(32,156,154,0.3);
  border-radius: 16px;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
}

.dm-speedup::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(103,232,229,0.18), transparent 70%);
  pointer-events: none;
}

.dm-speedup-icon {
  font-size: 2.2rem;
  flex-shrink: 0;
  line-height: 1;
  filter: drop-shadow(0 4px 8px rgba(32,156,154,0.3));
  animation: dmRocket 2.4s ease-in-out infinite;
}

@keyframes dmRocket {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-4px) rotate(-6deg); }
}

.dm-speedup-text {
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--dm-noir);
  position: relative;
  z-index: 1;
}

.dm-speedup-text strong {
  color: var(--dm-cyan-dark);
  font-weight: 800;
}

.dm-speedup-text strong:first-child {
  display: block;
  margin-bottom: 4px;
  font-size: 1.02em;
}

/* Groupes de documents */
.dm-docs-group {
  margin-bottom: 22px;
}

.dm-docs-group:last-of-type {
  margin-bottom: 12px;
}

.dm-docs-group-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dm-cyan-dark);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(32,156,154,0.15);
}

.dm-docs-group-emoji {
  font-size: 1.05rem;
}

.dm-docs-group-count {
  margin-left: auto;
  padding: 2px 10px;
  background: rgba(32,156,154,0.1);
  color: var(--dm-cyan-dark);
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  transition: all 0.25s ease;
}

.dm-docs-group-count.is-complete {
  background: var(--dm-success);
  color: #fff;
}

.dm-docs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}

.dm-doc {
  position: relative;
  cursor: pointer;
  display: block;
}

.dm-doc input[type="file"] {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
  overflow: hidden;
}

.dm-doc-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  background: #F8FAFC;
  border: 1.5px solid #CBD5E1;
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
  min-height: 64px;
}

.dm-doc:hover .dm-doc-card {
  background: rgba(32,156,154,0.05);
  border-color: rgba(32,156,154,0.5);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(32,156,154,0.1);
}

.dm-doc-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  flex: 1;
}

.dm-doc-name {
  font-family: 'League Spartan', sans-serif;
  font-size: 0.92rem;
  font-weight: 800;
  color: #1E293B;
  letter-spacing: 0.005em;
  line-height: 1.2;
}

.dm-doc-status {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--dm-grey);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}

.dm-doc-fmt {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 7px;
  background: rgba(15,23,42,0.05);
  border-radius: 100px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #64748B;
  text-transform: uppercase;
}

.dm-doc-action {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid #CBD5E1;
  color: #64748B;
  flex-shrink: 0;
  transition: all 0.2s ease;
}

.dm-doc:hover .dm-doc-action {
  background: var(--dm-cyan);
  border-color: var(--dm-cyan);
  color: #fff;
}

/* État FILLED — fichier sélectionné */
.dm-doc.is-filled .dm-doc-card {
  background: linear-gradient(135deg, rgba(32,156,154,0.12), rgba(103,232,229,0.06));
  border-color: var(--dm-cyan);
  box-shadow: 0 4px 14px rgba(32,156,154,0.15);
}

.dm-doc.is-filled .dm-doc-name {
  color: var(--dm-cyan-dark);
}

.dm-doc.is-filled .dm-doc-name::before {
  content: '✓ ';
  color: var(--dm-success);
  font-weight: 900;
}

.dm-doc.is-filled .dm-doc-status {
  color: #1E293B;
  font-weight: 600;
}

.dm-doc.is-filled .dm-doc-fmt {
  display: none;
}

.dm-doc.is-filled .dm-doc-action {
  background: rgba(220,38,38,0.1);
  border-color: rgba(220,38,38,0.3);
  color: var(--dm-error);
  transform: rotate(45deg);
}

.dm-doc.is-filled:hover .dm-doc-action {
  background: var(--dm-error);
  border-color: var(--dm-error);
  color: #fff;
  transform: rotate(45deg) scale(1.05);
}

/* État ERROR (fichier trop gros) */
.dm-doc.is-error .dm-doc-card {
  background: rgba(220,38,38,0.06);
  border-color: var(--dm-error);
  animation: dmShake 0.4s;
}

.dm-doc.is-error .dm-doc-name {
  color: var(--dm-error);
}

@keyframes dmShake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-6px); }
  75% { transform: translateX(6px); }
}

/* Hint global */
.dm-docs-hint {
  margin-top: 14px;
  padding: 12px 16px;
  background: rgba(15,23,42,0.03);
  border-radius: 10px;
  font-size: 0.82rem;
  color: var(--dm-grey);
  line-height: 1.5;
}

.dm-docs-hint strong { color: var(--dm-noir); font-weight: 700; }

/* Total status */
.dm-docs-total {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 22px;
  padding: 16px 20px;
  background: linear-gradient(135deg, rgba(15,23,42,0.04), rgba(15,23,42,0.01));
  border: 1px dashed rgba(15,23,42,0.15);
  border-radius: 12px;
  transition: all 0.3s ease;
}

.dm-docs-total.is-progress {
  background: linear-gradient(135deg, rgba(32,156,154,0.1), rgba(103,232,229,0.04));
  border-color: rgba(32,156,154,0.3);
  border-style: solid;
}

.dm-docs-total.is-complete {
  background: linear-gradient(135deg, rgba(16,185,129,0.15), rgba(16,185,129,0.05));
  border-color: var(--dm-success);
  border-style: solid;
}

.dm-docs-total-num {
  font-family: 'League Spartan', sans-serif;
  font-weight: 900;
  font-size: 1.4rem;
  color: var(--dm-noir);
  letter-spacing: -0.02em;
  flex-shrink: 0;
}

.dm-docs-total.is-progress .dm-docs-total-num { color: var(--dm-cyan-dark); }
.dm-docs-total.is-complete .dm-docs-total-num { color: var(--dm-success); }

.dm-docs-total-num #dmDocsCount {
  font-size: 1.6rem;
}

.dm-docs-total-label {
  font-size: 0.9rem;
  color: var(--dm-grey);
  line-height: 1.4;
  font-weight: 500;
}

@media (max-width: 720px) {
  .dm-speedup {
    flex-direction: column;
    gap: 10px;
    padding: 16px;
  }
  .dm-speedup-icon { font-size: 1.8rem; }
  .dm-docs-grid { grid-template-columns: 1fr; }
  .dm-docs-total { flex-direction: column; align-items: flex-start; gap: 4px; }
}

/* ─── Actions (Back/Next/Submit) ─── */
.dm-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 28px;
  margin-top: 28px;
  border-top: 1px solid var(--dm-border);
}

.dm-actions-spacer { flex: 1; }

.dm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: 100px;
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: all 0.25s cubic-bezier(0.16,1,0.3,1);
}

.dm-btn-primary {
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan));
  color: #fff;
  box-shadow: 0 8px 22px rgba(32,156,154,0.4);
}

.dm-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(32,156,154,0.5);
}

.dm-btn-primary:active { transform: translateY(0); }

.dm-btn-ghost {
  background: transparent;
  color: var(--dm-noir);
  border: 1.5px solid var(--dm-border);
}

.dm-btn-ghost:hover {
  background: var(--dm-cream);
  border-color: var(--dm-cyan);
  color: var(--dm-cyan-dark);
}

.dm-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
}

.dm-spinner {
  animation: dmSpin 0.8s linear infinite;
}

@keyframes dmSpin {
  to { transform: rotate(360deg); }
}

/* ─── Error ─── */
.dm-error {
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(220,38,38,0.08);
  border: 1px solid rgba(220,38,38,0.2);
  border-radius: 12px;
  color: var(--dm-error);
  font-size: 0.92rem;
  font-weight: 500;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.dm-error::before {
  content: '⚠️';
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════════
   SUCCESS STATE
   ════════════════════════════════════════════════════════════════ */
.dm-success {
  padding: 56px 30px 48px;
  text-align: center;
  animation: dmFadeUp 0.6s cubic-bezier(0.16,1,0.3,1);
}

@keyframes dmFadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.dm-success-icon {
  display: inline-flex;
  width: 88px;
  height: 88px;
  background: linear-gradient(135deg, var(--dm-cyan-dark), var(--dm-cyan-light));
  color: #fff;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
  box-shadow: 0 16px 40px rgba(32,156,154,0.4);
  animation: dmPop 0.5s cubic-bezier(0.16,1,0.3,1) 0.1s both;
}

@keyframes dmPop {
  from { opacity: 0; transform: scale(0.3); }
  to { opacity: 1; transform: scale(1); }
}

.dm-success-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 900;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  letter-spacing: -0.02em;
  color: var(--dm-noir);
  margin: 0 0 14px;
}

.dm-success-text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--dm-grey);
  max-width: 540px;
  margin: 0 auto 32px;
}

.dm-success-text strong { color: var(--dm-noir); font-weight: 700; }

.dm-success-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  max-width: 680px;
  margin: 0 auto 36px;
}

.dm-success-card {
  padding: 22px 16px;
  background: #FAFBFC;
  border: 1px solid var(--dm-border);
  border-radius: 16px;
  text-align: center;
}

.dm-success-card-emoji {
  font-size: 1.9rem;
  margin-bottom: 6px;
}

.dm-success-card-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1.05rem;
  color: var(--dm-cyan-dark);
  margin-bottom: 4px;
}

.dm-success-card-sub {
  font-size: 0.82rem;
  color: var(--dm-grey);
  line-height: 1.4;
}

.dm-success-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ════════════════════════════════════════════════════════════════
   REASSURE FOOTER
   ════════════════════════════════════════════════════════════════ */
.dm-reassure {
  padding: clamp(50px, 7vw, 90px) 24px;
  margin-top: clamp(40px, 6vw, 70px);
  background: #fff;
  border-top: 1px solid var(--dm-border);
}

.dm-reassure-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
}

.dm-reassure-card {
  padding: 28px 24px;
  background: var(--dm-cream);
  border: 1px solid var(--dm-border);
  border-radius: 18px;
  text-align: center;
  transition: all 0.3s ease;
}

.dm-reassure-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(32,156,154,0.12);
  border-color: rgba(32,156,154,0.3);
}

.dm-reassure-emoji {
  font-size: 2rem;
  margin-bottom: 10px;
}

.dm-reassure-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--dm-noir);
  margin-bottom: 8px;
}

.dm-reassure-text {
  font-size: 0.9rem;
  color: var(--dm-grey);
  line-height: 1.5;
}

.dm-reassure-text a {
  color: var(--dm-cyan-dark);
  text-decoration: underline;
  font-weight: 600;
}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  .dm-row-2,
  .dm-row-3 { grid-template-columns: 1fr; }

  .dm-shell { border-radius: 22px; }
  .dm-progress { padding: 22px 20px 0; }
  .dm-form { padding: 30px 20px 22px; }

  .dm-step-label {
    font-size: 0.6rem;
    letter-spacing: 0.02em;
  }

  .dm-step-dot { width: 32px; height: 32px; font-size: 0.85rem; }

  .dm-save-indicator { display: none; }

  .dm-actions {
    flex-direction: column-reverse;
    gap: 10px;
  }

  .dm-actions-spacer { display: none; }

  .dm-btn { width: 100%; }

  .dm-radios { grid-template-columns: 1fr 1fr; }

  .dm-hero-trust {
    gap: 8px;
    padding: 10px 16px;
  }

  .dm-trust-item { font-size: 0.75rem; }
}

@media (max-width: 480px) {
  .dm-step-label { display: none; }
}

/* ════════════════════════════════════════════════════════════════
   REDUCED MOTION
   ════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .dm-mesh,
  .dm-pulse,
  .dm-spinner {
    animation: none !important;
  }
  .dm-fieldset.is-active,
  .dm-success {
    animation: none;
  }
  .dm-btn:hover,
  .dm-radio:hover .dm-radio-card,
  .dm-reassure-card:hover {
    transform: none;
  }
}

/* ════════════════════════════════════════════════════════════════
   STEP 8 — DOCS : layout compact (17 cards à caser proprement)
   ════════════════════════════════════════════════════════════════ */

/* Doc cards plus petites */
.dm-fieldset[data-step="8"] .dm-doc-card {
  padding: 9px 12px;
  min-height: 50px;
  gap: 8px;
}

.dm-fieldset[data-step="8"] .dm-doc-name {
  font-size: 0.82rem;
}

.dm-fieldset[data-step="8"] .dm-doc-status {
  font-size: 0.68rem;
}

.dm-fieldset[data-step="8"] .dm-doc-action {
  width: 28px;
  height: 28px;
  min-width: 28px;
}

.dm-fieldset[data-step="8"] .dm-doc-action svg {
  width: 14px;
  height: 14px;
}

/* Grid 3 colonnes par défaut sur desktop, 2 sur tablette, 1 sur mobile */
.dm-fieldset[data-step="8"] .dm-docs-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}

@media (max-width: 900px) {
  .dm-fieldset[data-step="8"] .dm-docs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 540px) {
  .dm-fieldset[data-step="8"] .dm-docs-grid {
    grid-template-columns: 1fr;
  }
}

/* Group title plus compact */
.dm-fieldset[data-step="8"] .dm-docs-group {
  margin-bottom: 14px;
}

.dm-fieldset[data-step="8"] .dm-docs-group-title {
  font-size: 0.74rem;
  margin-bottom: 8px;
  padding-bottom: 6px;
  gap: 8px;
}

.dm-fieldset[data-step="8"] .dm-docs-group-emoji {
  font-size: 0.95rem;
}

.dm-fieldset[data-step="8"] .dm-docs-group-count {
  padding: 2px 8px;
  font-size: 0.66rem;
}

/* Speedup banner plus compact pour step 8 */
.dm-fieldset[data-step="8"] .dm-speedup {
  padding: 12px 16px;
  margin-bottom: 16px;
  gap: 12px;
}

.dm-fieldset[data-step="8"] .dm-speedup-icon {
  font-size: 1.7rem;
}

.dm-fieldset[data-step="8"] .dm-speedup-text {
  font-size: 0.82rem;
  line-height: 1.45;
}

.dm-fieldset[data-step="8"] .dm-speedup-text strong:first-child {
  font-size: 0.95em;
  margin-bottom: 2px;
}

/* Total + hint compact */
.dm-fieldset[data-step="8"] .dm-docs-total {
  margin-top: 14px;
  padding: 12px 16px;
}

.dm-fieldset[data-step="8"] .dm-docs-total-num {
  font-size: 1.15rem;
}

.dm-fieldset[data-step="8"] .dm-docs-total-num #dmDocsCount {
  font-size: 1.3rem;
}

.dm-fieldset[data-step="8"] .dm-docs-total-label {
  font-size: 0.82rem;
}

.dm-fieldset[data-step="8"] .dm-docs-hint {
  margin-top: 10px;
  padding: 10px 14px;
  font-size: 0.76rem;
}

/* Head plus tassé sur step 8 (déjà long) */
.dm-fieldset[data-step="8"] .dm-fieldset-head {
  margin-bottom: 18px;
  padding-bottom: 14px;
}

.dm-fieldset[data-step="8"] .dm-fieldset-title {
  font-size: clamp(1.4rem, 2.4vw, 1.8rem);
}

.dm-fieldset[data-step="8"] .dm-fieldset-sub {
  font-size: 0.92rem;
}

/* ════════════════════════════════════════════════════════════════
   FLUX CTA — Gros bouton vers la liste complète des flux
   ════════════════════════════════════════════════════════════════ */
.dm-flux-cta {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 22px 26px;
  margin: 22px 0 18px;
  background: linear-gradient(135deg, var(--dm-cyan-dark) 0%, var(--dm-cyan) 60%, #34D6CF 100%);
  color: #fff;
  border-radius: 18px;
  text-decoration: none;
  box-shadow:
    0 14px 36px -10px rgba(32,156,154,0.55),
    0 4px 14px -4px rgba(32,156,154,0.4),
    inset 0 1px 0 rgba(255,255,255,0.2);
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.dm-flux-cta::before {
  /* Halo blanc qui glisse au hover */
  content: '';
  position: absolute;
  top: 0;
  left: -80%;
  width: 60%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
  transform: skewX(-20deg);
  transition: left 0.7s cubic-bezier(0.16,1,0.3,1);
  pointer-events: none;
  z-index: 0;
}

.dm-flux-cta:hover {
  transform: translateY(-3px);
  box-shadow:
    0 22px 52px -12px rgba(32,156,154,0.7),
    0 8px 20px -4px rgba(32,156,154,0.5),
    inset 0 1px 0 rgba(255,255,255,0.25);
}

.dm-flux-cta:hover::before {
  left: 130%;
}

.dm-flux-cta > * {
  position: relative;
  z-index: 1;
}

.dm-flux-cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: rgba(255,255,255,0.18);
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 14px;
  font-size: 1.9rem;
  flex-shrink: 0;
  backdrop-filter: blur(6px);
}

.dm-flux-cta-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dm-flux-cta-title {
  font-family: 'League Spartan', sans-serif;
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: -0.005em;
  line-height: 1.2;
  color: #fff;
}

.dm-flux-cta-sub {
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  line-height: 1.4;
}

.dm-flux-cta-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.18);
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 50%;
  color: #fff;
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
}

.dm-flux-cta:hover .dm-flux-cta-arrow {
  transform: translateX(3px) rotate(-3deg);
  background: rgba(255,255,255,0.28);
}

@media (max-width: 600px) {
  .dm-flux-cta {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
    padding: 18px 20px;
  }
  .dm-flux-cta-icon { width: 48px; height: 48px; font-size: 1.6rem; }
  .dm-flux-cta-title { font-size: 1rem; }
  .dm-flux-cta-sub { font-size: 0.8rem; }
  .dm-flux-cta-arrow {
    align-self: flex-end;
    margin-top: -38px;
  }
}
