/* ========================================
   MINIMAL FLATPICKR CALENDAR
   Brand Color: #F9A141
======================================== */

:root {
  --fp-primary: #F9A141;
  --fp-primary-light: #FFF4E6;
  --fp-primary-dark: #E8891A;
  --fp-text: #1a1a1a;
  --fp-text-muted: #6b7280;
  --fp-border: #e5e7eb;
  --fp-bg: #ffffff;
  --fp-hover: #f9fafb;
}

/* Main Calendar Container */
.flatpickr-calendar {
  background: var(--fp-bg);
  border: 1px solid var(--fp-border);
  border-radius: 16px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 
              0 2px 4px -2px rgba(0, 0, 0, 0.1);
  padding: 16px;
  width: 320px;
  font-size: 14px;
  line-height: 1.5;
  opacity: 0;
  visibility: hidden;
  display: none;
  position: absolute;
  box-sizing: border-box;
  touch-action: manipulation;
  animation: none;
}

.flatpickr-calendar.open,
.flatpickr-calendar.inline {
  opacity: 1;
  visibility: visible;
}

.flatpickr-calendar.open {
  display: inline-block;
  z-index: 99999;
}

.flatpickr-calendar.animate.open {
  animation: fpFadeIn 200ms ease-out;
}

.flatpickr-calendar.inline {
  display: block;
  position: relative;
  box-shadow: none;
  border: 1px solid var(--fp-border);
}

.flatpickr-calendar.static {
  position: absolute;
  top: calc(100% + 8px);
}

.flatpickr-calendar.static.open {
  z-index: 999;
  display: block;
}

.flatpickr-calendar:focus {
  outline: none;
}

/* Remove arrows */
.flatpickr-calendar:before,
.flatpickr-calendar:after {
  display: none;
}

/* Wrapper */
.flatpickr-wrapper {
  position: relative;
  display: inline-block;
}

/* ========================================
   MONTHS HEADER
======================================== */

.flatpickr-months {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}

.flatpickr-months .flatpickr-month {
  flex: 1;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Navigation Arrows */
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  position: static;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s ease;
  color: var(--fp-text);
  fill: var(--fp-text);
}

.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  background: var(--fp-primary-light);
  color: var(--fp-primary);
  fill: var(--fp-primary);
}

.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 12px;
  height: 12px;
}

.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  fill: currentColor;
  transition: fill 0.15s ease;
}

.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,
.flatpickr-months .flatpickr-next-month.flatpickr-disabled {
  display: none;
}

/* Current Month Display */
.flatpickr-current-month {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 16px;
  font-weight: 600;
  color: var(--fp-text);
  position: static;
  width: auto;
  padding: 0;
  height: auto;
  transform: none;
}

.flatpickr-current-month span.cur-month {
  font-weight: 600;
  margin: 0;
  padding: 0;
}

.flatpickr-current-month span.cur-month:hover {
  background: none;
}

.flatpickr-current-month .numInputWrapper {
  width: 60px;
  display: inline-flex;
}

.flatpickr-current-month input.cur-year {
  background: transparent;
  border: none;
  font-size: 16px;
  font-weight: 600;
  color: var(--fp-text);
  padding: 0;
  margin: 0;
  width: 100%;
  text-align: center;
  appearance: textfield;
}

.flatpickr-current-month input.cur-year:focus {
  outline: none;
}

.flatpickr-current-month input.cur-year[disabled] {
  color: var(--fp-text-muted);
}

/* Month Dropdown */
.flatpickr-current-month .flatpickr-monthDropdown-months {
  appearance: none;
  background: transparent;
  border: none;
  font-size: 16px;
  font-weight: 600;
  color: var(--fp-text);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.15s ease;
}

.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
  background: var(--fp-hover);
}

.flatpickr-current-month .flatpickr-monthDropdown-months:focus {
  outline: none;
  background: var(--fp-primary-light);
}

/* ========================================
   WEEKDAYS
======================================== */

.flatpickr-weekdays {
  display: flex;
  height: 36px;
  margin-bottom: 4px;
}

.flatpickr-weekdays .flatpickr-weekdaycontainer {
  display: flex;
  flex: 1;
}

span.flatpickr-weekday {
  flex: 1;
  font-size: 12px;
  font-weight: 500;
  color: var(--fp-text-muted);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ========================================
   DAYS
======================================== */

.flatpickr-days {
  width: 100%;
}

.dayContainer {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  padding: 0;
  outline: none;
}

.flatpickr-day {
  width: 14.2857143%;
  flex-basis: 14.2857143%;
  max-width: 40px;
  height: 40px;
  line-height: 40px;
  margin: 1px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 400;
  color: var(--fp-text);
  border: none;
  border-radius: 10px;
  background: none;
  cursor: pointer;
  transition: all 0.15s ease;
  box-sizing: border-box;
}

.flatpickr-day:hover {
  background: var(--fp-primary-light);
  color: var(--fp-primary-dark);
}

.flatpickr-day:focus {
  outline: none;
  background: var(--fp-primary-light);
}

/* Today */
.flatpickr-day.today {
  color: var(--fp-primary);
  font-weight: 600;
  position: relative;
}

.flatpickr-day.today::after {
  content: '';
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background: var(--fp-primary);
  border-radius: 50%;
}

.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  background: var(--fp-primary-light);
  color: var(--fp-primary);
}

