/* =====================================================
   Shuaa v48 Institutional Mobile Menu
   Full redesign for the mobile drawer without capsule/pill styling.
   Keeps existing routing, language, currency, and donation behavior.
===================================================== */
:root{
  --mobile-menu-primary:#204C3C;
  --mobile-menu-accent:#48A054;
  --mobile-menu-ink:#1D2A25;
  --mobile-menu-muted:#65736E;
  --mobile-menu-line:rgba(32,76,60,.16);
  --mobile-menu-line-strong:rgba(32,76,60,.26);
  --mobile-menu-soft:#F5FAF7;
  --mobile-menu-white:#FFFFFF;
}

body.mobile-menu-open{
  overflow:hidden!important;
  touch-action:none;
}

.mobile-menu-overlay{
  position:fixed!important;
  inset:0!important;
  z-index:9998!important;
  display:block!important;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  background:rgba(9,25,18,.58)!important;
  -webkit-backdrop-filter:blur(10px) saturate(1.05);
  backdrop-filter:blur(10px) saturate(1.05);
  transition:opacity .24s ease, visibility .24s ease!important;
}
.mobile-menu-overlay.open{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}
.mobile-menu-overlay[hidden]{display:none!important;}

.mobile-nav-panel.mobile-side-drawer,
.mobile-nav-panel{
  position:fixed!important;
  top:0!important;
  bottom:0!important;
  height:100dvh!important;
  width:min(88vw,410px)!important;
  max-width:min(88vw,410px)!important;
  z-index:9999!important;
  display:flex!important;
  flex-direction:column!important;
  gap:0!important;
  padding:0!important;
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
  background:var(--mobile-menu-white)!important;
  color:var(--mobile-menu-primary)!important;
  border:0!important;
  box-shadow:0 28px 80px rgba(0,0,0,.30)!important;
  transition:transform .30s cubic-bezier(.2,.8,.2,1), opacity .20s ease!important;
  opacity:0!important;
  will-change:transform,opacity;
}
html[dir="ltr"] .mobile-nav-panel.mobile-side-drawer,
html[dir="ltr"] .mobile-nav-panel{
  left:0!important;
  right:auto!important;
  border-radius:0!important;
  transform:translate3d(-105%,0,0)!important;
  direction:ltr!important;
}
html[dir="rtl"] .mobile-nav-panel.mobile-side-drawer,
html[dir="rtl"] .mobile-nav-panel{
  right:0!important;
  left:auto!important;
  border-radius:0!important;
  transform:translate3d(105%,0,0)!important;
  direction:rtl!important;
}
.mobile-nav-panel.open{
  transform:translate3d(0,0,0)!important;
  opacity:1!important;
}
.mobile-nav-panel[hidden]{display:none!important;}

.mobile-menu-header,
.pro-mobile-menu-header{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:14px!important;
  padding:calc(18px + env(safe-area-inset-top,0px)) 18px 16px!important;
  background:#fff!important;
  border-bottom:1px solid var(--mobile-menu-line)!important;
  flex:0 0 auto!important;
}
.mobile-menu-brand{
  display:inline-flex!important;
  align-items:center!important;
  min-width:0!important;
  max-width:235px!important;
}
.mobile-menu-brand img{
  display:block!important;
  width:auto!important;
  max-width:min(225px,58vw)!important;
  max-height:56px!important;
  object-fit:contain!important;
}
.mobile-menu-close{
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:0!important;
  margin:0!important;
  border-radius:10px!important;
  border:1px solid var(--mobile-menu-line-strong)!important;
  background:#fff!important;
  color:var(--mobile-menu-primary)!important;
  font-size:32px!important;
  line-height:1!important;
  font-weight:400!important;
  box-shadow:none!important;
}
.mobile-menu-close span{display:block!important;transform:translateY(-2px)!important;}
.mobile-menu-close:hover,
.mobile-menu-close:focus-visible{
  background:var(--mobile-menu-primary)!important;
  color:#fff!important;
  outline:none!important;
}

