/*
 * Viacol Booking Institutional Style
 * Scope: solo booking views WPBookit/Flatpickr
 */

.wpb-booking-shortcode {
  --vcbis-green-900: #173b23;
  --vcbis-green-800: #1f4d2e;
  --vcbis-green-700: #255532;
  --vcbis-green-600: #2f6b3f;
  --vcbis-green-200: #b9cfbf;
  --vcbis-green-150: #c5d8ca;
  --vcbis-green-100: #ddebe1;
  --vcbis-green-50:  #eaf3ec;
  --vcbis-orange-700: rgba(125, 73, 12, 0.72);
  --vcbis-orange-300: rgba(243, 169, 68, 0.28);
  --vcbis-orange-100: rgba(243, 169, 68, 0.12);
  --vcbis-gray-300:  #d9dee3;
  --vcbis-gray-200:  #eef1f4;
  --vcbis-text:      #0f1720;
  --vcbis-white:     #ffffff;
  --vcbis-radius:    10px;
}

.wpb-booking-shortcode .flatpickr-calendar.inline {
  width: 100% !important;
  max-width: 100% !important;
  background: var(--vcbis-white) !important;
  border: 1px solid var(--vcbis-gray-300) !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  padding: 8px 0 14px !important;
}

.wpb-booking-shortcode .flatpickr-months {
  padding: 10px 12px 16px !important;
  border-bottom: 1px solid var(--vcbis-gray-200) !important;
}

.wpb-booking-shortcode .flatpickr-month,
.wpb-booking-shortcode .flatpickr-current-month,
.wpb-booking-shortcode .flatpickr-current-month .flatpickr-monthDropdown-months,
.wpb-booking-shortcode .flatpickr-current-month input.cur-year {
  color: var(--vcbis-text) !important;
  font-weight: 700 !important;
}

.wpb-booking-shortcode .flatpickr-prev-month,
.wpb-booking-shortcode .flatpickr-next-month {
  color: var(--vcbis-green-800) !important;
  fill: var(--vcbis-green-800) !important;
}

.wpb-booking-shortcode .flatpickr-prev-month:hover,
.wpb-booking-shortcode .flatpickr-next-month:hover {
  color: var(--vcbis-green-900) !important;
  fill: var(--vcbis-green-900) !important;
}

.wpb-booking-shortcode .flatpickr-weekdays {
  background: transparent !important;
  margin-top: 8px !important;
}

.wpb-booking-shortcode .flatpickr-weekday {
  color: #6b7782 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
}

.wpb-booking-shortcode .flatpickr-day {
  color: var(--vcbis-text) !important;
  font-weight: 600 !important;
  border-radius: var(--vcbis-radius) !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
}

/* 1) BLOQUEADOS -> naranja suave con transparencia */
.wpb-booking-shortcode .flatpickr-day.flatpickr-disabled,
.wpb-booking-shortcode .flatpickr-day.flatpickr-disabled:hover,
.wpb-booking-shortcode .flatpickr-day.prevMonthDay.flatpickr-disabled,
.wpb-booking-shortcode .flatpickr-day.prevMonthDay.flatpickr-disabled:hover,
.wpb-booking-shortcode .flatpickr-day.nextMonthDay.flatpickr-disabled,
.wpb-booking-shortcode .flatpickr-day.nextMonthDay.flatpickr-disabled:hover {
  background: var(--vcbis-orange-100) !important;
  background-color: var(--vcbis-orange-100) !important;
  border: 1px solid var(--vcbis-orange-300) !important;
  border-color: var(--vcbis-orange-300) !important;
  border-radius: 12px !important;
  color: var(--vcbis-orange-700) !important;
  opacity: 1 !important;
  cursor: not-allowed !important;
}

/* 2) HABILITADOS -> verde institucional */
.wpb-booking-shortcode .flatpickr-day.wpb-available:not(.selected):not(.today),
.wpb-booking-shortcode .flatpickr-day.wpb-available.nextMonthDay:not(.selected):not(.today) {
  background: var(--vcbis-green-50) !important;
  border: 1px solid rgba(211, 169, 31, 0.42) !important;
  color: var(--vcbis-green-800) !important;
  opacity: 1 !important;
}

/* 3) Hover / focus */
.wpb-booking-shortcode .flatpickr-day.wpb-available:not(.selected):not(.today):hover,
.wpb-booking-shortcode .flatpickr-day.wpb-available:not(.selected):not(.today):focus,
.wpb-booking-shortcode .flatpickr-day.wpb-available.nextMonthDay:not(.selected):not(.today):hover,
.wpb-booking-shortcode .flatpickr-day.wpb-available.nextMonthDay:not(.selected):not(.today):focus {
  background: var(--vcbis-green-100) !important;
  border-color: var(--vcbis-green-200) !important;
  color: var(--vcbis-green-900) !important;
}

