/* ==============================================
   FLIGHTS PAGE RESPONSIVE FIXES
   ============================================== */

/* Mobile (max-width: 768px) */
@media (max-width: 768px) {
  /* Hero Section - Better mobile video */
  .hero-section {
    min-height: 100vh !important;
    height: 100vh !important;
  }
  
  .hero-video {
    min-height: 100vh !important;
    height: 100vh !important;
  }
  
  .hero-content {
    padding: 0 20px !important;
  }
  
  .hero-title {
    font-size: clamp(28px, 8vw, 48px) !important;
  }
  
  .hero-subtitle {
    font-size: clamp(14px, 4vw, 18px) !important;
  }
  
  /* Search Container - Better mobile positioning */
  .search-container {
    margin-top: -50px !important;
    padding: 0 15px !important;
  }
  
  .search-box {
    padding: 25px 20px !important;
    border-radius: 15px !important;
  }
  
  /* Trip Type Selector - Mobile layout */
  .trip-type-selector {
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 20px !important;
  }
  
  .trip-type-btn {
    width: 100% !important;
    padding: 14px 20px !important;
    font-size: 13px !important;
  }
  
  /* Search Form - Mobile optimization */
  .search-row {
    grid-template-columns: 1fr !important;
    gap: 15px !important;
  }
  
  .swap-btn {
    display: none !important; /* Hide swap button on mobile */
  }
  
  .search-row-bottom {
    flex-direction: column !important;
    gap: 15px !important;
  }
  
  .search-row-bottom .form-field {
    width: 100% !important;
  }
  
  .search-row-bottom .search-btn {
    width: 100% !important;
    padding: 18px !important;
  }
  
  .input-wrapper {
    padding: 0 12px !important;
  }
  
  .input-wrapper input,
  .input-wrapper select {
    padding: 16px 0 !important;
    font-size: 16px !important; /* Prevent zoom on iOS */
  }
  
  /* Filters Section - Mobile layout */
  .filters-section {
    padding: 0 15px !important;
    margin: 20px 0 !important;
  }
  
  .filters-bar {
    flex-direction: column !important;
    gap: 15px !important;
  }
  
  .filter-group {
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
  }
  
  .filter-select {
    width: 100% !important;
    padding: 12px 15px !important;
  }
  
  .results-count {
    text-align: center !important;
  }
  
  /* Flight Results - Mobile cards */
  .results-container {
    padding: 0 15px !important;
  }
  
  .flight-card {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    padding: 20px 15px !important;
    text-align: center !important;
  }
  
  .airline-logo {
    width: 50px !important;
    height: 50px !important;
    margin: 0 auto !important;
    font-size: 10px !important;
  }
  
  .flight-info {
    text-align: left !important;
  }
  
  .flight-route {
    flex-direction: column !important;
    gap: 20px !important;
    align-items: center !important;
  }
  
  .route-line {
    width: 100% !important;
  }
  
  .flight-details {
    flex-direction: column !important;
    gap: 8px !important;
    text-align: center !important;
  }
  
  .flight-price-section {
    text-align: center !important;
  }
  
  .select-btn {
    width: 100% !important;
    padding: 14px 20px !important;
  }
  
  /* Modal - Mobile optimization */
  .modal-overlay {
    padding: 10px !important;
  }
  
  .modal-container {
    border-radius: 15px !important;
    max-height: 95vh !important;
  }
  
  .modal-header {
    padding: 20px !important;
  }
  
  .modal-title {
    font-size: 18px !important;
  }
  
  .modal-body {
    padding: 20px !important;
  }
  
  .passenger-form {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  
  .form-input {
    padding: 15px !important;
    font-size: 16px !important; /* Prevent zoom on iOS */
  }
  
  .modal-footer {
    padding: 15px 20px !important;
    flex-direction: column !important;
    gap: 10px !important;
  }
  
  .btn-secondary,
  .btn-primary {
    width: 100% !important;
    padding: 15px !important;
  }
}

/* Tablet (769px - 1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  /* Search Container - Tablet adjustments */
  .search-container {
    margin-top: -75px !important;
    padding: 0 30px !important;
  }
  
  .search-box {
    padding: 35px 30px !important;
  }
  
  /* Search Form - Tablet layout */
  .search-row {
    gap: 15px !important;
  }
  
  .swap-btn {
    width: 35px !important;
    height: 35px !important;
    margin-bottom: 5px !important;
  }
  
  /* Filters - Tablet layout */
  .filters-section {
    padding: 0 30px !important;
  }
  
  .filter-group {
    flex-wrap: wrap !important;
  }
  
  .filter-select {
    flex: 1 !important;
    min-width: 150px !important;
  }
  
  /* Flight Cards - Tablet optimization */
  .flight-card {
    grid-template-columns: auto 1fr !important;
    gap: 20px !important;
    padding: 20px !important;
  }
  
  .airline-logo {
    width: 55px !important;
    height: 55px !important;
  }
  
  .flight-price-section {
    grid-column: 1 / -1 !important;
    text-align: center !important;
    margin-top: 15px !important;
  }
  
  .select-btn {
    padding: 12px 30px !important;
  }
  
  /* Modal - Tablet adjustments */
  .passenger-form {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 15px !important;
  }
}

/* Small Mobile (max-width: 480px) */
@media (max-width: 480px) {
  /* Even smaller adjustments */
  .search-container {
    margin-top: -30px !important;
    padding: 0 10px !important;
  }
  
  .search-box {
    padding: 20px 15px !important;
  }
  
  .flight-card {
    padding: 15px 10px !important;
  }
  
  .airline-logo {
    width: 45px !important;
    height: 45px !important;
    font-size: 9px !important;
  }
  
  .route-time {
    font-size: 20px !important;
  }
  
  .price-amount {
    font-size: 24px !important;
  }
  
  .modal-container {
    margin: 5px !important;
  }
}

/* Large Desktop (min-width: 1200px) */
@media (min-width: 1200px) {
  /* Ensure proper spacing on large screens */
  .search-container {
    max-width: 1200px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  
  .filters-section,
  .results-container {
    max-width: 1200px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Prevent horizontal overflow */
@media (max-width: 768px) {
  .search-container,
  .filters-section,
  .results-container,
  .modal-container {
    overflow-x: hidden !important;
  }
  
  .flight-card {
    max-width: 100% !important;
  }
  
  .input-wrapper {
    max-width: 100% !important;
  }
  
  select, input {
    max-width: 100% !important;
  }
}
