/**
 * WP Time Slots Booking Form - Styles Personnalisés
 * Ludothèque Gruyère
 *
 * Ce fichier personnalise l'apparence des formulaires de réservation
 * pour correspondre à la charte graphique du site.
 */

/* ============================================
   VARIABLES CSS
   ============================================ */

:root {
  /* Couleurs principales */
  --booking-primary: #e5007d;
  --booking-primary-hover: #c70069;
  --booking-primary-light: #fce4f0;

  --booking-orange: #E8842A;
  --booking-orange-light: #f59c00;
  --booking-salmon: #f7ceac;

  --booking-success: #28a745;
  --booking-danger: #dc3545;

  /* Couleurs neutres */
  --booking-surface: #ffffff;
  --booking-background: #f5f5f5;
  --booking-border: #e0e0e0;
  --booking-text: #333333;
  --booking-text-muted: #6b6b6b;
  --booking-text-light: #999999;

  /* Espacement */
  --booking-radius: 12px;
  --booking-radius-lg: 20px;
  --booking-radius-sm: 8px;

  /* Ombres */
  --booking-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
  --booking-shadow-md: 0 4px 15px rgba(0, 0, 0, 0.06);
  --booking-shadow-lg: 0 8px 25px rgba(0, 0, 0, 0.08);

  /* Transitions */
  --booking-transition-fast: 150ms ease;
  --booking-transition-base: 300ms ease;
}

/* ============================================
   CONTAINER PRINCIPAL
   ============================================ */

.cp_cff {
  background: var(--booking-surface) !important;
  border-radius: var(--booking-radius-lg) !important;
  box-shadow: var(--booking-shadow-md) !important;
  padding: 2rem !important;
  border: 1px solid var(--booking-border) !important;
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* ============================================
   LABELS
   ============================================ */

.cp_cff #fbuilder label,
#fbuilder .fields > label {
  font-weight: 600 !important;
  color: var(--booking-text) !important;
  margin-bottom: 0.5rem !important;
  font-size: 1rem !important;
  display: block !important;
}

/* Astérisque champs obligatoires */
#fbuilder .fields > label .r,
.cp_cff .r {
  color: var(--booking-danger) !important;
  margin-left: 3px !important;
}

/* ============================================
   CHAMPS DE SAISIE
   ============================================ */

#fbuilder input[type="text"],
#fbuilder input[type="email"],
#fbuilder input[type="tel"],
#fbuilder input[type="number"],
#fbuilder input[type="password"],
#fbuilder input[type="date"],
#fbuilder textarea,
#fbuilder select,
.cp_cff input[type="text"],
.cp_cff input[type="email"],
.cp_cff input[type="tel"],
.cp_cff input[type="number"],
.cp_cff textarea,
.cp_cff select {
  width: 100% !important;
  padding: 0.875rem 1rem !important;
  border: 1.5px solid var(--booking-border) !important;
  border-radius: var(--booking-radius-sm) !important;
  font-size: 1rem !important;
  font-family: inherit !important;
  color: var(--booking-text) !important;
  background: var(--booking-surface) !important;
  transition: var(--booking-transition-fast) !important;
  box-sizing: border-box !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
}

/* Focus */
#fbuilder input[type="text"]:focus,
#fbuilder input[type="email"]:focus,
#fbuilder input[type="tel"]:focus,
#fbuilder input[type="number"]:focus,
#fbuilder input[type="password"]:focus,
#fbuilder input[type="date"]:focus,
#fbuilder textarea:focus,
#fbuilder select:focus,
.cp_cff input:focus,
.cp_cff textarea:focus,
.cp_cff select:focus {
  border-color: var(--booking-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(229, 0, 125, 0.15) !important;
}

/* Placeholder */
#fbuilder input::placeholder,
#fbuilder textarea::placeholder,
.cp_cff input::placeholder,
.cp_cff textarea::placeholder {
  color: var(--booking-text-light) !important;
  opacity: 1 !important;
}

/* Textarea */
#fbuilder textarea,
.cp_cff textarea {
  min-height: 120px !important;
  resize: vertical !important;
}

/* Select - flèche personnalisée */
#fbuilder select,
.cp_cff select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b6b6b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e") !important;
  background-position: right 0.75rem center !important;
  background-repeat: no-repeat !important;
  background-size: 1.25rem !important;
  padding-right: 2.5rem !important;
  cursor: pointer !important;
}

/* ============================================
   TEXTE D'AIDE
   ============================================ */

