@layer components {
  /* ==========================================================================
     Form Components
     Reusable form styles for contact and other forms
     ========================================================================== */

  .form-group {
    margin-bottom: 1.25rem;
  }

  .form-label {
    display: block;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: var(--font-size-base);
    color: var(--color-gray-800);
    margin-bottom: 0.5rem;
  }

  .form-input {
    display: block;
    width: 100%;
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    padding: 0.75rem 1rem;
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: 8px;
    color: var(--color-gray-900);
    transition: border-color var(--transition-base);
  }

  .form-input:focus {
    outline: none;
    border-color: var(--color-accent);
  }

  .form-textarea {
    resize: vertical;
    min-height: 8rem;
  }

  /* Error state */
  .form-group--error .form-input {
    border-color: #dc2626;
  }

  .form-group--error .form-input:focus {
    border-color: #dc2626;
  }

  .form-error {
    color: #dc2626;
    font-size: var(--font-size-sm);
    margin-top: 0.25rem;
  }

  /* Form actions */
  .form-actions {
    margin-top: var(--spacing-md);
  }

  .form-actions .btn {
    width: 100%;
  }

  /* Honeypot field - positioned off-screen to avoid bot detection of display:none */
  .honeypot-field {
    position: absolute;
    left: -9999px;
    top: -9999px;
  }

  /* Flash notice */
  .flash-notice {
    background: var(--color-lab-50);
    border: 1px solid var(--color-lab-300);
    padding: 1rem 1.25rem;
    color: var(--color-lab-800);
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-md);
  }

  /* Flash alert */
  .flash-alert {
    background: #fef2f2;
    border: 1px solid #fca5a5;
    padding: 1rem 1.25rem;
    color: #991b1b;
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-md);
  }

  /* Newsletter success */
  .newsletter-success {
    color: var(--color-accent);
    font-family: var(--font-body);
    font-size: var(--font-size-base);
    font-weight: 500;
  }

  /* Desktop: button not full-width */
  @media (min-width: 48rem) {
    .form-actions .btn {
      width: auto;
    }
  }
}
