/* =============================================
   Toggle Switch Component — UI-0089
   ============================================= */

/* --- Toggle Wrapper --- */
.toggle-wrap {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
}

/* --- Track --- */
.toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 48px;
  height: 24px;
  border-radius: 12px; /* half of height */
  background-color: var(--text-muted, #B0BAC5); /* off state */
  cursor: pointer;
  transition: background-color var(--duration-200, 200ms) var(--ease-default);
  flex-shrink: 0;
  border: none;
  padding: 0;
  outline: none;

  /* ARIA role handled in HTML */
}

/* On state */
.toggle.is-on,
.toggle[aria-checked="true"] {
  background-color: var(--color-electric, #2F80ED);
}

/* Focus ring */
.toggle:focus-visible {
  box-shadow: 0 0 0 3px rgba(47, 128, 237, 0.3);
}

/* Disabled */
.toggle:disabled,
.toggle.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* --- Knob --- */
.toggle__knob {
  position: absolute;
  left: 2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: var(--color-white, #FFFFFF);
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-200, 200ms) var(--ease-default);
}

/* Move knob to "on" position: 48 - 20 - 2*2 = 24px translate */
.toggle.is-on .toggle__knob,
.toggle[aria-checked="true"] .toggle__knob {
  transform: translateX(24px);
}

/* --- Toggle Label --- */
.toggle-wrap__label {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-primary, #111111);
  user-select: none;
}

.toggle-wrap__label--muted {
  color: var(--text-secondary, #4A5568);
}

/* --- Hidden Checkbox (for form submission) --- */
.toggle__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Checked state via checkbox */
.toggle__input:checked + .toggle {
  background-color: var(--color-electric, #2F80ED);
}

.toggle__input:checked + .toggle .toggle__knob {
  transform: translateX(24px);
}

.toggle__input:focus-visible + .toggle {
  box-shadow: 0 0 0 3px rgba(47, 128, 237, 0.3);
}

.toggle__input:disabled + .toggle {
  opacity: 0.5;
  cursor: not-allowed;
}

/* =============================================
   Toggle — Mobile Responsive
   ============================================= */
@media (max-width: 639px) {
  .toggle-wrap {
    min-height: 44px;
    padding: 8px 0;
  }
}
