/* ===========================================================
   G Systems Co. — vanilla mobile menu overlay
   Built fresh in JS with .gsys-* classes — no Elementor baggage.
   =========================================================== */

#gsys-mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);    /* dim backdrop; menu panel sits on top */
  z-index: 99999;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  flex-direction: column;
  font-family: "Montserrat", system-ui, -apple-system, sans-serif;
}
#gsys-mobile-overlay.gsys-open { display: flex; }

/* Menu panel (takes full screen on phones, slides up from bottom edge feel via flex) */
#gsys-mobile-overlay > .gsys-mobile-header,
#gsys-mobile-overlay > .gsys-mobile-nav,
#gsys-mobile-overlay > .gsys-mobile-footer { background: #fff; }

#gsys-mobile-overlay > .gsys-mobile-nav {
  flex: 1 1 auto;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* ---- Header ---- */
.gsys-mobile-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid #eaeaea;
  min-height: 60px;
  flex: 0 0 auto;
}
.gsys-mobile-logo { display: inline-flex; align-items: center; text-decoration: none; }
.gsys-mobile-logo img { height: 36px; width: auto; display: block; }

#gsys-mobile-close {
  width: 44px; height: 44px;
  border-radius: 8px;
  background: #0A4990;             /* brand primary */
  border: none;
  color: #fff;
  font-size: 24px; line-height: 1;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0; margin: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
  transition: background .15s, transform .1s;
}
#gsys-mobile-close:active { transform: scale(0.94); background: #073667; }

/* ---- Menu list (all our own classes, no Elementor inheritance) ---- */
.gsys-mobile-nav { padding: 0; }
ul.gsys-mobile-menu,
ul.gsys-mobile-submenu {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  width: 100% !important;
}
ul.gsys-mobile-menu > li {
  display: block !important;
  border-bottom: 1px solid #f0f0f0;
  position: relative;
  width: 100% !important;
  margin: 0 !important;
}
ul.gsys-mobile-menu > li:last-child { border-bottom: none; }

ul.gsys-mobile-menu > li > a {
  display: block !important;
  padding: 16px 56px 16px 20px;     /* extra right padding for the +/- chevron */
  color: #1D1D1B !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  background: transparent;
  transition: color .15s, background .15s;
  position: relative;
}
ul.gsys-mobile-menu > li.expanded > a,
ul.gsys-mobile-menu > li > a:active {
  color: #0A4990 !important;
  background: #f7f8fa;
}

/* +/- indicator on parent items */
ul.gsys-mobile-menu > li.has-children > a::after {
  content: '+';
  position: absolute;
  right: 16px; top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 28px;
  border-radius: 50%;
  background: #f4f7fb;
  color: #0A4990;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  text-align: center;
  transition: background .15s, color .15s, transform .2s;
}
ul.gsys-mobile-menu > li.has-children.expanded > a::after {
  content: '\2212';                 /* minus */
  background: #0A4990;
  color: #fff;
  transform: translateY(-50%) rotate(180deg);
}

/* Submenu — hidden until parent.expanded */
ul.gsys-mobile-submenu {
  display: none !important;
  background: #fafbfc;
  border-top: 1px solid #f0f0f0;
  padding: 4px 0 8px 0 !important;
}
ul.gsys-mobile-menu > li.expanded > ul.gsys-mobile-submenu { display: block !important; }
ul.gsys-mobile-submenu li {
  display: block !important;
  margin: 0 !important;
  list-style: none !important;
}
ul.gsys-mobile-submenu li a {
  display: block !important;
  padding: 12px 20px 12px 36px !important;
  color: #555 !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  background: transparent;
  transition: color .15s, padding-left .15s;
}
ul.gsys-mobile-submenu li a:active {
  color: #0A4990 !important;
  padding-left: 40px !important;
}

/* ---- Footer CTAs ---- */
.gsys-mobile-footer {
  border-top: 1px solid #eaeaea;
  padding: 14px 16px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 0 0 auto;
}
.gsys-mobile-cta {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 8px;
  background: #0A4990 !important;
  color: #fff !important;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none !important;
  box-shadow: 0 2px 6px rgba(0,0,0,0.10);
  min-height: 44px;
  transition: background .15s, transform .1s;
  border: none;
  line-height: 1;
}
.gsys-mobile-cta:active { transform: scale(0.97); background: #073667 !important; }
.gsys-mobile-cta span { color: inherit; }
.gsys-mobile-cta svg path { fill: currentColor; }
.gsys-mobile-cta--secondary {
  background: #fff !important;
  color: #0A4990 !important;
  border: 1px solid #0A4990 !important;
  box-shadow: none;
}
.gsys-mobile-cta--secondary:active { background: #f4f7fb !important; }

/* Hide on desktop */
@media (min-width: 1025px) {
  #gsys-mobile-overlay { display: none !important; }
}
