/*
  Upgrade 12 — Mobile Menu Overflow Fix
  Scope: mobile navbar/offcanvas only. Desktop UI, brand identity, sections, SEO, analytics and lead logic remain unchanged.
  Goal: no clipped hamburger button, no drawer overflow, clean CTA/text wrapping on 360/375/390/430px screens.
*/

@media (max-width: 1199.98px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  body.ea-menu-locked {
    overflow: hidden !important;
    touch-action: none;
  }

  .rs-header-area,
  .rs-header-area.header-transparent,
  .rs-sticky {
    width: 100% !important;
    max-width: 100vw !important;
    inset-inline-start: 0 !important;
    inset-inline-end: 0 !important;
    overflow: visible !important;
  }

  .rs-header-area .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
  }

  .rs-header-inner {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }

  .rs-header-left,
  .rs-header-logo {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  .rs-header-logo .ea-premium-logo {
    max-width: calc(100vw - 104px) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .rs-header-right {
    flex: 0 0 auto !important;
    min-width: 48px !important;
    max-width: 64px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    margin-left: auto !important;
  }

  .rs-header-hamburger {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 48px !important;
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
    margin: 0 !important;
  }

  .sidebar-toggle {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
    min-height: 48px !important;
    padding: 0 !important;
    border-radius: 16px !important;
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    flex: 0 0 48px !important;
  }

  .sidebar-toggle .bar-icon,
  button.bar-icon {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
    padding: 14px 12px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 5px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  .sidebar-toggle .bar-icon span,
  button.bar-icon span,
  .bar-icon span,
  .bar-icon span:nth-child(1),
  .bar-icon span:nth-child(2),
  .bar-icon span:nth-child(3) {
    display: block !important;
    height: 2px !important;
    border-radius: 999px !important;
    margin: 0 !important;
    margin-inline: 0 !important;
    max-width: 22px !important;
    background: #fff !important;
    flex: 0 0 2px !important;
  }

  .bar-icon span:nth-child(1),
  .bar-icon span:nth-child(3) { width: 20px !important; }
  .bar-icon span:nth-child(2) { width: 15px !important; }

  .offcanvas-overlay {
    width: 100vw !important;
    max-width: 100vw !important;
    inset-inline-start: 0 !important;
    inset-inline-end: auto !important;
  }

  .offcanvas-area {
    width: min(390px, 100vw) !important;
    max-width: min(390px, 100vw) !important;
    inset-inline-end: -100% !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    box-sizing: border-box !important;
    overscroll-behavior: contain !important;
  }

  .offcanvas-area.info-open {
    inset-inline-end: 0 !important;
  }

  .offcanvas-wrapper,
  .offcanvas-content,
  .offcanvas-top,
  .offcanvas-about,
  .offcanvas-diagnostic-cta,
  .mobile-menu,
  .rs-offcanvas-menu,
  .mean-container,
  .mean-container .mean-nav,
  .offcanvas-contact,
  .offcanvas-social {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  .offcanvas-wrapper {
    padding-top: clamp(24px, 6vw, 34px) !important;
    padding-bottom: clamp(30px, 7vw, 44px) !important;
    padding-left: clamp(18px, 5vw, 26px) !important;
    padding-right: clamp(18px, 5vw, 26px) !important;
  }

  .offcanvas-top {
    gap: 14px !important;
  }

  .offcanvas-logo,
  .offcanvas-logo a {
    min-width: 0 !important;
    max-width: calc(100% - 58px) !important;
  }

  .offcanvas-logo .ea-premium-logo {
    font-size: clamp(30px, 8vw, 42px) !important;
    line-height: 1.05 !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .offcanvas-close {
    flex: 0 0 44px !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    border-radius: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
  }

  .offcanvas-close-icon {
    width: 44px !important;
    height: 44px !important;
    display: grid !important;
    place-items: center !important;
  }

  .offcanvas-about p,
  .offcanvas-contact-text,
  .offcanvas-contact-text a,
  .mean-container .mean-nav ul li a {
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    white-space: normal !important;
  }

  .offcanvas-about p {
    line-height: 1.65 !important;
  }

  .offcanvas-diagnostic-cta .rs-btn {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 16px clamp(14px, 4vw, 22px) !important;
    border-radius: 999px !important;
    white-space: normal !important;
    text-align: center !important;
    line-height: 1.18 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  .offcanvas-diagnostic-cta .rs-btn .icon-box {
    flex: 0 0 auto !important;
    margin-left: 0 !important;
    min-width: 18px !important;
  }

  .mean-container .mean-nav ul,
  .mean-container .mean-nav ul li {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .mean-container .mean-nav ul li a {
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .offcanvas-contact ul li {
    min-width: 0 !important;
    align-items: flex-start !important;
  }
}

@media (max-width: 430px) {
  .offcanvas-area {
    width: calc(100vw - 22px) !important;
    max-width: calc(100vw - 22px) !important;
  }

  .offcanvas-wrapper {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}

@media (max-width: 370px) {
  .rs-header-area .container {
    padding-left: max(14px, env(safe-area-inset-left)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
  }

  .rs-header-logo .ea-premium-logo {
    max-width: calc(100vw - 96px) !important;
    font-size: 24px !important;
  }

  .rs-header-hamburger,
  .sidebar-toggle,
  .sidebar-toggle .bar-icon,
  button.bar-icon {
    width: 46px !important;
    min-width: 46px !important;
    max-width: 46px !important;
    height: 46px !important;
    min-height: 46px !important;
  }

  .offcanvas-area {
    width: calc(100vw - 18px) !important;
    max-width: calc(100vw - 18px) !important;
  }

  .offcanvas-wrapper {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .offcanvas-diagnostic-cta .rs-btn {
    font-size: 14px !important;
    padding-left: 13px !important;
    padding-right: 13px !important;
  }
}
