/**
 * Component-Specific Mobile Optimizations
 * Fixes specific UI components that cause mobile usability issues
 */

/* ADMIN DASHBOARD FIXES */
.list-group-item-action {
  padding: 12px 16px;
  min-height: 44px;
}

.list-group-item-action h6 {
  font-size: 14px;
  margin-bottom: 4px;
}

.list-group-item-action small {
  font-size: 12px;
  line-height: 1.3;
}

.list-group-item-action .ti {
  font-size: 16px;
}

/* CARD OPTIMIZATIONS - Exclude auth pages */
.card-header h5:not(.auth-page .card-header h5) {
  font-size: 16px;
  line-height: 1.4;
}

.card-body:not(.auth-page .card-body) {
  padding: 12px 16px;
}

/* SPINNER AND LOADING STATES */
.spinner-border {
  width: 24px;
  height: 24px;
}

.text-center.py-5 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

/* NAVIGATION AND MENU FIXES */
@media (max-width: 991.98px) {
  /* Sidebar menu optimization */
  .layout-menu .menu-item .menu-link {
    padding: 12px 20px;
    font-size: 14px;
  }
  
  /* Navbar improvements */
  .navbar-nav .nav-item .nav-link {
    padding: 12px 16px;
    min-height: 44px;
  }
}

/* TABLE IMPROVEMENTS FOR MOBILE */
@media (max-width: 767.98px) {
  /* DataTables mobile optimization */
  .dataTables_wrapper {
    padding: 0;
  }
  
  .dataTables_length,
  .dataTables_filter {
    margin-bottom: 12px;
  }
  
  .dataTables_length select {
    min-height: 40px;
    padding: 8px 12px;
  }
  
  .dataTables_filter input {
    min-height: 40px;
    padding: 8px 12px;
    width: 100%;
    margin-left: 0;
  }
  
  .dataTables_info {
    font-size: 12px;
    margin-bottom: 8px;
  }
  
  .dataTables_paginate .paginate_button {
    padding: 8px 12px;
    margin: 2px;
    font-size: 14px;
  }
}

/* MODAL CONTENT FIXES - Only on mobile screens, exclude auth pages */
@media (max-width: 767.98px) {
  .modal-dialog:not(.auth-page .modal-dialog) {
    margin: 8px;
  }
}

.modal-content {
  border-radius: 8px;
  overflow: hidden;
}

.modal-header {
  padding: 16px;
  border-bottom: 1px solid #e9ecef;
}

.modal-title {
  font-size: 16px;
  line-height: 1.4;
}

.modal-body {
  padding: 16px;
  max-height: 70vh;
  overflow-y: auto;
}

.modal-footer {
  padding: 12px 16px;
  gap: 8px;
}

.modal-footer .btn {
  flex: 1;
  min-height: 44px;
}

/* FORM SPECIFIC IMPROVEMENTS */
.form-floating {
  margin-bottom: 16px;
}

.form-floating > .form-control,
.form-floating > .form-select {
  height: 48px;
  font-size: 16px;
  padding: 12px;
}

.form-floating > label {
  padding: 12px;
  font-size: 14px;
}

/* SELECT2 MOBILE OPTIMIZATION */
.select2-container .select2-selection--single {
  height: 44px;
  padding: 8px 12px;
}

.select2-container .select2-selection--single .select2-selection__rendered {
  line-height: 28px;
  font-size: 16px;
}

.select2-dropdown {
  border-radius: 6px;
}

.select2-results__option {
  padding: 12px 16px;
  font-size: 16px;
}

/* ALERT OPTIMIZATIONS */
.alert {
  padding: 12px 16px;
  margin-bottom: 16px;
  border-radius: 6px;
  font-size: 14px;
}

.alert-dismissible .btn-close {
  padding: 12px;
}

/* BREADCRUMB FIXES */
.breadcrumb {
  padding: 8px 0;
  margin-bottom: 16px;
  font-size: 14px;
}

.breadcrumb-item + .breadcrumb-item::before {
  font-size: 12px;
}

/* PAGINATION MOBILE OPTIMIZATION */
.pagination {
  margin: 16px 0;
  justify-content: center;
}

.page-link {
  padding: 8px 12px;
  font-size: 14px;
  min-width: 40px;
  text-align: center;
}

/* DROPDOWN MENU IMPROVEMENTS */
.dropdown-menu {
  padding: 8px;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.dropdown-item {
  padding: 10px 12px;
  font-size: 14px;
  border-radius: 4px;
  margin-bottom: 2px;
}

.dropdown-divider {
  margin: 4px 0;
}

/* PROGRESS BAR FIXES */
.progress {
  height: 8px;
  border-radius: 4px;
  margin-bottom: 8px;
}

/* BADGE SYSTEM IMPROVEMENTS */
.badge {
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 4px;
  line-height: 1.2;
}

/* TAB NAVIGATION MOBILE */
.nav-tabs .nav-link {
  padding: 10px 12px;
  font-size: 14px;
  border-radius: 4px 4px 0 0;
}

.nav-pills .nav-link {
  padding: 10px 16px;
  font-size: 14px;
  border-radius: 6px;
}

/* ACCORDION MOBILE OPTIMIZATION */
.accordion-button {
  padding: 12px 16px;
  font-size: 14px;
}

.accordion-body {
  padding: 16px;
  font-size: 14px;
}

/* TOAST NOTIFICATIONS */
.toast {
  max-width: calc(100vw - 32px);
  margin: 8px auto;
}

.toast-body {
  padding: 12px 16px;
  font-size: 14px;
}

/* OFFCANVAS MOBILE OPTIMIZATION */
.offcanvas {
  max-width: 85vw;
}

.offcanvas-header {
  padding: 16px;
}

.offcanvas-body {
  padding: 16px;
}

/* INPUT GROUP FIXES */
.input-group > .form-control,
.input-group > .form-select,
.input-group > .btn {
  min-height: 44px;
}

.input-group-text {
  padding: 10px 12px;
  font-size: 14px;
}

/* FLOATING ACTION BUTTON (if used) */
.fab {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  z-index: 1000;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}

/* UTILITY CLASSES FOR COMMON FIXES */
.mobile-stack {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mobile-center {
  text-align: center;
}

.mobile-full-width {
  width: 100% !important;
}

.mobile-compact {
  padding: 8px 12px !important;
  font-size: 14px !important;
}

.mobile-touch-target {
  min-height: 44px !important;
  min-width: 44px !important;
}

/* RESPONSIVE IMAGES */
img {
  max-width: 100%;
  height: auto;
}

.avatar {
  width: 32px;
  height: 32px;
}

.avatar-lg {
  width: 48px;
  height: 48px;
}

/* DARK MODE MOBILE ADJUSTMENTS */
[data-style="dark"] .modal-content {
  background-color: #2d3748;
  color: #e2e8f0;
}

[data-style="dark"] .dropdown-menu {
  background-color: #2d3748;
  border-color: #4a5568;
}

[data-style="dark"] .form-control,
[data-style="dark"] .form-select {
  background-color: #1a202c;
  border-color: #4a5568;
  color: #e2e8f0;
}

/* PRINT MEDIA QUERIES */
@media print {
  .mobile-hide-print {
    display: none !important;
  }
  
  .btn, .dropdown, .modal {
    display: none !important;
  }
}

/* HIGH CONTRAST MODE */
@media (prefers-contrast: high) {
  .btn {
    border: 2px solid;
  }
  
  .form-control,
  .form-select {
    border: 2px solid;
  }
}

/* REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}