#fbuilder .uh,
.cp_cff .uh,
#fbuilder span.uh {
  display: block !important;
  font-size: 0.85rem !important;
  color: var(--booking-text-muted) !important;
  margin-top: 0.35rem !important;
  font-style: italic !important;
}

/* ============================================
   ESPACEMENT DES CHAMPS
   ============================================ */

#fbuilder .fields,
#fbuilder .fform {
  padding: 0.75rem 0 !important;
  margin-bottom: 0.5rem !important;
}

/* ============================================
   CALENDRIER (UI DATEPICKER)
   ============================================ */

#fbuilder .ui-datepicker,
.sbfieldCalendar .ui-datepicker {
  background: var(--booking-surface) !important;
  border: 1px solid var(--booking-border) !important;
  border-radius: var(--booking-radius) !important;
  box-shadow: var(--booking-shadow-lg) !important;
  padding: 1rem !important;
  font-family: inherit !important;
  width: auto !important;
  min-width: 320px !important;
}

/* En-tête du calendrier */
#fbuilder .ui-datepicker-header,
.sbfieldCalendar .ui-datepicker-header {
  background: var(--booking-primary) !important;
  border: none !important;
  border-radius: var(--booking-radius-sm) !important;
  padding: 0.75rem 1rem !important;
  margin-bottom: 0.5rem !important;
}

#fbuilder .ui-datepicker-title,
.sbfieldCalendar .ui-datepicker-title {
  color: white !important;
  font-weight: 700 !important;
  font-size: 1.1rem !important;
}

/* Flèches navigation */
#fbuilder .ui-datepicker-prev,
#fbuilder .ui-datepicker-next,
.sbfieldCalendar .ui-datepicker-prev,
.sbfieldCalendar .ui-datepicker-next {
  background: rgba(255,255,255,0.2) !important;
  border-radius: 50% !important;
  width: 32px !important;
  height: 32px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  cursor: pointer !important;
  transition: var(--booking-transition-fast) !important;
}

#fbuilder .ui-datepicker-prev:hover,
#fbuilder .ui-datepicker-next:hover,
.sbfieldCalendar .ui-datepicker-prev:hover,
.sbfieldCalendar .ui-datepicker-next:hover {
  background: rgba(255,255,255,0.35) !important;
}

#fbuilder .ui-datepicker-prev {
  left: 8px !important;
}

#fbuilder .ui-datepicker-next {
  right: 8px !important;
}

/* Icônes des flèches */
#fbuilder .ui-datepicker-prev span,
#fbuilder .ui-datepicker-next span,
.sbfieldCalendar .ui-datepicker-prev span,
.sbfieldCalendar .ui-datepicker-next span {
  background-image: none !important;
  text-indent: 0 !important;
  color: white !important;
  font-size: 1.2rem !important;
}

#fbuilder .ui-datepicker-prev span::after {
  content: "\2039" !important;
}

#fbuilder .ui-datepicker-next span::after {
  content: "\203A" !important;
}

/* Jours de la semaine */
#fbuilder .ui-datepicker th,
.sbfieldCalendar .ui-datepicker th {
  color: var(--booking-text-muted) !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  padding: 0.5rem !important;
  text-transform: uppercase !important;
}

/* Cellules des jours */
#fbuilder .ui-datepicker td,
.sbfieldCalendar .ui-datepicker td {
  padding: 2px !important;
}

#fbuilder .ui-datepicker td a,
#fbuilder .ui-datepicker td span,
.sbfieldCalendar .ui-datepicker td a,
.sbfieldCalendar .ui-datepicker td span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  transition: var(--booking-transition-fast) !important;
  background: transparent !important;
  border: none !important;
}

/* Jour au survol */
#fbuilder .ui-datepicker td a:hover,
.sbfieldCalendar .ui-datepicker td a:hover {
  background: var(--booking-primary-light) !important;
  color: var(--booking-primary) !important;
}

/* Jour sélectionné */
#fbuilder .ui-datepicker td a.ui-state-active,
#fbuilder .ui-datepicker td .ui-state-active,
.sbfieldCalendar .ui-datepicker td a.ui-state-active,
.sbfieldCalendar .ui-datepicker td .ui-state-active {
  background: var(--booking-primary) !important;
  color: white !important;
  font-weight: 700 !important;
}

/* Aujourd'hui */
#fbuilder .ui-datepicker td .ui-state-highlight,
.sbfieldCalendar .ui-datepicker td .ui-state-highlight {
  background: var(--booking-orange-light) !important;
  color: white !important;
}