.mobile-menu-intro{
  padding:22px 20px 20px!important;
  background:var(--mobile-menu-primary)!important;
  color:#fff!important;
  border-bottom:1px solid rgba(255,255,255,.12)!important;
  flex:0 0 auto!important;
}
.mobile-menu-kicker{
  display:block!important;
  min-height:auto!important;
  padding:0 0 0 12px!important;
  border-radius:0!important;
  background:transparent!important;
  color:rgba(255,255,255,.82)!important;
  border-left:3px solid var(--mobile-menu-accent)!important;
  font-size:12px!important;
  line-height:1.3!important;
  font-weight:900!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
}
html[dir="rtl"] .mobile-menu-kicker{
  padding:0 12px 0 0!important;
  border-left:0!important;
  border-right:3px solid var(--mobile-menu-accent)!important;
  letter-spacing:0!important;
}
.mobile-menu-title{
  margin:12px 0 0!important;
  color:#fff!important;
  font-size:28px!important;
  line-height:1.08!important;
  font-weight:950!important;
  letter-spacing:-.025em!important;
}
.mobile-menu-subtitle{
  margin:9px 0 0!important;
  max-width:32ch!important;
  color:rgba(255,255,255,.80)!important;
  font-size:14px!important;
  line-height:1.65!important;
  font-weight:650!important;
}

.mobile-menu-section-label{
  margin:0!important;
  padding:16px 20px 10px!important;
  color:var(--mobile-menu-muted)!important;
  font-size:12px!important;
  font-weight:950!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
  background:#fff!important;
}
html[dir="rtl"] .mobile-menu-section-label{letter-spacing:0!important;}

.mobile-menu-links{
  display:flex!important;
  flex-direction:column!important;
  gap:0!important;
  padding:0 20px 10px!important;
  margin:0!important;
  background:#fff!important;
  flex:0 0 auto!important;
}
.mobile-menu-links a{
  position:relative!important;
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:13px!important;
  width:100%!important;
  min-height:58px!important;
  padding:11px 0!important;
  border-radius:0!important;
  background:transparent!important;
  border:0!important;
  border-bottom:1px solid var(--mobile-menu-line)!important;
  color:var(--mobile-menu-ink)!important;
  text-decoration:none!important;
  font-size:16px!important;
  line-height:1.25!important;
  font-weight:850!important;
  box-shadow:none!important;
  transition:color .18s ease, background .18s ease, padding .18s ease!important;
}
.mobile-menu-links a:hover,
.mobile-menu-links a:focus-visible,
.mobile-menu-links a.is-active{
  background:var(--mobile-menu-soft)!important;
  color:var(--mobile-menu-primary)!important;
  outline:none!important;
}
html[dir="ltr"] .mobile-menu-links a:hover,
html[dir="ltr"] .mobile-menu-links a:focus-visible,
html[dir="ltr"] .mobile-menu-links a.is-active{padding-left:10px!important;}
html[dir="rtl"] .mobile-menu-links a:hover,
html[dir="rtl"] .mobile-menu-links a:focus-visible,
html[dir="rtl"] .mobile-menu-links a.is-active{padding-right:10px!important;}
.mobile-menu-links a:active{transform:none!important;}
.mobile-menu-links a::before{
  content:""!important;
  position:absolute!important;
  top:14px!important;
  bottom:14px!important;
  width:3px!important;
  background:transparent!important;
}
html[dir="ltr"] .mobile-menu-links a::before{left:0!important;}
html[dir="rtl"] .mobile-menu-links a::before{right:0!important;}
.mobile-menu-links a:hover::before,
.mobile-menu-links a:focus-visible::before,
.mobile-menu-links a.is-active::before{background:var(--mobile-menu-accent)!important;}
.mobile-menu-link-icon{
  width:34px!important;
  height:34px!important;
  min-width:34px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:0!important;
  background:transparent!important;
  color:var(--mobile-menu-primary)!important;
  border:0!important;
}
.mobile-menu-link-icon svg{
  width:22px!important;
  height:22px!important;
  display:block!important;
  fill:none!important;
  stroke:currentColor!important;
  stroke-width:2.15!important;
  stroke-linecap:round!important;
  stroke-linejoin:round!important;
}
.mobile-menu-link-text{
  min-width:0!important;
  flex:1 1 auto!important;
  display:block!important;
}
.mobile-menu-link-chevron{
  width:8px!important;
  height:8px!important;
  min-width:8px!important;
  border-top:2px solid currentColor!important;
  border-right:2px solid currentColor!important;
  opacity:.36!important;
}
html[dir="ltr"] .mobile-menu-link-chevron{transform:rotate(45deg)!important;}
html[dir="rtl"] .mobile-menu-link-chevron{transform:rotate(-135deg)!important;}

