/* ===================================================================
  EXAFLY - surcharges alignées à la maquette XD
  Conventions :
  - Préfixe variables/classes : `agence3ma`
  - Une déclaration par ligne, aucune règle monoligne
  - Espace avant chaque {
  - Toutes les couleurs via variables (ou tokens thème WP)
=================================================================== */

@import url("exafly-tokens.css");

/* ===========================
  En-tête / stepper wrapper
=========================== */
#exafly-step {
  background-color: var(--agence3ma-color-white);
  text-align: center;
  padding: 35px 0 !important;
}

.exafly-header {
  text-align: center;
  max-width: 1200px;
  margin: 0 auto;
}

/* ===========================
  Stepper (barre de progression)
=========================== */
.agence3ma-exafly {
  margin-top: 15px;
}

.agence3ma-exafly__list {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0;
  padding: 0;
  list-style: none;
  min-height: calc(var(--agence3ma-exafly-icon-size) + var(--agence3ma-exafly-track-offset) + var(--agence3ma-exafly-tick-size));
}

.agence3ma-exafly__list::before {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  top: calc(var(--agence3ma-exafly-icon-size) + var(--agence3ma-exafly-track-offset));
  border-top: 1px dotted var(--agence3ma-exafly-track);
}

.agence3ma-exafly__list::after {
  content: "";
  position: absolute;
  left: 10px;
  top: calc(var(--agence3ma-exafly-icon-size) + var(--agence3ma-exafly-track-offset));
  width: calc((100% - 20px) * var(--progress, 0));
  border-top: 2px solid var(--agence3ma-color-primary);
  pointer-events: none;
}

.agence3ma-exafly-step {
  position: relative;
  text-align: center;
  color: var(--agence3ma-exafly-color-upcoming);
}

.agence3ma-exafly-step.is-current,
.agence3ma-exafly-step.is-current a,
.agence3ma-exafly-step.is-complete,
.agence3ma-exafly-step.is-complete a {
  color: var(--agence3ma-color-primary);
}

.agence3ma-exafly-step.is-upcoming svg * {
  opacity: .7;
}

.agence3ma-exafly-step__icon {
  display: inline-flex;
  line-height: 1;
}

.agence3ma-exafly-step__svg {
  width: var(--agence3ma-exafly-icon-size);
  height: var(--agence3ma-exafly-icon-size);
  display: block;
}

.agence3ma-exafly-step__tick {
  position: absolute;
  top: calc(var(--agence3ma-exafly-icon-size) + var(--agence3ma-exafly-track-offset) - (var(--agence3ma-exafly-tick-size) / 2));
  left: 50%;
  transform: translateX(-50%);
  width: var(--agence3ma-exafly-tick-size);
  height: var(--agence3ma-exafly-tick-size);
  border-radius: 50%;
  background: currentcolor;
}

/* ===========================
  Titres
=========================== */
.exafly-title {
  margin: 20px 0;
  color: var(--agence3ma-color-primary);
  font: 300 28px / 34px var(--agence3ma-font-serif);
  letter-spacing: .005em;
}

.exafly-subtitle {
  margin: 0 0 16px;
  font: 400 20px / 26px var(--agence3ma-font-sans);
  color: var(--agence3ma-color-ink);
}

/* ===========================
  Carte "cadeau"
=========================== */
.exafly-gift,
.exafly-gift__date {
  display: none;
  max-width: 320px;
}

.exafly-gift {
  margin: 0 auto 1.5rem auto !important;
}

.exafly-gift__date {
  margin: 0 auto !important;
}

.exafly-gift {
  border-radius: var(--agence3ma-radius-lg);
  background: var(--agence3ma-color-gift-bg);
  color: var(--agence3ma-color-white);
}

.exafly-gift__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 16px 18px;
}

.exafly-gift #exafly_gift_delivery_date {
  margin: 0 15px;
  width: -webkit-fill-available;
}

.exafly-gift #exafly-gift-date {
  margin: 0 !important;
}

.exafly-gift #exafly-gift-date label {
  left: 20px;
}

.a3ma-exafly-step--passengers .exafly-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.a3ma-exafly-step--passengers input[type="checkbox"] {
  appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid var(--agence3ma-color-deep);
  border-radius: 4px;
  background: var(--agence3ma-color-white);
  display: inline-block;
  flex: 0 0 auto;
  margin: 0 10px 0 2px;
  position: relative;
  cursor: pointer;
}

