/**
 * Flatpickr — внешний вид в стиле приложения (токены из main.css).
 * Подключать сразу после vendor/flatpickr/flatpickr.min.css
 */

.flatpickr-calendar {
    background: var(--color-background) !important;
    color: var(--color-foreground);
    font-family: var(--font-sans);
    font-size: var(--font-size-sm);
    line-height: 1.4;
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
    width: auto;
    min-width: 200px;
    max-width: min(320px, calc(100vw - 24px));
}

.flatpickr-calendar.open {
    z-index: 1100;
}

/* Стрелка у выпадающего блока */
.flatpickr-calendar.arrowTop:before {
    border-bottom-color: var(--color-border);
}

.flatpickr-calendar.arrowTop:after {
    border-bottom-color: var(--color-background);
}

.flatpickr-calendar.arrowBottom:before {
    border-top-color: var(--color-border);
}

.flatpickr-calendar.arrowBottom:after {
    border-top-color: var(--color-background);
}

/* Только время — компактный блок */
.flatpickr-calendar.noCalendar.hasTime {
    padding: var(--spacing-3) var(--spacing-4);
}

.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
    border-top: none;
    min-height: auto;
    height: auto;
    padding: var(--spacing-1) 0;
}

.flatpickr-time {
    border-top: 1px solid var(--color-border);
    background: transparent;
}

.flatpickr-time:after {
    content: none;
}

.flatpickr-time input.flatpickr-hour,
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second,
.flatpickr-time .flatpickr-time-separator {
    color: var(--color-foreground);
    font-weight: 600;
    font-size: var(--font-size-base);
    font-family: var(--font-sans);
}

.flatpickr-time .numInputWrapper {
    background: var(--color-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    height: var(--touch-target-sm);
    min-width: 2.75rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.flatpickr-time .numInputWrapper:hover {
    background: var(--color-accent);
    border-color: var(--color-muted-foreground);
}

.flatpickr-time .numInputWrapper:focus-within {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.flatpickr-time input {
    background: transparent !important;
    box-shadow: none !important;
}

.flatpickr-time .numInputWrapper span.arrowUp,
.flatpickr-time .numInputWrapper span.arrowDown {
    border: none;
    opacity: 0.75;
}

.flatpickr-time .numInputWrapper span.arrowUp:hover,
.flatpickr-time .numInputWrapper span.arrowDown:hover {
    opacity: 1;
    background: color-mix(in srgb, var(--color-primary) 12%, transparent);
}

.flatpickr-time .numInputWrapper span.arrowUp:after {
    border-bottom-color: var(--color-foreground);
}

.flatpickr-time .numInputWrapper span.arrowDown:after {
    border-top-color: var(--color-foreground);
}

.flatpickr-time .flatpickr-am-pm {
    background: var(--color-muted);
    color: var(--color-foreground);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-weight: 600;
    font-family: var(--font-sans);
}

.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time .flatpickr-am-pm:focus {
    background: var(--color-accent);
    border-color: var(--color-primary);
}

/* --- Calendar grid (vendor uses fixed #393939 / #fff; must follow theme tokens) --- */

.flatpickr-inner {
    background: var(--color-background) !important;
}

.flatpickr-months {
    background: var(--color-background) !important;
}

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    color: var(--color-foreground) !important;
    fill: var(--color-foreground) !important;
}

.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
    color: var(--color-primary) !important;
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
    fill: var(--color-primary) !important;
}

.flatpickr-current-month {
    color: var(--color-foreground) !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: var(--color-muted) !important;
    color: var(--color-foreground) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md);
    font-family: var(--font-sans);
    font-weight: 600;
}

.flatpickr-current-month .numInputWrapper {
    background: var(--color-muted) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md);
}

.flatpickr-current-month .numInputWrapper:hover {
    background: var(--color-accent) !important;
}

.flatpickr-current-month input.cur-year {
    color: var(--color-foreground) !important;
    font-weight: 600 !important;
    font-family: var(--font-sans);
}

.flatpickr-current-month .numInputWrapper span.arrowUp,
.flatpickr-current-month .numInputWrapper span.arrowDown {
    border-color: var(--color-border) !important;
}

.flatpickr-current-month .numInputWrapper span.arrowUp:after {
    border-bottom-color: var(--color-foreground) !important;
}

.flatpickr-current-month .numInputWrapper span.arrowDown:after {
    border-top-color: var(--color-foreground) !important;
}

.flatpickr-weekdays {
    background: var(--color-background) !important;
}

span.flatpickr-weekday {
    color: var(--color-muted-foreground) !important;
    font-weight: 600;
}

.flatpickr-days {
    background: var(--color-background) !important;
}

.dayContainer {
    background: var(--color-background) !important;
}

.flatpickr-day {
    color: var(--color-foreground) !important;
    border-color: transparent !important;
    font-weight: 500;
}

.flatpickr-day:hover,
.flatpickr-day:focus {
    background: var(--color-accent) !important;
    color: var(--color-accent-foreground) !important;
    border-color: var(--color-border) !important;
}

.flatpickr-day.today {
    border-color: var(--color-primary) !important;
    background: color-mix(in srgb, var(--color-primary) 18%, transparent) !important;
}

.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
    background: var(--color-accent) !important;
    color: var(--color-accent-foreground) !important;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: var(--color-muted-foreground) !important;
    opacity: 0.55;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
    color: var(--color-muted-foreground) !important;
    opacity: 0.35;
    background: transparent !important;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
    background: var(--color-primary) !important;
    color: var(--color-primary-foreground) !important;
    border-color: var(--color-primary) !important;
    box-shadow: none !important;
}

.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
    background: var(--color-primary) !important;
    color: var(--color-primary-foreground) !important;
    filter: brightness(1.08);
}

.flatpickr-day.inRange {
    background: color-mix(in srgb, var(--color-primary) 32%, var(--color-muted)) !important;
    color: var(--color-foreground) !important;
    border-color: transparent !important;
    box-shadow: none !important;
}

.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange {
    background: var(--color-primary) !important;
    color: var(--color-primary-foreground) !important;
}
