/* Customização do Flatpickr para o tema Museus UFPB */

/* Container principal */
.flatpickr-calendar {
    background: #fff !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Cabeçalho do mês */
.flatpickr-months {
    background: #fff !important;
    border-bottom: 1px solid #e0e0e0 !important;
    padding: 10px 0 !important;
}

.flatpickr-month {
    color: #333 !important;
}

.flatpickr-current-month {
    font-size: 110% !important;
    font-weight: 500 !important;
    color: #333 !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
    background: #fff !important;
    color: #333 !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    padding: 4px 8px !important;
    font-weight: 500 !important;
}

.flatpickr-current-month .numInputWrapper {
    background: #fff !important;
}

.flatpickr-current-month input.cur-year {
    color: #333 !important;
    font-weight: 500 !important;
}

/* Setas de navegação */
.flatpickr-prev-month,
.flatpickr-next-month {
    fill: #666 !important;
    padding: 8px !important;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    background: #f5f5f5 !important;
    border-radius: 4px !important;
}

/* Dias da semana */
.flatpickr-weekdays {
    background: #fafafa !important;
    border-bottom: 1px solid #e0e0e0 !important;
    padding: 8px 0 !important;
}

.flatpickr-weekday {
    color: #666 !important;
    font-weight: 600 !important;
    font-size: 85% !important;
}

/* Container dos dias com grade */
.flatpickr-days {
    background: #fff !important;
    border: none !important;
}

.dayContainer {
    min-width: 280px !important;
    max-width: 280px !important;
}

/* Dias do calendário com grade */
.flatpickr-day {
    color: #333 !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 0 !important;
    font-weight: 400 !important;
    margin: 0 !important;
    height: 40px !important;
    line-height: 40px !important;
    max-width: 40px !important;
    width: 40px !important;
}

/* Dia normal (hover) */
.flatpickr-day:hover:not(.flatpickr-disabled) {
    background: #f0f0f0 !important;
    border-color: #d0d0d0 !important;
}

/* Dia selecionado */
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: #1a73e8 !important;
    color: #fff !important;
    border-color: #1a73e8 !important;
    font-weight: 500 !important;
}

/* Dia de hoje */
.flatpickr-day.today {
    border-color: #1a73e8 !important;
    background: #fff !important;
    font-weight: 500 !important;
}

.flatpickr-day.today:hover:not(.flatpickr-disabled) {
    background: #f0f0f0 !important;
}

/* Dia desabilitado - APENAS OPACIDADE REDUZIDA */
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
    color: #333 !important;
    background: #fff !important;
    cursor: not-allowed !important;
    opacity: 0.3 !important;
    border-color: #e8e8e8 !important;
}

/* Dias de outros meses */
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: #999 !important;
    opacity: 0.4 !important;
}

.flatpickr-day.prevMonthDay.flatpickr-disabled,
.flatpickr-day.nextMonthDay.flatpickr-disabled {
    opacity: 0.2 !important;
}

/* Input do campo de data */
#visitDate {
    background: #fff !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    padding: 10px 12px !important;
    font-size: 14px !important;
    color: #333 !important;
    cursor: pointer !important;
    transition: border-color 0.2s ease !important;
}

#visitDate:hover {
    border-color: #999 !important;
}

#visitDate:focus {
    outline: none !important;
    border-color: #1a73e8 !important;
    box-shadow: 0 0 0 2px rgba(26, 115, 232, 0.1) !important;
}

/* Animação de abertura */
.flatpickr-calendar.open {
    animation: flatpickrFadeIn 0.15s ease-out !important;
}

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

/* Responsivo */
@media (max-width: 768px) {
    .flatpickr-calendar {
        font-size: 14px !important;
    }
    
    .flatpickr-day {
        height: 36px !important;
        line-height: 36px !important;
        max-width: 36px !important;
        width: 36px !important;
    }
    
    .dayContainer {
        min-width: 252px !important;
        max-width: 252px !important;
    }
}