.mobile-menu-links .language-toggle{
  width:100%!important;
  min-height:54px!important;
  margin:8px 0 0!important;
  padding:10px 0!important;
  border-radius:0!important;
  border:0!important;
  border-top:1px solid var(--mobile-menu-line)!important;
  border-bottom:1px solid var(--mobile-menu-line)!important;
  background:#fff!important;
  box-shadow:none!important;
  color:var(--mobile-menu-primary)!important;
  font-weight:900!important;
  justify-content:center!important;
}
.mobile-menu-links .language-toggle svg{
  stroke:currentColor!important;
  fill:none!important;
}

.mobile-menu-currency{
  margin:0!important;
  padding:8px 20px 12px!important;
  background:#fff!important;
  flex:0 0 auto!important;
}
.mobile-side-drawer .shuaa-currency-switcher{
  min-height:54px!important;
  border-radius:0!important;
  border:0!important;
  border-top:1px solid var(--mobile-menu-line)!important;
  border-bottom:1px solid var(--mobile-menu-line)!important;
  background:#fff!important;
  box-shadow:none!important;
}

.mobile-menu-donate{
  min-height:56px!important;
  width:calc(100% - 40px)!important;
  margin:8px 20px 16px!important;
  padding:0 16px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:10px!important;
  border-radius:10px!important;
  border:1px solid rgba(255,255,255,.16)!important;
  background:var(--mobile-menu-primary)!important;
  background-image:none!important;
  color:#fff!important;
  font-size:17px!important;
  font-weight:950!important;
  text-decoration:none!important;
  box-shadow:none!important;
  flex:0 0 auto!important;
}
.mobile-menu-donate svg{
  width:22px!important;
  height:22px!important;
  fill:currentColor!important;
}
.mobile-menu-donate:hover,
.mobile-menu-donate:focus-visible{
  background:#173C2F!important;
  outline:2px solid rgba(72,160,84,.32)!important;
  outline-offset:2px!important;
  filter:none!important;
}

.mobile-menu-assurance{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:0!important;
  margin-top:auto!important;
  padding:14px 20px calc(18px + env(safe-area-inset-bottom,0px))!important;
  border-top:1px solid var(--mobile-menu-line)!important;
  background:var(--mobile-menu-soft)!important;
  flex:0 0 auto!important;
}
.mobile-menu-assurance__item{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:9px!important;
  min-height:40px!important;
  padding:0 10px!important;
  border-radius:0!important;
  background:transparent!important;
  color:var(--mobile-menu-primary)!important;
  font-size:12.5px!important;
  line-height:1.3!important;
  font-weight:850!important;
  text-align:start!important;
}
.mobile-menu-assurance__item + .mobile-menu-assurance__item{
  border-inline-start:1px solid var(--mobile-menu-line)!important;
}
.mobile-menu-assurance__item svg{
  width:18px!important;
  height:18px!important;
  min-width:18px!important;
  fill:none!important;
  stroke:currentColor!important;
  stroke-width:2.2!important;
  stroke-linecap:round!important;
  stroke-linejoin:round!important;
}

@media (min-width:821px){
  .mobile-menu-overlay,
  .mobile-nav-panel{display:none!important;}
  body.mobile-menu-open{overflow:auto!important;touch-action:auto!important;}
}

