/* === static/circuitMoto/css/step.css ===
   Version clean (sans duplications)
   Objectifs:
   - Layout wizard stable
   - Sections (cards) propres
   - Grilles 2/3 colonnes sans décalage
   - Astérisque required (*) parfaitement positionné
*/

/* =========================================================
   0) Variables & sécurité anti overflow
========================================================= */

.page-wizard{
  --layout-max: 1240px;                 /* largeur globale du contenu */
  --wizard-max: 1040px;                 /* largeur bloc wizard (header + form) */
  --wizard-pad: clamp(14px, 2.2vw, 24px);

  --field-gap: clamp(12px, 1.8vw, 18px);
  --row-gap: clamp(10px, 1.6vw, 16px);
  --section-gap: clamp(12px, 2.2vw, 20px);
}

.container, .form-step, .wizard-head{ min-width: 0; }
.grid-2 > *, .grid-3 > *, .grid-3-id > *{ min-width: 0; }

/* =========================================================
   1) Layout global (utilise les côtés)
========================================================= */

.page-wizard main.container{
  max-width: var(--layout-max);
  margin: 0 auto;
  padding: var(--wizard-pad);
}

/* Le wizard (header + form) centré */
.page-wizard .wizard-head,
.page-wizard .form-step,
.page-wizard .step-hero{
  max-width: var(--wizard-max);
  margin-left: auto;
  margin-right: auto;
}

/* Très grands écrans */
@media (min-width: 1400px){
  .page-wizard{
    --layout-max: 1360px;
    --wizard-max: 1120px;
  }
}

/* Mobile */
@media (max-width: 768px){
  .page-wizard{
    --layout-max: 100%;
    --wizard-max: 100%;
  }
}

/* =========================================================
   2) Step hero (titre + sous-titre)
========================================================= */

.page-wizard .step-hero{
  margin: 0 auto 1rem;
  text-align: left;
}

.page-wizard .step-title{
  margin: 0 0 .35rem;
  font-size: clamp(1.35rem, 2.8vw, 2rem);
  font-weight: 900;
  letter-spacing: -.02em;
  line-height: 1.15;
  background: linear-gradient(90deg, var(--primary), #8b5cf6);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.page-wizard .step-subtitle{
  margin: 0;
  color: var(--text-light);
  font-size: clamp(.95rem, 2.2vw, 1.05rem);
  line-height: 1.6;
  max-width: 70ch;
}

@media (max-width: 768px){
  .page-wizard .step-hero{ text-align:center; margin-bottom:.9rem; }
  .page-wizard .step-subtitle{ margin-left:auto; margin-right:auto; }
}

/* =========================================================
   3) Form card
========================================================= */

.form-step{
  background: color-mix(in oklab, var(--bg) 93%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
  border-radius: 0 0 18px 18px; /* si wizard-head “cap” */
  padding: clamp(14px, 2.2vw, 20px);
  box-shadow: 0 18px 48px rgba(0,0,0,.10);
}

@media (max-width: 768px){
  .form-step{ border-radius: 0 0 16px 16px; }
}

/* Titre + helptext (si présents) */
.form-step h2{
  text-align:center;
  margin: .2rem 0 .4rem;
  font-size: clamp(1.1rem, 2.6vw, 1.45rem);
}
.form-step .helptext{
  text-align:center;
  margin: 0 auto 1rem;
  max-width: 60ch;
}

/* =========================================================
   4) Sections (cards internes)
========================================================= */

.step-section{
  background: color-mix(in oklab, var(--bg) 94%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 16px;
  padding: clamp(12px, 2vw, 18px);
  margin-bottom: var(--section-gap);
  box-shadow: 0 8px 18px rgba(0,0,0,.05);
}

@media (max-width: 420px){
  .step-section{ padding:12px; border-radius:14px; }
}

.section-head{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  margin-bottom: 1rem;
}

.section-title{
  margin:0;
  font-size: 1.05rem;
  font-weight: 850;
  letter-spacing: -.01em;
  color: var(--text);
}

.section-subtitle{
  margin:0;
  color: var(--text-light);
  font-size: .95rem;
  line-height: 1.55;
}

/* =========================================================
   5) Grilles (2 colonnes)
========================================================= */

.grid-2{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--field-gap);
}

.grid-2 + .grid-2{ margin-top: var(--row-gap); }

.grid-2.grid-tight{
  gap: clamp(10px, 1.2vw, 14px);
}

@media (max-width: 640px){
  .grid-2{ grid-template-columns: 1fr; }
}

/* =========================================================
   6) Grilles (3 colonnes + identité plus large)
========================================================= */

.grid-3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--field-gap);
  align-items: start;
}

.grid-3.grid-tight{
  gap: clamp(10px, 1.2vw, 14px);
}

