@import url("https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400&display=swap");

/* Mowaq — Lato (Light/Regular/Bold) sitewide; see brand-colors.css for Elementor overrides */
/* Nav uses Lato Light (300) — “slim” — with Regular (400) on hover / current item */

/* Mowaq — premium design system (loaded via brand-colors.css) */
:root {
  --mowaq-font-display: "Lato", "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  --mowaq-font-nav: "Lato", "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  --mowaq-font-nav-weight: 300;
  --mowaq-font-nav-weight-active: 400;
  --mowaq-font-body: "Lato", "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  --mowaq-font-heading: "Lato", "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  --mowaq-nav-glass: rgba(12, 16, 28, 0.78);
  --mowaq-nav-glass-border: rgba(255, 255, 255, 0.08);
  --mowaq-nav-shadow: 0 8px 32px rgba(0, 0, 0, 0.35), 0 1px 0 rgba(255, 255, 255, 0.06) inset;
  --mowaq-primary: #000080;
  --mowaq-accent: #F9A825;
  /* Keep in sync with #xpro-theme-builder-footer in brand-colors.css */
  --mowaq-site-footer-gradient: linear-gradient(180deg, #000080 0%, #0a0a4a 50%, #12086f 100%);
  --mowaq-radius-lg: 16px;
  --mowaq-radius-md: 12px;
  --mowaq-shadow-sm: 0 2px 8px rgba(0, 0, 128, 0.08);
  --mowaq-shadow-md: 0 12px 40px rgba(0, 0, 128, 0.12);
  /* Hero: default; home tightens in brand-colors.css (body.home) */
  --mowaq-hero-h: min(100vh, 1400px);
  --mowaq-hero-h-min: clamp(780px, 95vh, 1400px);
  /* Bar content row — generous so wrapped nav + body offset stay in sync (no gap/overlap) */
  --mowaq-header-bar: 96px;
  --mowaq-header-offset: calc(var(--mowaq-header-bar) + env(safe-area-inset-top, 0px));
  --mowaq-header-z: 10050;
  --mowaq-menu-z: 10060;
}

/* Sticky / inner: slimmer bar so logo1 + nav read as one tight strip (home hero keeps :root height) */
body.mowaq-header--scrolled,
body:not(.home) {
  --mowaq-header-bar: 82px;
}

@media (max-width: 767px) {
  :root {
    --mowaq-header-bar: 76px;
    /* --mowaq-header-offset recalculates with new bar + safe area */
    --mowaq-hero-h: min(100vh, 1280px);
    --mowaq-hero-h-min: clamp(600px, 92vh, 1280px);
  }
  body.mowaq-header--scrolled,
  body:not(.home) {
    --mowaq-header-bar: 64px;
  }
}

html {
  /* Slightly smaller than browser default; scales all `rem` typography in this file */
  font-size: 92%;
  scroll-behavior: smooth;
  /* Anchor scroll: bar + safe + small buffer */
  scroll-padding-top: calc(var(--mowaq-header-offset) + 8px);
  /* clip avoids horizontal scroll without breaking fixed/sticky like overflow-x: hidden can */
  overflow-x: clip;
}

body {
  font-family: var(--mowaq-font-body);
  font-size: 1rem;
  line-height: 1.65;
  color: #1a1a2e;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern" 1, "liga" 1;
  /* Push all content below fixed header — same value as header’s total block height */
  padding-top: var(--mowaq-header-offset) !important;
}

/* Home: hero extends to top; bar overlays (transparent until scroll) */
body.home {
  padding-top: 0 !important;
}
body.home .mowaq-hero-slide {
  padding-top: calc(var(--mowaq-header-offset) + clamp(1.5rem, 4vw, 2.5rem)) !important;
}

@media (max-width: 767px) {
  html {
    scroll-padding-top: calc(var(--mowaq-header-offset) + 6px);
  }
}

h1,
h2,
h3,
h4,
h5,
h6,
.elementor-heading-title {
  font-family: var(--mowaq-font-heading);
  color: #111827;
  font-weight: 400;
  letter-spacing: 0.02em;
  line-height: 1.22;
}

h1,
.elementor-widget-heading h1.elementor-heading-title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: 400;
  letter-spacing: 0.03em;
}

h2,
.elementor-widget-heading h2.elementor-heading-title {
  font-size: clamp(1.5rem, 3.2vw, 2.25rem);
  font-weight: 400;
}

h3,
.elementor-widget-heading h3.elementor-heading-title {
  font-size: clamp(1.2rem, 2.2vw, 1.5rem);
  font-weight: 400;
}

h4,
.elementor-widget-heading h4.elementor-heading-title {
  font-size: clamp(1.05rem, 1.8vw, 1.2rem);
  font-weight: 400;
}

h5,
h6,
.elementor-widget-heading h5.elementor-heading-title,
.elementor-widget-heading h6.elementor-heading-title {
  font-size: clamp(0.95rem, 1.5vw, 1.05rem);
  font-weight: 400;
  line-height: 1.3;
}

.jkit-icon-box .title,
.elementor-icon-box-title,
.elementor-post__title a {
  font-family: var(--mowaq-font-heading);
}

/* Body copy: Elementor + JKit (sitewide) */
.elementor-widget-text-editor,
.elementor-widget-text-editor p,
.elementor-text-editor,
.elementor-tab-content,
.jkit-icon-box .title,
.jkit-icon-box .icon-box-description,
.elementor-widget-icon-list .elementor-icon-list-text,
.elementor-message,
.elementor-field-group .elementor-field-textual,
input:not([type="submit"]):not([type="button"]),
select,
textarea {
  font-family: var(--mowaq-font-body);
  line-height: 1.65;
}