@media (max-width:430px){
  .mobile-nav-panel.mobile-side-drawer,
  .mobile-nav-panel{
    width:min(92vw,390px)!important;
    max-width:min(92vw,390px)!important;
  }
  .mobile-menu-header,
  .pro-mobile-menu-header{padding-inline:16px!important;}
  .mobile-menu-intro{padding:20px 18px 18px!important;}
  .mobile-menu-title{font-size:25px!important;}
  .mobile-menu-subtitle{font-size:13.5px!important;}
  .mobile-menu-section-label{padding-inline:18px!important;}
  .mobile-menu-links{padding-inline:18px!important;}
  .mobile-menu-links a{min-height:56px!important;font-size:15.5px!important;}
  .mobile-menu-currency{padding-inline:18px!important;}
  .mobile-menu-donate{width:calc(100% - 36px)!important;margin-inline:18px!important;}
  .mobile-menu-assurance{padding-inline:18px!important;grid-template-columns:1fr!important;}
  .mobile-menu-assurance__item + .mobile-menu-assurance__item{
    border-inline-start:0!important;
    border-top:1px solid var(--mobile-menu-line)!important;
  }
}

@media (prefers-reduced-motion:reduce){
  .mobile-menu-overlay,
  .mobile-nav-panel,
  .mobile-menu-links a{transition:none!important;}
}


/* v51: RTL mobile menu visibility fix
   The direction-specific closed transforms were more specific than .open in Arabic,
   so the drawer stayed off-canvas and only the blur overlay appeared. */
html[dir="ltr"] .mobile-nav-panel.open,
html[dir="ltr"] .mobile-nav-panel.mobile-side-drawer.open,
html[dir="rtl"] .mobile-nav-panel.open,
html[dir="rtl"] .mobile-nav-panel.mobile-side-drawer.open{
  transform:translate3d(0,0,0)!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
}

/* Keep the menu button visible in Arabic and English. */
.menu-btn{
  background:#204C3C!important;
  color:#fff!important;
  border-color:#204C3C!important;
}
.menu-btn span{
  display:block!important;
  background:#fff!important;
  opacity:1!important;
  visibility:visible!important;
}
html[dir="rtl"] .menu-btn span,
html[lang^="ar"] .menu-btn span{
  background:#fff!important;
}

/* v53 mobile header logo center + enlargement */
@media (max-width: 760px){
  .site-header .header-shell{
    direction:ltr !important;
    display:grid !important;
    grid-template-columns:minmax(86px,1fr) auto minmax(58px,1fr) !important;
    align-items:center !important;
    gap:8px !important;
    min-height:96px !important;
    padding:12px 18px !important;
    position:relative !important;
  }

  .site-header .brand{
    grid-column:2 !important;
    justify-self:center !important;
    align-self:center !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:auto !important;
    max-width:none !important;
    margin:0 auto !important;
    padding:0 !important;
    z-index:2 !important;
  }

  .site-header .brand img{
    width:clamp(148px, 43vw, 186px) !important;
    max-width:43vw !important;
    height:auto !important;
    max-height:72px !important;
    object-fit:contain !important;
    display:block !important;
  }

  .site-header .donate-top{
    grid-column:1 !important;
    justify-self:start !important;
    align-self:center !important;
    z-index:3 !important;
    max-width:116px !important;
    min-width:0 !important;
  }

  .site-header .menu-btn{
    grid-column:3 !important;
    justify-self:end !important;
    align-self:center !important;
    z-index:3 !important;
  }

  html[dir="rtl"] .site-header .header-shell,
  html[lang^="ar"] .site-header .header-shell{
    direction:ltr !important;
  }
}

@media (max-width: 380px){
  .site-header .header-shell{
    grid-template-columns:minmax(78px,1fr) auto minmax(54px,1fr) !important;
    padding-inline:14px !important;
    gap:6px !important;
  }
  .site-header .brand img{
    width:clamp(138px, 40vw, 160px) !important;
    max-width:40vw !important;
  }
  .site-header .donate-top{
    max-width:104px !important;
    padding-inline:10px !important;
  }
}

