/* Mobile-friendly responsive improvements */

/* Base adjustments for better touch targets and readability on mobile */
@media (max-width: 991.98px) {
  body { font-size: 0.95rem; }
  
  /* Ensure buttons and links are easier to tap on mobile */
  .btn, a, button { min-height: 44px; min-width: 44px; display: inline-flex; align-items: center; justify-content: center; }
  
  /* Compact card spacing on tablets and below */
  .card { margin-bottom: 1rem; }
  .card-body { padding: 0.75rem; }
}

/* Mobile-specific (max 768px) */
@media (max-width: 767.98px) {
  /* Content below mobile navbar with adjusted padding */
  .main-content { 
    padding-top: 1.5rem !important; 
    padding-left: 0.75rem !important; 
    padding-right: 0.75rem !important; 
    padding-bottom: 2rem;
  }
  
  /* Compact headings on mobile */
  h1 { font-size: 1.5rem; margin-bottom: 0.75rem; }
  h2 { font-size: 1.25rem; margin-bottom: 0.75rem; }
  h3 { font-size: 1.1rem; margin-bottom: 0.5rem; }
  
  /* Improve form layout on mobile */
  .form-label { font-size: 0.9rem; font-weight: 600; margin-bottom: 0.25rem; }
  .form-control, .form-select { font-size: 1rem; padding: 0.5rem 0.75rem; }
  
  /* Better row spacing for mobile */
  .row { margin-right: -0.375rem; margin-left: -0.375rem; }
  .col, .col-1, .col-2, .col-3, .col-4, .col-5, .col-6, 
  .col-7, .col-8, .col-9, .col-10, .col-11, .col-12 { padding-right: 0.375rem; padding-left: 0.375rem; }
  
  /* Card compact mode */
  .card { margin-bottom: 0.75rem; }
  .card-header { padding: 0.5rem 0.75rem; }
  .card-body { padding: 0.75rem; }
  
  /* Table compact fonts */
  .table { font-size: 0.85rem; }
  .table thead th { padding: 0.5rem 0.25rem; }
  .table td { padding: 0.5rem 0.25rem; }
  
  /* Compact badges */
  .badge { font-size: 0.7rem; padding: 0.25rem 0.5rem; }
  
  /* Improve button sizing on mobile */
  .btn { padding: 0.5rem 0.75rem; font-size: 0.9rem; }
  .btn-sm { padding: 0.25rem 0.5rem; font-size: 0.8rem; }
  
  /* Make alerts more readable */
  .alert { margin-bottom: 0.75rem; padding: 0.75rem; font-size: 0.9rem; }
  
  /* Offcanvas menu readability */
  .offcanvas-body { padding: 0.75rem; }
  .offcanvas-body a { display: block; padding: 0.5rem 0.25rem; word-break: break-word; }
  .offcanvas-body .btn { width: 100%; margin-top: 0.5rem; }
  
  /* Sticky sidebar adjustment */
  .sticky-top { position: relative !important; top: auto !important; }
  
  /* Modal responsive */
  .modal-dialog { margin: 0.5rem; }
}

/* Extra small screens (max 576px) */
@media (max-width: 575.98px) {
  /* Reduce padding further on very small screens */
  .main-content { padding-top: 1rem !important; padding-left: 0.5rem !important; padding-right: 0.5rem !important; }
  
  /* Stack grid items better */
  .col-md-3, .col-md-4, .col-md-6, .col-md-8, .col-lg-6 { width: 100% !important; margin-bottom: 0.75rem; }
  
  /* Full-width buttons on mobile */
  .btn-group { display: flex; flex-direction: column; }
  .btn-group .btn { width: 100%; margin-bottom: 0.25rem; }
  
  /* Adjust nav tabs for mobile */
  .nav-tabs { flex-wrap: wrap; }
  .nav-link { padding: 0.5rem 0.75rem; font-size: 0.85rem; }
  
  /* Minimize margins on small content */
  .mb-4 { margin-bottom: 0.5rem !important; }
  .mt-5 { margin-top: 0.75rem !important; }
}

/* General mobile improvements */

/* Smooth scrolling for tables on mobile */
.table-responsive { -webkit-overflow-scrolling: touch; }

/* Ensure form inputs don't get zoomed on focus (iOS fix) */
.form-control, .form-select, input[type="email"], input[type="password"], input[type="text"] { 
  font-size: 1rem; 
}

/* Better link and button touch targets */
a, button, .btn { 
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1); 
  transition: all 0.2s ease;
}

/* Sidebar fixed width helper */
.sidebar-fixed { width: 250px; }

/* Card form helper for full-width controls */
.card .form-control, .card .form-select { 
  min-width: 0; 
  width: 100%;
}

/* Ensure icons scale properly */
i.fa { display: inline-flex; align-items: center; justify-content: center; }

/* List group items better spacing */
.list-group-item { 
  padding: 0.75rem; 
}

/* Improve modal visibility on mobile */
@media (max-height: 600px) {
  .modal-dialog { margin: 0.25rem auto; }
  .modal-body { max-height: 60vh; overflow-y: auto; }
}
