/* Modern Flatpickr Theme (Tailwind-compatible) */

.flatpickr-calendar {
    background: #ffffff;
    border: 1px solid #e5e7eb; /* gray-200 */
    border-radius: 0.5rem; /* rounded-lg */
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); /* shadow-lg */
    font-family: 'Almarai', sans-serif;
    width: 307.875px;
}

/* Dark Mode Support */
html.dark .flatpickr-calendar {
    background: #1f2937; /* gray-800 */
    border-color: #374151; /* gray-700 */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.5);
}

/* Header */
.flatpickr-calendar.arrowTop:before, .flatpickr-calendar.arrowTop:after {
    display: none; /* Hide arrow for cleaner look */
}

.flatpickr-month {
    background: transparent;
    color: #374151; /* gray-700 */
    fill: #374151;
    height: 48px;
    padding-top: 10px;
}
html.dark .flatpickr-month {
    color: #f3f4f6; /* gray-100 */
    fill: #f3f4f6;
}

.flatpickr-current-month span.cur-month {
    font-weight: 700;
    font-size: 1rem;
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: #374151;
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: #374151;
}
html.dark .flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: #fff;
}
html.dark .flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: #fff;
}


/* Days Wrapper */
.flatpickr-weekdays {
    background: transparent;
    height: 28px;
}
span.flatpickr-weekday {
    background: transparent;
    color: #6b7280; /* gray-500 */
    font-size: 0.8rem;
    font-weight: 600;
}
html.dark span.flatpickr-weekday {
    color: #9ca3af; /* gray-400 */
}

/* Days */
.flatpickr-day {
    color: #374151; /* gray-700 */
    border-radius: 0.375rem; /* rounded-md */
    font-weight: 500;
}
html.dark .flatpickr-day {
    color: #e5e7eb; /* gray-200 */
}

.flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover, .flatpickr-day:focus {
    background: #f3f4f6; /* gray-100 */
    border-color: #f3f4f6;
}
html.dark .flatpickr-day:hover, html.dark .flatpickr-day.prevMonthDay:hover, html.dark .flatpickr-day.nextMonthDay:hover, html.dark .flatpickr-day:focus {
    background: #374151; /* gray-700 */
    border-color: #374151;
}

/* 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: #2563eb; /* blue-600 */
    border-color: #2563eb;
    color: #ffffff;
}
html.dark .flatpickr-day.selected {
    background: #3b82f6; /* blue-500 */
    border-color: #3b82f6;
    color: #ffffff;
}

/* Today */
.flatpickr-day.today {
    border-color: #2563eb; /* blue-600 */
}
html.dark .flatpickr-day.today {
    border-color: #3b82f6; /* blue-500 */
}
.flatpickr-day.today:hover, .flatpickr-day.today:focus {
    border-color: #2563eb;
    background: #2563eb;
    color: #fff;
}

/* Time Picker */
.flatpickr-time {
    border-top: 1px solid #e5e7eb;
}
html.dark .flatpickr-time {
    border-top-color: #374151;
}

.flatpickr-time input {
    color: #374151;
}
html.dark .flatpickr-time input {
    color: #e5e7eb;
}

.flatpickr-time .flatpickr-time-separator, .flatpickr-time .flatpickr-am-pm {
    color: #374151;
}
html.dark .flatpickr-time .flatpickr-time-separator, html.dark .flatpickr-time .flatpickr-am-pm {
    color: #e5e7eb;
}

.flatpickr-time .flatpickr-am-pm:hover, .flatpickr-time .flatpickr-am-pm:focus {
    background: #f3f4f6;
}
html.dark .flatpickr-time .flatpickr-am-pm:hover, html.dark .flatpickr-time .flatpickr-am-pm:focus {
    background: #374151;
}
