.toggle-switch {
  position: relative;
  display: inline-block;
  width: 52px;
  height: 32px;
}

.toggle-input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--background--color);
  transition: 0.4s;
  border-radius: 100px;
  border: 1px solid var(--stroke--color);
}

.toggle-slider:before {
  position: absolute;
  content: "";
  height: 24px;
  width: 24px;
  left: 4px;
  bottom: 3px;
  background-color: var(--foreground--color);
  transition: 0.4s;
  border-radius: 100px;
}

.toggle-slider:hover:before {
  background-color: var(--foreground--color-hover);
}

.toggle-slider:active:before {
  background-color: var(--foreground--color-active);
}

.toggle-input:checked + .toggle-slider:before {
  transform: translateX(18px);
}
