@use '../../_styles/mixin.scss' as *;

.o-link {
  cursor: pointer;
  color: var(--link-color);
  align-items: center;
  text-decoration: none;
  border: none;
  outline: none;
  background-color: transparent;

  font-size: var(--link-text-size);
  line-height: var(--link-text-height);

  @include hover {
    color: var(--link-color-hover);
    .o-link-icon-arrow {
      transform: translate3d(4px, 0, 0);
    }
  }

  &:active {
    color: var(--link-color-active);
  }
}
.o-link-icon-arrow {
  transition: transform var(--o-easing-standard) var(--o-duration-m2);
}
.o-link-hover-underline {
  --link-underline-x: 100%;
  .o-link-label {
    background: linear-gradient(0deg, var(--link-color-hover), var(--link-color-hover)) no-repeat var(--link-underline-x) bottom;
    background-size: 0 1px;
    transition: background-size var(--o-easing-standard) var(--o-duration-m2);
  }

  @include hover {
    .o-link-label {
      background-size: var(--link-underline-x) 1px;
      background-position-x: left;
    }
  }
}

.o-link-hover-bg {
  padding: 0 2px;
  transition: background-color var(--o-easing-standard) var(--o-duration-m2);
  @include hover {
    color: var(--link-color);
    background-color: var(--link-bg-color-hover);
  }
  &:active {
    color: var(--link-color);
    background-color: var(--link-bg-color-active);
  }
}

.o-link-prefix,
.o-link-suffix {
  height: var(--link-icon-size, 1em);
  line-height: var(--link-icon-size, 1em);
  display: inline-flex;
  align-items: center;

  &::before {
    content: 'x';
    visibility: hidden;
    user-select: none;
    width: 0;
    font-size: 1em;
    flex-grow: 0;
  }

  .o-svg-icon {
    flex-grow: 0;
    flex-shrink: 0;
    font-size: var(--link-icon-size);
  }
}

.o-link-prefix {
  margin-right: var(--link-gap);
}
.o-link-suffix {
  margin-left: var(--link-gap);
}

.o-link-disabled {
  &,
  &:hover,
  &:active {
    cursor: not-allowed;
    color: var(--link-color-disabled);
  }
  @include hover {
    .o-link-icon-arrow {
      transform: translate3d(0, 0, 0);
    }
    .o-link-label {
      background: none;
    }
  }
  &.o-link-hover-underline {
    background: none;
  }
}
