.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.field label {
  font-size: var(--fs-14);
  font-weight: var(--fw-medium);
  color: var(--color-ink);
}

.input, .textarea, .select {
  display: block;
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-sans);
  font-size: var(--fs-16);
  line-height: var(--lh-base);
  color: var(--color-ink);
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--r-sm);
  box-shadow: var(--sh-inset);
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
  min-height: 48px;
}

.input:focus, .textarea:focus, .select:focus {
  border-color: var(--color-primary);
  box-shadow: var(--sh-glow-primary);
  outline: none;
}

.input::placeholder, .textarea::placeholder {
  color: var(--color-ink-subtle);
}

.textarea {
  min-height: 140px;
  resize: vertical;
}

.field-invalid .input,
.field-invalid .textarea,
.field-invalid .select {
  border-color: var(--color-danger);
}

.field-hint {
  font-size: var(--fs-12);
  color: var(--color-ink-muted);
}

.field-error {
  font-size: var(--fs-14);
  color: var(--color-danger);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
}

.floating {
  position: relative;
}

.floating .input,
.floating .textarea {
  padding-top: var(--sp-5);
  padding-bottom: var(--sp-2);
}

.floating label {
  position: absolute;
  top: 50%;
  left: var(--sp-4);
  transform: translateY(-50%);
  padding-inline: var(--sp-1);
  color: var(--color-ink-subtle);
  pointer-events: none;
  background: var(--color-surface);
  transition: top var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out),
              font-size var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}

.floating .input:focus ~ label,
.floating .input:not(:placeholder-shown) ~ label,
.floating .textarea:focus ~ label,
.floating .textarea:not(:placeholder-shown) ~ label {
  top: 0;
  transform: translateY(-50%) scale(0.9);
  color: var(--color-primary);
  font-weight: var(--fw-medium);
}

.floating .textarea ~ label {
  top: var(--sp-4);
  transform: none;
}

.floating .textarea:focus ~ label,
.floating .textarea:not(:placeholder-shown) ~ label {
  top: 0;
  transform: translateY(-50%) scale(0.9);
}
