/**
 * jobNinjas.live — shared mobile / safe-area improvements
 * Load after page-specific <style> blocks.
 */
:root {
  --nav-h: calc(56px + env(safe-area-inset-top, 0px));
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  overflow-x: hidden;
  -webkit-tap-highlight-color: rgba(5, 150, 105, 0.12);
}

/* ─── Top nav: notch + dynamic toolbar height ─── */
.topnav {
  min-height: var(--nav-h);
  height: auto !important;
  padding-top: env(safe-area-inset-top);
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
  padding-bottom: 0;
  box-sizing: border-box;
}

.topnav-left {
  gap: min(16px, 3vw);
  min-width: 0;
  flex: 1;
}

.logo {
  min-width: 0;
}

.logo .brand-main {
  font-size: clamp(15px, 4vw, 18px);
}

@media (max-width: 380px) {
  .logo .brand-by {
    display: none;
  }
}

.topnav-right {
  gap: 6px;
}

.btn,
.btn-sm {
  min-height: 44px;
  align-items: center;
  justify-content: center;
  touch-action: manipulation;
}

.btn-sm {
  padding-left: 12px;
  padding-right: 12px;
}

.btn .btn-label-short {
  display: none;
}

@media (max-width: 420px) {
  .btn .btn-label-long {
    display: none;
  }
  .btn .btn-label-short {
    display: inline;
  }
}

/* Hamburger + overlay + drawer (index, certifications, passive-income) */
.nav-overlay {
  top: 0 !important;
  padding-top: var(--nav-h) !important;
}

.nav-menu {
  top: var(--nav-h) !important;
  max-height: calc(100dvh - var(--nav-h)) !important;
  max-height: calc(100vh - var(--nav-h)) !important;
  -webkit-overflow-scrolling: touch;
  padding-left: max(16px, env(safe-area-inset-left)) !important;
  padding-right: max(16px, env(safe-area-inset-right)) !important;
  padding-bottom: max(16px, env(safe-area-inset-bottom)) !important;
}

.nav-menu a {
  touch-action: manipulation;
}

/* Left sidebar: align with dynamic header */
.sidebar {
  top: var(--nav-h) !important;
  height: calc(100vh - var(--nav-h)) !important;
  height: calc(100dvh - var(--nav-h)) !important;
}

.app {
  min-height: calc(100vh - var(--nav-h));
  min-height: calc(100dvh - var(--nav-h));
}

.main {
  padding-bottom: max(20px, env(safe-area-inset-bottom));
}

/* Job / cert pages: main column padding on phones */
@media (max-width: 900px) {
  .main {
    padding-left: max(12px, env(safe-area-inset-left));
    padding-right: max(12px, env(safe-area-inset-right));
  }
}

/* Toast: keep above home indicator */
.toast-container {
  bottom: max(24px, env(safe-area-inset-bottom));
  right: max(16px, env(safe-area-inset-right));
  left: auto;
  max-width: calc(100vw - 32px);
}

/* Checkout page */
body.checkout-page {
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
  padding-bottom: max(24px, env(safe-area-inset-bottom));
}

/* ─── Admin: slide-out sidebar on small screens ─── */
.admin-mobile-topbar {
  display: none;
}

.admin-sidebar-overlay {
  display: none;
}

@media (max-width: 900px) {
  body.admin-page {
    flex-direction: column;
  }

  .admin-mobile-topbar {
    display: flex;
    align-items: center;
    gap: 12px;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 60;
    min-height: var(--nav-h);
    padding: env(safe-area-inset-top) max(12px, env(safe-area-inset-right)) 0 max(12px, env(safe-area-inset-left));
    background: var(--p900, #4c1d95);
    color: #fff;
    box-sizing: border-box;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  }

  .admin-mnav-btn {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 20px;
    line-height: 1;
    touch-action: manipulation;
  }

  .admin-mnav-btn:active {
    background: rgba(255, 255, 255, 0.2);
  }

  .admin-mobile-title {
    font-weight: 800;
    font-size: 16px;
    letter-spacing: -0.02em;
  }

  body.admin-page .sidebar {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: 70;
    width: min(300px, 88vw);
    padding-top: max(20px, env(safe-area-inset-top));
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: none;
  }

  body.admin-page.admin-nav-open .sidebar {
    transform: translateX(0);
    box-shadow: 8px 0 32px rgba(0, 0, 0, 0.25);
  }

  .admin-sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 65;
    background: rgba(15, 23, 42, 0.45);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
  }

  body.admin-page.admin-nav-open .admin-sidebar-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  body.admin-page .main {
    margin-left: 0 !important;
    width: 100%;
    padding: 16px max(12px, env(safe-area-inset-right)) max(24px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
    padding-top: calc(var(--nav-h) + 12px);
  }

  body.admin-page .toolbar input {
    width: 100%;
    max-width: none;
    min-height: 44px;
  }

  body.admin-page .f-btn,
  body.admin-page .pg-btn,
  body.admin-page .trigger-btn {
    min-height: 44px;
    touch-action: manipulation;
  }

  body.admin-page .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  body.admin-page table {
    min-width: 640px;
  }

  body.admin-page .cards {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
}

@media (prefers-reduced-motion: reduce) {
  body.admin-page .sidebar {
    transition: none;
  }
}
