/* === MOBILE HEADER LOCK (single source of truth) === */
@media (max-width: 768px) {

  /* Bar height */
  .headerbg,
  #headerfloat{
    height:55px !important;
    min-height:55px !important;
    max-height:55px !important;
    box-sizing:border-box !important;
    padding:0 12px !important;   /* gives hamburger breathing room */
    overflow:hidden !important;
  }

  /* Make header a real row */
  #headerfloat{
    display:flex !important;
    align-items:center !important;
  }

  /* Kill spacer if it exists on mobile */
  #headermiddle{
    display:none !important;
    height:0 !important;
    padding:0 !important;
    margin:0 !important;
  }

  /* Logo lane */
  #headerleft{
    flex:1 1 auto !important;
    height:55px !important;
    display:flex !important;
    align-items:center !important;
    padding:0 !important;
    margin:0 !important;
    line-height:0 !important;
  }

  /* push logo link right */
  #headerleft > a{
    margin-left:auto !important;
    display:block !important;
    height:55px !important;
    line-height:0 !important;
  }

  /* logo sizing (match what you set in DevTools) */
  #headerlogo{
    width:300px !important;
    height:55px !important;
    background-size:contain !important;
    background-position:right center !important;
    transform:none !important;
    margin:0 !important;
    padding:0 !important;
  }
}


/* === MOBILE HEADER: SINGLE SOURCE OF TRUTH FINAL (2025-12-17) === */
@media (max-width: 768px){
  :root{
    --hdr-h: 54px;
    --hamb-w: 60px;
    --hamb-left: -3px;

    --hamb-y: -24px;   /* raise/lower hamburger: try -1..-4 or +1..+4 */

    /* Logo tuning knobs (safe defaults to avoid right-edge clipping) */
    --logo-w: 290px;     /* try 290..320 */
    --logo-h: 48px;      /* try 45..52 */
    --logo-x: 20px;      /* pull left a touch to prevent clipping */
    --logo-y: 0px;
    --side-pad: 16px;
  }

  .headerbg, #headerfloat{
    height: var(--hdr-h) !important;
    min-height: var(--hdr-h) !important;
  }

  #headerfloat{
    position: relative !important;
    overflow: hidden !important;
    padding: 0 !important;
  }

  /* Hamburger pinned left */
  #mobile-menu-toggle{
    position: absolute !important;
    left: var(--hamb-left) !important;
    right: auto !important;
    top: 0 !important;
    width: var(--hamb-w) !important;
    height: var(--hdr-h) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 9999 !important;
    transform: translateY(var(--hamb-y)) !important;
  }

  /* Center logo with safe max-width so it can’t collide/clip */
  #headerleft{
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) translateX(var(--logo-x)) translateY(var(--logo-y)) !important;
    width: var(--logo-w) !important;
    max-width: calc(100vw - (var(--hamb-w) + var(--hamb-left) + var(--side-pad)) - var(--side-pad)) !important;
    height: var(--logo-h) !important;
    z-index: 50 !important;
  }

  #headerleft > a{
    display: block !important;
    width: 100% !important;
    height: var(--logo-h) !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  #headerlogo{
    width: 100% !important;
    height: var(--logo-h) !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    transform: none !important;
  }
}

/* =========================================================
   NEXTGEN MOBILE HEADER + DRAWER LOCK (2026-01-15)
   Applies only to NextGen pages (.ng body).
   Does NOT affect legacy #headerfloat/#mobile-menu-toggle header.
   ========================================================= */
@media (max-width: 768px){

  /* ---- Header row layout ---- */
  body.ng .ng-header{
    position: sticky;
    top: 0;
    z-index: 5000;
    background: #fff;
  }

  body.ng .ng-header__inner{
    display: grid;
    grid-template-columns: 56px 1fr 56px; /* left burger | center brand | right actions */
    align-items: center;
    min-height: 56px;
    padding: 0 10px;
    box-sizing: border-box;
  }

  /* Burger stays left */
  body.ng .ng-menu{
    justify-self: start;
  }

  /* Brand centered */
  body.ng .ng-header__brand{
    justify-self: center;
    text-align: center;
    max-width: 100%;
  }

  /* Right actions stay right */
  body.ng .ng-header__actions{
    justify-self: end;
  }

  /* ---- Drawer overlay + panel ---- */
  body.ng .ng-drawer{
    position: fixed;
    inset: 0;
    z-index: 9000;
    pointer-events: none; /* disabled until open */
  }

  body.ng .ng-drawer__backdrop{
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.35);
    opacity: 0;
    transition: opacity 160ms ease;
  }

  /* If your drawer panel element uses another class, we’ll adjust after we inspect */
  body.ng .ng-drawer__panel{
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: min(82vw, 320px);
    background: #fff;
    transform: translateX(-105%);
    transition: transform 180ms ease;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  }

  body.ng .ng-drawer.is-open{
    pointer-events: auto;
  }

  body.ng .ng-drawer.is-open .ng-drawer__backdrop{
    opacity: 1;
  }

  body.ng .ng-drawer.is-open .ng-drawer__panel{
    transform: translateX(0);
  }

  /* Optional: when open, prevent background interactions (JS already sets overflow hidden) */
  body.ng.ng-drawer-open{
    touch-action: none;
  }
}
