/* ============================================
   全站表單欄位共通樣式（Mobile-First）
   ============================================ */

/* Label */
.form-label,
.formControlLabel {
  display: block;
  margin-bottom: var(--htsprout-spacing-xs);
  font-size: var(--htsprout-fs-16);
  font-weight: var(--htsprout-fw-medium);
  line-height: var(--htsprout-lh-150);
  color: var(--htsprout-text-800);
}

/* 必填星號 */
.form-label .required,
.formRequired {
  color: var(--htsprout-blue-800);
  font-weight: inherit;
}

/* Input / Select / Textarea */
.form-control,
.form-select {
  background-color: var(--htsprout-text-50);
  border: 1px solid var(--htsprout-green-200);
  border-radius: var(--htsprout-radius-lg);
  padding: 12px;
  font-size: var(--htsprout-fs-16);
  font-weight: var(--htsprout-fw-regular);
  line-height: var(--htsprout-lh-150);
  color: var(--htsprout-text-1000);
}

.form-control:hover,
.form-select:hover {
  border-color: var(--htsprout-green-600);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--htsprout-green-600);
  box-shadow: 0 0 0 2px var(--htsprout-green-100);
}

.form-control::placeholder {
  color: var(--htsprout-text-400);
}

textarea.form-control {
  min-height: 160px;
  resize: vertical;
}

/* 密碼切換按鈕（.input-group 提升特異性，覆蓋 .btn / .btn:hover） */
.input-group .input-password-toggle {
  background: var(--htsprout-text-50);
  border: none;
  color: var(--htsprout-text-400);
  padding: 0 12px;
}

.input-group .input-password-toggle:hover {
  background: var(--htsprout-text-50);
  color: var(--htsprout-text-600);
  box-shadow: none;
}

/* 輔助文字 */
.form-text {
  font-size: var(--htsprout-fs-14);
  font-weight: var(--htsprout-fw-regular);
  color: var(--htsprout-text-600);
  line-height: var(--htsprout-lh-150);
}