/* Jour désactivé */
#fbuilder .ui-datepicker td .ui-state-disabled span,
.sbfieldCalendar .ui-datepicker td .ui-state-disabled span {
  color: var(--booking-text-light) !important;
  cursor: not-allowed !important;
}

/* ============================================
   CRÉNEAUX HORAIRES (SLOTS)
   ============================================ */

/* Masquer l'indicateur de disponibilité */
.ts_slot_availability,
.slotsCalendar .ts_slot_availability,
#fbuilder .ts_slot_availability {
  display: none !important;
}

/* Container des slots */
#fbuilder .slots {
  border: 1px solid var(--booking-border) !important;
  border-radius: var(--booking-radius) !important;
  padding: 1rem !important;
  background: var(--booking-background) !important;
  box-shadow: none !important;
}

/* Slot individuel */
#fbuilder .slots div {
  margin: 0.35rem !important;
  border: none !important;
  padding: 0 !important;
}

/* Créneau disponible */
#fbuilder .slots .availableslot > a,
#fbuilder .slotsCalendar .availableslot > a,
.slotsCalendar .availableslot > a {
  background: var(--booking-primary-light) !important;
  color: var(--booking-primary) !important;
  border: 2px solid var(--booking-primary) !important;
  border-radius: var(--booking-radius-sm) !important;
  padding: 0.5rem 1rem !important;
  font-weight: 600 !important;
  transition: var(--booking-transition-fast) !important;
  text-decoration: none !important;
}

#fbuilder .slots .availableslot > a:hover,
#fbuilder .slotsCalendar .availableslot > a:hover,
.slotsCalendar .availableslot > a:hover {
  background: var(--booking-primary) !important;
  color: white !important;
  transform: translateY(-1px) !important;
}

/* Créneau sélectionné */
#fbuilder .slots .currentSelection > a,
#fbuilder .slotsCalendar .currentSelection > a,
.slotsCalendar .currentSelection > a {
  background: var(--booking-primary) !important;
  color: white !important;
  border-color: var(--booking-primary) !important;
}

/* Créneau indisponible */
#fbuilder .slots .usedslot > a {
  background: var(--booking-background) !important;
  color: var(--booking-text-light) !important;
  border: 1px solid var(--booking-border) !important;
  cursor: not-allowed !important;
  text-decoration: line-through !important;
}

/* ============================================
   BOUTONS
   ============================================ */

/* Bouton submit */
#fbuilder input[type="submit"],
#fbuilder .pbSubmit,
.cp_cff input[type="submit"],
.cp_cff .pbSubmit {
  background: var(--booking-orange-light) !important;
  color: white !important;
  border: none !important;
  padding: 1rem 2.5rem !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: var(--booking-transition-base) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  box-shadow: var(--booking-shadow-md) !important;
  display: inline-block !important;
  margin-top: 1rem !important;
}

#fbuilder input[type="submit"]:hover,
#fbuilder .pbSubmit:hover,
.cp_cff input[type="submit"]:hover,
.cp_cff .pbSubmit:hover {
  background: var(--booking-orange) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--booking-shadow-lg) !important;
}

/* Boutons pagination */
#fbuilder .pbreak .pbPrevious,
#fbuilder .pbreak .pbNext {
  background: var(--booking-surface) !important;
  color: var(--booking-text) !important;
  border: 2px solid var(--booking-border) !important;
  padding: 0.75rem 1.5rem !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: var(--booking-transition-fast) !important;
  margin-right: 0.5rem !important;
}

#fbuilder .pbreak .pbPrevious:hover,
#fbuilder .pbreak .pbNext:hover {
  background: var(--booking-background) !important;
  border-color: var(--booking-text-muted) !important;
}

/* Bouton reset */
#fbuilder input[type="reset"],
#fbuilder .pbReset,
.cp_cff input[type="reset"],
.cp_cff .pbReset {
  background: transparent !important;
  color: var(--booking-text-muted) !important;
  border: 1.5px solid var(--booking-border) !important;
  padding: 1rem 2rem !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  border-radius: 50px !important;
  cursor: pointer !important;
  transition: var(--booking-transition-base) !important;
}

#fbuilder input[type="reset"]:hover,
#fbuilder .pbReset:hover,
.cp_cff input[type="reset"]:hover,
.cp_cff .pbReset:hover {
  background: var(--booking-background) !important;
  border-color: var(--booking-text-muted) !important;
}

/* ============================================
   MESSAGES D'ERREUR
   ============================================ */