@media (max-width: 980px){
  .grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px){
  .grid-3{ grid-template-columns: 1fr; }
}

/* Variante identité plus large */
.grid-3.grid-3-id{
  grid-template-columns: 1.35fr 1fr 1fr;
}

@media (max-width: 980px){
  .grid-3.grid-3-id{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid-3.grid-3-id .form-group:first-child{ grid-column: 1 / -1; }
}
@media (max-width: 640px){
  .grid-3.grid-3-id{ grid-template-columns: 1fr; }
  .grid-3.grid-3-id .form-group:first-child{ grid-column: auto; }
}


/* =========================================================
   6bis) Grille 3 colonnes "basic" (prenom/nom/adresse etc.)
========================================================= */

.grid-3.grid-3-basic{
  align-items: start;
}

/* Même alignement label pour éviter que le required fasse bouger l’input */
.grid-3.grid-3-basic .form-group{
  display:flex;
  flex-direction:column;
  align-items:stretch;
}

/* Réserve une hauteur label identique -> inputs parfaitement alignés */
.grid-3.grid-3-basic .form-group > label{
  display:flex;
  align-items:flex-end;
  min-height: 2.7em; /* ~2 lignes : stable */
}


/* =========================================================
   7) Form groups / labels / required (*)
========================================================= */

.form-step .form-group{
  margin: 0; /* la grille gère les espaces */
}

/* Label base */
.form-step label{
  display:block;
  font-weight: 650;
  margin: 0 0 .55rem;
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* ✅ Astérisque: stable et bien placé (ne décale pas le texte) */
.form-step label.required{
  position: relative;
  padding-right: 1rem; /* place pour le * */
}

.form-step label.required::after{
  content: "*";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-55%);
  color: var(--error);
  font-weight: 900;
  line-height: 1;
}

/* =========================================================
   8) FIX PRINCIPAL: alignement parfait sur la ligne 3 champs
      (identité/email/téléphone)
========================================================= */

/* Chaque item en colonne */
.grid-3.grid-3-id .form-group{
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* ✅ On réserve EXACTEMENT la même zone label pour les 3 */
.grid-3.grid-3-id .form-group > label{
  display: flex;
  align-items: flex-end;  /* texte du label aligné en bas */
  min-height: 2.7em;      /* réserve ~2 lignes (ajuste si besoin) */
}

/* Astérisque dans la zone label (priorité sur ce contexte) */
.grid-3.grid-3-id .form-group > label.required::after{
  top: 50%;
  transform: translateY(-55%);
}

/* =========================================================
   9) Inputs (uniformes)
========================================================= */

.form-step input[type="text"],
.form-step input[type="email"],
.form-step input[type="tel"],
.form-step input[type="date"],
.form-step input[type="number"],
.form-step input[type="password"],
.form-step textarea,
.form-step select{
  appearance: none;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;

  padding: .82rem .95rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg);
  color: var(--text);
  font: inherit;

  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: 0 1px 0 rgba(0,0,0,.01);
}

.form-step textarea{ min-height: 130px; resize: vertical; }

.form-step input:focus,
.form-step select:focus,
.form-step textarea:focus{
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(59,130,246,.18);
}

/* Select flèche */
.form-step select{
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%),
    linear-gradient(to right, transparent, transparent);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 13px) calc(50% - 3px),
    calc(100% - 2.2rem) 0;
  background-size: 6px 6px, 6px 6px, 1px 100%;
  background-repeat: no-repeat;
  padding-right: 2.6rem;
}

/* =========================================================
   10) Erreurs Django
========================================================= */

.form-step .error-message,
.form-step .errorlist{
  max-width: 70ch;
  margin-left: auto;
  margin-right: auto;

  border: 1px solid #fecaca;
  background: #fff1f2;
  color: #7f1d1d;
  border-radius: 12px;
  padding: .6rem .75rem;
  list-style: none;
}

.form-step .errorlist li{ margin:.15rem 0; }

/* =========================================================
   11) Actions (boutons)
========================================================= */

.form-step .actions{
  display:flex;
  gap: .65rem;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;

  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}

.form-step .actions .btn{ min-width: 170px; }

