.step-indicators {
  @extend %reset;
  width: 100%;
  max-width: 100%;
  display: flex;
  padding-bottom: 15px;
  margin-bottom: 20px;
  overflow: hidden;

  &__items {
    position: relative;
    width: 100%;
    max-width: 100vw;
    padding-bottom: 15px;
    margin-bottom: 22.5px;
    display: flex;
    flex-grow: 0;
    justify-content: space-between;
    align-items: flex-start;

    &:before {
      content: '';
      position: absolute;
      width: 95%;
      height: 0;
      left: 2.5%;
      top: 20px;
      border-bottom: var(--tide-booking-step-indicators-line-trough);
    }
  }

  &__item {
    position: relative;
    padding-bottom: 1.05rem;
    @include column;
    align-items: center;
    text-align: center;
    text-decoration: none;
    color: inherit !important;

    &:first-child {
      align-items: flex-start;
      text-align: left;
    }

    &:last-child {
      align-items: flex-end;
      text-align: right;
    }
  }

  &__item--active {
    &:before {
      content: '';
      position: absolute;
      width: 200%;
      height: 1.5px;
      margin-top: 0.75px;
      top: 15px;
      left: 35px;
    }

    .step-indicators {
      &__icon {
        border: var(--tide-booking-step-indicators-icon-border-active);
        color: transparent;
        background-color: var(--tide-booking-step-indicators-icon-background-active);
        animation: pulse 7s infinite;

        &:before {
          content: '';
          position: absolute;
          width: 17px;
          height: 6px;
          margin-top: -5px;
          margin-left: -2px;
          border-left: 2px solid;
          border-bottom: 2px solid;
          border-color: var(--tide-booking-step-indicators-icon-check-color-active);
          transform: rotate(-45deg);
        }
      }

      &__text {
        color: var(--tide-booking-step-indicators-icon-color-text-active);
      }
    }
  }

  &__item--completed {
    &:before {
      content: '';
      position: absolute;
      width: 200%;
      height: 1.5px;
      margin-top: 0.75px;
      top: 15px;
      left: 35px;
    }

    .step-indicators__icon {
      border: var(--tide-booking-step-indicators-icon-color-completed);
      color: transparent;
      background-color: var(--tide-booking-step-indicators-icon-background-completed);

      &:before {
        content: '';
        position: absolute;
        width: 17px;
        height: 6px;
        margin-top: -5px;
        margin-left: -2px;
        border-left: 2px solid;
        border-bottom: 2px solid;
        border-color: var(--tide-booking-step-indicators-icon-check-color-completed);
        transform: rotate(-45deg);
      }
    }
  }

  &__icon {
    @extend %reset;
    position: relative;
    width: 40px;
    height: 40px;
    padding-top: 2px;
    @include flex--centerXY;
    flex: 0 0 40px;
    border-radius: var(--tide-booking-step-indicators-icon-border-radius);
    font-family: var(--tide-booking-step-indicators-icon-font-family);
    color: var(--tide-booking-step-indicators-icon-color);
    background-color: var(--tide-booking-step-indicators-icon-background);
    @extend %transition-easing;
    z-index: 1;
  }

  &__text {
    position: absolute;
    max-width: 20vw;
    white-space: nowrap;
    top: 50px;
    font-family: var(--tide-booking-step-indicators-icon-font-family);
    font-size: 10px;
    line-height: 1.2;
    text-overflow: ellipsis;
    overflow: hidden;

    @include media-xs {
      font-size: 12px;
    }

    @include media-sm {
      font-size: 14px;
    }

    @include media-md {
      //font-size: 1.8rem;
      font-size: 16px;
    }
  }
}
