@charset "UTF-8";

.p-calendar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: var(--space-xxs);
  font-size: var(--fs-18);
}

.p-calendar__row {
  display: grid;
  align-items: flex-start;
  gap: var(--space-xxs);
}

.p-calendar__label {
  grid-column: span 3;
  display: grid;
  place-content: center;
  height: 60px;
  color: #fff;
  background: var(--color-primary);
  font-weight: var(--fw-bold);
}

.p-calendarBlock__month {
  display: grid;
  place-content: center;
  height: 60px;
  color: var(--color-primary);
  font-weight: var(--fw-bold);
  background: #DEE4EF;
  line-height: 1;
}

.p-calendar__btn {
  position: relative;
  z-index: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  row-gap: var(--space-xs);
  width: fit-content;
  margin: auto;
  pointer-events: none;
}

.p-calendar__btn a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1px 1px 1px 16px;
  font-size: var(--fs-14);
  font-weight: var(--fw-bold);
  line-height: var(--lh-md);
  color: var(--color-primary);
  border: 1px solid var(--color-primary);
  border-radius: 100vmax;
  background: #fff;
  text-decoration: none;
  pointer-events: all;
}

.p-calendar__btn a::after {
  flex: 0 0 auto;
  content: "";
  width: 30px;
  height: 30px;
  background-color: currentColor;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
  mask-image: var(--icon-arrow-right-lg);
  -webkit-mask-image: var(--icon-arrow-right-lg);
}

@media (hover: hover) {
  .p-calendar__btn a:hover {
    border: 1px solid var(--color-primary) !important;
    background-color:  var(--color-light-blue) !important;
    color: var(--color-primary);
  }
}

@media (max-width: 767px) {
  .p-calendar {
    grid-template-columns: 1fr;
    row-gap: var(--space-xxs);
    font-size: var(--fs-16);
  }
  .p-calendar__row {
    grid-template-columns: 45px 1fr;
    grid-template-areas:
      "label row1"
      "label row2"
      "label row3"
    ;
  }
  .p-calendar__row:nth-child(1) .p-calendar__label {
    border-top-left-radius: 8px;
  }
  .p-calendar__row:nth-child(4) .p-calendar__label {
    border-bottom-left-radius: 8px;
  }
  .p-calendar__label {
    grid-area: label;
    height: 100%;
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
  .p-calendarBlock {
    display: grid;
    grid-template-columns: 45px 1fr;
  }
  .p-calendarBlock__month {
    height: 100%;
    min-height: 34px;
    padding-block: 4px;
    box-sizing: border-box;
  }
  .p-calendarBlock__content {
    padding: var(--space-xxs) 0 var(--space-xxs) var(--space-xs);
  }
  .p-calendar__btn {
    width: 100%;
    row-gap: var(--space-xxs);
  }
}

@media (min-width: 768px) {
  .p-calendar__row {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 60px 1fr;
    align-items: flex-start;
  }
  .p-calendar__row:nth-child(1) .p-calendar__label {
    border-top-left-radius: 8px;
  }
  .p-calendar__row:nth-child(1) .p-calendarBlock:first-of-type .p-calendarBlock__month {
    border-bottom-left-radius: 8px;
  }
  .p-calendar__row:nth-child(4) .p-calendar__label {
    border-top-right-radius: 8px;
  }
  .p-calendar__row:nth-child(4) .p-calendarBlock:last-of-type .p-calendarBlock__month {
    border-bottom-right-radius: 8px;
  }
  .p-calendarBlock__content:not(:empty) {
    position: relative;
    margin-inline: -150px;
    padding-top: 24px;
  }
  .p-calendarBlock--step1 .p-calendarBlock__content { padding-top: 24px; }
  .p-calendarBlock--step2 .p-calendarBlock__content { padding-top: 74px; }
  .p-calendarBlock--step3 .p-calendarBlock__content { padding-top: 124px; }
  .p-calendarBlock--step4 .p-calendarBlock__content { padding-top: 174px; }
  .p-calendarBlock--step5 .p-calendarBlock__content { padding-top: 222px; }
  .p-calendarBlock__content:not(:empty)::before,
  .p-calendarBlock__content:not(:empty)::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: var(--color-accent);
  }
  .p-calendarBlock__content::before {
    z-index: 2;
    top: -4px;
    aspect-ratio: 1/1;
    width: 8px;
    border-radius: 50%;
  }
  .p-calendarBlock__content::after {
    z-index: 0;
    top: 0;
    width: 1px;
    height: 100%;
  }
  .p-calendar__btn a {
    white-space: nowrap;
  }
}