/* Flatpickr minimal theme overrides (carga DESPUES de material_blue.css y confirmDate.css) */

.flatpickr-calendar {
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08) !important;
    border-radius: 10px !important;
    background: #fff !important;
    overflow: hidden !important;
}
.flatpickr-calendar.arrowTop:after,
.flatpickr-calendar.arrowBottom:after { border-color: #fff transparent transparent transparent !important; }
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowBottom:before { border-color: #e2e8f0 transparent transparent transparent !important; }

.flatpickr-months {
    background: #fff !important;
    padding: 6px 6px 0 !important;
}
.flatpickr-months .flatpickr-month {
    background: #fff !important;
    color: #1e293b !important;
    fill: #1e293b !important;
    height: 38px !important;
    border-radius: 0 !important;
}
.flatpickr-current-month {
    font-weight: 600 !important;
    color: #1e293b !important;
    font-size: 0.92rem !important;
    padding-top: 6px !important;
    height: 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: transparent !important;
    color: #1e293b !important;
    font-weight: 600 !important;
    font-size: 0.92rem !important;
    padding: 2px 6px !important;
    border-radius: 6px !important;
}
.flatpickr-current-month input.cur-year {
    color: #1e293b !important;
    font-weight: 600 !important;
    font-size: 0.92rem !important;
}
.flatpickr-current-month .numInputWrapper:hover,
.flatpickr-current-month .flatpickr-monthDropdown-months:hover { background: #f1f5f9 !important; }
.numInputWrapper span.arrowUp:after { border-bottom-color: #94a3b8 !important; }
.numInputWrapper span.arrowDown:after { border-top-color: #94a3b8 !important; }

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
    padding: 8px 10px !important;
    height: 32px !important;
    width: 32px !important;
    color: #64748b !important;
    fill: #64748b !important;
    border-radius: 8px !important;
    transition: background 0.15s, color 0.15s;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    top: 4px !important;
}
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
    background: #f1f5f9 !important;
    color: #2563eb !important;
    fill: #2563eb !important;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg { fill: #2563eb !important; }
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
    width: 12px !important;
    height: 12px !important;
    fill: inherit !important;
    color: inherit !important;
}

.flatpickr-weekdays { background: transparent !important; padding-top: 4px !important; }
.flatpickr-weekdaycontainer { background: transparent !important; }
span.flatpickr-weekday {
    color: #94a3b8 !important;
    background: transparent !important;
    font-weight: 600 !important;
    font-size: 0.7rem !important;
    text-transform: none !important;
}

.flatpickr-days { border-left: none !important; border-right: none !important; padding: 2px 0 4px !important; }
.dayContainer { padding: 2px 4px !important; }
.flatpickr-day {
    color: #475569 !important;
    border-radius: 8px !important;
    height: 32px !important;
    line-height: 32px !important;
    max-height: 32px !important;
    font-size: 0.8rem !important;
    border: none !important;
    margin: 1px 0 !important;
}
.flatpickr-day:hover {
    background: #f1f5f9 !important;
    border-color: transparent !important;
}
.flatpickr-day.today {
    background: transparent !important;
    border: 1.5px solid #2563eb !important;
    color: #2563eb !important;
    font-weight: 700 !important;
}
.flatpickr-day.today:hover { background: #eff6ff !important; color: #2563eb !important; }
.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange {
    background: #2563eb !important;
    color: #fff !important;
    border-color: #2563eb !important;
    box-shadow: none !important;
}
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay { color: #cbd5e1 !important; }
.flatpickr-day.flatpickr-disabled { color: #e2e8f0 !important; background: transparent !important; }

.flatpickr-time {
    background: #fff !important;
    border-top: 1px solid #f1f5f9 !important;
    max-height: 44px !important;
    height: 44px !important;
}
.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
    color: #1e293b !important;
    font-weight: 600 !important;
    font-size: 0.88rem !important;
    background: transparent !important;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover { background: #f1f5f9 !important; }
.flatpickr-time .flatpickr-time-separator {
    color: #94a3b8 !important;
    font-weight: 600 !important;
}
.flatpickr-time .numInputWrapper span.arrowUp:after { border-bottom-color: #64748b !important; }
.flatpickr-time .numInputWrapper span.arrowDown:after { border-top-color: #64748b !important; }

.flatpickr-confirm {
    background: #fff !important;
    color: #2563eb !important;
    fill: #2563eb !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    border-top: 1px solid #f1f5f9 !important;
    height: 40px !important;
    max-height: 40px !important;
    border-radius: 0 0 10px 10px !important;
    transition: background 0.15s;
}
.flatpickr-confirm:hover { background: #eff6ff !important; }
.flatpickr-confirm.darkTheme {
    background: #fff !important;
    color: #2563eb !important;
    fill: #2563eb !important;
}
.flatpickr-confirm svg path { fill: currentColor !important; }
