.form-field {
  margin-bottom: 24px;
  position: relative;
}

.form-field label {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--color-text-secondary);
  margin-bottom: 8px;
}

.form-field label span {
  color: var(--color-error);
}

.form-field input[type="text"],
.form-field input[type="email"],
.form-field input[type="password"],
.form-field input[type="date"],
.form-field select,
.form-field textarea {
  width: 100%;
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
  padding: 12px 16px;
  border-radius: var(--radius-input);
  font-size: var(--fs-body);
  font-family: var(--font-body);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-field input[type="text"]:focus,
.form-field input[type="email"]:focus,
.form-field input[type="password"]:focus,
.form-field input[type="date"]:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--color-gold-primary);
  box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.15);
}

/* Invalid State */
.form-field input.is-invalid,
.form-field select.is-invalid,
.form-field textarea.is-invalid {
  border-color: var(--color-error) !important;
  box-shadow: 0 0 0 3px rgba(224, 82, 82, 0.15) !important;
}

/* Custom select down chevron */
.form-field select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A84C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 16px;
  padding-right: 48px;
}

.form-error {
  display: block;
  font-size: var(--fs-tiny);
  color: var(--color-error);
  margin-top: 6px;
  min-height: 16px;
}

.form-success {
  background-color: rgba(76, 175, 130, 0.1);
  border: 1px solid var(--color-success);
  border-radius: var(--radius-card);
  padding: 20px;
  color: var(--color-text-primary);
  font-size: var(--fs-small);
  line-height: 1.6;
  margin-bottom: 24px;
}

.form-success p {
  color: var(--color-text-primary);
}

/* reCAPTCHA placeholder styling */
.g-recaptcha {
  margin-bottom: 24px;
  min-height: 1px;
}
