/* Custom styles for Flatpickr to match application design */

/* Container styles */
.flatpickr-calendar {
  background: #fff;
  border-radius: 0.5rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  border: 1px solid #e5e7eb;
  font-family: inherit;
}

/* Current day/selected date */
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  background: #7d52cf;
  border-color: #7d52cf;
}

/* Hover state */
.flatpickr-day:hover {
  background: #f3f4f6;
  border-color: #f3f4f6;
}

/* Today's date */
.flatpickr-day.today {
  border-color: #059669;
}

.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  background: #ecfdf5;
  border-color: #059669;
  color: #059669;
}

/* Month navigation */
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: #7d52cf;
}

.flatpickr-months .flatpickr-month {
  color: #1c1917; /* stone-900 */
}

/* Month dropdown and year input */
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  font-weight: 500;
  color: #1c1917; /* stone-900 */
}

.flatpickr-current-month .flatpickr-monthDropdown-months:hover,
.flatpickr-current-month input.cur-year:hover {
  background: #f9fafb;
}

/* Time picker */
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #f9fafb;
}

.flatpickr-time input.flatpickr-hour,
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
  font-weight: 400;
  color: #1c1917; /* stone-900 */
}

/* AM/PM selector */
.flatpickr-time .flatpickr-am-pm {
  color: #1c1917; /* stone-900 */
}

/* Weekday headers */
.flatpickr-weekday {
  color: #78716c; /* stone-500 */
  font-weight: 500;
}

/* In-range styles for date ranges */
.flatpickr-day.inRange {

  --color-primary-100: #f4eefc;
  background: #f4eefc;
  border-color: #f4eefc;
  box-shadow: -5px 0 0 #f4eefc, 5px 0 0 #f4eefc;
}