@media (max-width: 520px){
  .form-step .actions{
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .form-step .actions .btn{
    width: 100%;
    min-width: 0;
  }
}

/* Réduction mouvements */
@media (prefers-reduced-motion: reduce){
  .form-step{ animation: none !important; }
}

/* =========================================================
   MEDICAL STEP — UI moderne (scopé)
========================================================= */

.medical-note .info-card{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
}

.medical-confidential{
  background: linear-gradient(135deg, rgba(59,130,246,.08), rgba(139,92,246,.08));
  border: 1px solid color-mix(in oklab, var(--primary) 35%, var(--border));
  border-radius: 14px;
  padding: .85rem 1rem;
}

.medical-confidential .medical-icon{
  color: var(--primary);
  margin-top: .15rem;
  flex: 0 0 auto;
}

.medical-confidential .muted{
  color: var(--text-light);
}

/* petite aide sous champs (notes, groupe sanguin) */
.field-help{
  margin: .4rem 0 0;
  color: var(--text-light);
  font-size: .88rem;
  line-height: 1.45;
}

/* Conditions : grille responsive qui utilise bien la largeur */
.conditions-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(10px, 1.2vw, 14px);
}

/* Tablette: 2 colonnes */
@media (max-width: 980px){
  .conditions-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Mobile: 1 colonne */
@media (max-width: 640px){
  .conditions-grid{ grid-template-columns: 1fr; }
}

/* Ligne checkbox : look moderne, cliquable, accessible */
.checkbox-line{
  display:flex;
  align-items:flex-start;
  gap:.65rem;
  padding:.7rem .75rem;
  border: 1px solid color-mix(in oklab, var(--border) 90%, transparent);
  border-radius: 14px;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  cursor:pointer;
  user-select:none;
  transition: transform .12s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.checkbox-line:hover{
  transform: translateY(-1px);
  border-color: color-mix(in oklab, var(--primary) 25%, var(--border));
  box-shadow: 0 10px 18px rgba(0,0,0,.06);
}

.checkbox-line input[type="checkbox"]{
  margin-top: .12rem;
  width: 1.1rem;
  height: 1.1rem;
  accent-color: var(--primary);
  flex: 0 0 auto;
}

.checkbox-text{
  line-height: 1.35;
}

/* =========================================================
   MOTO STEP — alignement parfait (3 champs)
========================================================= */

.grid-3.grid-3-moto{
  align-items: start;
}

/* Chaque item en colonne + labels alignés */
.grid-3.grid-3-moto .form-group{
  display:flex;
  flex-direction:column;
  align-items:stretch;
}

/* Réserve une hauteur label stable -> inputs parfaitement alignés */
.grid-3.grid-3-moto .form-group > label{
  display:flex;
  align-items:flex-end;
  min-height: 2.7em; /* ~2 lignes */
}

/* Tablette: marque sur 1 ligne + deux champs dessous si besoin */
@media (max-width: 980px){
  .grid-3.grid-3-moto{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-3.grid-3-moto .form-group:first-child{
    grid-column: 1 / -1; /* marque sur toute la ligne */
  }
}

/* Mobile : 1 colonne */
@media (max-width: 640px){
  .grid-3.grid-3-moto{
    grid-template-columns: 1fr;
  }
  .grid-3.grid-3-moto .form-group:first-child{
    grid-column: auto;
  }
}

/* =========================================================
   PASSAGER CHOIX — Toggle pro (sans inline CSS)
========================================================= */

.toggle-card{
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 14px;
  padding: clamp(12px, 2vw, 16px);
}

/* Label toggle = zone cliquable large */
.toggle-label{
  display:flex;
  align-items:center;
  gap: 1rem;
  cursor: pointer;
  user-select: none;
  padding: .25rem 0;
}

/* Cache la checkbox native (reste accessible) */
.toggle-label input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* Switch */
.toggle-switch-custom{
  position: relative;
  display: inline-block;
  width: 3.5rem;
  height: 2rem;
  border-radius: 999px;

  background: color-mix(in oklab, var(--text) 12%, var(--border));
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);

  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
  flex: 0 0 auto;
}

/* Rond */
.toggle-switch-custom::after{
  content: "";
  position: absolute;
  top: 0.25rem;
  left: 0.25rem;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 6px 14px rgba(0,0,0,.18);
  transition: transform .2s ease;
}

/* Etat coché */
.toggle-label input[type="checkbox"]:checked + .toggle-switch-custom{
  background: linear-gradient(135deg, var(--primary), #8b5cf6);
  border-color: transparent;
}

.toggle-label input[type="checkbox"]:checked + .toggle-switch-custom::after{
  transform: translateX(1.5rem);
}

/* Focus accessible */
.toggle-label input[type="checkbox"]:focus-visible + .toggle-switch-custom{
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 35%, transparent);
}

/* Texte */
.toggle-text{
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}

/* Help */
.toggle-help{
  margin: .6rem 0 0;
  color: var(--text-light);
  font-size: .95rem;
  line-height: 1.6;
  max-width: 75ch;
}

/* Responsive: sur mobile on garde tout lisible */
@media (max-width: 520px){
  .toggle-label{
    gap: .75rem;
  }
  .toggle-text{
    font-size: .98rem;
  }
}

/* =========================================================
   OPTIONS — cards checkbox responsive (sans inline CSS)
========================================================= */

.options-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--field-gap);
}

