/* css/app-mobile.css
   Mobile/PWA enhancements (does not change desktop UI)
*/

:root {
  --safe-top: env(safe-area-inset-top);
  --safe-right: env(safe-area-inset-right);
  --safe-bottom: env(safe-area-inset-bottom);
  --safe-left: env(safe-area-inset-left);
}

html, body {
  height: 100%;
}

body {
  -webkit-tap-highlight-color: transparent;
}

/* iOS PWA: prevent content under notch */
@media (display-mode: standalone) {
  body {
    padding-top: var(--safe-top);
    padding-left: var(--safe-left);
    padding-right: var(--safe-right);
    padding-bottom: var(--safe-bottom);
    overscroll-behavior-y: none;
  }
}

/* Improve small-screen usability without touching layouts */
@media (max-width: 768px) {
  /* Allow wide tables to scroll horizontally instead of breaking layout */
  table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Reduce big paddings a bit */
  .p-8 { padding: 1.25rem !important; }
  .px-8 { padding-left: 1.25rem !important; padding-right: 1.25rem !important; }
  .py-8 { padding-top: 1.25rem !important; padding-bottom: 1.25rem !important; }

  /* Make large titles wrap */
  h1, h2 { word-break: break-word; }
}

/* Admin: off-canvas sidebar on small screens (app-like) */
@media (max-width: 768px) {
  #sidebar {
    position: fixed !important;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(86vw, 340px) !important;
    transform: translateX(-110%);
    transition: transform 220ms ease;
    z-index: 80;
  }
  body.sidebar-open #sidebar {
    transform: translateX(0);
  }
  #mobile-sidebar-overlay {
    display: none;
  }
  body.sidebar-open #mobile-sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 70;
  }

  /* Ensure main content uses full width */
  main { width: 100%; }
}
