.toggle {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  gap: 0.75rem;
  align-items: center;
  margin-left: 1rem;
  padding: 0.5rem;
  background-color: #444;
  border-radius: 2rem;
  user-select: none;
  cursor: pointer;
  transition: translate 0.3s, background-color 0.8s;
  max-height: 2rem;
}

.toggle::before {
  position: absolute;
  top: 1px;
  left: 1px;
  content: "";
  height: calc(100% - 2px);
  aspect-ratio: 1;
  border-radius: 50%;
  transition: translate 0.3s, background-color 0.8s;
  background: #fff;
}

.toggle input {
  position: absolute;
  appearance: none;
}

.toggle span {
  position: relative;
  transition: translate 0.6s ease 0.2s;
}

.toggle span:nth-of-type(1) {
  translate: 0 150%;
}

.toggle span:nth-of-type(2) {
  translate: 0 0%;
}

.toggle:has(input:checked) {
  background-color: #ddd;
}

.toggle:has(input:checked) span:nth-of-type(1) {
  translate: 0 0%;
}

.toggle:has(input:checked) span:nth-of-type(2) {
  translate: 0 -150%;
}

.toggle:has(input:checked)::before {
  translate: 100% 0;
  background-color: #444;
}