/* Calendario Flatpickr Premium Design - Dark & Light Mode */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap');

.flatpickr-calendar {
  width: 340px !important;
  background: #121212 !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 24px !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.6) !important;
  padding: 20px !important;
  font-family: 'Outfit', sans-serif !important;
  backdrop-filter: blur(12px) !important;
  overflow: hidden !important;
  animation: fpFadeIn 0.3s cubic-bezier(0.2, 0, 0, 1) !important;
}

@keyframes fpFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.flatpickr-months {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: transparent !important;
  padding: 0 5px 15px 5px !important;
  height: auto !important;
}

.flatpickr-month {
  background: transparent !important;
  color: #fff !important;
  fill: #fff !important;
  height: auto !important;
  font-weight: 600 !important;
}

.flatpickr-current-month {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  position: relative !important;
  left: 0 !important;
  width: auto !important;
  text-align: center !important;
  padding: 0 !important;
}

.flatpickr-current-month .cur-month {
  font-weight: 700 !important;
  margin-right: 4px !important;
}

.flatpickr-current-month input.cur-year {
  font-weight: 400 !important;
  color: rgba(255, 255, 255, 0.6) !important;
}

.flatpickr-prev-month, .flatpickr-next-month {
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255, 255, 255, 0.05) !important;
  transition: all 0.2s ease !important;
  color: #fff !important;
  fill: #fff !important;
}

.flatpickr-prev-month:hover, .flatpickr-next-month:hover {
  background: var(--primary, #3b82f6) !important;
  box-shadow: 0 4px 15px rgba(59, 130, 246, 0.4) !important;
}

.flatpickr-prev-month svg, .flatpickr-next-month svg {
  fill: currentColor !important;
  width: 14px !important;
  height: 14px !important;
}

.flatpickr-innerContainer {
  padding: 0 !important;
}

.flatpickr-weekdays {
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  margin-bottom: 10px !important;
}

.flatpickr-weekday {
  color: rgba(255, 255, 255, 0.4) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

.flatpickr-days {
  padding: 5px 0 0 0 !important;
  width: 100% !important;
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
}

.flatpickr-day {
  width: 40px !important;
  height: 40px !important;
  line-height: 40px !important;
  border-radius: 12px !important;
  color: rgba(255, 255, 255, 0.8) !important;
  margin: 2px auto !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  transition: all 0.2s ease !important;
  border: 1px solid transparent !important;
}

.flatpickr-day:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  transform: scale(1.05) !important;
  color: #fff !important;
}

.flatpickr-day.today {
  border-color: var(--primary, #3b82f6) !important;
  color: var(--primary, #3b82f6) !important;
  font-weight: 700 !important;
}

.flatpickr-day.selected {
  background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
  color: #fff !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 12px rgba(37, 99, 235, 0.4) !important;
  border: none !important;
}

.flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay {
  color: rgba(255, 255, 255, 0.2) !important;
}

.flatpickr-time {
  border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
  height: 40px !important;
  line-height: 40px !important;
  max-height: 40px !important;
}

/* LIGHT MODE */
[data-theme="light"] .flatpickr-calendar {
  background: #ffffff !important;
  color: #1e293b !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08) !important;
}

[data-theme="light"] .flatpickr-month,
[data-theme="light"] .flatpickr-current-month,
[data-theme="light"] .flatpickr-current-month .cur-month {
  color: #1e293b !important;
}

[data-theme="light"] .flatpickr-current-month input.cur-year {
  color: #64748b !important;
}

[data-theme="light"] .flatpickr-prev-month, 
[data-theme="light"] .flatpickr-next-month {
  background: #f1f5f9 !important;
  color: #1e293b !important;
}

[data-theme="light"] .flatpickr-weekday {
  color: #94a3b8 !important;
}

[data-theme="light"] .flatpickr-day {
  color: #334155 !important;
}

[data-theme="light"] .flatpickr-day:hover {
  background: #f8fafc !important;
  color: #0f172a !important;
}

[data-theme="light"] .flatpickr-day.prevMonthDay, 
[data-theme="light"] .flatpickr-day.nextMonthDay {
  color: #cbd5e1 !important;
}
