.CalendarNew {
  background: var(--color-background-surface-highest-default);
  box-shadow: var(--shadow-m);
  border-radius: var(--border-radius-xs);
  inline-size: var(--calendar-body-inline-size);
}

  .CalendarNew-BaseContainer {
    display: flex;
    flex-direction: column;
  }

  .CalendarNew-Header {
    display: flex;
    justify-content: space-between;
    padding: var(--calendar-header-padding);
  }

  .CalendarNew-HeaderContainer {
    display: flex;
    justify-content: space-between;
    min-inline-size: 100%;
  }

  .CalendarNew-HeaderElement {
    display: flex;
  }

  .CalendarNew-HeaderElement_data {
      gap: var(--calender-header-data-gap);
    }

  .CalendarNew-HeaderElement_buttons {
      direction: ltr;
      gap: 18px;
    }

  .CalendarNew-HeaderButton {
    gap: 2px;
  }

  .CalendarNew-HeaderButton_hidden {
      visibility: hidden;
    }

  .CalendarNew-Body {
    display: grid;
    align-items: center;
    block-size: var(--calendar-body-block-size);
    min-inline-size: var(--calendar-body-inline-size);
    padding: 0 var(--calendar-body-inline-padding)
      var(--calendar-body-block-padding) var(--calendar-body-inline-padding);
    box-sizing: border-box;
    row-gap: 2px;
  }

  .CalendarNew-Body_base {
      grid-template-columns: repeat(7, 1fr);
    }

  .CalendarNew-Body_select {
      grid-template-columns: repeat(3, 1fr);
    }

  .CalendarNew-DateItem {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .CalendarNew-DateItem_day {
      block-size: var(--calendar-day-block-size);
      inline-size: var(--calendar-day-inline-size);
    }

  .CalendarNew-DateItem_month {
      block-size: var(--calendar-month-year-block-size);
    }

  .CalendarNew-MonthYearButton {
    padding: 0;
    border-radius: var(--border-radius-xs);
    background: none;
    border: none;
    cursor: pointer;
    transition: background var(--transition-default);
  }

  .CalendarNew-MonthYearButton:hover:not(.CalendarNew-MonthYearButton_selected) {
      background: var(--color-background-base-main-hover);
    }

  .CalendarNew-MonthYearButton:focus-visible {
      border: solid 2px var(--color-border-accent-focused);
      box-sizing: border-box;
      outline: 0;
      z-index: 2;
    }

  .CalendarNew-MonthYearButton_selected {
      background: var(--color-background-accent-default);
    }

  .CalendarNew-DayButton {
    position: relative;
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
    transition: none;
  }

  .CalendarNew-DayButton:hover:not(
        .CalendarNew-DayButton_selected,
        .CalendarNew-DayButton_rangeSelected,
        .CalendarNew-DayButton_disabled
      )::after {
        opacity: 1;
        background: var(--color-background-base-main-hover);
      }

  .CalendarNew-DayButton:focus-visible {
      outline: 0;
      z-index: 2;
    }

  .CalendarNew-DayButton:focus-visible::after {
        opacity: 1;
        border: solid 2px var(--color-border-accent-focused);
        box-sizing: border-box;
      }

  .CalendarNew-DayButton::after {
      content: '';
      position: absolute;
      opacity: 0;
      border-radius: 50%;
      block-size: var(--calendar-day-block-size);
      inline-size: var(--calendar-day-block-size);
    }

  .CalendarNew-DayButton::before {
      content: '';
      position: absolute;
      opacity: 0;
      inline-size: var(--calendar-day-inline-size);

      /* Увеличиваем область кнопки на 2px, чтобы компенсировать gap */
      block-size: calc(var(--calendar-day-block-size) + 2px);
    }

  .CalendarNew-DayButton_disabled {
      cursor: not-allowed;
    }

  .CalendarNew-DayButton_selected::after {
        opacity: 1;
        background: var(--color-background-accent-default);
      }

  .CalendarNew-DayButton_rangeSelected {
      background: var(--color-background-accent-light);
    }

  .CalendarNew-DayButton_rangeSelectedRight {
      background: linear-gradient(
        to right,
        transparent 50%,
        var(--color-background-accent-light) 50%
      );
    }

  .CalendarNew-DayButton_rangeSelectedLeft {
      background: linear-gradient(
        to left,
        transparent 50%,
        var(--color-background-accent-light) 50%
      );
    }

  .CalendarNew-DayButton_rangeSupposed {
      background: var(--color-background-base-main-hover);
    }

  .CalendarNew-DayButton_rangeSupposedRight {
      background: linear-gradient(
        to right,
        transparent 50%,
        var(--color-background-base-main-hover) 50%
      );
    }

  .CalendarNew-DayButton_rangeSupposedLeft {
      background: linear-gradient(
        to left,
        transparent 50%,
        var(--color-background-base-main-hover) 50%
      );
    }

  .CalendarNew-DateText {
    z-index: 2;
  }

  .CalendarNew-DateText_disabled {
      text-decoration: line-through;
    }

  .CalendarNew_size_s {
      --calendar-header-padding: 14px 16px;
      --calender-header-data-gap: 12px;
      --calendar-day-block-size: 36px;
      --calendar-day-inline-size: 40px;
      --calendar-month-year-block-size: 40px;
      --calendar-body-block-padding: 8px;
      --calendar-body-inline-padding: 8px;
      --calendar-body-block-size: calc(
        264px + var(--calendar-body-block-padding)
      );
      --calendar-body-inline-size: calc(
        280px + var(--calendar-body-inline-padding) * 2
      );
    }

  .CalendarNew_size_m {
      --calendar-header-padding: 14px 24px;
      --calender-header-data-gap: 16px;
      --calendar-day-block-size: 40px;
      --calendar-day-inline-size: 46px;
      --calendar-month-year-block-size: 48px;
      --calendar-body-block-padding: 8px;
      --calendar-body-inline-padding: 12px;
      --calendar-body-block-size: calc(
        292px + var(--calendar-body-block-padding)
      );
      --calendar-body-inline-size: calc(
        322px + var(--calendar-body-inline-padding) * 2
      );
    }

  .CalendarNew_size_l {
      --calendar-header-padding: 20px 28px;
      --calender-header-data-gap: 20px;
      --calendar-day-block-size: 48px;
      --calendar-day-inline-size: 54px;
      --calendar-month-year-block-size: 56px;
      --calendar-body-block-padding: 8px;
      --calendar-body-inline-padding: 16px;
      --calendar-body-block-size: calc(
        348px + var(--calendar-body-block-padding)
      );
      --calendar-body-inline-size: calc(
        378px + var(--calendar-body-inline-padding) * 2
      );
    }

  .CalendarNew_dateRange {
    display: flex;
    inline-size: calc(2 * var(--calendar-body-inline-size));
  }