.a3ma-exafly-step--passengers input[type="checkbox"]:checked {
  border-color: var(--agence3ma-color-primary);
  background: var(--agence3ma-color-primary);
}

.a3ma-exafly-step--passengers input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 5px;
  height: 10px;
  border-right: 2px solid var(--agence3ma-color-white);
  border-bottom: 2px solid var(--agence3ma-color-white);
  transform: rotate(45deg);
}

.a3ma-exafly-step--passengers input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--agence3ma-color-primary);
  outline-offset: 2px;
}

.exafly-gift__label {
  flex: 1 1 auto;
  text-align: left;
  font-weight: 300;
}

.exafly-gift__icon {
  flex: 0 0 auto;
  line-height: 1;
  color: var(--agence3ma-color-primary);
}

.exafly-gift__svg,
.exafly-gift__svg * {
  stroke: currentcolor !important;
}

.exafly-gift__svg {
  width: 37px;
  height: 37px;
  display: block;
}

/* ---------- Collapse (réutilisable) ---------- */
.exafly-collapse {
  overflow: hidden;
  opacity: 1;
}

.exafly-collapse.is-animating {
  transition: height .5s ease, opacity .5s ease;
}

.exafly-collapse.is-collapsed {
  height: 0;
  opacity: 0;
  margin: 0 !important;
  padding: 0 !important;
}

#exafly-shipping {
  margin-top: 0;
  padding-top: 0;
}

/* Note d'aide sous champ (style discret, cohérent) */
.exafly-field__note {
  display: block;
  margin-top: var(--agence3ma-space-1);
  margin-bottom: 15px;
  font-size: 12px;
  line-height: 1.4;
  color: var(--agence3ma-color-white);
  padding: 0 15px;
}

.exafly-collapse.is-collapsed .exafly-field__note {
  display: none;
}

@media (width <= 420px) {
  .exafly-gift__btn {
    padding: 14px 16px;
  }
}

/* ===========================
  Elementor container
=========================== */
.e-con > .e-con-inner {
  max-width: 100%;
  padding: 0;
}

/* ===========================
  PASSAGERS (cartes + fields)
=========================== */
.a3ma-exafly-step--passengers .exafly-passenger {
  background: var(--agence3ma-color-soft);
  border-radius: var(--agence3ma-radius-lg);
  padding: var(--agence3ma-space-4);
  margin: 18px auto;
  max-width: 360px;
  position: relative;
}

.a3ma-exafly-step--passengers .exafly-passenger__title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--agence3ma-color-primary);
}

.a3ma-exafly-step--passengers .exafly-passenger__icon {
  width: 18px;
  height: 18px;
  opacity: .9;
}

.a3ma-exafly-step--passengers .exafly-passenger__optional {
  font-weight: 400;
  text-transform: none;
}

.a3ma-exafly-step--passengers .exafly-field {
  margin: 0 auto 10px !important;
}

.a3ma-exafly-step--passengers .exafly-field label {
  display: block;
  font-size: 12px;
  margin-bottom: 6px;
  color: var(--agence3ma-color-muted);
}

/* Inputs (label flottant) */
.a3ma-exafly-step--passengers .exafly-field--floating {
  --exf-label-h: 18px;
  --exf-label-on: 0;
  position: relative;
}

.a3ma-exafly-step--passengers .exafly-field--floating:focus-within,
.a3ma-exafly-step--passengers .exafly-field--floating:has(:is(input, select, textarea):not(:placeholder-shown)) {
  --exf-label-on: 1;
}

.a3ma-exafly-step--passengers .exafly-field--floating label {
  position: absolute;
  z-index: 1;
  left: 5px;
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
  font-size: 16px;
  color: var(--agence3ma-color-muted);
  pointer-events: none;
  padding: 0 4px;
  transition: all .18s ease;
}

.a3ma-exafly-step--passengers .exafly-field--floating input,
.a3ma-exafly-step--passengers .exafly-field--floating select,
.a3ma-exafly-step--passengers .exafly-field--floating textarea {
  display: block;
  width: 100%;
  background: var(--agence3ma-color-white);
  border: none;
  border-radius: var(--agence3ma-radius);
  font-size: 16px;
  color: var(--agence3ma-color-ink);
  transition: border-color .15s ease, box-shadow .15s ease;
}

