.date-range-picker {
  display: flex;
  width: 100%;
  padding: 15px;
  gap: 30px;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;

  @include media-md {
    flex-flow: row;
  }

  * {
    box-sizing: border-box;
  }

  &__from,
  &__to {
    flex-basis: 50%;
  }
}

.calendar {
  display: flex;
  flex-flow: column;

  &__header {
    display: flex;
    flex-flow: column;
  }

  &__pager {
    @include h4;
    position: relative;
    display: flex;
    align-items: center;
    height: 30px;
    gap: 5px;
    color: var(--tide-booking-datepicker-month-color);
    font-family: var(--tide-booking-datepicker-month-font);
  }

  &__current-month {
    flex-grow: 1;
    text-align: center;

    &:first-letter {
      text-transform: uppercase;
    }
  }

  &__previous,
  &__next {
    width: auto;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--tide-booking-datepicker-prev-next-color);
    fill: var(--tide-booking-datepicker-prev-next-color);
    background: var(--tide-booking-datepicker-prev-next-background);
    cursor: pointer;

    &--disabled {
      visibility: hidden;
    }

    .icon {
      position: relative !important;
      top: 0 !important;
      left: 0 !important;
      width: 15px !important;
      height: 15px !important;
      display: block !important;
    }
  }

  &__next {
    @media (max-width: 991px) {
      position: absolute;
      top: initial;
      right: 0;
      justify-content: flex-end;
    }
  }

  &__previous {
    transform: rotate(180deg);
  }

  &__day-labels {
    display: flex;
    justify-content: stretch;
    margin: 10px 0;
    font-size: 16px;
    color: var(--tide-booking-datepicker-day-labels-color);

    @include media-lg {
      font-size: 18px;
    }
  }

  &__day-label {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    width: 55px;
  }

  &__body {
    display: flex;
    flex-flow: column;
    gap: 3px;
    width: 100%;
  }

  &__week {
    display: flex;
    gap: 3px;
  }

  &__day {
    position: relative;
    width: calc(100% / 7);
    height: 45px;
    padding: 2px 0;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    border-radius: var(--tide-booking-datepicker-day-border-radius);
    border: var(--tide-booking-datepicker-day-border);
    font-size: 16px;
    line-height: 1;
    background: var(--tide-booking-datepicker-day-background);
    color: var(--tide-booking-datepicker-day-color);
    transition-property: border, background-color, color;
    transition-duration: 200ms;
    box-sizing: border-box;
    cursor: pointer;
    overflow: hidden;

    @include media-lg {
      font-size: 18px;
    }

    &:hover {
      color: var(--tide-booking-datepicker-day-color-hover);
      background: var(--tide-booking-datepicker-day-background-hover);
      border: var(--tide-booking-datepicker-day-border-hover);
    }

    &--selected {
      border: var(--tide-booking-datepicker-day-border-selected);
      background-color: var(--tide-booking-datepicker-day-background-selected);
      color: var(--tide-booking-datepicker-day-color-selected);

      &:hover {
        border: var(--tide-booking-datepicker-day-border-selected-hover);
        background: var(--tide-booking-datepicker-day-background-selected-hover);
        color: var(--tide-booking-datepicker-day-color-selected-hover);
      }
    }

    &--disabled {
      color: var(--tide-booking-datepicker-day-color-disabled);
      background: var(--tide-booking-datepicker-day-background-disabled);
      border: var(--tide-booking-datepicker-day-border-disabled);
      cursor: not-allowed;

      &:hover {
        color: var(--tide-booking-datepicker-day-color-disabled);
        background: var(--tide-booking-datepicker-day-background-disabled);
        border: var(--tide-booking-datepicker-day-border-disabled);
      }
    }

    &--outside-month {
      color: var(--tide-booking-datepicker-day-color-outside-month);
      background: var(--tide-booking-datepicker-day-background-outside-month);
      border: var(--tide-booking-datepicker-day-border-outside-month);
      opacity: var(--tide-booking-datepicker-day-opacity-outside-month);

      &:hover {
        color: var(--tide-booking-datepicker-day-color-outside-month);
        background: var(--tide-booking-datepicker-day-background-outside-month);
        border: var(--tide-booking-datepicker-day-border-outside-month);
      }
    }
  }
}

.qsm__panel--mobile {
  top: 0;
  position: fixed;
  bottom: 0;
}

.qsm__panel .date-range-picker {
  margin: auto;

  &__from,
  &__to {
    width: 100%;
    flex-basis: initial;
  }
}

.product-intro .qsm--inline .qsm__panel--dates-pricing {
  @include media-sm {
    width: 100% !important;
    left: 2px !important;
  }

  @include media-lg {
    width: auto !important;
    left: initial !important;
    padding: 15px;
  }
}
