/* ── FORMS ── */
@layer components {
  .form-group {
    display: flex;
    flex-direction: column;
  }

  .form-label {
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--text-secondary);
    margin-bottom: var(--space-1);
  }

  .form-input {
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-main);
    font-size: var(--text-base);
    color: var(--text-primary);
    background: var(--surface-card);
    border: 1px solid var(--surface-card-border);
    border-radius: var(--radius-md);
    outline: none;
    transition: border-color var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-fast) var(--ease-out);
  }

  .form-input:focus-visible {
    border-color: var(--gold-mid);
    box-shadow: 0 0 0 2px var(--gold-glow);
  }

  .form-input.touched:invalid {
    border-color: var(--danger);
    box-shadow: 0 0 0 2px var(--danger-glow);
  }

  .form-error {
    font-size: var(--text-xs);
    color: var(--danger);
    margin-top: var(--space-1);
    display: none;
  }

  .form-input.touched:invalid ~ .form-error {
    display: block;
  }

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

  .form-hint {
    font-size: var(--text-xs);
    color: var(--text-muted);
    margin-top: var(--space-1);
  }

  .form-fields {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
  }

  .form-btn {
    width: 100%;
    padding: var(--space-2) var(--space-4);
    font-family: var(--font-main);
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--btn-gold-text);
    background: var(--gold-mid);
    border-radius: var(--radius-md);
    transition: background var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-fast) var(--ease-out);
  }

  .form-btn:hover {
    background: var(--gold-light);
    box-shadow: 0 0 0 3px var(--gold-glow);
  }

  .form-btn:focus-visible {
    outline: 2px solid var(--gold-mid);
    outline-offset: 2px;
  }

  .htmx-request .form-btn {
    pointer-events: none;
    opacity: 0.7;
  }

  .form-link {
    font-size: var(--text-sm);
    color: var(--gold-mid);
    transition: color var(--duration-fast) var(--ease-out);
  }

  .form-link:hover {
    color: var(--gold-light);
  }

  .form-link:focus-visible {
    outline: 2px solid var(--gold-mid);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
  }

  .form-link--disabled {
    color: var(--text-muted);
    pointer-events: none;
  }
}
