:root {
  --button--bg-color--primary: var(--color-primary);
  --button--bg-color--primary-hover: white;
}

.button {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  min-height: 3.5rem;
  border: 0.125rem solid transparent;
  border-radius: 62.5rem;
  background: var(--button--bg-color--primary);
  color: var(--color-text);
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: -0.02rem;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  box-shadow: none;
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease,
    box-shadow 0.3s ease;
  min-width: 8rem;

  &:is(a) {
    text-decoration: none !important;
  }
}

.button:hover,
.button:focus {
  background: var(--button--bg-color--primary-hover);
  /* box-shadow: 0 0 0 1px rgb(0 0 0 / 0.12); */
  border-color: var(--color-text);
  color: var(--color-text);
}

/* -- Outline variant -- */
.button--outline {
  background: transparent;
  border-color: var(--color-text);
  color: var(--color-text);
}

/* -- Dark variant -- */
.button--dark {
  background: var(--color-dark);
  color: var(--color-text-inverse);
}
