/* WebKraft — shared mobile layout for all admin / dashboard pages */

@media (max-width: 767px) {
  html {
    overflow-x: clip;
  }

  body {
    overflow-x: clip;
    max-width: 100%;
    min-width: 0;
  }

  /* Avoid double safe-area shrink (mobile-global + dashboard padding) */
  body.admin-page,
  body:has(.app-shell),
  body:has(#app),
  body:has(.admin-layout) {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* App shells — full width column (gym fixed sidebar, ecommerce, agency) */
  #app,
  #appView,
  .app-shell,
  .admin-shell {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
    box-sizing: border-box !important;
  }

  body:has(.sidebar),
  body:has(.admin-sidebar) {
    display: block !important;
  }

  .sidebar,
  aside.sidebar,
  .admin-sidebar {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    flex-shrink: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-right: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    z-index: auto !important;
  }

  .main,
  main.main,
  .admin-main,
  .content,
  main#dash,
  .app-shell > .main,
  #app > .main {
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    box-sizing: border-box !important;
    padding: max(12px, env(safe-area-inset-left)) max(12px, env(safe-area-inset-right)) 24px !important;
  }

  .admin-layout {
    grid-template-columns: minmax(0, 1fr) !important;
    min-height: 0 !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .admin-layout > *,
  .app-shell > *,
  .dash-grid > *,
  .kpi-row > *,
  .panel,
  .card,
  .chart-wrap,
  .table-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .admin-sidebar {
    display: flex !important;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.75rem max(12px, env(safe-area-inset-left)) !important;
    background: var(--admin-sidebar, #2a211f);
  }

  .admin-sidebar__label {
    width: 100%;
  }

  .admin-sidebar__link {
    border-left: none !important;
    border-radius: 999px;
    padding: 0.5rem 0.85rem !important;
    min-height: 44px;
    font-size: 0.8125rem;
  }

  .admin-main {
    padding: 1rem max(12px, env(safe-area-inset-right)) 2rem max(12px, env(safe-area-inset-left)) !important;
    max-width: 100% !important;
  }

  .admin-topbar,
  .topbar,
  .nav-inner,
  header {
    flex-wrap: wrap;
    gap: 0.65rem;
    padding-left: max(12px, env(safe-area-inset-left)) !important;
    padding-right: max(12px, env(safe-area-inset-right)) !important;
  }

  .admin-topbar__actions,
  .topbar-actions,
  .nav-actions {
    width: 100%;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .admin-topbar__meta {
    width: 100%;
    font-size: 0.75rem;
  }

  .admin-btn,
  .btn,
  button,
  .nav-item {
    min-height: 44px;
  }

  .admin-btn--hide-mobile {
    display: none !important;
  }

  /* Stat / KPI grids */
  .stats,
  .stats-row,
  .stat-row,
  .kpi-grid,
  .admin-stats,
  .type-breakdown {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.75rem !important;
  }

  .layout,
  .charts-grid,
  .charts-row-2,
  .app-card-body,
  .slots-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 1rem !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .range-pills,
  .main__actions,
  .panel-header .panel-tools {
    max-width: 100% !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
  }

  .range-pills {
    flex-wrap: nowrap !important;
  }

  .range-pills button {
    flex: 0 0 auto;
  }

  .chart-wrap,
  .chart-card,
  canvas {
    max-width: 100% !important;
  }

  .chart-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .topbar h1,
  .topbar h2,
  .main__title {
    word-break: break-word;
    max-width: 100%;
  }

  /* Tables scroll inside card, not the page */
  .table-wrap,
  .admin-table-wrap,
  .panel,
  .admin-card {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .admin-table,
  table {
    min-width: min(520px, 100%);
  }

  .message-cell {
    max-width: min(280px, 70vw);
    white-space: normal;
    word-break: break-word;
  }

  /* Login screens */
  #loginScreen,
  #login-screen,
  #view-login,
  #login,
  .login-wrap,
  .login-view,
  .admin-login-wrap {
    min-height: 100dvh;
    padding: max(16px, env(safe-area-inset-left)) max(16px, env(safe-area-inset-right)) !important;
  }

  #loginScreen:not(.hidden),
  #loginScreen[style*='display: flex'] {
    display: flex !important;
    align-items: center;
    justify-content: center;
  }

  .login-box,
  .login-card,
  .box,
  .admin-login {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 1.5rem 1.25rem !important;
  }

  .container,
  .c,
  #dash {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
    box-sizing: border-box !important;
  }

  .form-inline {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .form-inline input,
  .form-inline select {
    width: 100% !important;
    min-width: 0 !important;
  }

  .filters-bar,
  .panel-header {
    flex-direction: column;
    align-items: stretch !important;
  }

  .filters-bar input,
  .filters-bar select,
  .search-input {
    width: 100% !important;
    min-width: 0 !important;
  }

  .toast {
    left: 12px !important;
    right: 12px !important;
    bottom: max(12px, env(safe-area-inset-bottom)) !important;
    max-width: none;
  }

  /* Doctor portal bottom nav */
  .admin-sidebar.order-2,
  .admin-layout .admin-sidebar {
    order: 2;
  }

  .admin-layout .admin-main {
    order: 1;
  }

  .admin-viewport,
  .admin-page-body {
    max-width: 100%;
    overflow-x: clip;
  }

  .admin-patient-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .cal-grid {
    gap: 4px !important;
  }

  .cal-day {
    min-height: 44px !important;
    font-size: 11px !important;
    padding: 4px !important;
  }
}

@media (max-width: 480px) {
  .stats,
  .stats-row,
  .stat-row,
  .kpi-grid,
  .admin-stats,
  .type-breakdown {
    grid-template-columns: 1fr !important;
  }

  .admin-stats {
    grid-template-columns: 1fr 1fr !important;
  }

  h1 {
    font-size: clamp(1.2rem, 6vw, 1.65rem) !important;
    line-height: 1.2 !important;
  }

  .login-box,
  .login-card {
    padding: 1.25rem 1rem !important;
  }

  .panel-header h3,
  .admin-card__title {
    font-size: 1rem !important;
  }
}

@media (max-width: 360px) {
  .admin-stats {
    grid-template-columns: 1fr !important;
  }
}
