/* Mobile elements hidden on desktop */
.mobile-nav, .mobile-nav-overlay, .mobile-header { display: none !important; }

@media (max-width: 1024px) {

  .container, .max-w-7xl, .max-w-6xl, .main-content { padding: 0 1.25rem !important; }
  .grid-2, .grid-3, .grid-4, .grid-receipt, .stat-grid, .two-col { 
    grid-template-columns: 1fr !important; 
    gap: 1.5rem !important;
  }
}

@media (max-width: 768px) {
  /* Fix overflows */
  html, body { overflow-x: hidden !important; width: 100vw !important; overflow-wrap: anywhere; }
  
  /* Hero Refinements */
  .hero, .hero-section { padding: 3rem 1rem !important; text-align: center !important; }
  .hero-container, .hero-content { display: flex !important; flex-direction: column !important; align-items: center !important; gap: 2rem !important; }
  h1 { font-size: 2rem !important; line-height: 1.2 !important; word-break: break-word; }
  .hero-subtext, .hero p { font-size: 1rem !important; }
  
  /* Buttons & Flexbox */
  .hero-buttons, .flex-row-mobile, .btn-wrap, .search-form { 
    flex-direction: column !important; 
    width: 100% !important; 
    gap: 1rem !important; 
  }
  .btn-primary, .btn-secondary, .btn, button { 
    width: 100% !important; 
    display: flex !important; 
    justify-content: center !important; 
    text-align: center !important;
  }
  
  /* Grid Normalization */
  .grid-2, .grid-3, .grid-4, .grid-receipt, .stat-grid, .two-col, .footer-container, .services-grid, .pricing-grid { 
    grid-template-columns: 1fr !important; 
    display: flex !important; 
    flex-direction: column !important; 
    gap: 1.5rem !important; 
  }
  
  /* Card Spacing */
  .service-card, .pricing-card, .card, .checker-box { padding: 1.5rem !important; }
  
  /* Navigation Fixes */
  .nav-links { display: none !important; }
  .mobile-toggle { display: flex !important; visibility: visible !important; }
  .mobile-nav { display: none !important; }
  .mobile-nav.active { display: flex !important; }
  .mobile-nav-overlay.active { display: block !important; }
  .nav-actions .nav-login { display: none !important; }

  .navbar .nav-container {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0.5rem !important;
  }
  .navbar .logo img {
    height: 40px !important;
    width: auto !important;
    max-width: 180px !important;
  }
  .navbar .nav-actions {
    display: flex !important;
    flex-direction: row !important;
    width: auto !important;
    gap: 0.5rem !important;
    align-items: center !important;
  }
  .navbar .nav-actions .nav-phone,
  .navbar .nav-actions .nav-login {
    display: none !important;
  }
  .navbar .mobile-toggle {
    width: 42px !important;
    height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 0.5rem !important;
    background: #f3f4f6 !important;
  }


  
  /* Receipt / Bonnetje */
  .bonnetje { width: 100% !important; max-width: 320px !important; margin: 0 auto !important; }
  .receipt-visual { margin-top: 2rem; }
  
  /* Forms */
  input, select, textarea { width: 100% !important; max-width: 100% !important; }
  
  /* Hide desktop-only things */
  .desktop-only { display: none !important; }
}

/* Specific fix for Sidebar (Portal) on Mobile */
@media (max-width: 1024px) {
  body:has(.sidebar) { display: block !important; }
  .sidebar { 
    position: fixed !important; top: 0; left: -280px !important; 
    width: 280px !important; height: 100% !important; z-index: 1000 !important;
  }
  .sidebar.active { left: 0 !important; }
  .main-content, .main { margin-left: 0 !important; width: 100% !important; }
  .mobile-header { display: flex !important; }
}
