.elementor-1536 .elementor-element.elementor-element-c0000001{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-yojtnuu{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-esrn2b9{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-0fae050{--display:flex;}.elementor-1536 .elementor-element.elementor-element-cd06c68 .fluentform-widget-wrapper .ff-el-group .ff-btn-submit{background-color:#1a7efb !important;color:#ffffff !important;}.elementor-1536 .elementor-element.elementor-element-aj4d0ic{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-c0000009{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-c000000b{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-c000000d{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1536 .elementor-element.elementor-element-c0000011{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for fluent-form-widget, class: .elementor-element-cd06c68 *//* =============================================================
   GD LIGHT — FLUENT FORMS MULTI-ÉTAPES (4 étapes)
   Couleur principale : #589936 (vert) · version FOND CLAIR

   À ADAPTER si besoin :
   • #589936  → COULEUR ACCENT GD Light
   • #3f6f26  → ACCENT foncé (hover, variante) — facultatif
   • #ffffff  → COULEUR DU FOND derrière le formulaire (cercles inactifs)
   ============================================================= */

/* --- Radios en pilules (UNIQUEMENT les radios, pas les checkbox) --- */
.ff-el-form-check:has(input[type="radio"]) {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}

.ff-el-form-check label:has(input[type="radio"]) {
  border: 2px solid #d1d5db;
  border-radius: 50px;
  padding: 14px 18px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  transition: all 0.25s ease;
  background: #fff;
  color: #333;
  display: block;
  text-align: center;
}

.ff-el-form-check input[type="radio"] {
  display: none;
}

.ff-el-form-check label:has(input[type="radio"]):hover {
  border-color: #589936;   /* ACCENT */
  color: #589936;          /* ACCENT */
}

.ff-el-form-check label:has(input[type="radio"]:checked) {
  background: #589936;     /* ACCENT */
  color: #fff;             /* TEXTE SUR ACCENT (blanc, le vert est foncé) */
  border-color: #589936;   /* ACCENT */
}

/* --- Barre de progression / étapes --- */
.fluentform .ff-step-titles {
  display: flex;
  justify-content: space-between;
  margin: 0 0 30px;
  padding: 0;
  position: relative;
}

/* Ligne de fond unique */
.fluentform .ff-step-titles:before {
  content: "";
  position: absolute;
  top: 18px;
  left: 12%;
  right: 12%;
  height: 2px;
  background: #d1d5db;
  z-index: 0;
}

/* Masquer les lignes natives */
.fluentform .ff-step-titles li:after { display: none !important; }

.fluentform .ff-step-titles li {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  color: #999;
  padding: 0 5px;
  flex: 1;
  text-align: center;
  position: relative;
}

/* Cercles numérotés (inactifs) */
.fluentform .ff-step-titles li:before {
  background: #ffffff;     /* FOND : doit masquer la ligne */
  border: 2px solid #d1d5db;
  border-radius: 50%;
  color: #999;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  width: 36px;
  height: 36px;
  min-width: 36px;
  line-height: 1;
  margin: 0 auto 8px;
  position: relative;
  z-index: 2;
  transition: all 0.3s ease;
}

/* Numéros forcés — 4 étapes */
.fluentform .ff-step-titles li:nth-child(1):before { content: "1"; }
.fluentform .ff-step-titles li:nth-child(2):before { content: "2"; }
.fluentform .ff-step-titles li:nth-child(3):before { content: "3"; }
.fluentform .ff-step-titles li:nth-child(4):before { content: "4"; }

/* Étape active */
.fluentform .ff-step-titles li.ff_active { color: #589936; }
.fluentform .ff-step-titles li.ff_active:before {
  background: #589936;     /* ACCENT */
  border-color: #589936;   /* ACCENT */
  color: #fff;             /* TEXTE SUR ACCENT */
}

/* Étape complétée */
.fluentform .ff-step-titles li.ff_completed { color: #589936; }
.fluentform .ff-step-titles li.ff_completed:before {
  background: #589936;     /* ACCENT */
  border-color: #589936;   /* ACCENT */
  color: #fff;             /* TEXTE SUR ACCENT */
  content: "\2713" !important;
  font-size: 16px;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .ff-el-form-check:has(input[type="radio"]) {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .ff-el-form-check label:has(input[type="radio"]) {
    padding: 12px 14px;
    font-size: 14px;
  }
  .fluentform .ff-step-titles li { font-size: 0; padding: 0 3px; }
  .fluentform .ff-step-titles li:before {
    width: 30px; height: 30px; min-width: 30px; font-size: 12px;
  }
  .fluentform .ff-step-titles:before { top: 15px; }
}

@media (max-width: 480px) {
  .ff-el-form-check:has(input[type="radio"]) {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}/* End custom CSS */