#fbuilder .cff-error,
.cp_cff .cff-error,
#fbuilder div.cpefb_error {
  color: var(--booking-danger) !important;
  font-size: 0.85rem !important;
  margin-top: 0.35rem !important;
  background: #fff5f5 !important;
  border: 1px solid var(--booking-danger) !important;
  border-radius: var(--booking-radius-sm) !important;
  padding: 0.5rem 0.75rem !important;
}

#fbuilder div.cpefb_error:after {
  display: none !important;
}

#fbuilder input.cff-required-error,
#fbuilder select.cff-required-error,
#fbuilder textarea.cff-required-error,
#fbuilder .cpefb_error {
  border-color: var(--booking-danger) !important;
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.15) !important;
}

/* ============================================
   CHECKBOXES ET RADIOS
   ============================================ */

#fbuilder input[type="checkbox"],
#fbuilder input[type="radio"] {
  width: 20px !important;
  height: 20px !important;
  margin-right: 0.5rem !important;
  accent-color: var(--booking-primary) !important;
  cursor: pointer !important;
}

#fbuilder input[type="checkbox"] + label,
#fbuilder input[type="radio"] + label {
  display: inline !important;
  font-weight: 400 !important;
  cursor: pointer !important;
}

/* ============================================
   FIELDSET ET LEGEND
   ============================================ */

#fbuilder fieldset {
  border: 1px solid var(--booking-border) !important;
  border-radius: var(--booking-radius) !important;
  padding: 1.5rem !important;
  margin-bottom: 1rem !important;
}

#fbuilder legend {
  border: none !important;
  background: var(--booking-primary) !important;
  color: white !important;
  padding: 0.5rem 1rem !important;
  border-radius: var(--booking-radius-sm) !important;
  font-weight: 600 !important;
}

/* ============================================
   SECTION BREAKS
   ============================================ */

#fbuilder .section_break {
  border-top: 2px solid var(--booking-border) !important;
  margin: 1.5rem 0 !important;
  padding-top: 1.5rem !important;
}

/* ============================================
   DATE VERROUILLÉE (WPLudo)
   ============================================ */

.cart-date-locked {
  background: linear-gradient(135deg, var(--booking-salmon) 0%, #f5c6a5 100%) !important;
  padding: 1.25rem 1.5rem !important;
  border-radius: var(--booking-radius) !important;
  border: 2px solid var(--booking-orange) !important;
  text-align: center !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  color: #7a4510 !important;
  margin-bottom: 1.5rem !important;
  box-shadow: var(--booking-shadow-sm) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.75rem !important;
}

.cart-date-locked .lock-icon {
  font-size: 1.3rem !important;
}

/* Calendrier verrouillé */
.sbfieldCalendar.calendar-locked {
  position: relative !important;
  pointer-events: none !important;
  opacity: 0.7 !important;
}

.sbfieldCalendar.calendar-locked::after {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: rgba(255,255,255,0.4) !important;
  border-radius: var(--booking-radius) !important;
}

/* ============================================
   CAPTCHA
   ============================================ */

#fbuilder .captcha {
  margin-top: 1rem !important;
}

#fbuilder .captcha img {
  border-radius: var(--booking-radius-sm) !important;
  border: 1px solid var(--booking-border) !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media screen and (max-width: 768px) {
  .cp_cff {
    padding: 1.25rem !important;
  }

  #fbuilder .ui-datepicker,
  .sbfieldCalendar .ui-datepicker {
    min-width: 280px !important;
  }

  #fbuilder .ui-datepicker td a,
  #fbuilder .ui-datepicker td span,
  .sbfieldCalendar .ui-datepicker td a,
  .sbfieldCalendar .ui-datepicker td span {
    width: 32px !important;
    height: 32px !important;
    font-size: 0.9rem !important;
  }

  #fbuilder input[type="submit"],
  #fbuilder .pbSubmit,
  .cp_cff input[type="submit"],
  .cp_cff .pbSubmit {
    width: 100% !important;
    padding: 1rem !important;
  }

  #fbuilder .pbreak .pbPrevious,
  #fbuilder .pbreak .pbNext {
    padding: 0.6rem 1rem !important;
    font-size: 0.9rem !important;
  }
}

@media screen and (max-width: 480px) {
  .cp_cff {
    padding: 1rem !important;
    border-radius: var(--booking-radius) !important;
  }

  #fbuilder input[type="text"],
  #fbuilder input[type="email"],
  #fbuilder input[type="tel"],
  #fbuilder textarea,
  #fbuilder select {
    padding: 0.75rem !important;
    font-size: 16px !important; /* Evite le zoom sur iOS */
  }
}
