.form-group {
  display: grid;
  gap: var(--space-xs);
}

.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--theme-text);
}

.form-input,
.form-select,
.form-textarea {
  inline-size: 100%;
  padding: var(--space-sm) var(--space-md);
  font-size: var(--text-base);
  background-color: var(--theme-surface);
  border: 1px solid var(--theme-border);
  border-radius: var(--radius-md);
  color: var(--theme-text);
  transition: border-color var(--transition-fast);

  &:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgb(15 118 110 / 0.15);
  }
}

.form-textarea {
  resize: vertical;
  min-block-size: 5rem;
}

.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-sm) center;
  padding-inline-end: var(--space-xl);
}

.form-hint {
  font-size: var(--text-xs);
  color: var(--theme-muted);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--color-danger);
}
