@layer base {
  .form {
    background-color: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-6);
    box-shadow: var(--shadow);
  }

  .mainFields {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-4);
  }

  .locationFields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-4);
  }

  .dateSeatsRow {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-4);
    align-items: end;
  }

  .field {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
  }

  .label {
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--foreground);
  }

  .dateButton {
    justify-content: flex-start;
    gap: var(--spacing-2);
    min-width: 10rem;
  }

  .advancedToggle {
    margin-bottom: var(--spacing-4);
  }

  .advancedFilters {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    padding: var(--spacing-4);
    background-color: var(--muted);
    border-radius: var(--radius);
    margin-bottom: var(--spacing-4);
  }

  .timeFilters {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-4);
  }

  .searchButton {
    width: 100%;
    height: 3rem;
    font-size: 1rem;
    font-weight: 600;
  }

  .validationErrors {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-2);
    padding: var(--spacing-3);
    background-color: var(--error);
    color: var(--error-foreground);
    border-radius: var(--radius);
    margin-bottom: var(--spacing-4);
    font-size: 0.875rem;
  }

  .errorList {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
  }

  .errorMessage {
    margin: 0;
  }

  .selectedLocation {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2);
    background-color: var(--primary);
    color: var(--primary-foreground);
    border-radius: var(--radius);
    font-size: 0.875rem;
    margin-top: var(--spacing-1);
  }

  .selectedLocationIcon {
    font-size: 0.75rem;
  }

  .selectedLocationText {
    font-weight: 500;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  /* Mobile responsive */
  @media (max-width: 768px) {
    .form {
      padding: var(--spacing-4);
    }

    .locationFields,
    .dateSeatsRow,
    .timeFilters {
      grid-template-columns: 1fr;
    }

    .dateSeatsRow {
      align-items: stretch;
    }
  }
}