.elementor-widget-text-editor p {
  max-width: 65ch;
}

/* Site header: home = transparent at top; scroll / inner pages = dark glass. */
.xpro-theme-builder-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--mowaq-header-z);
  width: 100%;
  box-sizing: border-box;
  min-height: var(--mowaq-header-offset);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background-color: transparent !important;
  background-image: none !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
  border-bottom: 1px solid transparent;
  transition:
    background-color 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.45s ease,
    backdrop-filter 0.45s ease,
    color 0.35s ease;
  padding-top: env(safe-area-inset-top, 0);
  padding-left: max(0px, env(safe-area-inset-left, 0px));
  padding-right: max(0px, env(safe-area-inset-right, 0px));
  overflow: visible;
  isolation: isolate;
  font-family: var(--mowaq-font-nav);
  font-size: 0.9375rem;
  font-weight: var(--mowaq-font-nav-weight);
  letter-spacing: 0.04em;
  padding-bottom: 0;
  color: #ffffff;
}

/* Inner pages & scrolled home: solid white bar (sticky brand strip) */
body.mowaq-header--scrolled .xpro-theme-builder-header,
body:not(.home) .xpro-theme-builder-header {
  background-color: #ffffff !important;
  background-image: none !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 1px 0 rgba(0, 0, 128, 0.1), 0 10px 28px rgba(0, 0, 0, 0.08);
  border-bottom: 1px solid rgba(0, 0, 128, 0.12);
  color: var(--mowaq-primary);
}
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li > a,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li > a {
  color: var(--mowaq-primary) !important;
}
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li > a:hover,
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li > a:focus-visible,
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li.current-menu-item > a,
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li.current_page_item > a,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li > a:hover,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li > a:focus-visible,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li.current-menu-item > a,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li.current_page_item > a {
  color: #F9A825 !important;
  background-color: rgba(249, 168, 37, 0.12) !important;
}
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li > a:focus-visible,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li > a:focus-visible {
  outline: 2px solid var(--mowaq-primary) !important;
  outline-offset: 2px;
}
body.mowaq-header--scrolled .mowaq-header-icon-btn,
body:not(.home) .mowaq-header-icon-btn {
  background: transparent !important;
  color: var(--mowaq-primary) !important;
}
body.mowaq-header--scrolled .mowaq-header-icon-btn:hover,
body.mowaq-header--scrolled .mowaq-header-icon-btn:focus-visible,
body:not(.home) .mowaq-header-icon-btn:hover,
body:not(.home) .mowaq-header-icon-btn:focus-visible {
  color: #D99000 !important;
  background: transparent !important;
}
/* Search glyph: match primary nav link color on sticky / inner pages (not forced white) */
body.mowaq-header--scrolled .mowaq-header-search-btn .mowaq-header-search-svg,
body:not(.home) .mowaq-header-search-btn .mowaq-header-search-svg {
  color: var(--mowaq-primary) !important;
  fill: currentColor !important;
}
body.mowaq-header--scrolled .mowaq-header-search-btn .mowaq-header-search-svg path,
body:not(.home) .mowaq-header-search-btn .mowaq-header-search-svg path {
  fill: currentColor !important;
}
body.mowaq-header--scrolled .mowaq-header-search-btn:hover .mowaq-header-search-svg,
body.mowaq-header--scrolled .mowaq-header-search-btn:focus-visible .mowaq-header-search-svg,
body:not(.home) .mowaq-header-search-btn:hover .mowaq-header-search-svg,
body:not(.home) .mowaq-header-search-btn:focus-visible .mowaq-header-search-svg {
  color: #f9a825 !important;
  fill: currentColor !important;
}
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .jkit-hamburger-menu,
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .jkit-hamburger-menu svg,
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .jkit-hamburger-menu .e-font-icon-svg,
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .mowaq-header-search-btn svg,
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .mowaq-header-search-btn .mowaq-header-search-svg {
  color: #ffffff !important;
  fill: #ffffff !important;
}

/* Home, top of page: stay transparent (hero sits beneath) */
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header {
  background-color: transparent !important;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: none;
  border-bottom-color: transparent;
  color: #ffffff;
}

@media (prefers-reduced-motion: reduce) {
  .xpro-theme-builder-header,
  .xpro-theme-builder-header .jkit-nav-logo img,
  .xpro-theme-builder-header .jkit-menu > li > a,
  .xpro-theme-builder-header .jkit-menu .sub-menu a {
    transition: none !important;
  }
}

.xpro-theme-builder-header-nav {
  display: block;
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
}

.xpro-theme-builder-header .elementor-79 {
  width: 100%;
  max-width: 100%;
  overflow: visible;
}
/* First boxed row only — keeps logo + menu in one line without breaking nested columns */
.xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0,
.xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner {
  width: 100%;
  max-width: 100%;
  min-height: var(--mowaq-header-bar);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  row-gap: 0.5rem;
  column-gap: 0.5rem;
  overflow: visible;
  padding-left: max(clamp(0.75rem, 4vw, 1.5rem), env(safe-area-inset-left, 0px)) !important;
  padding-right: max(clamp(0.75rem, 4vw, 1.5rem), env(safe-area-inset-right, 0px)) !important;
}

@media (min-width: 768px) {
  .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner {
    justify-content: space-between;
    align-items: center;
    column-gap: clamp(0.75rem, 2vw, 1.5rem);
  }
}