.a3ma-exafly-step--passengers .exafly-field--floating input,
.a3ma-exafly-step--passengers .exafly-field--floating select {
  padding: 8px 14px;
  height: 56px;
  line-height: 56px;
}

.a3ma-exafly-step--passengers .exafly-field--floating textarea {
  padding: 18px 14px 12px;
  line-height: 1.4;
  transition: border-color .15s ease, box-shadow .15s ease;
  min-height: 6rem;
  resize: vertical;
}

.a3ma-exafly-step--passengers .exafly-field--floating:focus-within input,
.a3ma-exafly-step--passengers .exafly-field--floating:has(input:not(:placeholder-shown)) input,
.a3ma-exafly-step--passengers .exafly-field--floating:focus-within select,
.a3ma-exafly-step--passengers .exafly-field--floating:has(select:not(:placeholder-shown)) select {
  line-height: 1.2;
}

.a3ma-exafly-step--passengers .exafly-field--floating:focus-within input,
.a3ma-exafly-step--passengers .exafly-field--floating:has(input:not(:placeholder-shown)) input,
.a3ma-exafly-step--passengers .exafly-field--floating:focus-within select,
.a3ma-exafly-step--passengers .exafly-field--floating:has(select:not(:placeholder-shown)) select,
.a3ma-exafly-step--passengers .exafly-field--floating:focus-within textarea,
.a3ma-exafly-step--passengers .exafly-field--floating:has(textarea:not(:placeholder-shown)) textarea {
  padding-top: calc( 5px + var(--exf-label-h));
}

/* focus : même style pour input, select ET textarea */
.a3ma-exafly-step--passengers .exafly-field--floating :is(input, select, textarea):focus,
.a3ma-exafly-step--reservation .exafly-field--floating :is(input, select, textarea):focus {
  border-color: var(--agence3ma-color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--agence3ma-color-primary) 20%, var(--agence3ma-color-transparent));
}

.a3ma-exafly-step--passengers .exafly-field--floating:focus-within label,
.a3ma-exafly-step--passengers .exafly-field--floating:has(input:not(:placeholder-shown)) label,
.a3ma-exafly-step--passengers .exafly-field--floating:has(select:not(:placeholder-shown)) label,
.a3ma-exafly-step--passengers .exafly-field--floating:has(textarea:not(:placeholder-shown)) label,
.a3ma-exafly-step--passengers .exafly-field--floating.has-value label,
.a3ma-exafly-step--reservation .exafly-field--floating:focus-within label,
.a3ma-exafly-step--reservation .exafly-field--floating:has(input:not(:placeholder-shown)) label,
.a3ma-exafly-step--reservation .exafly-field--floating:has(select:not(:placeholder-shown)) label,
.a3ma-exafly-step--reservation .exafly-field--floating:has(textarea:not(:placeholder-shown)) label,
.a3ma-exafly-step--reservation .exafly-field--floating.has-value label {
  top: 5px;
  transform: none;
  font-size: 12px;
  color: var(--agence3ma-color-primary);
}

.a3ma-exafly-step--passengers .exafly-field--floating:has(:is(input, select, textarea):required) label::after,
.a3ma-exafly-step--reservation .exafly-field--floating:has(:is(input, select, textarea):required) label::after {
  content: " *";
}

/* Erreurs */
.a3ma-exafly-step--passengers .exafly-field--floating input.is-error,
.a3ma-exafly-step--passengers .exafly-field--floating input[aria-invalid="true"],
.a3ma-exafly-step--passengers .exafly-field--floating select.is-error,
.a3ma-exafly-step--passengers .exafly-field--floating select[aria-invalid="true"],
.a3ma-exafly-step--reservation .exafly-field--floating input.is-error,
.a3ma-exafly-step--reservation .exafly-field--floating input[aria-invalid="true"],
.a3ma-exafly-step--reservation .exafly-field--floating select.is-error,
.a3ma-exafly-step--reservation .exafly-field--floating select[aria-invalid="true"] {
  border-color: var(--agence3ma-color-danger);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--agence3ma-color-danger) 18%, var(--agence3ma-color-transparent));
}

.a3ma-exafly-step--passengers .exafly-field__error,
.a3ma-exafly-step--reservation .exafly-field__error {
  margin-top: 6px;
  font-size: 12px;
  color: var(--agence3ma-color-danger);
}

