:where([role=switch]) {
  appearance: none;
  box-shadow: none;
  outline: none;
  position: relative;
  height: 1rem;
  min-height: 1rem;
  width: 2rem;
  display: inline-block;
  vertical-align: top;
  padding: 0;
  cursor: pointer;
  border: 0.0625rem solid var(--color-9);
  border-radius: 0.6875rem;
  background-color: var(--color-9);
  transition: background-color .3s, border-color .3s;

  &::after {
    content: '';
    display: block;
    position: absolute;
    opacity: 1;
    left: .125rem;
    top: .125rem;
    border-radius: 50%;
    width: .65rem;
    height: .625rem;
    background-color: var(--color-1);
    transform: translateX(var(--x, 0));
    border: 0;
  }

  &:checked {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    --x: 1rem;

    &::after {
      background-color: var(--color-1);
    }
    label:has(&) { font-weight: 600;}
  }

  &:disabled:not(:checked) {
    background-color: var(--color-8);
  }

  label:has(&) {
    align-items: center;
  }
}