/* Sticky / inner: tighter vertical rhythm so the white bar matches logo1 + nav */
body.mowaq-header--scrolled .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0,
body.mowaq-header--scrolled .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner,
body:not(.home) .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0,
body:not(.home) .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner {
  row-gap: 0.35rem;
}

body.mowaq-header--scrolled .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner,
body:not(.home) .xpro-theme-builder-header .elementor-79 .elementor-element-6fc75af0 > .e-con-inner {
  padding-top: 0.3rem !important;
  padding-bottom: 0.3rem !important;
}

/* Logo column: breathing room from nav cluster */
.xpro-theme-builder-header .elementor-element-533dcbf5 {
  flex-shrink: 0;
  margin-inline-end: 0.35rem;
}

@media (min-width: 768px) {
  .xpro-theme-builder-header .elementor-element-533dcbf5 {
    margin-inline-end: 0.75rem;
  }
  /* Nav + CTA cluster: use remaining width and hug the right edge */
  .xpro-theme-builder-header .elementor-element-3f93ae0b {
    flex: 1 1 auto;
    min-width: 0;
    justify-content: flex-end;
  }
}

/* Submenu carets (JKit) — extra-slim, aligned with label */
.xpro-theme-builder-header .jkit-menu > .menu-item-has-children > a {
  display: inline-flex;
  align-items: center;
  gap: 0.1em;
}
.xpro-theme-builder-header .jkit-menu > .menu-item-has-children > a .e-font-icon-svg,
.xpro-theme-builder-header .jkit-menu > .menu-item-has-children > a svg {
  fill: currentColor !important;
  color: inherit !important;
  opacity: 0.78;
  width: 0.42em;
  height: 0.44em;
  min-width: 0;
  min-height: 0;
  max-width: 0.5em;
  max-height: 0.5em;
  margin: 0;
  flex-shrink: 0;
  transform: scale(0.62, 0.86);
  transform-origin: 50% 50%;
}

/* JKit in header: overlay + panel above fixed bar (scoped to header only) */
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper,
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu .jkit-overlay,
.xpro-theme-builder-header .jkit-menu-wrapper,
.xpro-theme-builder-header .jkit-overlay,
.xpro-theme-builder-header .jkit-nav-identity-panel {
  z-index: var(--mowaq-menu-z) !important;
}
.xpro-theme-builder-header .jkit-hamburger-menu {
  position: relative;
  z-index: calc(var(--mowaq-menu-z) + 1);
  border-radius: 8px;
  padding: 8px;
  margin: -4px;
  transition: background-color 0.3s ease, color 0.3s ease;
  color: rgba(255, 255, 255, 0.95) !important;
}
.xpro-theme-builder-header .jkit-hamburger-menu:hover,
.xpro-theme-builder-header .jkit-hamburger-menu:focus-visible {
  background-color: rgba(255, 255, 255, 0.12) !important;
  outline: none;
}

/* Logo: branded PNG (transparent) — no filters or faux “plate” backgrounds.
   Assets are very wide (~1.95:1); cap width so the bar stays balanced on small viewports. */
.xpro-theme-builder-header .mowaq-brand-lockup {
  max-height: clamp(44px, 6.5vw, 64px);
  max-width: min(72vw, 220px);
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
  background: transparent !important;
  box-shadow: none;
  filter: none !important;
}
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .mowaq-brand-lockup {
  max-height: clamp(64px, 11vw, 104px);
  max-width: min(90vw, 40rem);
}
.xpro-theme-builder-header .mowaq-header-logo-link,
.xpro-theme-builder-header .jkit-nav-logo a {
  background: transparent !important;
  display: inline-flex;
  align-items: center;
  line-height: 0;
}

/* Dual assets: assets/branding/logo.png (hero) vs logo1.png (white bar / inner pages) */
.xpro-theme-builder-header .mowaq-brand-lockup--hero {
  display: none;
}
.xpro-theme-builder-header .mowaq-brand-lockup--bar {
  display: inline-block;
  vertical-align: middle;
}
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .mowaq-brand-lockup--hero {
  display: inline-block;
  vertical-align: middle;
}
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .mowaq-brand-lockup--bar {
  display: none;
}

/* Legacy Taylo / non–brand-lockup: keep previous monochrome treatment */
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .jkit-nav-logo img:not(.mowaq-brand-lockup) {
  filter: brightness(0) invert(1);
  transition: filter 0.45s ease;
}
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-nav-logo img:not(.mowaq-brand-lockup),
body:not(.home) .xpro-theme-builder-header .jkit-nav-logo img:not(.mowaq-brand-lockup) {
  filter: none;
}

