/* Flatpickr Custom Theme for AstroHot */
.flatpickr-calendar {
  background: #0B0B0B !important;
  border: 1px solid rgba(167, 255, 208, 0.2) !important;
  border-radius: 15px !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.8), 0 0 1px rgba(167, 255, 208, 0.3) !important;
  font-family: 'Inter', sans-serif !important;
  overflow: hidden !important;
}

.flatpickr-calendar.open {
  z-index: 99999 !important;
}

.flatpickr-calendar:before,
.flatpickr-calendar:after {
  display: none !important;
}

.flatpickr-rContainer {
  border-radius: 15px !important;
  overflow: hidden !important;
}

/* Month navigation */
.flatpickr-months {
  background: #0B0B0B !important;
  border-bottom: 1px solid rgba(167, 255, 208, 0.1) !important;
  padding: 15px 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  border-radius: 15px 15px 0 0 !important;
}

.flatpickr-month {
  color: #ffffff !important;
  fill: #ffffff !important;
  height: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.flatpickr-current-month {
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 !important;
  position: static !important;
  left: auto !important;
}

.flatpickr-current-month input.cur-year {
  color: #ffffff !important;
  font-weight: 600 !important;
  background: transparent !important;
  border: none !important;
}

.flatpickr-current-month input.cur-year:hover {
  background: rgba(167, 255, 208, 0.1) !important;
}

/* Month dropdown */
.flatpickr-current-month .flatpickr-monthDropdown-months {
  background: #0B0B0B !important;
  color: #ffffff !important;
  border: 1px solid rgba(167, 255, 208, 0.2) !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  padding-right: 30px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  min-width: 120px !important;
  height: auto !important;
  font-size: 14px !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months:hover,
.flatpickr-current-month .flatpickr-monthDropdown-months:focus {
  background: rgba(167, 255, 208, 0.1) !important;
  border-color: #A7FFD0 !important;
  outline: none !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months option {
  background: #0B0B0B !important;
  color: #ffffff !important;
  padding: 8px !important;
}

/* Year input */
.flatpickr-current-month .numInputWrapper {
  width: auto !important;
  min-width: 70px !important;
}

.flatpickr-current-month .numInputWrapper input,
.flatpickr-current-month .numInputWrapper select {
  background: #0B0B0B !important;
  color: #ffffff !important;
  border: 1px solid rgba(167, 255, 208, 0.2) !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  width: 70px !important;
  text-align: center !important;
  font-size: 14px !important;
}

.flatpickr-current-month .numInputWrapper:hover input,
.flatpickr-current-month .numInputWrapper:hover select,
.flatpickr-current-month .numInputWrapper input:focus,
.flatpickr-current-month .numInputWrapper select:focus {
  background: rgba(167, 255, 208, 0.1) !important;
  border-color: #A7FFD0 !important;
  outline: none !important;
}

/* Hide spinner arrows */
.flatpickr-current-month .numInputWrapper .arrowUp,
.flatpickr-current-month .numInputWrapper .arrowDown {
  display: none !important;
}

/* Navigation arrows */
.flatpickr-prev-month,
.flatpickr-next-month {
  color: #b8b9c1 !important;
  fill: #b8b9c1 !important;
  padding: 10px !important;
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.flatpickr-prev-month {
  left: 10px !important;
}

.flatpickr-next-month {
  right: 10px !important;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  fill: #b8b9c1 !important;
  stroke: #b8b9c1 !important;
  width: 18px !important;
  height: 18px !important;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
  color: #A7FFD0 !important;
  fill: #A7FFD0 !important;
  background: rgba(167, 255, 208, 0.1) !important;
  border-radius: 8px !important;
}

.flatpickr-prev-month:hover svg,
.flatpickr-next-month:hover svg {
  fill: #A7FFD0 !important;
  stroke: #A7FFD0 !important;
}

/* Weekdays */
.flatpickr-weekdays {
  background: #0B0B0B !important;
  border-bottom: 1px solid rgba(167, 255, 208, 0.1) !important;
}

span.flatpickr-weekday {
  color: #b8b9c1 !important;
  font-weight: 600 !important;
  font-size: 12px !important;
}

/* Days */
.flatpickr-days {
  background: #0B0B0B !important;
  border-radius: 0 0 15px 15px !important;
  overflow: hidden !important;
}

.flatpickr-days:focus {
  outline: none !important;
}

.flatpickr-innerContainer {
  background: #0B0B0B !important;
  overflow: hidden !important;
}

.dayContainer {
  background: #0B0B0B !important;
  min-width: 100% !important;
  max-width: 100% !important;
}

.flatpickr-day {
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
}

.flatpickr-day:hover {
  background: rgba(167, 255, 208, 0.1) !important;
  border-color: rgba(167, 255, 208, 0.3) !important;
  color: #ffffff !important;
}

/* Today */
.flatpickr-day.today {
  border: 1px solid rgba(167, 255, 208, 0.5) !important;
  background: rgba(167, 255, 208, 0.05) !important;
}

.flatpickr-day.today:hover {
  background: rgba(167, 255, 208, 0.15) !important;
  border-color: rgba(167, 255, 208, 0.7) !important;
}

/* Selected date */
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
  background: linear-gradient(90deg, #A7FFD0 0%, #7CF696 100%) !important;
  color: #0B0B0B !important;
  border: none !important;
  font-weight: 700 !important;
}

/* Disabled/other month days */
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: #545665 !important;
}

.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
  background: transparent !important;
  color: #545665 !important;
  cursor: not-allowed !important;
}

/* Time picker (if needed) */
.flatpickr-time {
  background: #0B0B0B !important;
  border-top: 1px solid rgba(167, 255, 208, 0.1) !important;
}

.flatpickr-time input {
  color: #ffffff !important;
  background: #0B0B0B !important;
  border: 1px solid rgba(167, 255, 208, 0.2) !important;
  border-radius: 8px !important;
}

.flatpickr-time input:hover {
  background: rgba(167, 255, 208, 0.05) !important;
}

.flatpickr-time input:focus {
  border-color: #A7FFD0 !important;
  outline: none !important;
}

/* Mobile responsiveness */
@media (max-width: 768px) {
  .flatpickr-calendar {
    max-width: 90vw;
    font-size: 14px;
  }

  .flatpickr-day {
    height: 38px;
    line-height: 38px;
    max-width: 38px;
  }

  .flatpickr-current-month {
    font-size: 14px;
  }
}

/* Animation */
.flatpickr-calendar.animate.open {
  animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
}

@keyframes fpFadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, -10px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
