.escr-reservar-wrap {
  --escr-verde: #355E2C;
  --escr-verde-dark: #243f1e;
  --escr-oro: #D99A17;
  --escr-oro-light: #e8b545;
  --escr-beige: #F3E4C6;
  --escr-blanco: #FAFAF7;
  --escr-texto: #222222;
  --escr-gris: #666666;
  --escr-rojo: #b3261e;
  --escr-ff-display: 'Playfair Display', Georgia, serif;
  --escr-ff-body: 'Inter', system-ui, sans-serif;
  font-family: var(--escr-ff-body);
  color: var(--escr-texto);
  margin-bottom: 80px;
}
.escr-reservar-wrap * { box-sizing: border-box; }
.escr-reservar-wrap h1,
.escr-reservar-wrap h2,
.escr-reservar-wrap h3,
.escr-reservar-wrap h4 { text-transform: none !important; }
.escr-body { max-width: 1000px; margin: 0 auto; padding: 0 24px; }

.escr-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.22em;
  text-transform: uppercase; color: var(--escr-oro); margin-bottom: 16px;
}
.escr-eyebrow::before { content: ''; display: block; width: 24px; height: 1px; background: var(--escr-oro); }
.escr-title {
  font-family: var(--escr-ff-display); font-size: clamp(1.5rem, 2.6vw, 2rem);
  font-weight: 700; line-height: 1.2; color: var(--escr-texto); margin: 0;
  text-transform: none !important;
}
.escr-desc { margin-top: 12px; font-size: 0.92rem; color: var(--escr-gris); font-weight: 300; line-height: 1.8; max-width: 560px; }

/* HEADER type micro-hero avec photo (même style que les autres pages du site) */
.escr-micro-hero {
  position: relative;
  height: 34vh; min-height: 240px; max-height: 340px;
  display: flex; align-items: center; overflow: hidden;
  background:
    linear-gradient(90deg, rgba(20,35,14,0.8) 0%, rgba(20,35,14,0.5) 45%, rgba(20,35,14,0.2) 100%),
    url('https://escorpiontravels.com/wp-content/uploads/2026/06/IMG_5568-scaled.jpg') center 40%/cover no-repeat;
  width: 100vw; margin-left: calc(50% - 50vw); margin-bottom: 48px;
}
.escr-micro-hero-content {
  position: relative; z-index: 2; width: 100%; max-width: 1200px; margin: 0 auto;
  padding: 120px 48px 28px; display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
}
.escr-micro-hero-title {
  font-family: var(--escr-ff-display); font-size: clamp(1.7rem, 3.2vw, 2.6rem);
  font-weight: 700; line-height: 1.1; color: var(--escr-blanco); margin: 0;
  text-shadow: 0 2px 16px rgba(0,0,0,0.3); order: 1;
  text-transform: none !important;
}
.escr-micro-hero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--escr-oro); margin: 0; order: 2;
}
.escr-micro-hero-eyebrow::before { content: ''; display: block; width: 24px; height: 1px; background: var(--escr-oro); }

/* back link */
.escr-back-link {
  display: inline-flex; align-items: center; gap: 6px; background: none; border: none;
  font-family: var(--escr-ff-body); font-size: 0.82rem; font-weight: 600; color: var(--escr-gris);
  cursor: pointer; padding: 0; margin-bottom: 20px; text-transform: uppercase; letter-spacing: .04em;
}
.escr-back-link:hover { color: var(--escr-verde-dark); }

/* steps */
.escr-steps { display: flex; align-items: center; gap: 10px; margin: 32px 0 24px; flex-wrap: wrap; }
.escr-step { display: flex; align-items: center; gap: 8px; font-size: 0.78rem; font-weight: 600; color: var(--escr-gris); }
.escr-step-num {
  width: 26px; height: 26px; border-radius: 50%; background: rgba(34,34,34,0.08);
  color: var(--escr-gris); display: flex; align-items: center; justify-content: center;
  font-size: 0.78rem; font-weight: 700;
}
.escr-step.active .escr-step-num { background: var(--escr-oro); color: #1a1a1a; }
.escr-step.active { color: var(--escr-texto); }
.escr-step.done .escr-step-num { background: var(--escr-verde); color: var(--escr-blanco); }
.escr-step-line { width: 28px; height: 1px; background: rgba(34,34,34,0.15); }

/* path selector */
.escr-path-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 32px; }
.escr-path-card {
  padding: 36px 28px; border-radius: 6px; background: var(--escr-blanco);
  border: 2px solid rgba(34,34,34,0.1); cursor: pointer; transition: all .25s ease; text-align: center;
}
.escr-path-card:hover { border-color: var(--escr-oro); transform: translateY(-3px); box-shadow: 0 14px 32px rgba(34,34,34,.1); }
.escr-path-flag { font-size: 2.6rem; margin-bottom: 16px; display: block; }
.escr-path-title { font-family: var(--escr-ff-display); font-size: 1.2rem; font-weight: 700; margin-bottom: 8px; text-transform: none !important; }
.escr-path-desc { font-size: 0.85rem; color: var(--escr-gris); font-weight: 300; line-height: 1.7; }

/* flow & cards */
.escr-flow { display: none; }
.escr-flow.active { display: block; }
.escr-card { background: var(--escr-blanco); border-radius: 6px; padding: 32px; box-shadow: 0 6px 24px rgba(34,34,34,.06); }
.escr-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.escr-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; position: relative; }
.escr-field label { font-size: 0.78rem; font-weight: 600; }
.escr-field input {
  font-family: var(--escr-ff-body); font-size: 0.9rem; padding: 12px 14px;
  border: 1px solid rgba(34,34,34,.15); border-radius: 2px; background: var(--escr-blanco);
  width: 100%;
}
.escr-field input:focus { outline: none; border-color: var(--escr-verde); }
.escr-field.escr-field-invalid input,
.escr-field.escr-field-invalid select { border-color: var(--escr-rojo); }