/* v55 Arabic-first mobile header logo fix
   Fixes RTL overlap: logo is centered visually and cannot stretch over Donate/Menu buttons. */
@media (max-width: 760px){
  html[dir="rtl"] .site-header .header-shell,
  html[lang^="ar"] .site-header .header-shell,
  body[dir="rtl"] .site-header .header-shell{
    position: relative !important;
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) 52px !important;
    align-items: center !important;
    gap: 8px !important;
    height: 78px !important;
    min-height: 78px !important;
    padding-inline: 12px !important;
    direction: ltr !important;
    overflow: visible !important;
  }

  html[dir="rtl"] .site-header .donate-top,
  html[lang^="ar"] .site-header .donate-top,
  body[dir="rtl"] .site-header .donate-top{
    grid-column: 1 !important;
    justify-self: start !important;
    order: 0 !important;
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 48px !important;
    padding: 0 9px !important;
    gap: 5px !important;
    border-radius: 14px !important;
    font-size: 13px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    z-index: 3 !important;
  }

  html[dir="rtl"] .site-header .donate-top svg,
  html[lang^="ar"] .site-header .donate-top svg,
  body[dir="rtl"] .site-header .donate-top svg{
    width: 17px !important;
    height: 17px !important;
    flex: 0 0 17px !important;
  }

  html[dir="rtl"] .site-header .donate-top span,
  html[lang^="ar"] .site-header .donate-top span,
  body[dir="rtl"] .site-header .donate-top span{
    display: inline-block !important;
    max-width: 68px !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
    line-height: 1.1 !important;
  }

  html[dir="rtl"] .site-header .brand,
  html[lang^="ar"] .site-header .brand,
  body[dir="rtl"] .site-header .brand{
    grid-column: 2 !important;
    justify-self: center !important;
    align-self: center !important;
    order: 0 !important;
    width: min(174px, 100%) !important;
    min-width: 0 !important;
    max-width: 174px !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1 !important;
    overflow: hidden !important;
  }

  html[dir="rtl"] .site-header .brand img,
  html[lang^="ar"] .site-header .brand img,
  body[dir="rtl"] .site-header .brand img{
    width: 174px !important;
    max-width: 100% !important;
    max-height: 54px !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
  }

  html[dir="rtl"] .site-header .menu-btn,
  html[lang^="ar"] .site-header .menu-btn,
  body[dir="rtl"] .site-header .menu-btn{
    grid-column: 3 !important;
    justify-self: end !important;
    order: 0 !important;
    width: 52px !important;
    min-width: 52px !important;
    height: 52px !important;
    border-radius: 14px !important;
    z-index: 3 !important;
  }
}

@media (max-width: 390px){
  html[dir="rtl"] .site-header .header-shell,
  html[lang^="ar"] .site-header .header-shell,
  body[dir="rtl"] .site-header .header-shell{
    grid-template-columns: 98px minmax(0, 1fr) 50px !important;
    gap: 6px !important;
    padding-inline: 10px !important;
  }
  html[dir="rtl"] .site-header .donate-top,
  html[lang^="ar"] .site-header .donate-top,
  body[dir="rtl"] .site-header .donate-top{
    width: 98px !important;
    min-width: 98px !important;
    max-width: 98px !important;
    font-size: 12.5px !important;
    padding: 0 8px !important;
  }
  html[dir="rtl"] .site-header .brand,
  html[lang^="ar"] .site-header .brand,
  body[dir="rtl"] .site-header .brand{
    width: min(158px, 100%) !important;
    max-width: 158px !important;
  }
  html[dir="rtl"] .site-header .brand img,
  html[lang^="ar"] .site-header .brand img,
  body[dir="rtl"] .site-header .brand img{
    width: 158px !important;
    max-height: 50px !important;
  }
  html[dir="rtl"] .site-header .menu-btn,
  html[lang^="ar"] .site-header .menu-btn,
  body[dir="rtl"] .site-header .menu-btn{
    width: 50px !important;
    min-width: 50px !important;
    height: 50px !important;
  }
}
