/* =============================================================================
   FORM COMPONENTS - ACTUAL FORM STYLES
   ============================================================================= */

.form-group {
  margin-bottom: var(--spacing-lg);
}

.form-group label {
  display: block;
  margin-bottom: var(--spacing-sm);
  font-weight: 500;
  color: var(--color-text);
  font-size: var(--font-size-sm);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  font-size: var(--font-size-base);
  color: var(--color-text);
  background: var(--color-background);
  transition: all var(--transition-base);
  font-family: var(--font-family-ui);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.1);
}

.form-group textarea {
  resize: vertical;
  min-height: 120px;
}

.form-group--inline {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
}

.form-group--inline label {
  margin-bottom: 0;
  white-space: nowrap;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--spacing-lg);
}

.form-group--full {
  grid-column: 1 / -1;
}

/* Form Validation States */
.form-group input.valid,
.form-group select.valid,
.form-group textarea.valid {
  border-color: #16a34a;
}

.form-group input.invalid,
.form-group select.invalid,
.form-group textarea.invalid {
  border-color: #dc2626;
}

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

.form-help {
  color: var(--color-text-light);
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-xs);
}

/* Checkbox and Radio */
.form-checkbox,
.form-radio {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.form-checkbox input,
.form-radio input {
  width: auto;
  margin: 0;
}

.form-checkbox label,
.form-radio label {
  margin: 0;
  font-weight: normal;
  cursor: pointer;
}

/* Form Sections */
.form-section {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  padding: var(--spacing-xl);
  margin-bottom: var(--spacing-xl);
}

.form-section-title {
  font-size: var(--font-size-lg);
  font-weight: 300;;
  color: var(--color-primary);
  margin-bottom: var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--spacing-sm);
}

/* Form Actions */
.form-actions {
  display: flex;
  gap: var(--spacing-md);
  justify-content: flex-end;
  align-items: center;
  margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--color-border);
}

.form-actions--center {
  justify-content: center;
}

.form-actions--left {
  justify-content: flex-start;
}

.form-actions--between {
  justify-content: space-between;
}

/* Contact Form Styles */
.contact-form {
  max-width: 600px;
  margin: 0 auto;
  background: var(--color-background);
  padding: var(--spacing-3xl);
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--color-border);
}

.membership-form {

  border: 0 solid var(--color-border);
}

/* Search Forms */
.search-form {
  position: relative;
  display: flex;
  align-items: center;
}

.search-form input {
  flex: 1;
  padding-right: var(--spacing-3xl);
}

.search-form button {
  position: absolute;
  right: var(--spacing-sm);
  background: none;
  border: none;
  color: var(--color-text-light);
  cursor: pointer;
  padding: var(--spacing-sm);
  transition: color var(--transition-base);
}

.search-form button:hover {
  color: var(--color-primary);
}

/* Filter Forms */
.filter-form {
  background: var(--color-background-light);
  padding: var(--spacing-xl);
  border-radius: var(--border-radius);
  margin-bottom: var(--spacing-xl);
}

.filter-form .form-grid {
  gap: var(--spacing-md);
}

.filter-form .form-group {
  margin-bottom: var(--spacing-md);
}

/* Newsletter Form */
.newsletter-form {
  display: flex;
  gap: var(--spacing-sm);
  max-width: 400px;
}

.newsletter-form input {
  flex: 1;
  margin-bottom: 0;
}

.newsletter-form button {
  white-space: nowrap;
}

/* File Upload */
.file-upload {
  position: relative;
  display: inline-block;
  cursor: pointer;
}

.file-upload input[type="file"] {
  position: absolute;
  left: -9999px;
  opacity: 0;
}

.file-upload-label {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-lg);
  border: 2px dashed var(--color-border);
  border-radius: var(--border-radius);
  background: var(--color-background-light);
  color: var(--color-text);
  cursor: pointer;
  transition: all var(--transition-base);
}

.file-upload:hover .file-upload-label {
  border-color: var(--color-primary);
  background: var(--color-background);
}

.file-upload input:focus + .file-upload-label {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.1);
}

/* Form Loading States */
.form-loading {
  position: relative;
  opacity: 0.7;
  pointer-events: none;
}

.form-loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--border-radius);
}

/* Form Success/Error Messages */
.form-message {
  padding: var(--spacing-lg);
  border-radius: var(--border-radius);
  margin-bottom: var(--spacing-lg);
  font-weight: 500;
}

.form-message--success {
  background: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
}

.form-message--error {
  background: #fecaca;
  color: #991b1b;
  border: 1px solid #fca5a5;
}

.form-message--warning {
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fde68a;
}

.form-message--info {
  background: #dbeafe;
  color: #1e40af;
  border: 1px solid #93c5fd;
}

/* Responsive Forms */
@media (max-width: 768px) {
  .form-grid {
    grid-template-columns: 1fr;
  }
  
  .form-actions {
    flex-direction: column;
    align-items: stretch;
  }
  
  .contact-form,
  .membership-form {
    padding: var(--spacing-xl);
  }
  
  .newsletter-form {
    flex-direction: column;
    max-width: none;
  }
  
  .form-group--inline {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 480px) {
  .contact-form,
  .membership-form {
    padding: var(--spacing-lg);
  }
  
  .form-section {
    padding: var(--spacing-lg);
  }
  
  .filter-form {
    padding: var(--spacing-md);
  }
}

/* High contrast mode */
@media (prefers-contrast: high) {
  .form-group input,
  .form-group select,
  .form-group textarea {
    border-width: 2px;
  }
  
  .form-section {
    border-width: 2px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .form-group input,
  .form-group select,
  .form-group textarea,
  .file-upload-label {
    transition: none;
  }
}