/* ═══════════════════════════════════════════════════════════════
   Escale Stages — Front CSS V1.2.1
   ═══════════════════════════════════════════════════════════════
   Toutes les règles sont préfixées par .escale-stages-app pour
   neutraliser les styles du thème Hello Elementor qui écrase le
   letter-spacing et autres propriétés typographiques.
   ═══════════════════════════════════════════════════════════════ */

/* ─── RESET GLOBAL CONTRE LE THEME ───────────────────────────── */
.escale-stages-app,
.escale-stages-app * {
  letter-spacing: normal !important;
  word-spacing: normal !important;
  text-transform: none;
  box-sizing: border-box;
}

.escale-stages-app {
  font-family: 'Lato', sans-serif;
  max-width: 960px;
  margin: 0 auto;
  padding: 20px 0;
  color: #2D1A24;
}

/* ─── TITRE ET SOUS-TITRE DE SECTION ─────────────────────────── */
.escale-stages-app .esc-section-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 30px !important;
  font-weight: 600 !important;
  color: #5C1A2E !important;
  text-align: center !important;
  margin: 0 0 10px 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-section-sub {
  text-align: center !important;
  color: #5C3A4A !important;
  font-size: 14px !important;
  margin: 0 0 36px 0 !important;
  padding: 0 !important;
  line-height: 1.5 !important;
  font-family: 'Lato', sans-serif !important;
  letter-spacing: normal !important;
}

/* ═══════════════════════════════════════════════════════════════
   SÉLECTEUR DE STAGES — 4 BOUTONS
   ═══════════════════════════════════════════════════════════════ */
.escale-stages-app .esc-stage-selector {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  justify-content: center !important;
  margin: 0 auto !important;
}

.escale-stages-app .esc-stage-btn {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  padding: 24px 20px !important;
  width: 200px !important;
  min-height: 160px !important;
  background: #FFFFFF !important;
  border: 1.5px solid rgba(200, 24, 90, 0.18) !important;
  border-radius: 14px !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  text-align: center !important;
  box-shadow: 0 1px 3px rgba(92, 26, 46, 0.04) !important;
  font-family: inherit !important;
  letter-spacing: normal !important;
  overflow: hidden !important;
}

.escale-stages-app .esc-stage-btn:hover {
  border-color: #C8185A !important;
  background: #FDF5FB !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 18px rgba(200, 24, 90, 0.12) !important;
}

.escale-stages-app .esc-stage-btn.active {
  border-color: #C8185A !important;
  background: #C8185A !important;
  box-shadow: 0 8px 22px rgba(200, 24, 90, 0.25) !important;
  transform: translateY(-3px) !important;
}

/* ─── NUMÉRO DANS LE CERCLE ──────────────────────────────────── */
.escale-stages-app .esc-stage-btn-num {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  border-radius: 50% !important;
  background: #FCE4F5 !important;
  color: #C8185A !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.25s ease !important;
  line-height: 1 !important;
  letter-spacing: normal !important;
  margin: 0 !important;
  padding: 0 !important;
}

.escale-stages-app .esc-stage-btn.active .esc-stage-btn-num {
  background: rgba(255, 255, 255, 0.25) !important;
  color: #FFFFFF !important;
}

/* ─── LABEL DU STAGE ─────────────────────────────────────────── */
.escale-stages-app .esc-stage-btn-label {
  font-family: 'Lato', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #5C1A2E !important;
  line-height: 1.3 !important;
  letter-spacing: normal !important;
  transition: color 0.25s ease !important;
  margin: 0 !important;
  padding: 0 !important;
  text-transform: none !important;
}

.escale-stages-app .esc-stage-btn.active .esc-stage-btn-label {
  color: #FFFFFF !important;
}

/* ─── NOMBRE DE DATES ────────────────────────────────────────── */
.escale-stages-app .esc-stage-btn-count {
  font-family: 'Lato', sans-serif !important;
  font-size: 11px !important;
  color: #9E7488 !important;
  margin-top: 4px !important;
  padding: 0 !important;
  line-height: 1.4 !important;
  letter-spacing: normal !important;
  transition: color 0.25s ease !important;
  text-transform: none !important;
}

