/**
 * Reusable full-width inline jQuery UI Datepicker styling.
 *
 * Usage:
 *   <div id="my_picker" class="bm-datepicker-inline"></div>
 *   $("#my_picker").datepicker({ ... });
 *
 * Requires: jQuery UI datepicker, Font Awesome 5 (admin header).
 * Optional: mark cells with class "ui-state-actived" in beforeShowDay (e.g. blocked dates).
 */

.bm-datepicker-inline {
  display: block;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 0.25rem;
  padding: 1rem 1.1rem 1.15rem;
  background: linear-gradient(180deg, #eff6ff 0%, #f1f5f9 55%, #f8fafc 100%);
  border: 1px solid #c7d2fe;
  border-radius: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.bm-datepicker-inline .ui-datepicker {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.1) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

.bm-datepicker-inline .ui-datepicker-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 0.5rem !important;
  height: auto !important;
  min-height: 3.1rem !important;
  line-height: 1.25 !important;
  margin: 0 !important;
  padding: 0.65rem 0.85rem !important;
  background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 45%, #3b82f6 100%) !important;
  border: none !important;
  border-radius: 0 !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 1.05rem !important;
  position: relative !important;
}

.bm-datepicker-inline .ui-datepicker-title {
  flex: 1 1 auto !important;
  order: 2 !important;
  margin: 0 !important;
  text-align: center !important;
  line-height: 1.3 !important;
  font-size: 1.05rem !important;
  letter-spacing: 0.02em !important;
}

.bm-datepicker-inline .ui-datepicker-title select.ui-datepicker-month,
.bm-datepicker-inline .ui-datepicker-title select.ui-datepicker-year {
  margin: 0 0.15rem !important;
  padding: 0.3rem 0.45rem !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255, 255, 255, 0.45) !important;
  background: rgba(255, 255, 255, 0.96) !important;
  color: #0f172a !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  vertical-align: middle !important;
  max-width: 48% !important;
}

.bm-datepicker-inline .ui-datepicker-prev,
.bm-datepicker-inline .ui-datepicker-next {
  position: relative !important;
  float: none !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  width: 2.35rem !important;
  height: 2.35rem !important;
  min-width: 2.35rem !important;
  margin: 0 !important;
  text-indent: 0 !important;
  overflow: visible !important;
  cursor: pointer !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255, 255, 255, 0.35) !important;
  background: rgba(255, 255, 255, 0.12) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.bm-datepicker-inline .ui-datepicker-prev {
  order: 1 !important;
  margin-left: 0 !important;
}

.bm-datepicker-inline .ui-datepicker-next {
  order: 3 !important;
  margin-right: 0 !important;
}

.bm-datepicker-inline .ui-datepicker-prev:hover,
.bm-datepicker-inline .ui-datepicker-next:hover {
  background: rgba(255, 255, 255, 0.22) !important;
  border-color: rgba(255, 255, 255, 0.55) !important;
}

.bm-datepicker-inline .ui-datepicker-prev .ui-icon,
.bm-datepicker-inline .ui-datepicker-next .ui-icon {
  display: none !important;
}

.bm-datepicker-inline .ui-datepicker-prev:after,
.bm-datepicker-inline .ui-datepicker-next:after {
  font-family: "Font Awesome 5 Free" !important;
  font-weight: 900 !important;
  content: "\f104" !important;
  position: static !important;
  display: block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  border: none !important;
  color: #fff !important;
  font-size: 1.1rem !important;
  line-height: 1 !important;
  transform: none !important;
  top: auto !important;
}

.bm-datepicker-inline .ui-datepicker-next:after {
  content: "\f105" !important;
}

.bm-datepicker-inline .ui-datepicker-calendar {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  table-layout: fixed !important;
  border-collapse: separate !important;
  border-spacing: 6px !important;
  padding: 0.5rem 0.65rem 0.85rem !important;
  box-sizing: border-box !important;
}

.bm-datepicker-inline .ui-datepicker-calendar thead th {
  padding: 0.35rem 0.15rem 0.5rem !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: #64748b !important;
  border: none !important;
  background: transparent !important;
}