@media (width <= 480px) {
  .a3ma-exafly-step--passengers .exafly-passenger {
    padding: 14px;
  }
}

/* ===========================
  Actions (Retour / Valider)
=========================== */
.exafly-actions {
  margin-top: var(--agence3ma-space-7);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}

.exafly-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  border-radius: var(--agence3ma-radius-pill);
  font: 500 16px / 1 var(--agence3ma-font-sans);
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .02s ease, filter .15s ease, background-color .15s ease, border-color .15s ease;
}

.exafly-btn--ghost {
  background: var(--agence3ma-color-ghost);
  color: var(--agence3ma-color-ink);
  border-color: var(--agence3ma-color-border-strong);
}

.exafly-btn--ghost:hover {
  background: var(--agence3ma-color-white);
}

.exafly-btn--primary {
  background: var(--agence3ma-color-deep);
  color: var(--agence3ma-color-white);
}

.exafly-btn--primary::after {
  content: "→";
}

.exafly-btn--primary:hover {
  filter: brightness(0.96);
}

.exafly-btn__arrow {
  margin-left: 8px;
}

.exafly-btn__counter,
.exafly-btn__remove {
  padding: 10px 15px;
  width: 30px;
  height: 30px;
  border-color: var(--agence3ma-color-border-strong);
}

.exafly-btn__counter:disabled {
  cursor: not-allowed;
}

.exafly-btn__remove {
  background: var(--agence3ma-color-primary);
  color: var(--agence3ma-color-white);
  border: none;
  padding: 0;
  position: absolute;
  top: 25px;
  right: 10px;
  transform: translateY(-50%);
  line-height: 1;
}

.exafly-passenger[data-index="1"] .exafly-btn__remove {
  display: none;
}

@media (width <= 420px) {
  .exafly-actions {
    gap: 10px;
  }

  .exafly-btn {
    padding: 12px 18px;
  }
}

/* Conditions d'embarquement - layout */
.exafly-conditions {
  max-width: 720px;
  margin: 0 auto;
  padding: 0;
}

.exafly-conditions__block {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-items: start;
  padding: 18px 0;
  border-top: 1px solid var(--agence3ma-color-border-strong);
}

.exafly-conditions__block:first-of-type {
  border-top: 0;
}

.exafly-conditions__icon {
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--agence3ma-color-primary);
}

.exafly-conditions__icon svg {
  width: 56px;
  height: 56px;
}

.exafly-conditions__title {
  margin: 0 0 6px;
  font-weight: 700;
  font-size: 18px;
  color: var(--agence3ma-color-ink);
}

.exafly-conditions__list {
  margin: 0;
  padding-left: 18px;
}

.exafly-conditions__list li {
  margin: 6px 0;
}

.exafly-conditions__contact {
  text-align: center;
  margin: 22px 0 8px;
  color: var(--agence3ma-color-ink);
}

.exafly-conditions__contact a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dotted currentcolor;
}

.exafly-conditions__contact a:hover {
  text-decoration: none;
  border-bottom-color: transparent;
}

/* Header selon la maquette (titre orange + sous-titre centré) */
.a3ma-exafly-step--requirements .exafly-title {
  font-size: 28px;
  line-height: 1.2;
  margin-bottom: 6px;
}

.a3ma-exafly-step--requirements .exafly-subtitle {
  color: var(--agence3ma-color-muted);
  margin: 0 auto 12px;
  max-width: 720px;
}

/* ===== Étape 3 - Infos (icône + texte) ===== */
.a3ma-exafly-step--passengers .exafly-infos__row {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.a3ma-exafly-step--passengers .exafly-infos__row + .exafly-infos__row {
  margin-top: 0.75rem;
}

.a3ma-exafly-step--passengers .exafly-infos__icon {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  line-height: 0;
}

.a3ma-exafly-step--passengers .exafly-infos__text {
  margin: 0;
}

/* ===== Grille 2 colonnes pour Code postal / Ville ===== */
@media (width >= 640px) {
  .a3ma-exafly-step--passengers .exafly-grid.exafly-grid--2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap, 12px);
  }
}

/* ===== Récap commande ===== */
.a3ma-exafly-step--summary .exafly-card--summary {
  padding: 20px;
}

.a3ma-exafly-step--summary .exafly-orderlines {
  margin: 0 0 18px;
}