@media (max-width: 820px){
  .options-grid{ grid-template-columns: 1fr; }
}

/* Card */
.option-card{
  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 14px;
  padding: clamp(12px, 2vw, 16px);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

/* Ligne cliquable */
.option-check{
  display:flex;
  align-items:flex-start;
  gap: .9rem;
  cursor: pointer;
  user-select: none;
}

/* Checkbox native cachée (accessible) */
.option-check input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* UI checkbox (custom) */
.option-ui{
  width: 1.3rem;
  height: 1.3rem;
  border-radius: .35rem;
  border: 1px solid color-mix(in oklab, var(--border) 90%, transparent);
  background: var(--bg);
  box-shadow: inset 0 0 0 2px color-mix(in oklab, var(--border) 75%, transparent);
  flex: 0 0 auto;
  margin-top: .15rem;
  position: relative;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .06s ease;
}

/* Check visible */
.option-check input[type="checkbox"]:checked + .option-ui{
  background: linear-gradient(135deg, var(--primary), #8b5cf6);
  border-color: transparent;
  box-shadow: 0 10px 22px rgba(99,102,241,.22);
}

.option-check input[type="checkbox"]:checked + .option-ui::after{
  content:"";
  position:absolute;
  left: .44rem;
  top: .20rem;
  width: .35rem;
  height: .70rem;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* Focus clavier */
.option-check input[type="checkbox"]:focus-visible + .option-ui{
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 35%, transparent), inset 0 0 0 2px color-mix(in oklab, var(--border) 75%, transparent);
}

/* Text */
.option-main{ display:flex; flex-direction:column; gap:.35rem; min-width:0; }
.option-title{
  font-weight: 800;
  color: var(--text);
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.option-help{
  color: var(--text-light);
  font-size: .92rem;
  line-height: 1.55;
}

/* Astérisque option required (si utilisé) */
.req-star{
  color: var(--error);
  font-weight: 900;
  margin-left: .25rem;
}

/* Non checkbox fields */
.option-noncheck label{
  margin-bottom: .55rem;
  font-weight: 700;
}

/* Info card spécifique options */
.info-card--options{
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid color-mix(in oklab, var(--primary) 25%, var(--border));
  border-left: 4px solid var(--primary);
  border-radius: 14px;
}

/* =========================================================
   OPTIONS — CHECKBOX BLEU ULTRA VISIBLE (FIX FINAL)
   À coller tout en bas de step.css
========================================================= */

/* Scope correct */
.step-options .option-check{
  display:grid;
  grid-template-columns: 56px 1fr;
  gap: 12px;
  align-items: start;
  cursor: pointer;
  user-select: none;
}

/* Cache input natif mais accessible */
.step-options .option-check input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}

/* ✅ OFF state : visible + bleu (pas noir/blanc) */
.step-options .option-ui{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;

  /* bleu visible même non coché */
  background: rgba(59,130,246,.08);
  border: 2px solid rgba(59,130,246,.55);
  box-shadow: 0 8px 18px rgba(59,130,246,.10);

  flex: 0 0 auto;
  margin-top: 2px;
  position: relative;

  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .08s ease;
}

/* Petit “tick” très léger en OFF (optionnel mais aide la visibilité) */
.step-options .option-ui::after{
  content:"";
  width: 12px;
  height: 20px;
  border: solid rgba(59,130,246,.35);
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
  margin-top: -2px;
}

/* ✅ ON state : bleu plein + check blanc */
.step-options .option-check input[type="checkbox"]:checked + .option-ui{
  background: linear-gradient(135deg, #3b82f6, #2563eb);
  border-color: rgba(37,99,235,1);
  box-shadow: 0 14px 28px rgba(37,99,235,.25);
}

.step-options .option-check input[type="checkbox"]:checked + .option-ui::after{
  border-color: #fff;
}

/* Focus clavier (accessible) */
.step-options .option-check input[type="checkbox"]:focus-visible + .option-ui{
  box-shadow: 0 0 0 4px rgba(59,130,246,.25), 0 14px 28px rgba(37,99,235,.20);
}

/* Mobile */
@media (max-width: 520px){
  .step-options .option-check{ grid-template-columns: 50px 1fr; }
  .step-options .option-ui{
    width: 40px;
    height: 40px;
    border-radius: 13px;
  }
}


/* =========================================
   CONTACTS — 2 cards sur la même ligne
========================================= */

.contacts-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--section-gap);
  align-items: start;
}

/* Tablet/Mobile => 1 colonne */
@media (max-width: 980px){
  .contacts-grid{
    grid-template-columns: 1fr;
  }
}

/* Card interne contact (cohérente avec step-section) */
.contact-card{
  background: color-mix(in oklab, var(--bg) 96%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 16px;
  padding: clamp(12px, 1.8vw, 16px);
  box-shadow: 0 8px 18px rgba(0,0,0,.04);
  min-width: 0;
}

.contact-title{
  margin: 0 0 .9rem;
  font-size: 1.05rem;
  font-weight: 850;
  letter-spacing: -.01em;
  color: var(--text);
}

/* Sur mobile très petit */
@media (max-width: 420px){
  .contact-card{
    border-radius: 14px;
    padding: 12px;
  }
}

/* =========================================
   DOCUMENTS — upload pro + responsive
========================================= */

/* Guidelines */
.doc-guidelines{
  max-width: var(--wizard-max);
  margin: 0 auto 1rem;
  background: color-mix(in oklab, var(--bg) 96%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 16px;
  padding: .9rem 1rem;
  box-shadow: 0 8px 18px rgba(0,0,0,.04);
  font-size: .95rem;
}

.doc-guidelines ul{ margin:.25rem 0 0 1rem; padding:0; }
.doc-guidelines li{ margin:.25rem 0; line-height:1.5; }

/* Grid docs */
.docs-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--section-gap);
  align-items: start;
}

@media (max-width: 980px){
  .docs-grid{ grid-template-columns: 1fr; }
}

.doc-field{
  min-width: 0;
}

/* Bloc fichier actuel */
.current-file{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  justify-content:space-between;
  align-items:center;

  background: color-mix(in oklab, var(--bg) 92%, transparent);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: .6rem .75rem;
  margin: .35rem 0 .55rem;
}

.current-file-main{
  display:flex;
  align-items:center;
  gap:.55rem;
  min-width: 220px;
  overflow-wrap:anywhere;
}

.current-file a{
  text-decoration: none;
  color: var(--text);
  font-weight: 650;
}

.current-file a:hover{
  text-decoration: underline;
}

.current-file .badge{
  font-size:.8rem;
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.18);
  padding: .12rem .55rem;
  border-radius: 999px;
}