.escale-stages-app .esc-stage-btn.active .esc-stage-btn-count {
  color: rgba(255, 255, 255, 0.85) !important;
}

/* ═══════════════════════════════════════════════════════════════
   PANNEAU DES DATES
   ═══════════════════════════════════════════════════════════════ */
.escale-stages-app .esc-dates-panel {
  margin-top: 24px !important;
  background: #FFFFFF !important;
  border-radius: 14px !important;
  border: 1px solid rgba(92, 26, 46, 0.12) !important;
  overflow: hidden !important;
  animation: escFadeDown 0.25s ease !important;
  box-shadow: 0 4px 12px rgba(92, 26, 46, 0.06) !important;
}

@keyframes escFadeDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.escale-stages-app .esc-dates-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 16px 24px !important;
  background: #5C1A2E !important;
}

.escale-stages-app .esc-dates-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 19px !important;
  font-weight: 600 !important;
  color: #FFFFFF !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-close-btn {
  font-family: 'Lato', sans-serif !important;
  font-size: 12px !important;
  color: rgba(255, 255, 255, 0.8) !important;
  background: none !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 20px !important;
  padding: 5px 14px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-close-btn:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #FFFFFF !important;
}

.escale-stages-app .esc-dates-grid {
  display: flex !important;
  flex-direction: column !important;
}

.escale-stages-app .esc-date-row {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 16px 24px !important;
  border-bottom: 1px solid rgba(92, 26, 46, 0.07) !important;
  transition: background 0.15s !important;
}

.escale-stages-app .esc-date-row:last-child {
  border-bottom: none !important;
}

.escale-stages-app .esc-date-row:hover {
  background: #FDF5FB !important;
}

.escale-stages-app .esc-date-pill {
  background: #FDF0F6 !important;
  border: 1px solid #F5C9DF !important;
  border-radius: 10px !important;
  padding: 8px 12px !important;
  text-align: center !important;
  min-width: 56px !important;
  flex-shrink: 0 !important;
}