.a3ma-exafly-step--summary .exafly-orderline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
}

.a3ma-exafly-step--summary .exafly-sep {
  border: 0;
  border-top: 1px solid var(--agence3ma-color-border);
  margin: 0;
}

.a3ma-exafly-step--summary .exafly-orderline__label {
  font-weight: 400;
}

.a3ma-exafly-step--summary .exafly-orderline__value {
  font-weight: 700;
}

.a3ma-exafly-step--summary .exafly-orderline--total .exafly-orderline__label {
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.a3ma-exafly-step--summary .exafly-taxnote {
  margin: 6px 0 18px;
  font-size: 14px;
  color: var(--agence3ma-color-muted);
}

.a3ma-exafly-step--summary .exafly-h3 {
  margin: 20px 0 10px;
  font-weight: 300;
  font-size: 20px;
  line-height: 26px;
  font-family: var(--agence3ma-font-serif);
}

.a3ma-exafly-step--summary .exafly-passengerlist {
  list-style: none;
  margin: 0;
  padding: 0;
}

.a3ma-exafly-step--summary .exafly-passenger {
  padding: 14px 0;
  border-bottom: 1px solid var(--agence3ma-color-border);
}

.a3ma-exafly-step--summary .exafly-passenger__title {
  display: block;
  margin: 0 0 6px;
}

.a3ma-exafly-step--summary .exafly-passenger__meta {
  margin-left: 6px;
  color: var(--agence3ma-color-muted);
  font-weight: 400;
}

.a3ma-exafly-step--summary .exafly-passenger__line {
  margin: 0;
}

/* ===== Unified "Décollage de …" blocks ===== */
.exafly-depart .exafly-hero {
  text-align: center;
}

/* Overline (orange, uppercase) - utilisé sur Colmar, dispo pour Saverne */
.exafly-depart__overline {
  font: 700 14px / 1 var(--agence3ma-font-sans);
  letter-spacing: .06em;
  color: var(--agence3ma-color-primary);
  text-transform: uppercase;
  margin: 0 0 6px;
}

/* Titre générique (sera précisé par modificateur) */
.exafly-depart__title {
  margin: 0 0 18px;
  color: var(--agence3ma-color-ink);
}

/* Texte (utile pour Saverne) */
.exafly-depart__text {
  margin: 0;
  color: var(--agence3ma-color-ink);
  font: 400 16px / 1.5 var(--agence3ma-font-sans);
}

.exafly-depart__text a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px dotted currentColor;
}

.exafly-depart__text a:hover {
  border-bottom-color: transparent;
}

/* ===== Modifiers ===== */

/* Colmar (carte grisée + titre sans-serif 20) */
.exafly-depart--primary {
  max-width: 420px;
  margin: 0 auto;
  padding: var(--agence3ma-space-5) var(--agence3ma-space-4) var(--agence3ma-space-6);
  background: var(--agence3ma-color-soft);
  border-radius: var(--agence3ma-radius-lg);
  box-shadow: var(--agence3ma-shadow-card);
}

.exafly-depart--primary .exafly-depart__title {
  font: 600 20px / 1.25 var(--agence3ma-font-sans);
}

/* Saverne (titre serif orange + bloc centré) */
.exafly-depart--alt {
  margin: 26px 0 0;
}

.exafly-depart--alt .exafly-depart__title {
  color: var(--agence3ma-color-primary);
  font: 300 28px / 1.2 var(--agence3ma-font-serif);
  letter-spacing: .005em;
}

/* Placeholder du champ Colmar (cohérent maquette) */
.exafly-depart--primary .exafly-field--xl input::placeholder {
  color: var(--agence3ma-color-muted);
  opacity: 1;
}

/* Notice d'erreur (commune si besoin) */
.exafly-notice {
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: var(--agence3ma-radius);
}

.exafly-notice--error {
  background: color-mix(in srgb,
    var(--agence3ma-color-danger) 8%, var(--agence3ma-color-white)
  );
  border: 1px solid color-mix(in srgb,
    var(--agence3ma-color-danger) 35%, var(--agence3ma-color-white)
  );
  color: var(--agence3ma-color-danger);
}

.exafly-notice--error ul {
  margin: 0;
  padding-left: 18px;
}

/* Desktop: carte un peu plus large (optionnel) */
@media (width >= 768px) {
  .exafly-depart--primary {
    max-width: 520px;
  }
}