/* Zone upload */
.file-upload[data-collapsed="1"] input[type="file"]{
  display:none;
}

/* Le bouton d’upload */
.file-upload-btn{
  position: relative;
  display:flex;
  align-items:center;
  gap:.6rem;
  flex-wrap: wrap;

  border: 1px dashed color-mix(in oklab, var(--border) 80%, transparent);
  border-radius: 14px;
  padding: .75rem .85rem;
  cursor: pointer;

  background: color-mix(in oklab, var(--bg) 96%, transparent);
  transition: border-color .2s ease, box-shadow .2s ease, transform .08s ease;
}

.file-upload-btn:hover{
  border-color: color-mix(in oklab, var(--primary) 55%, var(--border));
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.file-upload-btn:active{
  transform: translateY(1px);
}

.file-upload-btn input[type="file"]{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}

.file-upload-text{
  font-weight: 700;
}

.file-name{
  font-size:.92rem;
  opacity:.82;
}

/* Meta chips */
.file-meta{
  display:flex;
  gap:.55rem;
  align-items:center;
  margin-top:.55rem;
  flex-wrap:wrap;
}

.chip{
  display:inline-block;
  padding:.18rem .55rem;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:.82rem;
  background: color-mix(in oklab, var(--bg) 96%, transparent);
}

.btn-xs{
  font-size:.82rem;
  padding:.18rem .45rem;
  border-radius:.55rem;
}

.btn-ghost{
  background:transparent;
  border:1px solid var(--border);
}

/* Preview */
.preview{
  margin-top:.6rem;
}

.preview img{
  max-width:100%;
  height:auto;
  display:block;
  border-radius: 12px;
  border:1px solid var(--border);
}

.preview .preview-info{
  font-size:.85rem;
  opacity:.85;
  margin-top:.3rem;
}

/* Inline warning */
.inline-warning{
  margin-top:.55rem;
  font-size:.9rem;
  color:#9a3412;
  background:#fff7ed;
  border:1px solid #fed7aa;
  padding:.55rem .65rem;
  border-radius: 12px;
}

/* Uploading message */
.uploading{
  margin-top:.55rem;
  font-size:.95rem;
  opacity:.9;
}

/* Mobile: current-file stack */
@media (max-width: 640px){
  .current-file{
    flex-direction: column;
    align-items:flex-start;
  }
}

/* =========================================
   DÉCHARGE — terms + signature (responsive)
========================================= */

.section-head-row{
  display:flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

/* Terms scroll */
.terms-scroll{
  max-height: 360px;
  overflow: auto;
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 14px;
  padding: 14px;
  background: color-mix(in oklab, var(--bg) 92%, transparent);
}

@media (max-width: 768px){
  .terms-scroll{ max-height: 320px; }
}

/* Harmonise le contenu HTML injecté (decharge_html) */
.terms h3{ margin: 0 0 .5rem; }
.terms .muted{ opacity: .82; }
.terms ul, .terms-list{ padding-left: 1.2rem; }
.terms li{ margin: .35rem 0; line-height: 1.55; }
.signature-hints{ opacity: .85; margin-top: .75rem; }

/* Acceptation (toggle check moderne) */
.ack-row{
  margin-top: 12px;
  display:flex;
  flex-direction: column;
  gap: .35rem;
}

.toggle-check{
  display:flex;
  align-items:center;
  gap:.75rem;
  cursor:pointer;
  user-select:none;
  padding: .4rem 0;
}

.toggle-check input[type="checkbox"]{
  position:absolute;
  opacity:0;
  width:0;
  height:0;
}

.toggle-ui{
  width: 3.1rem;
  height: 1.85rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--text) 35%, transparent);
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  position: relative;
  transition: .2s ease;
}

