/* DSNET Portal Sidebar (Phase 8 - mobile fix)
   Fixes: mobile menu not showing due to portal.css hiding .portal-sidebar.
   - Forces display on mobile (overrides portal.css display:none).
   - Uses header height CSS var so drawer sits below header.
   - Keeps overlay below header so toggle stays clickable.
*/

.portal-layout {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  flex: 1 1 auto;
  min-height: 0;
}

.portal-main { flex: 1; min-width: 0; }

/* Desktop sidebar */
.portal-sidebar {
  width: 260px;
  flex: 0 0 260px;
  position: sticky;
  top: 72px; /* overridden by JS var on mobile */
  align-self: flex-start;
  max-height: calc(100vh - 96px);
  overflow: auto;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  z-index: 60;
}

.portal-sidebar-inner { padding: 14px; }
.portal-sidebar-title { font-weight: 700; margin-bottom: 10px; letter-spacing: 0.2px; }

.portal-sidebar-section {
  margin-top: 14px;
  margin-bottom: 6px;
  font-size: 12px;
  opacity: 0.85;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.portal-sidebar-nav { display: flex; flex-direction: column; gap: 8px; }

.portal-sidebar-link{
  display:block;
  padding:10px 10px;
  border-radius:10px;
  text-decoration:none;
  color:inherit;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.10);
}
.portal-sidebar-link:hover{ background: rgba(255, 255, 255, 0.10); }

/* Toggle button: shown whenever logged in (desktop + mobile). */
.portal-nav-toggle{
  display:none;
  border:0;
  background:transparent;
  padding:6px;
  margin-left:6px;
  border-radius:10px;
}
.portal-nav-toggle img{ width:26px; height:26px; }
body.auth .portal-nav-toggle{ display:inline-flex; align-items:center; }

/* Desktop collapse */
@media (min-width: 901px){
  body.auth.sidebar-collapsed .portal-sidebar{ display:none; }
  body.auth.sidebar-collapsed .portal-layout{ display:block; }
}

/* Overlay: starts below header, so the toggle stays clickable */
.portal-overlay{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: var(--dsnet-header-h, 72px);
  background: rgba(0,0,0,0.35);
  opacity: 0;
  transition: opacity 150ms ease;
  z-index: 940;
  pointer-events: none;
}
.portal-overlay.open{
  opacity: 1;
  pointer-events: auto;
}

/* Prevent background scroll while drawer is open */
body.auth.menu-open{ overflow: hidden; }

/* Mobile drawer */
@media (max-width: 900px){
  /* IMPORTANT: portal.css sets .portal-sidebar{display:none} on mobile.
     Override it here so the sidebar can be used as an off-canvas drawer. */
  .portal-sidebar{
    display: block !important;
    position: fixed;
    top: var(--dsnet-header-h, 64px);
    left: 0;
    width: min(86vw, 320px);
    height: calc(100dvh - var(--dsnet-header-h, 64px));
    max-height: calc(100dvh - var(--dsnet-header-h, 64px));
    transform: translateX(-105%);
    transition: transform 170ms ease;
    z-index: 950;
    border-radius: 0 14px 14px 0;
    box-shadow: 0 20px 60px rgba(0,0,0,0.45);
    padding-bottom: max(16px, env(safe-area-inset-bottom));
    -webkit-overflow-scrolling: touch;
  }
  .portal-sidebar.open{ transform: translateX(0); }

  .portal-layout{ display:block; }

  /* Avoid duplicate hamburger from old portal dropdown system */
  body.auth .nav-toggle{ display:none !important; }
}