/* === Étape 1 (Colmar) - Floating label comme Passagers === */
.exafly-depart--primary .exafly-field--floating {
  --exf-label-h: 18px;
  position: relative;
}

.exafly-depart--primary .exafly-field--floating .exafly-label {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
  font-size: 16px;
  color: var(--agence3ma-color-muted);
  pointer-events: none;
  padding: 0 4px;
  background: transparent;
  transition: all .18s ease;
}

/* Champ (mêmes tokens que ta carte) */
.exafly-depart--primary .exafly-field--xl input {
  display: block;
  width: 100%;
  background: var(--agence3ma-color-white);
  border: 1px solid var(--agence3ma-color-border);
  border-radius: var(--agence3ma-radius);
  padding: 8px 14px;
  height: 56px;
  line-height: 56px;
  font: 500 16px/1 var(--agence3ma-font-sans);
  color: var(--agence3ma-color-ink);
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.exafly-depart--primary .exafly-field--xl input:focus {
  border-color: var(--agence3ma-color-deep);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--agence3ma-color-deep) 8%, var(--agence3ma-color-transparent));
}

/* Quand le champ a du contenu OU est focus → label monte + input décale */
.exafly-depart--primary .exafly-field--floating:focus-within .exafly-label,
.exafly-depart--primary .exafly-field--floating:has(input:not(:placeholder-shown)) .exafly-label {
  top: 6px;
  transform: none;
  font-size: 12px;
  color: var(--agence3ma-color-primary);
  padding: 0 4px;
}

/* Décaler le contenu quand le label est levé */
.exafly-depart--primary .exafly-field--floating:focus-within input,
.exafly-depart--primary .exafly-field--floating:has(input:not(:placeholder-shown)) input {
  padding-top: calc( 5px + var(--exf-label-h) );
  line-height: 1.2;
}

/* === Step 4 - Planning === */
.a3ma-exafly-step--calendar {
  --cell: 48px;
  --gap: 8px;
}

/* Carte calendrier */
.a3ma-exafly-step--calendar .exafly-cal {
  background: var(--agence3ma-color-white);
  border: 1px solid var(--agence3ma-color-border-weak);
  border-radius: 12px;
  padding: 16px;
}

/* Header (mois + flèches) */
.a3ma-exafly-step--calendar .exafly-cal__head {
  display: grid;
  grid-template-columns: 40px 1fr 40px;
  align-items: center;
  margin-bottom: 8px;
}

.a3ma-exafly-step--calendar .exafly-cal__nav {
  height: 36px;
  width: 36px;
  border-radius: 8px;
  border: 1px solid var(--agence3ma-color-border-mid);
  background: var(--agence3ma-color-white);
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
}

.a3ma-exafly-step--calendar .exafly-cal__nav:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.a3ma-exafly-step--calendar .exafly-cal__month {
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-align: center;
}

/* Ligne des jours (alignée à la grille) */
.a3ma-exafly-step--calendar .exafly-cal__week {
  display: grid;
  grid-template-columns: repeat(7, var(--cell));
  gap: var(--gap);
  justify-content: center;
  margin: 12px 0 8px;
  color: var(--agence3ma-color-muted-2);
  font-size: 13px;
}

.a3ma-exafly-step--calendar .exafly-cal__week > span {
  text-align: center;
}

/* Grille des dates */
.a3ma-exafly-step--calendar .exafly-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, var(--cell));
  grid-auto-rows: var(--cell);
  gap: var(--gap);
  justify-content: center;
  min-height: calc(var(--cell) * 6 + var(--gap) * 5);
}

/* Cellules */
.a3ma-exafly-step--calendar .exafly-cal__cell {
  border: 1px solid var(--agence3ma-color-border-alt);
  border-radius: 6px;
  background: var(--agence3ma-color-white);
  font-weight: 600;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  user-select: none;
}

.a3ma-exafly-step--calendar .exafly-cal__cell[disabled] {
  opacity: 1;
}

.a3ma-exafly-step--calendar .exafly-cal__cell--other {
  color: var(--agence3ma-color-muted-2);
  border-style: dashed;
}

.a3ma-exafly-step--calendar .exafly-cal__cell--disabled {
  color: var(--agence3ma-color-muted-2);
  background: #f6f8fa;
}