.toggle-ui::after{
  content:"";
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 999px;
  background: #fff;
  position:absolute;
  top: 50%;
  left: .24rem;
  transform: translateY(-50%);
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
  transition: .2s ease;
}

.toggle-check input[type="checkbox"]:checked + .toggle-ui{
  background: color-mix(in oklab, var(--primary) 75%, transparent);
  border-color: color-mix(in oklab, var(--primary) 70%, var(--border));
}

.toggle-check input[type="checkbox"]:checked + .toggle-ui::after{
  transform: translateY(-50%) translateX(1.25rem);
}

.toggle-check input[type="checkbox"]:focus-visible + .toggle-ui{
  box-shadow: 0 0 0 3px rgba(59,130,246,.25);
}

.toggle-text{
  font-weight: 650;
}

/* Signature */
.sig-card{
  border: 1px dashed color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 16px;
  padding: 12px;
  background: color-mix(in oklab, var(--bg) 94%, transparent);
}

.sig-canvas-wrap{
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  background: var(--bg);
}

.sig-canvas{
  width: 100%;
  height: 240px;
  display:block;
  touch-action: none;
  background: var(--bg);
}

@media (max-width: 520px){
  .sig-canvas{ height: 220px; }
}

.sig-actions{
  margin-top: 10px;
  display:flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.sig-hint{
  opacity: .78;
  font-size: .92rem;
}

.sig-existing{
  margin-top: 12px;
  display:flex;
  flex-direction: column;
  gap: 8px;
}

.sig-existing-img{
  max-width: 100%;
  height: auto;
  border: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
  border-radius: 14px;
  background: var(--bg);
}

/* Loader bouton submit (pro) */
.btn.is-loading{
  opacity: .92;
  cursor: not-allowed;
}

.btn-spinner{
  width: 16px;
  height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,.35);
  border-top-color: rgba(255,255,255,1);
  display:inline-block;
  animation: spin .75s linear infinite;
}

@keyframes spin{ to{ transform: rotate(360deg); } }

/* =========================================================
   DÉCHARGE — FIX lisibilité + marge + toggle
   (à coller tout en bas de step.css)
========================================================= */

/* Le bloc qui contient le HTML de décharge */
.page-wizard .terms-scroll{
  margin-top: .6rem;
  margin-bottom: 1rem;                 /* ✅ vraie marge avant l’acceptation */
  min-height: 240px;                   /* ✅ évite “petit champ vide” */
  max-height: 360px;
  overflow: auto;

  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;

  background: color-mix(in oklab, var(--bg) 92%, white);
  color: var(--text);                  /* ✅ force la lisibilité */
  box-shadow: inset 0 1px 0 rgba(0,0,0,.02);
}

/* Contenu interne rendu par _decharge_contenu.html */
.page-wizard .terms-scroll .terms{
  color: inherit;
}
.page-wizard .terms-scroll .terms h3{
  margin: 0 0 .75rem;
  font-size: 1.05rem;
}
.page-wizard .terms-scroll .terms p{
  margin: .6rem 0;
  line-height: 1.65;
}
.page-wizard .terms-scroll .terms ul{
  margin: .5rem 0;
  padding-left: 1.25rem;
}
.page-wizard .terms-scroll .terms li{
  margin: .35rem 0;
  line-height: 1.55;
}

/* Ligne d’acceptation (séparée et respirante) */
.page-wizard .ack-row{
  margin-top: 1rem;
  padding-top: .9rem;
  border-top: 1px dashed color-mix(in oklab, var(--border) 75%, transparent);
}

/* Toggle (checkbox stylée) */
.page-wizard .toggle-check{
  display: flex;
  align-items: center;
  gap: .75rem;
  cursor: pointer;
  user-select: none;
}