/* Selected */
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.selected:focus {
  background: var(--fp-primary);
  color: #ffffff;
  font-weight: 500;
  box-shadow: 0 2px 8px rgba(249, 161, 65, 0.4);
}

.flatpickr-day.selected.today::after {
  background: #ffffff;
}

/* Range Selection */
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus {
  background: var(--fp-primary);
  color: #ffffff;
  font-weight: 500;
}

.flatpickr-day.startRange {
  border-radius: 10px 0 0 10px;
}

.flatpickr-day.endRange {
  border-radius: 0 10px 10px 0;
}

.flatpickr-day.startRange.endRange {
  border-radius: 10px;
}

.flatpickr-day.inRange {
  background: var(--fp-primary-light);
  color: var(--fp-primary-dark);
  border-radius: 0;
  box-shadow: none;
}

.flatpickr-day.inRange:hover {
  background: #FFE8CC;
}

/* Other Month Days */
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: var(--fp-text-muted);
  opacity: 0.5;
}

.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover {
  background: var(--fp-hover);
  color: var(--fp-text-muted);
}

/* Disabled Days */
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed:hover {
  color: var(--fp-text-muted);
  opacity: 0.3;
  cursor: not-allowed;
  background: transparent;
}

.flatpickr-day.hidden {
  visibility: hidden;
}

/* ========================================
   NUM INPUT WRAPPER
======================================== */

.numInputWrapper {
  position: relative;
  height: auto;
}

.numInputWrapper input {
  width: 100%;
}

.numInputWrapper input::-ms-clear {
  display: none;
}

.numInputWrapper input::-webkit-outer-spin-button,
.numInputWrapper input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.numInputWrapper span {
  display: none;
}

.numInputWrapper:hover span {
  display: none;
}

/* ========================================
   TIME PICKER
======================================== */

.flatpickr-calendar.hasTime .flatpickr-time {
  height: 48px;
  border-top: 1px solid var(--fp-border);
  margin-top: 12px;
  padding-top: 12px;
}

.flatpickr-time {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 0;
  overflow: hidden;
  max-height: 48px;
}

.flatpickr-time .numInputWrapper {
  flex: 1;
  height: 40px;
  max-width: 60px;
}

.flatpickr-time input {
  background: var(--fp-hover);
  border: none;
  border-radius: 8px;
  text-align: center;
  font-size: 16px;
  font-weight: 500;
  color: var(--fp-text);
  height: 100%;
  padding: 0;
  transition: all 0.15s ease;
}

.flatpickr-time input:hover,
.flatpickr-time input:focus {
  background: var(--fp-primary-light);
  outline: none;
}

.flatpickr-time input.flatpickr-hour {
  font-weight: 600;
}

.flatpickr-time .flatpickr-time-separator {
  color: var(--fp-text-muted);
  font-weight: 600;
  padding: 0 4px;
  align-self: center;
}

.flatpickr-time .flatpickr-am-pm {
  background: var(--fp-hover);
  border: none;
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 14px;
  font-weight: 500;
  color: var(--fp-text);
  cursor: pointer;
  margin-left: 8px;
  transition: all 0.15s ease;
}

.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time .flatpickr-am-pm:focus {
  background: var(--fp-primary-light);
  color: var(--fp-primary);
  outline: none;
}

/* ========================================
   WEEK NUMBERS
======================================== */

.flatpickr-weekwrapper {
  float: left;
}

.flatpickr-weekwrapper .flatpickr-weeks {
  padding: 0 8px;
  border-right: 1px solid var(--fp-border);
}

.flatpickr-weekwrapper .flatpickr-weekday {
  width: 100%;
  line-height: 36px;
}

.flatpickr-weekwrapper span.flatpickr-day {
  color: var(--fp-text-muted);
  font-size: 12px;
  background: transparent;
  cursor: default;
  max-width: none;
  width: 100%;
}

/* ========================================
   INNER CONTAINER
======================================== */

.flatpickr-innerContainer {
  display: flex;
  box-sizing: border-box;
}

.flatpickr-rContainer {
  display: inline-block;
  padding: 0;
  box-sizing: border-box;
}

/* ========================================
   INPUT STYLES
======================================== */

.flatpickr-input {
  cursor: pointer;
}

.flatpickr-input[readonly] {
  cursor: pointer;
}

/* ========================================
   MULTI-MONTH
======================================== */

.flatpickr-calendar.multiMonth {
  width: auto;
}

.flatpickr-calendar.multiMonth .flatpickr-days {
  width: auto;
}

.flatpickr-calendar.multiMonth .dayContainer {
  width: 288px;
  min-width: 288px;
  max-width: 288px;
}

.dayContainer + .dayContainer {
  margin-left: 16px;
  padding-left: 16px;
  border-left: 1px solid var(--fp-border);
  box-shadow: none;
}

/* ========================================
   ANIMATIONS
======================================== */

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

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

/* ========================================
   RANGE MODE
======================================== */

.rangeMode .flatpickr-day {
  margin-top: 1px;
}

/* ========================================
   NO CALENDAR (TIME ONLY)
======================================== */

.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
  height: auto;
  border: none;
  margin: 0;
  padding: 0;
}