/* input.css — extracted from input.html */
/* Input.css */
.input-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  width: 100%;
  max-width: 400px;
}

.input-group__label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
}

.input-group__hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* ── 输入框基础 ─────────────────────── */
.input {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  transition: all var(--duration-fast) var(--ease-default);
  width: 100%;
  box-sizing: border-box;
}

.input::placeholder {
  color: var(--color-text-muted);
}

.input:hover {
  border-color: var(--color-border-hover);
}

.input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-ghost);
}

/* ── 状态 ──────────────────────────── */
.input--error {
  border-color: var(--color-danger);
}
.input--error:focus {
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

.input--success {
  border-color: var(--color-success);
}
.input--success:focus {
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1);
}

/* ── 带图标 ────────────────────────── */
.input__wrapper {
  position: relative;
  width: 100%;
  max-width: 400px;
}

.input__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--color-text-muted);
  pointer-events: none;
}

.input--icon-left {
  padding-left: 42px;
}

.input__error-msg {
  font-size: var(--text-xs);
  color: var(--color-danger);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* ── Textarea ──────────────────────── */
.textarea {
  min-height: 100px;
  resize: vertical;
  line-height: var(--leading-normal);
}