/* 4) Seleccionado -> circular, verde intenso */
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected:hover,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected:focus,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected.wpb-available,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected.wpb-available:hover,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected:hover,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected:focus,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected.wpb-available,
.wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected.wpb-available:hover {
  background: #8BC34A !important;
  border: 1px solid #6E9B35 !important;
  color: #111111 !important;
  font-weight: 700 !important;
  border-radius: 999px !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
}

/* 5) Today disponible pero no seleccionado */
.wpb-booking-shortcode .flatpickr-day.today.wpb-available:not(.selected) {
  background: var(--vcbis-green-50) !important;
  border: 1px solid var(--vcbis-green-200) !important;
  color: var(--vcbis-green-800) !important;
}

/* Slots disponibles -> grid compacto, 4 por línea */
.wpb-booking-shortcode .booking-slots-time-wrapper {
  overflow: visible !important;
}

.wpb-booking-shortcode .booking-slots-time {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
}

.wpb-booking-shortcode .booking-slots-time .item {
  width: auto !important;
  margin: 0 !important;
}

.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn {
  width: 100% !important;
  min-height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px 6px !important;
  border-radius: 14px !important;
  border: 1px solid var(--vcbis-green-150) !important;
  background: rgba(243, 203, 48, 0.10) !important;
  color: #111111 !important;
  box-shadow: none !important;
}

.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn:hover,
.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn:focus {
  border-color: rgba(211, 169, 31, 0.60) !important;
  background: rgba(243, 203, 48, 0.16) !important;
  color: #111111 !important;
}

.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn .date-time-slot {
  color: inherit !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
}

.wpb-booking-shortcode .booking-slots-time .item.active .avaliable-slot-btn,
.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn.active,
.wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn[aria-pressed="true"] {
  background: #F3CB30 !important;
  border-color: #D2A91E !important;
  color: #111111 !important;
}

@media (max-width: 767px) {
  .wpb-booking-shortcode .flatpickr-calendar.inline {
    border-radius: 16px !important;
  }

  .wpb-booking-shortcode .flatpickr-weekday {
    font-size: 13px !important;
  }

  /* Mobile: habilitados y seleccionado siempre redondos, no ovalados */
  .wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.wpb-available:not(.flatpickr-disabled),
  .wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.selected,
  .wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected,
  .wpb-booking-shortcode .flatpickr-calendar .flatpickr-day.today.selected.wpb-available {
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    height: 44px !important;
    line-height: 44px !important;
    border-radius: 50% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

@media (max-width: 767px) {
  .wpb-booking-shortcode .booking-slots-time {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn {
    min-height: 48px !important;
    padding: 8px 4px !important;
    border-radius: 12px !important;
  }

  .wpb-booking-shortcode .booking-slots-time .avaliable-slot-btn .date-time-slot {
    font-size: 12px !important;
  }
}

/* Override fuerte por conflicto de especificidad del theme - seleccionado */
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected:hover,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected:focus,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected:hover,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected:focus,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected.wpb-available,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected.wpb-available:hover,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected.wpb-available,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected.wpb-available:hover {
  background: #8BC34A !important;
  background-color: #8BC34A !important;
  color: #111111 !important;
  border: 1px solid #6E9B35 !important;
  border-color: #6E9B35 !important;
  border-radius: 50% !important;
  box-shadow: none !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

/* Override fuerte por conflicto de especificidad del theme - deshabilitados */
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.flatpickr-disabled,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.flatpickr-disabled:hover,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.prevMonthDay.flatpickr-disabled,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.prevMonthDay.flatpickr-disabled:hover,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.nextMonthDay.flatpickr-disabled,
body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.nextMonthDay.flatpickr-disabled:hover {
  background: rgba(243, 169, 68, 0.12) !important;
  background-color: rgba(243, 169, 68, 0.12) !important;
  color: rgba(125, 73, 12, 0.72) !important;
  border: 1px solid rgba(243, 169, 68, 0.28) !important;
  border-color: rgba(243, 169, 68, 0.28) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
  opacity: 1 !important;
}

/* Override fuerte mobile - círculos perfectos en habilitados */
@media (max-width: 767px) {
  body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.wpb-available:not(.flatpickr-disabled),
  body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.selected,
  body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected,
  body .wpb-shortcode-wrapper .wpb-booking-shortcode .calander-body .flatpickr-calendar .flatpickr-rContainer .flatpickr-day.today.selected.wpb-available {
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    height: 44px !important;
    line-height: 44px !important;
    border-radius: 50% !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
