[data-fui-comp="ui-number-input"] {
  display: grid;
  gap: var(--spacing-xs, 4px);
}
[data-fui-comp="ui-number-input"] .ui-number-input__label {
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--color-text, #18181B);
}
[data-fui-comp="ui-number-input"] .ui-number-input__row {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--color-border, #E4E4E7);
  border-radius: var(--radii-md, 8px);
  background: var(--color-surface, #FFFFFF);
  overflow: hidden;
  width: fit-content;
}
[data-fui-comp="ui-number-input"] .ui-number-input__input {
  appearance: textfield;
  -moz-appearance: textfield;
  border: 0;
  background: transparent;
  text-align: center;
  font: inherit;
  font-size: 0.95rem;
  color: var(--color-text, #18181B);
  min-block-size: var(--spacing-touch-target, 44px);
  width: 5ch;
  padding: 0;
}
[data-fui-comp="ui-number-input"] .ui-number-input__input::-webkit-outer-spin-button,
[data-fui-comp="ui-number-input"] .ui-number-input__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
[data-fui-comp="ui-number-input"] .ui-number-input__input:focus {
  outline: none;
  background: var(--color-surface-soft, #F4F4F5);
}
[data-fui-comp="ui-number-input"] .ui-number-input__step {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  /* WCAG 2.5.5 — each step button is independently tappable. */
  min-block-size: var(--spacing-touch-target, 44px);
  min-inline-size: var(--spacing-touch-target, 44px);
  background: var(--color-surface-soft, #F4F4F5);
  border: 0;
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-text, #18181B);
  cursor: pointer;
  user-select: none;
}
[data-fui-comp="ui-number-input"] .ui-number-input__step:hover {
  background: var(--color-border, #E4E4E7);
}
[data-fui-comp="ui-number-input"] .ui-number-input__step:focus-visible {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: -2px;
}
[data-fui-comp="ui-number-input"] .ui-number-input__step:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
[data-fui-comp="ui-number-input"] .ui-number-input__help {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-text-muted, #52525B);
}
[data-fui-comp="ui-number-input"] .ui-number-input__error {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-danger, #DC2626);
}
[data-fui-comp="ui-number-input"].is-error .ui-number-input__row {
  border-color: var(--color-danger, #DC2626);
  box-shadow: inset 0 0 0 1px var(--color-danger, #DC2626);
}