[data-fui-comp="ui-toggle"] {
  display: inline-flex;
  /* flex-wrap so the help/error pseudo-line below wraps to a new
     line instead of forcing itself between the control and the
     label text. */
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-md, 8px);
  cursor: pointer;
  /* Token-scaled touch target. */
  min-block-size: var(--spacing-touch-target, 44px);
  padding-block: 4px;
}
[data-fui-comp="ui-toggle"].is-disabled { opacity: 0.55; cursor: not-allowed; }

[data-fui-comp="ui-toggle"] .ui-toggle__control {
  position: relative;
  flex-shrink: 0;
  inline-size: 1.25rem;
  block-size:  1.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
[data-fui-comp="ui-toggle"] .ui-toggle__input {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  margin: 0;
  opacity: 0;
  cursor: inherit;
}
[data-fui-comp="ui-toggle"] .ui-toggle__indicator {
  /* inline-flex so the ::after marker (checkmark / radio dot) is
     centered both axes regardless of variant. inline-block lets the
     pseudo-element drift to top-left in some browsers — visible
     bug. */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 1.1rem;
  block-size:  1.1rem;
  border: 1.5px solid var(--color-border-strong, #A1A1AA);
  background: var(--color-surface, #FFFFFF);
  transition: background var(--duration-fast, 150ms) ease,
              border-color var(--duration-fast, 150ms) ease;
}

/* ─── Checkbox ─── */
[data-fui-comp="ui-toggle"].ui-toggle--checkbox .ui-toggle__indicator {
  border-radius: var(--radii-sm, 4px);
}
[data-fui-comp="ui-toggle"].ui-toggle--checkbox .ui-toggle__input:checked + .ui-toggle__indicator {
  background: var(--color-primary, #4F46E5);
  border-color: var(--color-primary, #4F46E5);
}
[data-fui-comp="ui-toggle"].ui-toggle--checkbox .ui-toggle__input:checked + .ui-toggle__indicator::after {
  content: "";
  display: block;
  inline-size: 0.35rem;
  block-size:  0.65rem;
  border: solid var(--color-primary-fg, #FFFFFF);
  border-width: 0 2px 2px 0;
  transform: translateY(-1px) rotate(45deg);
}

/* ─── Radio ─── */
[data-fui-comp="ui-toggle"].ui-toggle--radio .ui-toggle__indicator {
  border-radius: 50%;
}
[data-fui-comp="ui-toggle"].ui-toggle--radio .ui-toggle__input:checked + .ui-toggle__indicator {
  border-color: var(--color-primary, #4F46E5);
}
[data-fui-comp="ui-toggle"].ui-toggle--radio .ui-toggle__input:checked + .ui-toggle__indicator::after {
  content: "";
  inline-size: 0.55rem;
  block-size: 0.55rem;
  border-radius: 50%;
  background: var(--color-primary, #4F46E5);
}

/* ─── Switch ─── */
[data-fui-comp="ui-toggle"].ui-toggle--switch .ui-toggle__control {
  inline-size: 2.25rem;
  block-size:  1.25rem;
}
[data-fui-comp="ui-toggle"].ui-toggle--switch .ui-toggle__indicator {
  inline-size: 2.25rem;
  block-size:  1.25rem;
  border-radius: 9999px;
  background: var(--color-surface-soft, #F4F4F5);
  border-color: var(--color-border, #E4E4E7);
  position: relative;
}
[data-fui-comp="ui-toggle"].ui-toggle--switch .ui-toggle__indicator::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 2px;
  inline-size: 1rem;
  block-size: 1rem;
  border-radius: 50%;
  background: #FFFFFF;
  transform: translateY(-50%);
  transition: inset-inline-start var(--duration-fast, 150ms) ease;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
[data-fui-comp="ui-toggle"].ui-toggle--switch .ui-toggle__input:checked + .ui-toggle__indicator {
  background: var(--color-primary, #4F46E5);
  border-color: var(--color-primary, #4F46E5);
}
[data-fui-comp="ui-toggle"].ui-toggle--switch .ui-toggle__input:checked + .ui-toggle__indicator::after {
  inset-inline-start: calc(100% - 1.125rem);
}

/* ─── Focus ring shared across all variants ─── */
[data-fui-comp="ui-toggle"] .ui-toggle__input:focus-visible + .ui-toggle__indicator {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: 2px;
}
[data-fui-comp="ui-toggle"].is-error .ui-toggle__indicator {
  border-color: var(--color-danger, #DC2626);
}

[data-fui-comp="ui-toggle"] .ui-toggle__label {
  flex: 1 1 auto;
  font-size: 0.95rem;
  color: var(--color-text, #18181B);
  line-height: 1.4;
}
[data-fui-comp="ui-toggle"] .ui-toggle__help,
[data-fui-comp="ui-toggle"] .ui-toggle__error {
  display: block;
  flex-basis: 100%;
  margin: var(--spacing-xs, 2px) 0 0 calc(1.25rem + var(--spacing-md, 8px));
  font-size: 0.85rem;
}
[data-fui-comp="ui-toggle"] .ui-toggle__help  { color: var(--color-text-muted, #52525B); }
[data-fui-comp="ui-toggle"] .ui-toggle__error { color: var(--color-danger, #DC2626); }

/* ─── Toggle Group (fieldset wrapper for RadioGroup / CheckboxGroup) ─── */
.ui-toggle-group {
  border: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--spacing-sm, 8px);
}
.ui-toggle-group .ui-toggle-group__legend {
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--color-text, #18181B);
  padding: 0;
  margin-bottom: var(--spacing-xs, 4px);
}
.ui-toggle-group .ui-toggle-group__help {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-text-muted, #52525B);
}
.ui-toggle-group .ui-toggle-group__error {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-danger, #DC2626);
}