.progress-bar {
  height: 3px;
  background-color: rgb(var(--color-border));
}

.progress-bar::before {
  content: '';
  background: var(--gradient-progress);
  background-color: rgb(var(--color-progress, var(--color-text)));
  border-radius: inherit;
  display: block;
  height: inherit;
  transform: scaleX(0);
  transform-origin: var(--transform-origin-start);
  transition: transform 0.8s cubic-bezier(.19, 1, .22, 1);
}

.progress-bar[data-decrease]::before {
  transform: scaleX(1);
}

.progress-bar span {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: calc(var(--progress) * 100%);
  transform: translateY(-50%);
  padding: 0 8px;
  opacity: 0;
  color: rgb(var(--color-progress, var(--color-text)));
  background-color: rgb(var(--color-background));
  transition: opacity 0.3s ease 0.5s;
}

.progress-bar.animated:before {
  transform: scaleX(var(--progress));
}

.progress-bar.animated span {
  opacity: 1;
}