/* TT Flatpickr theme — estilo limpio con header, botones redondos y selección morada */

.flatpickr-calendar {
  border: 0 !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.12) !important;
  /*font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";*/
  padding: 8px 6px 14px !important;
}

.flatpickr-months {
  padding: 8px 8px 0 !important;
}

.flatpickr-months .flatpickr-month {
  height: auto !important;
  line-height: 1.2 !important;
}

.flatpickr-current-month {
  left: 0 !important;
  width: 100% !important;
  padding: 8px 48px !important; /* espacio para flechas */
  text-align: left !important;
}

.flatpickr-current-month .cur-month {
  font-weight: 700 !important;
  font-size: 18px !important;
  margin-right: 6px !important;
}

.flatpickr-current-month .numInputWrapper input.cur-year {
  font-weight: 700 !important;
  font-size: 18px !important;
}

.flatpickr-current-month .numInputWrapper input {
  border: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.flatpickr-prev-month, .flatpickr-next-month {
  top: 10px !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  background: #F3F0FF !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
  color: #5B3AA4 !important;
  display: grid !important;
  place-items: center !important;
}

.flatpickr-prev-month svg, .flatpickr-next-month svg {
  fill: currentColor !important;
  width: 12px !important;
  height: 12px !important;
}

.flatpickr-prev-month:hover, .flatpickr-next-month:hover {
  background: #e9e3fd !important;
}

.flatpickr-weekdays {
  margin-top: 6px !important;
}

span.flatpickr-weekday {
  color: #6b7280 !important; /* gris medio */
  font-weight: 600 !important;
  font-size: 12px !important;
}

/* Grid de días */
.flatpickr-days {
  padding: 4px 8px 8px !important;
}

.dayContainer {
  gap: 2px !important;
}

.flatpickr-day {
  width: 40px !important;
  height: 40px !important;
  line-height: 40px !important;
  margin: 3px !important;
  border-radius: 10px !important;
  border: 0 !important;
  color: #111827 !important; /* gris muy oscuro */
  font-weight: 500;
}

.flatpickr-day:hover {
  background: #f3f4f6 !important;
}

.flatpickr-day.today {
  border: 0 !important;
  box-shadow: inset 0 0 0 2px #e5e7eb !important; /* contorno suave */
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
  background: #5B3AA4 !important; /* morado */
  color: #fff !important;
  box-shadow: 0 4px 10px rgba(91,43,218,.35) !important;
}

.flatpickr-day.inRange {
  background: rgba(91,43,218,.12) !important;
  color: #111827 !important;
  border-radius: 10px !important;
}

.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after,
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
  display: none !important; /* sin flecha de tooltip */
}

/* Input sugerido: bordes suaves */
input.tt-flatpickr,
input.js-date,
input.js-datetime,
input.js-daterange {
  
  outline: none;
}
input.tt-flatpickr:focus,
input.js-date:focus,
input.js-datetime:focus,
input.js-daterange:focus {
  
}

/* Forzar visibilidad y estilo del título Mes Año */
.flatpickr-calendar .flatpickr-current-month{
  display: flex !important;
  align-items: center !important;
  gap: .375rem !important;
  padding: 8px 48px !important; /* sitio para las flechas */
  color: #111827 !important;
}
.flatpickr-calendar .flatpickr-current-month .cur-month{
  display: inline !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  opacity: 1 !important;
  visibility: visible !important;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper{
  display: inline-flex !important;
}
.flatpickr-calendar .flatpickr-current-month .numInputWrapper input.cur-year{
  width: 4.5ch !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: #111827 !important;
  background: transparent !important;
  border: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.flatpickr-months .flatpickr-month {
     height: 34px !important;     
}

.flatpickr-calendar{
  padding: 24px 32px !important;
  width: auto !important;
}

.flatpickr-prev-month{
  left: 32px !important;
  top: 24px !important;
}


.flatpickr-next-month{
  right: 32px !important;
  top: 24px !important;
}

.flatpickr-calendar .dayContainer{
  min-width: none !important;
  max-width: none !important;
}



/*Select*/

.choices__inner{

}

select.form__control-select:focus {
  outline: none;
  border-color: #5B3AA4;
  box-shadow: 0 0 0 4px rgba(91, 43, 218, 0.15);
}


.choices__list--dropdown .choices__item,
    .choices__list[aria-expanded] .choices__item,
    .choices__list--dropdown .choices__item--selectable,
    .choices__list[aria-expanded] .choices__item--selectable {
        height: 40px;
        padding: 12px 12px 12px 24px;
        align-self: stretch;
        text-align: left;
        border-bottom: 1px solid #F3F4F6;
    }

    .choices__list--dropdown .choices__item.is-highlighted,
    .choices__list[aria-expanded] .choices__item.is-highlighted,
    .choices__list--dropdown .choices__item--selectable:hover,
    .choices__list[aria-expanded] .choices__item--selectable:hover {
      background: var(--Lila-01, #F3F0FF) !important;
      color: #111827 !important;  
    }

    .choices[data-type*=select-one]::after{
      display: none !important;
    }
