.ui-field {
  display: grid;
  gap: var(--ui-space-2);
}

.ui-label {
  color: var(--ui-text-primary);
  font-weight: 600;
}

.ui-input,
.ui-select {
  background: var(--ui-surface-base);
  border: 1px solid var(--ui-border-strong);
  border-radius: var(--ui-radius-control);
  box-shadow: var(--ui-shadow-sm);
  color: var(--ui-text-primary);
  font-family: var(--ui-font-sans);
  min-height: 2.5rem;
  padding: 0.625rem 0.75rem;
  transition:
    background-color var(--ui-motion-duration-fast) var(--ui-motion-easing-standard),
    border-color var(--ui-motion-duration-fast) var(--ui-motion-easing-standard),
    box-shadow var(--ui-motion-duration-fast) var(--ui-motion-easing-standard);
  width: 100%;
}

.ui-input::placeholder {
  color: var(--ui-text-muted);
}

.ui-input:focus-visible,
.ui-select:focus-visible {
  border-color: var(--ui-color-action);
  box-shadow: var(--ui-focus-ring);
  outline: 0;
}

.ui-input[disabled],
.ui-select[disabled] {
  background: var(--ui-surface-muted);
  box-shadow: none;
  color: var(--ui-text-muted);
  cursor: not-allowed;
  opacity: var(--ui-state-disabled-opacity);
}

.ui-input[readonly] {
  background: var(--ui-surface-muted);
  box-shadow: none;
  color: var(--ui-text-muted);
}

.ui-input.is-invalid,
.ui-select.is-invalid {
  border-color: var(--ui-color-danger);
  box-shadow: var(--ui-shadow-sm);
}

.ui-table-shell .ui-input,
.ui-table-shell .ui-select,
.ui-table .ui-input,
.ui-table .ui-select {
  box-shadow: none;
}

.ui-table-shell .ui-input:focus-visible,
.ui-table-shell .ui-select:focus-visible,
.ui-table .ui-input:focus-visible,
.ui-table .ui-select:focus-visible {
  box-shadow: var(--ui-focus-ring);
}

.ui-check {
  accent-color: var(--ui-color-action);
}

.ui-help {
  color: var(--ui-text-secondary);
  font-size: 0.875rem;
}

.ui-error {
  color: var(--ui-color-danger);
  font-size: 0.875rem;
}

/* transitional VIS-P8: keep Bootstrap/plugin hooks while UI tokens own appearance */
.form-control.ui-input,
.form-select.ui-select {
  background-color: var(--ui-surface-base);
  border-color: var(--ui-border-strong);
  color: var(--ui-text-primary);
}

@media (prefers-reduced-motion: reduce) {
  .ui-input,
  .ui-select {
    transition: none;
  }
}