/* Cache la checkbox native mais reste accessible */
.page-wizard .toggle-check input[type="checkbox"]{
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}

/* UI du switch */
.page-wizard .toggle-ui{
  width: 3.3rem;
  height: 1.9rem;
  border-radius: 999px;
  background: color-mix(in oklab, var(--text) 22%, var(--bg));
  border: 1px solid var(--border);
  position: relative;
  flex: 0 0 auto;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

/* Le rond */
.page-wizard .toggle-ui::after{
  content: "";
  position: absolute;
  top: 50%;
  left: .22rem;
  transform: translateY(-50%);
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 6px 14px rgba(0,0,0,.12);
  transition: transform .2s ease;
}

/* Checked -> switch ON */
.page-wizard .toggle-check input[type="checkbox"]:checked + .toggle-ui{
  background: color-mix(in oklab, var(--primary) 78%, var(--bg));
  border-color: color-mix(in oklab, var(--primary) 70%, var(--border));
}
.page-wizard .toggle-check input[type="checkbox"]:checked + .toggle-ui::after{
  transform: translate(1.35rem, -50%);
}

/* Focus accessibilité */
.page-wizard .toggle-check input[type="checkbox"]:focus-visible + .toggle-ui{
  box-shadow: 0 0 0 3px rgba(59,130,246,.25);
}

/* Texte à droite */
.page-wizard .toggle-text{
  font-weight: 650;
  line-height: 1.35;
}

/* Mobile : un peu plus compact */
@media (max-width: 520px){
  .page-wizard .terms-scroll{
    min-height: 220px;
    padding: 12px 12px;
  }
}

/* =========================================================
   DÉCHARGE — FIX "texte invisible" (override des styles .terms)
   À COLLER TOUT EN BAS du step.css
========================================================= */

/* Le wrapper */
.page-wizard .terms-scroll{
  color: var(--text) !important;
  font-size: .98rem;
  line-height: 1.65;
  opacity: 1 !important;
  visibility: visible !important;
}

/* ✅ Force la couleur/visibilité sur TOUT le contenu rendu */
.page-wizard .terms-scroll *{
  color: var(--text) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* Titres/lists un peu plus clean */
.page-wizard .terms-scroll h1,
.page-wizard .terms-scroll h2,
.page-wizard .terms-scroll h3{
  color: var(--text) !important;
  margin: 0 0 .75rem;
}

.page-wizard .terms-scroll a{
  color: var(--primary) !important;
  text-decoration: underline;
}

/* ===== Passager: 2 lignes x 3 champs (responsive) ===== */
.grid-3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.grid-3.grid-top{ margin-top: 12px; }

.form-wide{ margin-top: 12px; }

/* tablette -> 2 colonnes */
@media (max-width: 900px){
  .grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* mobile -> 1 colonne */
@media (max-width: 560px){
  .grid-3{ grid-template-columns: 1fr; }
}

/* =========================================================
   WIZARD — FIX TEXTE ETAPE ACTIVE + COMPACT (FINAL)
   À COLLER TOUT EN BAS de step.css
========================================================= */

/* 1) Rendre le wizard plus compact (libère de la place) */
.page-wizard .wizard-head{
  padding: .55rem .7rem !important;
  border-radius: 14px !important;
}

.page-wizard .wizard-head .page-title{
  font-size: clamp(1.05rem, 1.4vw, 1.35rem) !important;
  margin: .05rem 0 .35rem !important;
  line-height: 1.15 !important;
}

/* Progress plus fine */
.page-wizard .progress-container{
  height: .42rem !important;
  margin: .35rem 0 .55rem !important;
}

/* 2) Chips encore plus petites */
.page-wizard .step-indicator{
  gap: .35rem !important;
  padding: .05rem 0 !important;
}

.page-wizard .step{
  padding: .28rem .52rem .28rem .34rem !important;
  font-size: .78rem !important;
  font-weight: 750 !important;
}

.page-wizard .step-number{
  width: 1.22rem !important;
  height: 1.22rem !important;
  font-size: .66rem !important;
  font-weight: 900 !important;
}

/* 3) ✅ FIX: texte de l’étape active invisible (annule gradient/transparent) */
.page-wizard .step.active,
.page-wizard .step.active *{
  color: #fff !important;
  opacity: 1 !important;
  visibility: visible !important;

  /* annule les styles “texte transparent” */
  -webkit-text-fill-color: #fff !important;
  /* background: none !important; */
  -webkit-background-clip: border-box !important;
          background-clip: border-box !important;
}

/* Si tes steps sont des <a> ou <button> */
.page-wizard .step a,
.page-wizard .step .step-link{
  color: inherit !important;
  text-decoration: none !important;
  -webkit-text-fill-color: inherit !important;
}

/* 4) Titre de page (hero) plus petit aussi */
.page-wizard .step-title{
  font-size: clamp(1.1rem, 2vw, 1.55rem) !important;
  margin: 0 0 .25rem !important;
}
.page-wizard .step-subtitle{
  font-size: clamp(.92rem, 1.8vw, 1rem) !important;
}

/* =========================================================
   WIZARD — état "cliquable mais pas encore complété"
   Usage: <li class="step pending">…</li>
   ou     <li class="step" data-state="pending">…</li>
========================================================= */

/* Variante 1: classe .pending */
.step.pending{
  /* on garde l’aspect “clic” mais plus soft que active/completed */
  background: color-mix(in oklab, var(--bg) 92%, var(--primary) 8%);
  border-color: color-mix(in oklab, var(--primary) 30%, var(--border));
  color: color-mix(in oklab, var(--text) 75%, var(--text-light));
  cursor: pointer;

  /* petit liseré + profondeur subtile */
  box-shadow:
    0 8px 16px rgba(0,0,0,.04),
    inset 0 0 0 1px rgba(59,130,246,.08);
}

/* Le numéro aussi "en attente" */
.step.pending .step-number{
  background: color-mix(in oklab, var(--bg) 88%, var(--primary) 12%);
  box-shadow: inset 0 0 0 2px color-mix(in oklab, var(--primary) 35%, var(--border));
}

/* Hover : confirme que c’est cliquable */
@media (hover:hover){
  .step.pending:hover{
    transform: translateY(-1px);
    border-color: color-mix(in oklab, var(--primary) 45%, var(--border));
    box-shadow:
      0 12px 22px rgba(0,0,0,.06),
      inset 0 0 0 1px rgba(59,130,246,.14);
  }
}

/* Focus clavier : anneau visible */
.step.pending .step-link:focus-visible,
.step.pending a:focus-visible{
  outline: 3px solid color-mix(in srgb, var(--primary) 45%, transparent);
  outline-offset: 2px;
}

/* Petite pastille "•" optionnelle pour signaler "à compléter" */
.step.pending::after{
  content: "•";
  margin-left: .25rem;
  color: color-mix(in oklab, var(--primary) 70%, var(--text-light));
  font-weight: 900;
  line-height: 1;
  transform: translateY(-1px);
}

/* Variante 2: data-state (si tu préfères éviter les classes) */
/*.step[data-state="pending"]{*/ /* même style que .pending */ /*}*/
/* .step[data-state="pending"] .step-number{ } */

/* =========================================================
   FIX NUMÉROS ÉTAPES INVISIBLES (create + edit)
   À COLLER TOUT EN BAS de step.css
========================================================= */

/* 1) Force l’affichage des chiffres dans le rond */
.page-wizard .step .step-number{
  position: relative;               /* utile pour ::after du check */
  z-index: 1;

  color: var(--text) !important;
  -webkit-text-fill-color: var(--text) !important;

  opacity: 1 !important;
  visibility: visible !important;
}

/* 2) Active: numéro blanc dans le rond */
.page-wizard .step.active .step-number{
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  background: rgba(255,255,255,.18) !important;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.35) !important;
}

/* 3) Completed: on cache le chiffre et on affiche ✓ */
.page-wizard .step.completed .step-number{
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  background: rgba(255,255,255,.18) !important;
}

.page-wizard .step.completed .step-number::after{
  content: "✓";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  font-size: .9rem;
  font-weight: 900;
}

/* 4) Sécurité: le lien ne doit plus écraser le fill-color du numéro */
.page-wizard .step a .step-number,
.page-wizard .step .step-link .step-number{
  -webkit-text-fill-color: unset !important; /* laisse la règle ci-dessus gagner */
}

/* =========================================================
   FIX: numéros/✓ invisibles dans le wizard
   (compatible create + edit)
   À COLLER TOUT EN BAS de step.css
========================================================= */

/* 1) Le ✓ doit se positionner DANS le rond */
.page-wizard .wizard-head .step-number{
  position: relative;                 /* ✅ clé */
  display: grid;
  place-items: center;
  overflow: hidden;
}

/* 2) Completed : chiffre invisible, ✓ visible AU CENTRE */
.page-wizard .wizard-head .step.completed .step-number{
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
}

.page-wizard .wizard-head .step.completed .step-number::after{
  content: "✓";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  font-size: .9rem;
  font-weight: 900;
  pointer-events: none;
}

/* 3) Active : numéro bien visible */
.page-wizard .wizard-head .step.active .step-number{
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

.page-wizard .wizard-head .step-label{
  font-weight: 750;
  font-size: .78rem;
  line-height: 1;
  color: inherit;
  background: none !important;
  -webkit-text-fill-color: inherit !important;
}