.escale-stages-app .esc-date-day {
  font-size: 20px !important;
  font-weight: 500 !important;
  color: #C8185A !important;
  line-height: 1 !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-date-month {
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.07em !important;
  color: #5C1A2E !important;
  margin-top: 2px !important;
}

.escale-stages-app .esc-date-info {
  flex: 1 !important;
}

.escale-stages-app .esc-date-dates {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #2D1A24 !important;
  margin-bottom: 3px !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-date-meta {
  font-size: 12px !important;
  color: #8C6A7A !important;
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-date-action {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}

.escale-stages-app .esc-pl-ok,
.escale-stages-app .esc-pl-few,
.escale-stages-app .esc-pl-full {
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 10px !important;
  border-radius: 12px !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-pl-ok   { background: #EAF6ED !important; color: #1D7A3A !important; }
.escale-stages-app .esc-pl-few  { background: #FEF3E2 !important; color: #8A5200 !important; }
.escale-stages-app .esc-pl-full { background: #FDE8E8 !important; color: #9B1C1C !important; }

.escale-stages-app .esc-btn-inscr {
  font-family: 'Lato', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  padding: 9px 20px !important;
  background: #D81B7A !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 20px !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  white-space: nowrap !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
}

.escale-stages-app .esc-btn-inscr:hover {
  background: #5C1A2E !important;
}

.escale-stages-app .esc-dates-empty {
  padding: 32px !important;
  text-align: center !important;
  color: #8C6A7A !important;
  font-style: italic !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  letter-spacing: normal !important;
}

.escale-stages-app .esc-loading {
  text-align: center !important;
  color: #9E7488 !important;
  padding: 24px !important;
  font-size: 14px !important;
  letter-spacing: normal !important;
}

/* ═══════════════════════════════════════════════════════════════
   MODAL INSCRIPTION
   ═══════════════════════════════════════════════════════════════ */
.esc-backdrop {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(26, 10, 16, 0.55) !important;
  z-index: 9999 !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  overflow-y: auto !important;
  /* display est contrôlé par JS (none par défaut, flex quand ouvert)
     -- pas de !important pour ne pas bloquer le JS */
  display: none;
}

.esc-backdrop[style*="display: flex"],
.esc-backdrop[style*="display:flex"] {
  display: flex !important;
}

.esc-backdrop * {
  letter-spacing: normal !important;
  box-sizing: border-box !important;
}

.esc-modal {
  background: #FFFFFF !important;
  border-radius: 14px !important;
  width: 100% !important;
  max-width: 680px !important;
  max-height: 92vh !important;
  overflow-y: auto !important;
  animation: escUp 0.2s ease !important;
  font-family: 'Lato', sans-serif !important;
}

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

.esc-mhead {
  padding: 20px 24px 16px !important;
  border-bottom: 1px solid rgba(92, 26, 46, 0.12) !important;
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
}

.esc-mtitle {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 21px !important;
  font-weight: 600 !important;
  color: #2D1A24 !important;
  letter-spacing: normal !important;
  line-height: 1.3 !important;
  margin: 0 !important;
}

.esc-msub {
  font-size: 12px !important;
  color: #8C6A7A !important;
  margin-top: 3px !important;
  letter-spacing: normal !important;
}

.esc-mclose {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(200, 24, 90, 0.22) !important;
  background: #FFFFFF !important;
  cursor: pointer !important;
  font-size: 16px !important;
  color: #5C1A2E !important;
  flex-shrink: 0 !important;
  margin-left: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  line-height: 1 !important;
  pointer-events: auto !important;
  position: relative !important;
  z-index: 10 !important;
  font-family: 'Lato', sans-serif !important;
  transition: all 0.15s !important;
}

.esc-mclose:hover {
  background: #FDF0F6 !important;
  border-color: #C8185A !important;
  color: #C8185A !important;
}

.esc-mrecap {
  margin: 16px 24px 0 !important;
  padding: 12px 14px !important;
  background: #FDF0F6 !important;
  border-radius: 8px !important;
  border-left: 3px solid #C8185A !important;
}

.esc-mrecap p {
  font-size: 13px !important;
  color: #5C1A2E !important;
  margin: 0 0 2px 0 !important;
  letter-spacing: normal !important;
}

.esc-mform {
  padding: 16px 24px 22px !important;
}

.esc-section-head {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #FFFFFF !important;
  background: #5C1A2E !important;
  padding: 5px 10px !important;
  border-radius: 3px !important;
  margin: 16px 0 12px !important;
  display: block !important;
}

.esc-frow {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}

.esc-fg {
  margin-bottom: 10px !important;
}

.esc-lbl {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #5C3A4A !important;
  display: block !important;
  margin-bottom: 4px !important;
  letter-spacing: normal !important;
}

.esc-lbl span {
  color: #C8185A !important;
}

.esc-fi {
  width: 100% !important;
  padding: 9px 12px !important;
  font-size: 13px !important;
  border: 1px solid rgba(200, 24, 90, 0.22) !important;
  border-radius: 7px !important;
  background: #FFFFFF !important;
  color: #2D1A24 !important;
  outline: none !important;
  transition: border-color 0.15s !important;
  font-family: 'Lato', sans-serif !important;
  letter-spacing: normal !important;
}

.esc-fi:focus {
  border-color: #C8185A !important;
  box-shadow: 0 0 0 3px rgba(200, 24, 90, 0.07) !important;
}

.esc-divider {
  border: none !important;
  border-top: 1px solid rgba(92, 26, 46, 0.12) !important;
  margin: 14px 0 !important;
}

.esc-prix-box {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: #FEF9EC !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  margin: 12px 0 !important;
  border-left: 3px solid #C49A3C !important;
}

.esc-prix-label {
  font-size: 13px !important;
  color: #5C3A4A !important;
  letter-spacing: normal !important;
}

.esc-prix-sub {
  font-size: 11px !important;
  color: #8C6A7A !important;
  margin-top: 3px !important;
  letter-spacing: normal !important;
}

.esc-prix-val {
  font-size: 21px !important;
  font-weight: 600 !important;
  color: #C49A3C !important;
  letter-spacing: normal !important;
}

.esc-cheque-info {
  /* Conservé pour compatibilité ascendante, mais n'est plus utilisé en v1.2.7+ */
  background: rgba(200, 24, 90, 0.06) !important;
  border-radius: 6px !important;
  padding: 10px 13px !important;
  font-size: 12px !important;
  color: #5C3A4A !important;
  line-height: 1.6 !important;
  margin-bottom: 12px !important;
  letter-spacing: normal !important;
}

/* ══════════════════════════════════════════════════════════════
   Bloc INFO PAIEMENT EN LIGNE (remplace .esc-cheque-info)
   ══════════════════════════════════════════════════════════════ */
.esc-paiement-info {
  background: linear-gradient(135deg, rgba(200,24,90,0.06) 0%, rgba(200,24,90,0.02) 100%) !important;
  border: 1px solid rgba(200, 24, 90, 0.2) !important;
  border-radius: 8px !important;
  padding: 12px 15px !important;
  font-size: 12.5px !important;
  color: #5C3A4A !important;
  line-height: 1.65 !important;
  margin-bottom: 14px !important;
  letter-spacing: normal !important;
}
.esc-paiement-info strong {
  color: #5C1A2E !important;
}

/* ══════════════════════════════════════════════════════════════
   CASE À COCHER CGV / SIGNATURE ÉLECTRONIQUE
   ══════════════════════════════════════════════════════════════ */
.esc-cgv-box {
  background: #FDF0F6 !important;
  border: 1px solid rgba(200, 24, 90, 0.2) !important;
  border-left: 3px solid #C8185A !important;
  border-radius: 6px !important;
  padding: 12px 14px !important;
  margin-bottom: 14px !important;
}
.esc-cgv-label {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  cursor: pointer !important;
  font-size: 12.5px !important;
  color: #5C3A4A !important;
  line-height: 1.6 !important;
  letter-spacing: normal !important;
  font-family: 'Lato', sans-serif !important;
}
.esc-cgv-check {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  margin-top: 2px !important;
  accent-color: #C8185A !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
}
.esc-cgv-label strong {
  color: #5C1A2E !important;
  font-weight: 700 !important;
}
.esc-cgv-label .esc-required {
  color: #C8185A !important;
  font-weight: 700 !important;
  margin-left: 3px !important;
}

/* ══════════════════════════════════════════════════════════════
   ÉCRAN DE SUCCÈS : RÉFÉRENCE + BOUTON SUMUP
   ══════════════════════════════════════════════════════════════ */
.esc-suc-ref {
  background: #FDF0F6 !important;
  border: 1px solid rgba(200, 24, 90, 0.25) !important;
  border-radius: 10px !important;
  padding: 14px 18px !important;
  max-width: 380px !important;
  margin: 0 auto 18px !important;
  text-align: center !important;
}
.esc-suc-ref-label {
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #8C6A7A !important;
  margin-bottom: 6px !important;
}
.esc-suc-ref-value {
  font-family: 'Courier New', monospace !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  color: #5C1A2E !important;
  letter-spacing: 1px !important;
  margin-bottom: 8px !important;
  user-select: all !important;
}
.esc-suc-ref-help {
  font-size: 11px !important;
  color: #5C3A4A !important;
  line-height: 1.5 !important;
  letter-spacing: normal !important;
}
.esc-btn-sumup {
  display: inline-block !important;
  padding: 14px 32px !important;
  background: linear-gradient(135deg, #C8185A 0%, #5C1A2E 100%) !important;
  color: #FFFFFF !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  border-radius: 10px !important;
  margin-bottom: 14px !important;
  transition: all 0.2s !important;
  letter-spacing: normal !important;
  font-family: 'Lato', sans-serif !important;
  box-shadow: 0 4px 12px rgba(200, 24, 90, 0.25) !important;
}
.esc-btn-sumup:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 18px rgba(200, 24, 90, 0.35) !important;
  color: #FFFFFF !important;
}
.esc-suc-note {
  font-size: 11.5px !important;
  color: #8C6A7A !important;
  font-style: italic !important;
  max-width: 380px !important;
  margin: 0 auto 18px !important;
  line-height: 1.5 !important;
  letter-spacing: normal !important;
}

.esc-err {
  color: #9B1C1C !important;
  font-size: 12px !important;
  margin-bottom: 10px !important;
  letter-spacing: normal !important;
}

.esc-btn-sub {
  width: 100% !important;
  padding: 13px !important;
  background: #C8185A !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  font-family: 'Lato', sans-serif !important;
  letter-spacing: normal !important;
}

.esc-btn-sub:hover {
  background: #5C1A2E !important;
}

.esc-legal {
  font-size: 10px !important;
  color: #9E7488 !important;
  text-align: center !important;
  margin-top: 10px !important;
  line-height: 1.55 !important;
  letter-spacing: normal !important;
}

.esc-succes {
  padding: 36px 24px !important;
  text-align: center !important;
}

.esc-suc-icon {
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  background: #EAF6ED !important;
  color: #1D7A3A !important;
  font-size: 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto 14px !important;
}

.esc-suc-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 23px !important;
  color: #2D1A24 !important;
  margin-bottom: 10px !important;
  letter-spacing: normal !important;
}

.esc-suc-txt {
  font-size: 13px !important;
  color: #5C3A4A !important;
  max-width: 360px !important;
  margin: 0 auto 18px !important;
  line-height: 1.65 !important;
  letter-spacing: normal !important;
}

.esc-btn-sec {
  font-size: 13px !important;
  padding: 10px 24px !important;
  border: 1px solid rgba(200, 24, 90, 0.3) !important;
  border-radius: 20px !important;
  background: #FFFFFF !important;
  color: #5C3A4A !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  font-family: 'Lato', sans-serif !important;
  letter-spacing: normal !important;
}

.esc-btn-sec:hover {
  background: #FDF0F6 !important;
}

.esc-conjoint-toggle {
  margin: 12px 0 0 !important;
}

.esc-toggle-label {
  font-size: 13px !important;
  color: #5C3A4A !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  cursor: pointer !important;
  letter-spacing: normal !important;
}

.esc-conjoint-section {
  background: #FDF5FB !important;
  border-radius: 8px !important;
  padding: 16px !important;
  margin-top: 10px !important;
  border: 1px solid rgba(200, 24, 90, 0.15) !important;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

/* TABLETTE */
@media (max-width: 900px) {
  .escale-stages-app .esc-stage-btn {
    width: 180px !important;
    min-height: 150px !important;
    padding: 20px 16px !important;
  }
}

/* MOBILE */
@media (max-width: 640px) {
  .escale-stages-app .esc-stage-selector {
    gap: 12px !important;
  }
  .escale-stages-app .esc-stage-btn {
    width: calc(50% - 6px) !important;
    min-width: 140px !important;
    min-height: 140px !important;
    padding: 18px 12px !important;
  }
  .escale-stages-app .esc-stage-btn-label {
    font-size: 13px !important;
  }
  .escale-stages-app .esc-section-title {
    font-size: 24px !important;
  }
  .esc-frow {
    grid-template-columns: 1fr !important;
  }
  .escale-stages-app .esc-date-row {
    flex-wrap: wrap !important;
    padding: 14px 16px !important;
  }
  .escale-stages-app .esc-dates-header {
    padding: 14px 16px !important;
  }
}

/* Modal élargie — 2 colonnes sur desktop */
@media (min-width: 600px) {
  .esc-modal .esc-frow {
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
  }
  .esc-mform {
    padding: 18px 30px 26px !important;
  }
  .esc-mhead {
    padding: 22px 30px 18px !important;
  }
  .esc-mrecap {
    margin: 16px 30px 0 !important;
  }
}
