/* Mobile responsiveness improvements for the 3-step form */

/* General mobile improvements */
@media (max-width: 768px) {
  .form-section {
    padding: 1.5rem 1rem;
  }
  
  /* Stepper improvements for mobile */
  .stepper {
    flex-direction: row;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
  }
  
  .step {
    flex: 0 0 auto;
    min-width: 110px;
    padding: 0.5rem;
    font-size: 0.9rem;
    white-space: nowrap;
  }
  
  .step i {
    font-size: 0.9rem;
  }
  
  /* Form grid for mobile */
  .form-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
  
  /* Step actions for mobile */
  .step-actions {
    flex-direction: row;
    justify-content: space-between;
  }
  
  .step-actions button {
    flex: 1;
    padding: 0.75rem 0.5rem;
    font-size: 0.95rem;
    white-space: nowrap;
  }
  
  /* Form controls for mobile */
  .form-control, .form-select {
    padding: 0.75rem;
    font-size: 1rem;
  }
  
  /* Form labels for mobile */
  .form-label {
    font-size: 0.9rem;
  }
  
  /* Help icons for mobile */
  .help-icon {
    width: 16px;
    height: 16px;
  }
  
  /* Submit button for mobile */
  .submit-btn {
    width: 100%;
    padding: 0.875rem;
    font-size: 1rem;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .form-section {
    padding: 1rem 0.75rem;
  }
  
  .step {
    min-width: 100px;
    padding: 0.4rem;
    font-size: 0.8rem;
  }
  
  .step i {
    font-size: 0.8rem;
  }
  
  .form-group {
    padding: 0.75rem;
  }
  
  .step-actions button {
    padding: 0.6rem 0.5rem;
    font-size: 0.9rem;
  }
  
  .form-control, .form-select {
    padding: 0.7rem;
    font-size: 0.95rem;
  }
}

/* Improve form animations for mobile */
@media (max-width: 768px) {
  #step1, #step2, #step3 {
    transition: opacity 0.3s ease-in-out;
  }
  
  .step-enter {
    opacity: 0;
  }
  
  .step-enter-active {
    opacity: 1;
  }
  
  .step-exit {
    opacity: 1;
  }
  
  .step-exit-active {
    opacity: 0;
  }
}

/* Fix for mobile scrolling when switching steps */
@media (max-width: 768px) {
  .professional-theme .left-pane {
    overflow-x: hidden;
  }
}
