/* Switch */

.switch-wrapper {
  display: flex;
  align-items: center;
}

.switch-wrapper input[type='checkbox'] {
  display: none;
}

.switch-input {
  height: 0;
  width: 0;
  visibility: hidden;
}

.switch {
  cursor: var(--form-switch-base-cursor);
  text-indent: -9999px;
  width: var(--form-switch-sizes-md-track-width);
  height: var(--form-switch-sizes-md-track-height);
  background: var(--form-switch-track-bg);
  display: block;
  border-radius: var(--form-switch-track-border-radius);
  position: relative;
  transition: var(--form-switch-base-transition);
}

.switch:after {
  content: '';
  position: absolute;
  top: var(--form-switch-thumb-top);
  left: var(--form-switch-thumb-left);
  width: var(--form-switch-sizes-md-thumb-size);
  height: var(--form-switch-sizes-md-thumb-size);
  background: var(--form-switch-thumb-bg);
  border-radius: var(--form-switch-thumb-border-radius);
  box-shadow: var(--form-switch-thumb-shadow);
  transition: var(--form-switch-base-transition);
}

.switch-input:checked + .switch {
  background: var(--form-switch-track-checked-bg);
}

.switch-input:checked + .switch:after {
  left: calc(100% - 2px);
  transform: translateX(-100%);
}

.switch:active:after {
  width: 28px; /* effetto pressione */
}

.switch-label {
  margin-left: 0.5rem;
  margin-bottom: 0;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-semantic-primary-dark);
  text-indent: 0;
  display: inline-block;
  vertical-align: middle;
}

.switch.sm {
  width: var(--form-switch-sizes-sm-track-width);
  height: var(--form-switch-sizes-sm-track-height);
}
.switch.sm:after {
  width: var(--form-switch-sizes-sm-thumb-size);
  height: var(--form-switch-sizes-sm-thumb-size);
}
.switch.md {
  width: var(--form-switch-sizes-md-track-width);
  height: var(--form-switch-sizes-md-track-height);
}
.switch.md:after {
  width: var(--form-switch-sizes-md-thumb-size);
  height: var(--form-switch-sizes-md-thumb-size);
}
.switch.lg {
  width: var(--form-switch-sizes-lg-track-width);
  height: var(--form-switch-sizes-lg-track-height);
}
.switch.lg:after {
  width: var(--form-switch-sizes-lg-thumb-size);
  height: var(--form-switch-sizes-lg-thumb-size);
}