/* paquetes : catégories + select */
.escr-pkg-category {
  padding: 16px 18px; border: 1px solid rgba(34,34,34,.12); border-radius: 4px;
  margin-bottom: 12px; transition: all .2s ease;
}
.escr-pkg-category.selected { border-color: var(--escr-verde); background: rgba(53,94,44,.06); }
.escr-pkg-category-title {
  font-family: var(--escr-ff-display); font-size: 0.95rem; font-weight: 700;
  color: var(--escr-verde-dark); margin-bottom: 10px;
  text-transform: none !important;
}
.escr-pkg-select {
  width: 100%; font-family: var(--escr-ff-body); font-size: 0.9rem; color: var(--escr-texto);
  padding: 11px 14px; border: 1px solid rgba(34,34,34,.15); border-radius: 2px; background: var(--escr-blanco);
  cursor: pointer; text-transform: none !important;
}
.escr-pkg-select:focus { outline: none; border-color: var(--escr-verde); }

.escr-summary {
  background: var(--escr-verde-dark); border-radius: 4px; padding: 22px 28px; margin: 24px 0;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
}
.escr-summary span:first-child { color: rgba(250,250,247,.85); font-size: 0.88rem; font-weight: 500; }
.escr-summary-amount {
  font-family: var(--escr-ff-body) !important; font-size: 1.9rem !important; font-weight: 700 !important;
  color: var(--escr-blanco) !important; letter-spacing: 0.01em; line-height: 1;
  font-variant-numeric: tabular-nums;
}

.escr-qr-panel { text-align: center; padding: 30px; background: var(--escr-beige); border-radius: 6px; margin-top: 8px; }
.escr-qr-box { display: inline-flex; padding: 16px; background: var(--escr-blanco); border-radius: 6px; box-shadow: 0 8px 24px rgba(34,34,34,.1); }
.escr-qr-note { font-size: 0.78rem; color: var(--escr-gris); font-weight: 300; margin-top: 14px; max-width: 420px; margin-left: auto; margin-right: auto; }

.escr-confirm-banner {
  display: none; margin-top: 24px; padding: 20px 24px; border-radius: 4px;
  background: rgba(53,94,44,.1); border: 1px solid rgba(53,94,44,.3);
  align-items: center; gap: 14px;
}
.escr-confirm-banner.show { display: flex; }

.escr-bank-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; background: rgba(34,34,34,.08); border-radius: 4px; overflow: hidden; margin-top: 8px; }
.escr-bank-cell { background: var(--escr-blanco); padding: 16px 20px; }
.escr-bank-cell label { display: block; font-size: 0.7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--escr-oro); margin-bottom: 4px; }
.escr-bank-note { margin-top: 18px; padding: 16px 20px; background: var(--escr-beige); border-radius: 4px; font-size: 0.82rem; color: var(--escr-gris); font-weight: 300; line-height: 1.7; }
.escr-email-fallback { margin-top: 14px; font-size: 0.8rem; color: var(--escr-gris); font-weight: 300; }
.escr-email-fallback strong { color: var(--escr-verde-dark); font-weight: 600; }

/* Autocomplete pays personnalisée */
.escr-autocomplete { position: relative; }
.escr-autocomplete-list {
  display: none; position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 20;
  background: var(--escr-blanco); border: 1px solid rgba(34,34,34,.15); border-radius: 2px;
  max-height: 220px; overflow-y: auto; box-shadow: 0 10px 28px rgba(34,34,34,.12);
}
.escr-autocomplete-list.show { display: block; }
.escr-autocomplete-item {
  padding: 10px 14px; font-size: 0.88rem; cursor: pointer; color: var(--escr-texto);
}
.escr-autocomplete-item:hover,
.escr-autocomplete-item.active { background: var(--escr-beige); color: var(--escr-verde-dark); }

/* Erreurs de validation */
.escr-form-error {
  display: none; margin-top: 14px; padding: 12px 16px; border-radius: 4px;
  background: rgba(179,38,30,.08); border: 1px solid rgba(179,38,30,.25);
  color: var(--escr-rojo); font-size: 0.82rem; font-weight: 500;
}
.escr-form-error.show { display: block; }

.escr-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--escr-ff-body); font-size: 0.85rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase; text-decoration: none;
  padding: 13px 26px; border-radius: 2px; transition: all .25s ease; cursor: pointer;
  border: 1px solid transparent;
}
.escr-btn-primary { background: var(--escr-oro); color: #1a1a1a; border-color: var(--escr-oro); }
.escr-btn-primary:hover { background: var(--escr-oro-light); transform: translateY(-2px); }
.escr-btn-verde { background: var(--escr-verde); color: var(--escr-blanco); border-color: var(--escr-verde); }
.escr-btn-verde:hover { background: var(--escr-verde-dark); }
.escr-btn-ghost { background: transparent; color: var(--escr-texto); border-color: rgba(34,34,34,.2); }
.escr-btn-ghost:hover { background: rgba(34,34,34,.05); }
.escr-btn:disabled { opacity: .4; cursor: not-allowed; }
.escr-btn-row { display: flex; gap: 14px; margin-top: 28px; flex-wrap: wrap; }

@media (max-width: 768px) {
  .escr-path-grid { grid-template-columns: 1fr; }
  .escr-grid2, .escr-bank-grid { grid-template-columns: 1fr; }
  .escr-card { padding: 22px; }
  .escr-micro-hero-content { padding: 16px 24px; }
}