.a3ma-exafly-step--calendar .exafly-cal__cell--avail {
  cursor: pointer;
  border-color: var(--agence3ma-color-accent);
}

.a3ma-exafly-step--calendar .exafly-cal__cell--avail:hover {
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--agence3ma-color-accent) 15%, var(--agence3ma-color-transparent)) inset;
}

.a3ma-exafly-step--calendar .exafly-cal__cell--selected {
  outline: 2px solid var(--agence3ma-color-accent);
}

.a3ma-exafly-step--calendar .exafly-cal__cell--full {
  background: var(--agence3ma-color-calendar-full);
  color: var(--agence3ma-color-white);
  border-color: var(--agence3ma-color-calendar-full);
}

/* Légende */
.a3ma-exafly-step--calendar .exafly-cal__legend {
  display: flex;
  gap: 24px;
  align-items: center;
  margin-top: 12px;
  font-size: 14px;
}

.a3ma-exafly-step--calendar .exafly-cal__legend i {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 3px;
  border: 1px solid var(--agence3ma-color-border-alt);
  margin-right: 8px;
}

.a3ma-exafly-step--calendar .exafly-cal__legend .i-available {
  border-color: var(--agence3ma-color-accent);
}

.a3ma-exafly-step--calendar .exafly-cal__legend .i-full {
  background: var(--agence3ma-color-calendar-full);
  border-color: var(--agence3ma-color-calendar-full);
}

/* Bloc sunrise (icône SVG) */
.a3ma-exafly-step--calendar .exafly-sunrise {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 8px;
  align-items: center;
  padding: 16px 0;
}

.a3ma-exafly-step--calendar .exafly-sunrise .i {
  width: 20px;
  height: 20px;
  display: inline-block;
}

/* Cases “jours dispo” à cocher */
.a3ma-exafly-step--calendar .exafly-days {
  display: grid;
  grid-template-columns: repeat(4, minmax(140px, 1fr));
  gap: 10px 16px;
}

.a3ma-exafly-step--calendar .exafly-day {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--agence3ma-color-border-weak);
  padding: 10px 12px;
  border-radius: 8px;
  background: var(--agence3ma-color-white);
}

#admin_schedule_settings {
    padding: 0 1rem;
}

#admin_schedule_settings .widefat input[type="text"],
#admin_schedule_settings .widefat input[type="time"],
#admin_schedule_settings .widefat select {
    width: 100%;
}

#admin_schedule_settings .time-group {
    display: flex;
    gap: 6px;
    align-items: center;
}

#admin_schedule_settings .time-end.hidden {
    display: none;
}

#admin_schedule_settings .remove-row {
    background: none;
    border: #a00 solid 1px;
    cursor: pointer;
    color: #a00;
    transition: 0.2s;
}

#admin_schedule_settings .remove-row:hover {
    background: #a00;
    color: white;
    opacity: 0.7;
}

/* ===== Exafly API Settings ===== */
#exafly-api-settings.form-table {
  width: 100%;
  table-layout: auto;
}

#exafly-api-settings th[scope="row"] {
  width: 1%;
  white-space: nowrap;
  vertical-align: middle;
}

#exafly-api-settings td {
  vertical-align: middle;
}

#exafly-api-settings th,
#exafly-api-settings td {
  padding: 10px;
}

#exafly-api-settings td > *,
#exafly-api-settings th > * {
  vertical-align: middle;
}

.rt-calendar--visual .rt-calendar-grid .cell {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: default !important;
}

.rt-calendar--visual .rt-calendar-grid .cell:not(.exafly-cal__cell--disabled, .exafly-cal__cell--other) {
  background: var(--color-white) !important;
  border: 1px solid var(--agence3ma-color-deep) !important;
  color: var(--agence3ma-color-deep);
}

.exafly-cal__cell-avail {
  position: absolute;
  bottom: 0.125rem;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 0.625rem;
  font-weight: 500;
  line-height: 1;
}

.exafly-calendar-shortcode {
  min-width: 400px;
  max-width: 100%;
  margin: 0 auto;
}

.exafly-calendar-shortcode .rt-calendar {
  max-width: 800px;
  margin: 0 auto;
}

.exafly-calendar-error,
.exafly-calendar-empty {
  padding: 16px;
  background: #fff3cd;
  border: 1px solid #ffc107;
  border-radius: 6px;
  color: #856404;
  text-align: center;
}