/* Primary nav: top bar only in ALL CAPS; dropdowns stay sentence case */
.xpro-theme-builder-header .jkit-menu.mowaq-main-menu > li > a,
.xpro-theme-builder-header .jkit-menu > li > a {
  text-transform: uppercase;
  text-decoration: none !important;
  border-radius: 8px;
  padding: 0.45em 0.65em;
  font-weight: var(--mowaq-font-nav-weight);
  font-family: var(--mowaq-font-nav);
  letter-spacing: 0.07em;
  transition: color 0.3s ease, background-color 0.3s ease, box-shadow 0.3s ease, font-weight 0.2s ease;
  color: rgba(255, 255, 255, 0.92) !important;
}
.xpro-theme-builder-header .jkit-menu > li > a:hover,
.xpro-theme-builder-header .jkit-menu > li > a:focus-visible,
.xpro-theme-builder-header .jkit-menu > li.current-menu-item > a,
.xpro-theme-builder-header .jkit-menu > li.current_page_item > a {
  font-weight: var(--mowaq-font-nav-weight-active);
  color: #F9A825 !important;
  background-color: rgba(255, 255, 255, 0.1) !important;
  outline: none;
}
body.home:not(.mowaq-header--scrolled) .xpro-theme-builder-header .jkit-menu > li > a:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.55) !important;
  outline-offset: 2px;
}
body.mowaq-header--scrolled .xpro-theme-builder-header .jkit-menu > li > a,
body:not(.home) .xpro-theme-builder-header .jkit-menu > li > a {
  padding: 0.32em 0.52em;
  letter-spacing: 0.055em;
}
.xpro-theme-builder-header ~ [data-elementor-type="wp-page"] {
  position: relative;
  z-index: 0;
  margin-top: 0 !important;
  isolation: isolate;
}

/* Elementor motion: .elementor-invisible (visibility:hidden) for entrance effects.
   If motion JS does not run, main content can stay blank — same fix as Contact for all built pages. */
body.elementor-page-36 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-51 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-55 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-61 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-72 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-58 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-67 [data-elementor-type="wp-page"] .elementor-invisible,
body.elementor-page-47 [data-elementor-type="wp-page"] .elementor-invisible {
  visibility: visible !important;
}

