/* Safe mobile logo sizing: keep all header elements, only improve logo fit */
@media (max-width: 767px) {
  #header .header-nav .mobile #_mobile_logo,
  #header .header-nav .mobile .top-logo {
    margin: 0 .35rem;
    max-width: calc(100% - 88px);
    overflow: hidden;
    text-align: center;
    white-space: nowrap;
  }

  #header .header-nav .mobile #_mobile_logo img,
  #header .header-nav .mobile .top-logo img {
    display: inline-block;
    width: auto;
    max-width: 100%;
    max-height: 44px;
    object-fit: contain;
    vertical-align: middle;
  }
}

@media (max-width: 420px) {
  #header .header-nav .mobile #_mobile_logo,
  #header .header-nav .mobile .top-logo {
    max-width: calc(100% - 78px);
  }

  #header .header-nav .mobile #_mobile_logo img,
  #header .header-nav .mobile .top-logo img {
    max-height: 40px;
  }
}

@media (max-width: 360px) {
  #header .header-nav .mobile #_mobile_logo,
  #header .header-nav .mobile .top-logo {
    max-width: calc(100% - 72px);
  }

  #header .header-nav .mobile #_mobile_logo img,
  #header .header-nav .mobile .top-logo img {
    max-height: 36px;
  }
}

/* +10px header row height for better logo breathing room */
@media (max-width: 767px) {
  #header .header-nav #mobile-header-row {
    min-height: 66px;
  }
}


/* Small mobile refinements */
@media (max-width: 390px) {
  #header .header-nav #mobile-header-row {
    min-height: 58px;
  }

  #header .header-nav .mobile #_mobile_logo,
  #header .header-nav .mobile .top-logo {
    max-width: calc(100% - 68px);
  }

  #header .header-nav .mobile #_mobile_logo img,
  #header .header-nav .mobile .top-logo img {
    max-height: 34px;
  }
}

@media (max-width: 360px) {
  #header .header-nav #mobile-header-row {
    min-height: 52px;
  }

  #header .header-nav .mobile #_mobile_logo,
  #header .header-nav .mobile .top-logo {
    max-width: calc(100% - 62px);
  }

  #header .header-nav .mobile #_mobile_logo img,
  #header .header-nav .mobile .top-logo img {
    max-height: 30px;
  }
}
