/* ═══════════════════════════════════════
   FLATPICKR — TEMA PREMIUM DARK
═══════════════════════════════════════ */

.flatpickr-calendar {
    background: #0d0d1a !important;
    border: 1px solid rgba(108, 124, 255, .30) !important;
    border-radius: 24px !important;
    box-shadow:
        0 8px 32px rgba(0, 0, 0, .60),
        0 0 0 1px rgba(108, 124, 255, .10),
        0 0 60px rgba(108, 124, 255, .12) !important;
    padding: 20px !important;
    width: min(360px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    font-family: inherit !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

.flatpickr-months {
    display: flex !important;
    align-items: center !important;
    margin-bottom: 16px !important;
    position: relative !important;
    width: 100% !important;
}

.flatpickr-month {
    background: transparent !important;
    color: #fff !important;
    height: 36px !important;
    line-height: 36px !important;
    width: 100% !important;
}

.flatpickr-current-month {
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    padding-top: 0 !important;
    width: 100% !important;
    left: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
}

.flatpickr-current-month .cur-month,
.flatpickr-current-month input.cur-year {
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 16px !important;
}

.flatpickr-monthDropdown-months {
    background: #0d0d1a !important;
    color: #fff !important;
    font-weight: 700 !important;
    border: none !important;
    font-size: 16px !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    padding: 8px 10px !important;
    border-radius: 10px !important;
    transition: background .2s !important;
    position: relative !important;
    top: 0 !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    z-index: 10 !important;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    background: rgba(108, 124, 255, .18) !important;
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
    fill: rgba(255, 255, 255, .70) !important;
    transition: fill .2s !important;
    width: 14px !important;
    height: 14px !important;
}

.flatpickr-prev-month:hover svg,
.flatpickr-next-month:hover svg {
    fill: #7f8cff !important;
}

.flatpickr-weekdays {
    background: transparent !important;
    margin-bottom: 8px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid rgba(108, 124, 255, .12) !important;
    width: 100% !important;
}

.flatpickr-weekdaycontainer {
    width: 100% !important;
    display: flex !important;
    justify-content: space-around !important;
}

span.flatpickr-weekday {
    background: transparent !important;
    color: #ffffff !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    flex: 1 !important;
    text-align: center !important;
}

.flatpickr-innerContainer,
.flatpickr-rContainer {
    width: 100% !important;
}

.flatpickr-days {
    width: 100% !important;
    border: none !important;
}

.dayContainer {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: space-around !important;
    gap: 2px 0 !important;
}

.flatpickr-day {
    position: relative !important;
    background: transparent !important;
    border: none !important;
    border-radius: 10px !important;
    color: #e0e0ff !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    height: 36px !important;
    line-height: 36px !important;
    width: 14.2857143% !important;
    max-width: 14.2857143% !important;
    flex-basis: 14.2857143% !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    margin: 1px 0 !important;
    transition: background .15s, color .15s !important;
    box-sizing: border-box !important;
}

.flatpickr-day:hover {
    background: rgba(108, 124, 255, .22) !important;
    color: #fff !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: linear-gradient(135deg, #6c7cff, #9b59ff) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 18px rgba(108, 124, 255, .55) !important;
}

.flatpickr-day.today {
    border: 1.5px solid #6c7cff !important;
    color: #a0aaff !important;
    font-weight: 700 !important;
}

.flatpickr-day.today.selected {
    color: #fff !important;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: rgba(224, 224, 255, .18) !important;
}

.flatpickr-day.flatpickr-disabled {
    color: rgba(224, 224, 255, .30) !important;
    background: rgba(255, 255, 255, .018) !important;
    cursor: not-allowed !important;
}

.flatpickr-day.flatpickr-disabled:hover {
    color: rgba(224, 224, 255, .30) !important;
    background: rgba(255, 255, 255, .018) !important;
}

.flatpickr-day.dia-fechado:not(.prevMonthDay):not(.nextMonthDay)::after {
    content: '' !important;
    position: absolute !important;
    left: 50% !important;
    bottom: 4px !important;
    width: 4px !important;
    height: 4px !important;
    border-radius: 50% !important;
    background: #ef4444 !important;
    box-shadow: 0 0 6px rgba(239, 68, 68, .65) !important;
    transform: translateX(-50%) !important;
}

.flatpickr-day.dia-disponivel:not(.prevMonthDay):not(.nextMonthDay)::after {
    content: '' !important;
    position: absolute !important;
    left: 50% !important;
    bottom: 4px !important;
    width: 4px !important;
    height: 4px !important;
    border-radius: 50% !important;
    background: #22c55e !important;
    box-shadow: 0 0 6px rgba(34, 197, 94, .55) !important;
    transform: translateX(-50%) !important;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.prevMonthDay.flatpickr-disabled,
.flatpickr-day.nextMonthDay.flatpickr-disabled {
    color: rgba(224, 224, 255, .18) !important;
    background: transparent !important;
}

.calendar-legenda {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 14px !important;
    padding-top: 12px !important;
    margin-top: 8px !important;
    border-top: 1px solid rgba(108, 124, 255, .12) !important;
    color: rgba(224, 224, 255, .62) !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: .02em !important;
}

.calendar-legenda span {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
}

.calendar-dot {
    display: inline-block !important;
    width: 5px !important;
    height: 5px !important;
    border-radius: 50% !important;
}

.calendar-dot.disponivel {
    background: #22c55e !important;
    box-shadow: 0 0 6px rgba(34, 197, 94, .55) !important;
}

.calendar-dot.indisponivel {
    background: #ef4444 !important;
    box-shadow: 0 0 6px rgba(239, 68, 68, .65) !important;
}

/* ═══════════════════════════════════════
   TIME PICKER PREMIUM
═══════════════════════════════════════ */

.tp-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s ease;
    overscroll-behavior: contain;
}

.tp-overlay.open {
    opacity: 1;
    pointer-events: all;
}

.tp-modal {
    background: #0e0e1c;
    border: 1px solid rgba(108,124,255,.28);
    border-radius: 28px;
    width: min(360px, calc(100vw - 24px));
    max-width: calc(100vw - 24px);
    padding: 24px 20px 20px;
    box-shadow:
        0 32px 80px rgba(0,0,0,.7),
        0 0 0 1px rgba(108,124,255,.08),
        0 0 100px rgba(108,124,255,.12);
    transform: scale(.93) translateY(16px);
    transition: transform .3s cubic-bezier(.32,1,.6,1);
    box-sizing: border-box;
}

.tp-overlay.open .tp-modal {
    transform: scale(1) translateY(0);
}