/* FAQ route: same export as contact, but main contact strip is removed — give the Q&A block more room */
body.mowaq-faq-page [data-elementor-type="wp-page"] [data-id="504f20bf"] .e-con-inner {
  padding-top: clamp(0.5rem, 2vw, 1.5rem);
  padding-bottom: clamp(2.5rem, 6vw, 4.5rem);
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
body.mowaq-faq-page [data-elementor-type="wp-page"] [data-id="6ec4dec"] {
  min-height: min(70vh, 900px);
}

/* FAQ accordions (contact + pricing): remove inner “box” around answer text; keep the row border only */
[data-id="6ec4dec"] .e-n-accordion-item [data-e-type="container"].e-con-boxed.e-con,
[data-id="667bb895"] .e-n-accordion-item [data-e-type="container"].e-con-boxed.e-con {
  border: none !important;
  box-shadow: none !important;
  background: none !important;
  background-color: transparent !important;
  outline: none !important;
  --padding-top: 0;
  --padding-bottom: 0;
  --padding-left: 0;
  --padding-right: 0;
  padding: 0.25rem 0 0.65rem !important;
}
[data-id="6ec4dec"] .e-n-accordion-item .e-con-boxed .e-con-inner,
[data-id="667bb895"] .e-n-accordion-item .e-con-boxed .e-con-inner {
  padding: 0 !important;
  gap: 0 !important;
}

/* Elementor also draws a full border on the direct .e-con wrapper under each <details> (answer region) — extra “box” under the title, often obvious on the last row */
[data-id="6ec4dec"] .e-n-accordion .e-n-accordion-item > .e-con,
[data-id="667bb895"] .e-n-accordion .e-n-accordion-item > .e-con {
  border: none !important;
  box-shadow: none !important;
  background: none !important;
  background-color: transparent !important;
  margin: 0 !important;
  padding: 0 0 0.35rem !important;
}

/* Contact + Resources pages: see mowaq-resources.css */

.xpro-theme-builder-header .elementor-widget-image img.attachment-full:not(.mowaq-brand-lockup) {
  max-height: 52px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.xpro-theme-builder-header .jkit-menu .sub-menu li {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}
.xpro-theme-builder-header .jkit-menu .sub-menu a {
  text-transform: none;
  color: rgba(255, 255, 255, 0.9) !important;
  text-decoration: none !important;
  display: block;
  padding: 0.32em 0.45em;
  border-radius: 6px;
  transition: color 0.25s ease, background 0.25s ease, font-weight 0.2s ease;
  font-family: var(--mowaq-font-nav);
  font-size: 0.9rem;
  font-weight: var(--mowaq-font-nav-weight);
  letter-spacing: 0.04em;
  line-height: 1.3;
  white-space: nowrap;
}
.xpro-theme-builder-header .jkit-menu .sub-menu a:hover,
.xpro-theme-builder-header .jkit-menu .sub-menu a:focus {
  font-weight: var(--mowaq-font-nav-weight-active);
  color: #F9A825 !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

/* Dropdown / mega: same gradient as site footer + search sheet (#xpro-theme-builder-footer, .mowaq-site-search__shell) */
.xpro-theme-builder-header .jkit-menu .sub-menu {
  background: var(--mowaq-site-footer-gradient) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.45) !important;
  padding: 0.3rem 0.28rem !important;
  min-width: 14rem;
  font-family: var(--mowaq-font-nav);
  z-index: calc(var(--mowaq-menu-z) + 20);
}
/* Keep dropdown above siblings / bar chrome; not clipped by container */
.xpro-theme-builder-header .jkit-menu > li {
  position: relative;
}
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu .jkit-menu-container,
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper {
  overflow: visible !important;
}
.xpro-theme-builder-header .jkit-menu .sub-menu li a {
  color: rgba(255, 255, 255, 0.9) !important;
  font-weight: var(--mowaq-font-nav-weight);
}
/* Services (merged) — 2-col grid, scroll if needed */
@media (min-width: 1025px) {
  .xpro-theme-builder-header .jkit-menu li.mowaq-services-merged {
    z-index: 2;
  }
  .xpro-theme-builder-header .jkit-menu li.mowaq-services-merged .sub-menu.mowaq-services-merged {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(11.5rem, 1fr));
    column-gap: 0.4rem;
    row-gap: 0;
    min-width: min(100%, 26rem);
    max-width: 42rem;
    max-height: min(70vh, 32rem);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: 0.4rem 0.4rem !important;
  }
  .xpro-theme-builder-header .jkit-menu li.mowaq-services-merged .sub-menu.mowaq-services-merged li {
    margin: 0;
  }
}
@media (max-width: 1024px) {
  .xpro-theme-builder-header .jkit-menu li.mowaq-services-merged .sub-menu.mowaq-services-merged {
    display: block !important;
    min-width: 0;
    max-width: 100%;
    max-height: none;
    overflow: visible;
  }
}
/* Production: dropdown labels only (no page links) — same panel behavior as Overview */
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged {
  position: relative;
  z-index: 4;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged > a.mowaq-nav-parent-label {
  cursor: default;
}
/* JKit hides .sub-menu until hover; reinforce for Production (spans were invisible without .sub-menu a rules) */
.jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper .jkit-menu li.mowaq-production-merged.menu-item-has-children:hover > .sub-menu,
.jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper .jkit-menu li.mowaq-production-merged.menu-item-has-children:focus-within > .sub-menu,
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged:hover > .sub-menu,
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged:focus-within > .sub-menu {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged .sub-menu.mowaq-production-dropdown {
  display: block !important;
  grid-template-columns: unset !important;
  min-width: max(16rem, max-content) !important;
  max-width: min(24rem, calc(100vw - 1.5rem)) !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 0.35rem 0 !important;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged .sub-menu.mowaq-production-dropdown li {
  display: block;
  width: 100%;
  margin: 0;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-production-merged .sub-menu.mowaq-production-dropdown a {
  display: block !important;
  padding: 0.45em 0.9em !important;
  white-space: nowrap;
  cursor: pointer;
}
/* Mobile / tablet off-canvas: JKit .dropdown-open */
.jeg-elementor-kit.jkit-nav-menu.break-point-laptop .jkit-menu-wrapper .jkit-menu li.mowaq-production-merged .sub-menu.dropdown-open,
body[data-elementor-device-mode="tablet"] .jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper .jkit-menu li.mowaq-production-merged .sub-menu.dropdown-open,
body[data-elementor-device-mode="mobile"] .jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper .jkit-menu li.mowaq-production-merged .sub-menu.dropdown-open {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}
@media (max-width: 1024px) {
  .xpro-theme-builder-header .jkit-menu li.mowaq-production-merged .sub-menu.mowaq-production-dropdown {
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

/* Overview: simple dropdown (not the Services/Production mega grid) */
.xpro-theme-builder-header .jkit-menu li.mowaq-overview-merged {
  position: relative;
  z-index: 3;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-overview-merged .sub-menu.mowaq-overview-dropdown {
  display: block !important;
  grid-template-columns: unset !important;
  min-width: max(15.5rem, max-content) !important;
  max-width: min(22rem, calc(100vw - 1.5rem)) !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 0.35rem 0 !important;
  column-gap: unset !important;
  row-gap: 0 !important;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-overview-merged .sub-menu.mowaq-overview-dropdown li {
  display: block;
  width: 100%;
  margin: 0;
}
.xpro-theme-builder-header .jkit-menu li.mowaq-overview-merged .sub-menu.mowaq-overview-dropdown a {
  display: block;
  padding: 0.45em 0.9em !important;
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .xpro-theme-builder-header .jkit-menu li.mowaq-overview-merged .sub-menu.mowaq-overview-dropdown {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.mowaq-production-landing h1,
.mowaq-production-landing h2,
.mowaq-production-landing p {
  max-width: 65ch;
  margin-left: 0;
  margin-right: auto;
}
.mowaq-production-landing .mowaq-production-hub-list {
  margin: 1.5rem 0 0;
  padding-left: 1.1rem;
  line-height: 1.8;
  max-width: 40rem;
}
.mowaq-production-landing .mowaq-production-hub-list a {
  color: var(--mowaq-primary, #000080);
  text-decoration: none;
  font-weight: 500;
  border-bottom: 1px solid var(--mowaq-primary, #000080);
  transition: color 0.2s, border-color 0.2s;
}
.mowaq-production-landing .mowaq-production-hub-list a:hover {
  color: #D99000;
  border-color: #F9A825;
}

/* JKit / Elementor: off-canvas, overlay, and side panel surfaces come from the template + JKit. */

/* Row: JKit wrapper (nav links) + end tools (search) after the menu list in markup */
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu {
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  flex: 1 1 auto;
  min-width: 0;
  gap: 0.5rem 0.75rem;
}
.xpro-theme-builder-header .jeg-elementor-kit.jkit-nav-menu .jkit-menu-wrapper {
  flex: 1 1 auto;
  min-width: 0;
  order: 1;
}

/* After menu list: search control (JKit hamburger keeps default template position) */
.xpro-theme-builder-header .jkit-menu-container {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.35rem 0.5rem;
  min-width: 0;
  flex: 1 1 auto;
}
.xpro-theme-builder-header .jkit-menu-container .jkit-menu {
  flex: 1 1 auto;
  min-width: 0;
  justify-content: flex-end;
}
.mowaq-header-end-tools {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 0.1rem 0.25rem;
  margin-left: 0.15rem;
  order: 2;
}
.mowaq-header-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  padding: 0;
  border: none !important;
  border-radius: 8px;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  color: rgba(255, 255, 255, 0.9);
  cursor: pointer;
  transition: color 0.2s ease, transform 0.2s ease;
}
.mowaq-header-icon-btn:hover,
.mowaq-header-icon-btn:active {
  color: #F9A825;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  outline: none;
}
.mowaq-header-icon-btn:focus-visible {
  color: #F9A825;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  outline: none;
  box-shadow: 0 0 0 2px currentColor;
}
.mowaq-header-icon-btn svg {
  width: 1.05em;
  height: 1.05em;
  display: block;
}
/* Search: own class so global `.e-font-icon-svg` / `fill="currentColor"` quirks never hide the glyph */
.mowaq-header-search-btn .mowaq-header-search-svg {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  color: inherit;
  fill: currentColor;
}
.mowaq-header-search-btn .mowaq-header-search-svg path {
  fill: currentColor;
}
.mowaq-header-end-tools .jkit-hamburger-menu {
  /* If the hamburger is ever placed in end-tools */
  position: relative;
  z-index: 0;
  width: 2.4rem;
  height: 2.4rem;
  min-width: 2.4rem;
  padding: 0;
  border: none;
  border-radius: 8px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06) !important;
  color: rgba(255, 255, 255, 0.9) !important;
  visibility: visible !important;
}
.mowaq-header-end-tools .jkit-hamburger-menu:hover,
.mowaq-header-end-tools .jkit-hamburger-menu:focus-visible {
  color: #F9A825 !important;
  background: rgba(255, 255, 255, 0.12) !important;
}
.mowaq-header-end-tools .jkit-hamburger-menu svg,
.mowaq-header-end-tools .jkit-hamburger-menu .e-font-icon-svg {
  fill: currentColor;
}

/* —— Search: large top “sheet” (movable to <body> via JS) —— */
.mowaq-site-search[hidden] {
  display: none !important;
}
.mowaq-site-search {
  position: fixed;
  inset: 0;
  z-index: calc(var(--mowaq-menu-z) + 5000);
  display: block;
  pointer-events: none;
  visibility: hidden;
}
.mowaq-site-search.mowaq-site-search--open {
  pointer-events: auto;
  visibility: visible;
}
.mowaq-site-search__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2, 4, 12, 0.55);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.mowaq-site-search--open .mowaq-site-search__backdrop {
  opacity: 1;
}
/* Full-bleed top sheet: flush to the top of the viewport; sits above the bar (higher z-index) */
.mowaq-site-search__shell {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: none;
  min-height: min(52vh, 36rem);
  display: flex;
  flex-direction: column;
  background: var(--mowaq-site-footer-gradient);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.5);
  border-radius: 0 0 28px 28px;
  transform: translate3d(0, -100%, 0);
  will-change: transform;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  /* Safe area only: sheet touches the top of the screen */
  padding: max(0.75rem, env(safe-area-inset-top, 0px)) 0 0;
  margin: 0;
  margin-top: 0 !important;
  box-sizing: border-box;
}
.mowaq-site-search--open .mowaq-site-search__shell {
  transform: translate3d(0, 0, 0);
}
.mowaq-site-search__inner {
  width: 100%;
  max-width: min(96rem, 100%);
  margin: 0 auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(2rem, 5vw, 4.25rem) clamp(1.5rem, 4vw, 3.5rem) clamp(2.25rem, 5vw, 4.5rem);
  box-sizing: border-box;
}
.mowaq-site-search__head {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
}
.mowaq-site-search__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.1rem;
  height: 3.1rem;
  border: none !important;
  border-radius: 10px;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  color: rgba(255, 255, 255, 0.92);
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: color 0.2s, transform 0.2s;
}
.mowaq-site-search__close:hover,
.mowaq-site-search__close:focus-visible,
.mowaq-site-search__close:active {
  color: #F9A825;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  outline: none;
}
.mowaq-site-search__close:focus-visible {
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.4) !important;
}
.mowaq-site-search__close svg,
.mowaq-site-search__close .mowaq-site-search__close-svg {
  width: 1.35rem;
  height: 1.35rem;
  display: block;
  color: inherit;
  fill: currentColor;
}
.mowaq-site-search__close .mowaq-site-search__close-svg path {
  fill: currentColor;
}
.mowaq-site-search__form {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: 100%;
  max-width: 100%;
}
.mowaq-site-search__label {
  display: block;
  width: 100%;
  max-width: min(64rem, 100%);
  margin: 0 auto;
  padding: 0 0.75rem;
  box-sizing: border-box;
  text-align: center;
  font-family: var(--mowaq-font-heading);
  font-size: clamp(1rem, 2.8vw, 1.85rem);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.96);
  cursor: pointer;
}
.mowaq-site-search__input {
  width: 100%;
  max-width: min(64rem, 100%);
  margin: 0 auto;
  box-sizing: border-box;
  min-height: 2.5rem;
  height: 2.65rem;
  padding: 0.45rem 1rem;
  font-family: var(--mowaq-font-body);
  font-size: clamp(0.95rem, 1.35vw, 1.1rem);
  line-height: 1.35;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.98);
  color: #1a1a2e;
}
.mowaq-site-search__input::placeholder {
  color: #64748b;
}
.mowaq-site-search__input:focus {
  outline: 2px solid #F9A825;
  outline-offset: 1px;
  border-color: #F9A825;
}
/* When reparented to <body>, keep the sheet flush to the top (see .mowaq-site-search__shell padding) */
body > .mowaq-site-search .mowaq-site-search__shell {
  margin-top: 0 !important;
}
body.mowaq-site-search--open {
  overflow: hidden;
}
@media (max-width: 767px) {
  .mowaq-header-icon-btn {
    width: 2.25rem;
    height: 2.25rem;
  }
}

.xpro-theme-builder-header .elementor-79 .e-con,
.xpro-theme-builder-header .e-con-boxed,
.xpro-theme-builder-header .e-con {
  --padding-top: 0.5rem;
  --padding-bottom: 0.5rem;
  background: transparent !important;
}

/* Hero — below header; not drawn behind the bar */
body.home .elementor-7 .elementor-element-c8c11e0 {
  position: relative;
  z-index: 0;
  min-height: var(--mowaq-hero-h-min) !important;
  height: auto !important;
  --padding-top: 0 !important;
  --padding-bottom: 0 !important;
  padding: 0 !important;
  margin-top: 0 !important;
  background-image: none !important;
  display: block !important;
  justify-content: stretch !important;
  align-items: stretch !important;
  overflow: hidden;
}

body.home .elementor-7 .elementor-element-c8c11e0 > .e-con-inner {
  min-height: var(--mowaq-hero-h-min) !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block;
}

.mowaq-hero-swiper {
  width: 100%;
  min-height: var(--mowaq-hero-h);
  height: 100%;
  position: relative;
  border-radius: 0;
  overflow: hidden;
}
/* Before mowaq-hero.js adds .mowaq-hero--native: global Swiper CSS lays slides in a row — only show first */
.mowaq-hero-swiper:not(.mowaq-hero--native) .swiper-wrapper {
  display: block !important;
  transform: none !important;
}
.mowaq-hero-swiper:not(.mowaq-hero--native) .mowaq-hero-slide {
  display: none !important;
  width: 100% !important;
}
.mowaq-hero-swiper:not(.mowaq-hero--native) .mowaq-hero-slide--active,
.mowaq-hero-swiper:not(.mowaq-hero--native) .mowaq-hero-slide:first-of-type {
  display: flex !important;
}
/* Native hero (mowaq-hero.js): stacked slides, no Swiper */
.mowaq-hero--native .swiper-wrapper {
  display: block !important;
  position: relative !important;
  width: 100% !important;
  min-height: var(--mowaq-hero-h) !important;
  height: auto !important;
  transform: none !important;
}
.mowaq-hero--native .mowaq-hero-slide {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: 0 !important;
  width: 100% !important;
  min-height: var(--mowaq-hero-h) !important;
  margin: 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: opacity 0.6s ease;
  z-index: 0;
  pointer-events: none;
}
.mowaq-hero--native .mowaq-hero-slide.mowaq-hero-slide--active {
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 2;
  pointer-events: auto;
}

.mowaq-hero-swiper .swiper-wrapper,
.mowaq-hero-swiper .swiper-slide {
  min-height: var(--mowaq-hero-h) !important;
  height: auto;
}

.mowaq-hero-slide {
  position: relative;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
  padding: clamp(1.75rem, 4.5vw, 3.25rem) clamp(1.25rem, 4vw, 2rem) !important;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  isolation: isolate;
}

.mowaq-hero-slide--1 {
  background-image: linear-gradient(
      120deg,
      rgba(0, 0, 128, 0.78) 0%,
      rgba(0, 20, 80, 0.5) 45%,
      rgba(249, 168, 37, 0.2) 100%
    ),
    url("../../content/uploads/sites/27/2025/08/Hero-BG.webp");
}

.mowaq-hero-slide--2 {
  background-image: linear-gradient(
      115deg,
      rgba(0, 0, 64, 0.72) 0%,
      rgba(4, 8, 32, 0.45) 40%,
      rgba(0, 0, 32, 0.35) 100%
    ),
    url("../images/hero-slide-2-bespoke-measuring.png");
}

.mowaq-hero-slide--3 {
  background-image: linear-gradient(
      110deg,
      rgba(0, 0, 48, 0.78) 0%,
      rgba(30, 18, 0, 0.35) 48%,
      rgba(0, 0, 0, 0.6) 100%
    ),
    url("../images/hero-slide-3-sewing-needle.png");
  background-position: center 42%;
}

.mowaq-hero-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 30%, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.25) 100%);
  pointer-events: none;
}

.mowaq-hero-content {
  position: relative;
  z-index: 1;
  max-width: 42rem;
  margin: 0 auto;
}

.mowaq-hero-eyebrow {
  display: block;
  font-family: var(--mowaq-font-body);
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: #F9A825;
  font-weight: 600;
  margin: 0 0 0.75rem;
}

.mowaq-hero-title {
  font-family: var(--mowaq-font-display);
  font-weight: 400;
  color: #ffffff;
  margin: 0 0 1rem;
  letter-spacing: 0.03em;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.25);
  transform-origin: center center;
}

.mowaq-hero-text {
  font-family: var(--mowaq-font-body);
  color: rgba(255, 255, 255, 0.95);
  margin: 0 0 1.5rem;
  font-size: clamp(0.95rem, 1.4vw, 1.1rem);
  line-height: 1.65;
  font-weight: 400;
}

.mowaq-hero-cta {
  font-family: var(--mowaq-font-body);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.75rem;
  background: #F9A825 !important;
  color: #000080 !important;
  font-weight: 600;
  border: none;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.95rem;
  box-shadow: 0 4px 20px rgba(249, 168, 37, 0.4);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.mowaq-hero-cta:hover {
  background: #D99000 !important;
  color: #000080 !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(249, 168, 37, 0.5);
}

.mowaq-hero-swiper .swiper-button-prev,
.mowaq-hero-swiper .swiper-button-next {
  color: #ffffff;
  width: 44px;
  height: 44px;
  background: rgba(0, 0, 128, 0.45);
  border-radius: 50%;
  transition: background 0.2s, transform 0.2s;
  margin-top: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  cursor: pointer;
}

.mowaq-hero-swiper .swiper-button-prev:hover,
.mowaq-hero-swiper .swiper-button-next:hover {
  background: rgba(0, 0, 128, 0.9);
  color: #ffffff;
}

.mowaq-hero-swiper .swiper-button-prev {
  left: 12px;
}
.mowaq-hero-swiper .swiper-button-next {
  right: 12px;
}

.mowaq-hero-swiper .swiper-button-prev::after,
.mowaq-hero-swiper .swiper-button-next::after {
  font-size: 1rem;
  font-weight: 700;
}

.mowaq-hero-swiper .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background: rgba(255, 255, 255, 0.45);
  opacity: 1;
  transition: background 0.2s, transform 0.2s;
}
.mowaq-hero-swiper .swiper-pagination-bullet-active {
  background: #F9A825;
  transform: scale(1.2);
}
.mowaq-hero-swiper .swiper-pagination {
  bottom: 1.5rem !important;
}

.mowaq-hero--native .mowaq-hero-pagination {
  position: absolute;
  bottom: 1.5rem;
  z-index: 5;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.mowaq-hero--native .mowaq-hero-bullet {
  width: 10px;
  height: 10px;
  border: none;
  border-radius: 50%;
  padding: 0;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.45);
  transition: background 0.2s, transform 0.2s;
}
.mowaq-hero--native .mowaq-hero-bullet--active {
  background: #F9A825;
  transform: scale(1.2);
}

.mowaq-hero--native .mowaq-hero-slide--active .mowaq-hero-content,
.mowaq-hero-swiper .swiper-slide-active .mowaq-hero-content {
  animation: mowaqHeroIn 0.75s ease forwards;
}
@keyframes mowaqHeroIn {
  from {
    opacity: 0.85;
    transform: translateY(12px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 767px) {
  .mowaq-hero-swiper .swiper-button-prev,
  .mowaq-hero-swiper .swiper-button-next {
    width: 36px;
    height: 36px;
  }
  .mowaq-hero-swiper .swiper-button-prev {
    left: 6px;
  }
  .mowaq-hero-swiper .swiper-button-next {
    right: 6px;
  }
}

/* Subtle card lift on home sections */
body.home .elementor-7 .e-con.e-parent {
  transition: box-shadow 0.25s ease;
}

/* Product / logo strip — nav + pagination (elements injected in JS) */
.mowaq-prod-swiper,
body.home .elementor-7 .elementor-element-56a6dfcb .elementor-image-carousel-wrapper,
.elementor-element-56a6dfcb .elementor-image-carousel-wrapper.swiper,
.elementor-element-aad805d .elementor-image-carousel-wrapper.swiper {
  position: relative;
  /* Inset nav via button offset only — avoids wide side “lanes” if any bg leaks */
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
}

.elementor-element-56a6dfcb .elementor-widget-container,
.elementor-element-aad805d .elementor-widget-container {
  background: transparent !important;
  background-color: transparent !important;
}

@media (max-width: 600px) {
  .mowaq-prod-swiper,
  body.home .elementor-7 .elementor-element-56a6dfcb .elementor-image-carousel-wrapper,
  .elementor-element-56a6dfcb .elementor-image-carousel-wrapper.swiper,
  .elementor-element-aad805d .elementor-image-carousel-wrapper.swiper {
    padding-left: 10px;
    padding-right: 10px;
  }
  .mowaq-prod-prev {
    left: 2px !important;
  }
  .mowaq-prod-next {
    right: 2px !important;
  }
}

.mowaq-prod-prev,
.mowaq-prod-next {
  color: #ffffff !important;
  width: 40px;
  height: 40px;
  background: #000080 !important;
  border-radius: 4px;
  box-shadow: var(--mowaq-shadow-sm);
  transition: background 0.2s, color 0.2s, transform 0.2s;
  margin-top: 0;
  position: absolute !important;
  z-index: 3;
  top: 50% !important;
  transform: translateY(-50%);
}
.mowaq-prod-prev {
  left: 4px !important;
  right: auto !important;
}
.mowaq-prod-next {
  right: 4px !important;
  left: auto !important;
}
.mowaq-prod-prev:hover,
.mowaq-prod-next:hover {
  color: #ffffff !important;
  background: #00005c !important;
  transform: translateY(-50%) scale(1.05);
}
.mowaq-prod-prev::after,
.mowaq-prod-next::after {
  font-size: 0.9rem;
  font-weight: 800;
}
.mowaq-prod-pagi {
  position: static !important;
  margin-top: 1rem;
  text-align: center;
  background: transparent !important;
}
.mowaq-prod-pagi .swiper-pagination-bullet {
  background: rgba(0, 0, 128, 0.3);
  opacity: 1;
}
.mowaq-prod-pagi .swiper-pagination-bullet-active {
  background: #000080;
}

body.home
  .elementor-7
  .elementor-element-56a6dfcb
  .swiper-slide.swiper-slide-active
  .swiper-slide-image,
body.home .elementor-7 .elementor-element-56a6dfcb .swiper-slide.swiper-slide-active .swiper-slide-inner img {
  transform: scale(1.04);
  transition: transform 0.5s ease;
}
