.scroll-link {
  display: flex;
  align-items: center;
  position: relative;
  color: var(--text--color);
  text-decoration: none;
  cursor: pointer;
}

.scroll-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 1px;
  background-color: var(--stroke--color);
  will-change: transform;
  transform-origin: 100% 100%;
  transform: scaleX(0);
  pointer-events: none;
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-duration: 0.5s;
}

.scroll-link:hover::after {
  transform-origin: 0 0;
  transform: scaleX(1);
}

.scroll-link:hover .default-text {
  transform: translateY(-125%);
}

.scroll-link:hover .hover-text {
  transform: none;
}

.scroll-link .scroll-link-inner {
  overflow: hidden;
  position: relative;
  display: block;
}

.scroll-link .default-text,
.scroll-link .hover-text {
  display: block;
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  transition-duration: 0.5s;
}

.scroll-link .hover-text {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(125%);
}