.bm-datepicker-inline .ui-datepicker-calendar thead tr th span {
  display: block !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  font-size: inherit !important;
  color: inherit !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td {
  padding: 0 !important;
  vertical-align: middle !important;
  border: none !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default,
.bm-datepicker-inline .ui-datepicker-calendar tbody td span.ui-state-default {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 2.65rem !important;
  height: auto !important;
  margin: 0 auto !important;
  padding: 0.35rem 0.2rem !important;
  box-sizing: border-box !important;
  border-radius: 10px !important;
  font-size: 0.98rem !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  color: #1e293b !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default:hover {
  background: #eff6ff !important;
  color: #1d4ed8 !important;
  border-color: #93c5fd !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-today a.ui-state-default {
  background: #dbeafe !important;
  color: #1e40af !important;
  border-color: #60a5fa !important;
}

/* Selected day (focused choice): dark pill + white number — booking & admin inline pickers */
.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default,
.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active {
  background: #0f172a !important;
  color: #fff !important;
  border-color: #0f172a !important;
  font-weight: 700 !important;
  font-size: 1.08rem !important;
  min-height: 2.85rem !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.28) !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default:hover,
.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active:hover {
  background: #1e293b !important;
  color: #fff !important;
  border-color: #334155 !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-state-actived a.ui-state-default {
  background: #dc3545 !important;
  color: #fff !important;
  border-color: #b02a37 !important;
}

.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-state-actived a.ui-state-default:hover {
  background: #fff !important;
  color: #dc3545 !important;
  border-color: #dc3545 !important;
}

/* Appointments/POS: holidays from Settings — not bookable, light red cell + red-toned number */
.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-unselectable.bm-holiday-blocked {
  background: #fef2f2 !important;
}
.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-unselectable.bm-holiday-blocked span.ui-state-default {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 2.65rem !important;
  margin: 0 auto !important;
  padding: 0.35rem 0.2rem !important;
  box-sizing: border-box !important;
  border-radius: 10px !important;
  font-size: 0.98rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  background: #fecdd3 !important;
  color: #991b1b !important;
  border: 1px solid #f87171 !important;
  opacity: 1 !important;
  cursor: not-allowed !important;
}

.bm-datepicker-inline .ui-datepicker-calendar .ui-state-disabled span.ui-state-default,
.bm-datepicker-inline .ui-datepicker-unselectable .ui-state-default {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
  background: #f1f5f9 !important;
  color: #94a3b8 !important;
  border-color: #e2e8f0 !important;
}

.bm-datepicker-inline .ui-datepicker-buttonpane {
  margin: 0 !important;
  padding: 0.5rem 0.75rem !important;
  border-top: 1px solid #e2e8f0 !important;
  background: #f8fafc !important;
}

/* -------------------------------------------------------------------------
   ID-scoped overrides (#datepickers / #holiday_picker): load order and other
   admin stylesheets were winning over .bm-datepicker-inline alone; these rules
   match the same DOM as Holidays and force the skin to apply on Appointments.
   ------------------------------------------------------------------------- */
#datepickers.bm-datepicker-inline,
#holiday_picker.bm-datepicker-inline {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  margin-top: 0.25rem !important;
  padding: 1rem 1.1rem 1.15rem !important;
  background: linear-gradient(180deg, #eff6ff 0%, #f1f5f9 55%, #f8fafc 100%) !important;
  border: 1px solid #c7d2fe !important;
  border-radius: 14px !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7) !important;
}

#datepickers.bm-datepicker-inline .ui-datepicker,
#holiday_picker.bm-datepicker-inline .ui-datepicker {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow: 0 8px 28px rgba(15, 23, 42, 0.1) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
}

#datepickers.bm-datepicker-inline .ui-datepicker-header,
#holiday_picker.bm-datepicker-inline .ui-datepicker-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 0.5rem !important;
  height: auto !important;
  min-height: 3.1rem !important;
  line-height: 1.25 !important;
  margin: 0 !important;
  padding: 0.65rem 0.85rem !important;
  background: linear-gradient(135deg, #1d4ed8 0%, #2563eb 45%, #3b82f6 100%) !important;
  border: none !important;
  border-radius: 0 !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: 1.05rem !important;
  position: relative !important;
}

/* Hide "Prev"/"Next" label text inside jQuery UI icons (no theme CSS required) */
#datepickers.bm-datepicker-inline .ui-datepicker-prev .ui-icon,
#datepickers.bm-datepicker-inline .ui-datepicker-next .ui-icon,
#holiday_picker.bm-datepicker-inline .ui-datepicker-prev .ui-icon,
#holiday_picker.bm-datepicker-inline .ui-datepicker-next .ui-icon {
  display: none !important;
}

#datepickers.bm-datepicker-inline .ui-datepicker-buttonpane button,
#holiday_picker.bm-datepicker-inline .ui-datepicker-buttonpane button {
  border-radius: 8px !important;
  padding: 0.35rem 0.85rem !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  border: 1px solid #cbd5e1 !important;
  background: #fff !important;
  color: #1e293b !important;
}

#datepickers.bm-datepicker-inline .ui-datepicker-buttonpane button:hover,
#holiday_picker.bm-datepicker-inline .ui-datepicker-buttonpane button:hover {
  background: #eff6ff !important;
  border-color: #93c5fd !important;
  color: #1d4ed8 !important;
}

/* Selected day — repeat for #datepickers so customer booking wins over load order */
#datepickers.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default,
#datepickers.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active,
#holiday_picker.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default,
#holiday_picker.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active {
  background: #0f172a !important;
  color: #fff !important;
  border-color: #0f172a !important;
  font-weight: 700 !important;
  font-size: 1.08rem !important;
  min-height: 2.85rem !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.28) !important;
}

#datepickers.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default:hover,
#datepickers.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active:hover,
#holiday_picker.bm-datepicker-inline .ui-datepicker-calendar tbody td.ui-datepicker-current-day a.ui-state-default:hover,
#holiday_picker.bm-datepicker-inline .ui-datepicker-calendar tbody td a.ui-state-default.ui-state-active:hover {
  background: #1e293b !important;
  color: #fff !important;
  border-color: #334155 !important;
}
