/*
Theme Name: OutCloud Child
Description: Child theme for OutCloud standalone templates.
Author: Telma Costa
Template: hello-biz
Version: 1.0
*/

/* Global baseline to avoid white gaps from parent/Elementor wrappers */
html,
body,
body.page,
body.single,
body.archive,
body.blog,
#page,
#content,
.site,
.site-content,
.site-main,
.content-area,
main,
article,
section {
  background: #050b18 !important;
}

/* Prevent lateral movement on mobile caused by decorative absolute layers */
html,
body {
  max-width: 100%;
}

body:not(.wp-admin),
body:not(.wp-admin) #page,
body:not(.wp-admin) #content,
body:not(.wp-admin) .site,
body:not(.wp-admin) .site-content,
body:not(.wp-admin) .site-main,
body:not(.wp-admin) .content-area,
body:not(.wp-admin) main {
  max-width: 100% !important;
  overflow-x: clip !important;
}

@supports not (overflow: clip) {
  body:not(.wp-admin),
  body:not(.wp-admin) #page,
  body:not(.wp-admin) #content,
  body:not(.wp-admin) .site,
  body:not(.wp-admin) .site-content,
  body:not(.wp-admin) .site-main,
  body:not(.wp-admin) .content-area,
  body:not(.wp-admin) main {
    overflow-x: hidden !important;
  }
}

/* Mobile overflow hardening for standalone templates */
@media (max-width: 900px) {
  body:not(.wp-admin).outcloud-standalone,
  body:not(.wp-admin).outcloud-standalone #page,
  body:not(.wp-admin).outcloud-standalone #content,
  body:not(.wp-admin).outcloud-standalone .site,
  body:not(.wp-admin).outcloud-standalone .site-content,
  body:not(.wp-admin).outcloud-standalone .site-main,
  body:not(.wp-admin).outcloud-standalone .content-area,
  body:not(.wp-admin).outcloud-standalone main {
    width: 100%;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  body:not(.wp-admin).outcloud-standalone section,
  body:not(.wp-admin).outcloud-standalone .container {
    max-width: 100vw !important;
  }

  /* Keep very long labels from forcing horizontal pan */
  body:not(.wp-admin).outcloud-standalone .hero-providers-label,
  body:not(.wp-admin).outcloud-standalone .client-logo-text,
  body:not(.wp-admin).outcloud-standalone .cat-score,
  body:not(.wp-admin).outcloud-standalone .matrix-row-label {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  /* Defensive clipping for large decorative layers */
  body:not(.wp-admin).outcloud-standalone .hero,
  body:not(.wp-admin).outcloud-standalone .resources-hero,
  body:not(.wp-admin).outcloud-standalone .use-case-section,
  body:not(.wp-admin).outcloud-standalone .cta-section {
    overflow-x: clip !important;
  }

  /* Keep horizontally-scrollable data blocks inside viewport */
  body:not(.wp-admin).outcloud-standalone .table-scroll,
  body:not(.wp-admin).outcloud-standalone .escalation-flow,
  body:not(.wp-admin).outcloud-standalone .matrix-table-wrap,
  body:not(.wp-admin).outcloud-standalone div[style*="overflow-x:auto"] {
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* Keep links neutral unless component sets its own color */
a,
a:visited {
  color: inherit;
}

/* Frontend link reset:
   avoid browser/parent-theme underlines leaking after template changes/navigation */
body:not(.wp-admin) a,
body:not(.wp-admin) a:visited,
body:not(.wp-admin) a:hover,
body:not(.wp-admin) a:focus,
body:not(.wp-admin) a:active {
  text-decoration: none !important;
}

/* Keep explicit underlines where they communicate utility/action inside consent copy */
.oc-cookie__text a {
  text-decoration: underline !important;
}

/* Filled yellow CTAs should use dark text; outline variants keep amber text */
body:not(.wp-admin) .btn-primary:not(.nav-cta),
body:not(.wp-admin) .btn.btn-primary:not(.nav-cta),
body:not(.wp-admin) a.btn-primary:not(.nav-cta),
body:not(.wp-admin) button.btn-primary:not(.nav-cta),
body:not(.wp-admin) .sidebar-cta-btn,
body:not(.wp-admin) .cta-action {
  color: #080f20 !important;
  -webkit-text-fill-color: #080f20 !important;
}

body:not(.wp-admin) .btn-primary:not(.nav-cta):hover,
body:not(.wp-admin) .btn.btn-primary:not(.nav-cta):hover,
body:not(.wp-admin) a.btn-primary:not(.nav-cta):hover,
body:not(.wp-admin) button.btn-primary:not(.nav-cta):hover,
body:not(.wp-admin) .sidebar-cta-btn:hover,
body:not(.wp-admin) .cta-action:hover,
body:not(.wp-admin) .btn-primary:not(.nav-cta):focus,
body:not(.wp-admin) .btn.btn-primary:not(.nav-cta):focus,
body:not(.wp-admin) a.btn-primary:not(.nav-cta):focus,
body:not(.wp-admin) button.btn-primary:not(.nav-cta):focus,
body:not(.wp-admin) .cta-action:focus {
  color: #080f20 !important;
  -webkit-text-fill-color: #080f20 !important;
}

/* Keep outline header/mobile nav CTAs yellow */
body:not(.wp-admin) .nav-cta,
body:not(.wp-admin) .btn.btn-primary.nav-cta,
body:not(.wp-admin) a.btn.btn-primary.nav-cta {
  color: #f6ba2c !important;
  -webkit-text-fill-color: #f6ba2c !important;
}

/* Client logos in trust strips/cards */
body:not(.wp-admin) .client-logo-img {
  display: block;
  width: auto;
  max-width: min(150px, 100%);
  max-height: 30px;
  object-fit: contain;
  opacity: 0.82;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

body:not(.wp-admin) .client-logo-fallback {
  display: inline-block;
  max-width: min(150px, 100%);
  font-family: var(--font-display, "Plus Jakarta Sans", "Inter", "Segoe UI", Arial, sans-serif);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #a9bed8;
  opacity: 0.88;
  white-space: nowrap;
}

body:not(.wp-admin) .client-logo:hover .client-logo-img,
body:not(.wp-admin) .client-name:hover .client-logo-img,
body:not(.wp-admin) .logo-item:hover .client-logo-img {
  opacity: 1;
  transform: translateY(-1px);
}

@media (max-width: 767px) {
  body:not(.wp-admin) .client-logo-img {
    max-height: 24px;
    max-width: min(128px, 100%);
  }

  body:not(.wp-admin) .client-logo-fallback {
    max-width: min(128px, 100%);
    font-size: 12px;
  }
}

/* Post/resource cards should never inherit theme accent colors (pink/purple) */
.article-card .card-title,
.article-card .card-title a,
.article-card .card-title a:visited,
.featured-card h3,
.featured-card h3 a,
.featured-card h3 a:visited {
  color: #eef4fc !important;
}

.article-card .card-title a:hover,
.featured-card h3 a:hover {
  color: #ffffff !important;
}

/* Header consistency across all standalone templates */
#main-nav {
  z-index: 12000 !important;
  isolation: isolate !important;
  overflow: visible !important;
}

#main-nav .nav-inner {
  height: 72px !important;
  padding: 0 20px !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
}

@media (min-width: 768px) {
  #main-nav .nav-inner {
    padding: 0 32px !important;
  }
}

@media (min-width: 1280px) {
  #main-nav .nav-inner {
    padding: 0 56px !important;
  }
}

#main-nav .nav-logo {
  display: flex !important;
  align-items: center !important;
}

#main-nav .nav-logo img {
  height: 32px !important;
  width: auto !important;
  object-fit: contain !important;
}

#main-nav .nav-links a {
  color: #98afcc !important;
  padding: 7px 14px !important;
  border-radius: 10px !important;
}

#main-nav .nav-links a:hover,
#main-nav .nav-links a.active {
  color: #eef4fc !important;
}

#main-nav.scrolled {
  overflow: visible !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: rgba(5, 11, 24, 0.92) !important;
}

#main-nav .nav-inner,
#main-nav .nav-links,
#main-nav .nav-dropdown {
  overflow: visible !important;
}

#main-nav .nav-dropdown-menu {
  z-index: 12010 !important;
}

#main-nav .nav-toggle {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 44px !important;
  height: 44px !important;
  padding: 0 !important;
  color: #d7e0ee !important;
  background: rgba(255, 255, 255, 0.02) !important;
  border: 0 !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  -webkit-tap-highlight-color: transparent !important;
}

#main-nav .nav-toggle span {
  width: 22px !important;
  height: 2px !important;
  background: #d7e0ee !important;
}

#main-nav .nav-toggle::before,
#main-nav .nav-toggle::after {
  content: none !important;
  display: none !important;
}

#main-nav .nav-mobile {
  top: 72px !important;
  z-index: 12005 !important;
}

#main-nav .nav-cta {
  border: 1px solid rgba(246, 186, 44, 0.62) !important;
  background: transparent !important;
  color: #f6ba2c !important;
  box-shadow: none !important;
}

#main-nav .nav-cta:hover {
  background: rgba(246, 186, 44, 0.08) !important;
  border-color: rgba(246, 186, 44, 0.9) !important;
}

/* Defensive: force header CTA style even on templates with legacy/misaligned header CSS */
#main-nav .btn.btn-primary,
#main-nav a.btn.btn-primary,
#main-nav .nav-cta.btn-primary {
  background: transparent !important;
  color: #f6ba2c !important;
  border: 1px solid rgba(246, 186, 44, 0.62) !important;
  box-shadow: none !important;
}

#main-nav .btn.btn-primary:hover,
#main-nav a.btn.btn-primary:hover,
#main-nav .nav-cta.btn-primary:hover {
  background: rgba(246, 186, 44, 0.08) !important;
  border-color: rgba(246, 186, 44, 0.9) !important;
}

/* Resources/blog cards pagination button */
#articles-load-more {
  background: transparent !important;
  color: #98afcc !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  box-shadow: none !important;
}

#articles-load-more:hover {
  color: #eef4fc !important;
  border-color: rgba(255, 255, 255, 0.35) !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

#main-nav .nav-mobile-submenu {
  margin-left: 0 !important;
  padding: 6px 0 6px 12px !important;
  border-left: none !important;
  display: grid !important;
  gap: 6px !important;
}

#main-nav .nav-mobile-submenu a {
  display: block !important;
  width: 100% !important;
  white-space: normal !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 10px !important;
  background: rgba(255, 255, 255, 0.02) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

#main-nav .nav-mobile-submenu a:hover {
  border-color: rgba(255, 255, 255, 0.18) !important;
  background: rgba(255, 255, 255, 0.05) !important;
}

@media (max-width: 899px) {
  #main-nav .nav-dropdown {
    display: none !important;
  }
  #main-nav .nav-mobile {
    display: flex !important;
  }
}

@media (min-width: 900px) {
  #main-nav .nav-toggle {
    display: none !important;
  }
  #main-nav .nav-links {
    display: flex !important;
  }
  #main-nav .nav-mobile {
    display: none !important;
  }
  #main-nav .nav-cta {
    display: inline-flex !important;
  }
}

/* WP admin bar offset (avoid cropped header/logo when logged in) */
body.admin-bar #main-nav,
body.admin-bar .nav {
  top: 32px !important;
}

body.admin-bar #main-nav .nav-mobile {
  top: 104px !important; /* 32 admin bar + 72 nav */
}

@media screen and (max-width: 782px) {
  body.admin-bar #main-nav,
  body.admin-bar .nav {
    top: 46px !important;
  }

  body.admin-bar #main-nav .nav-mobile {
    top: 118px !important; /* 46 admin bar + 72 nav */
  }
}

/* Footer links: base color consistency */
.footer a,
.footer a:visited,
.footer-col a,
.footer-col a:visited,
.footer-contact a,
.footer-contact a:visited,
.footer-findmore a,
.footer-findmore a:visited {
  color: #6e86a8 !important;
}

.footer a:hover,
.footer-col a:hover,
.footer-contact a:hover,
.footer-findmore a:hover {
  color: #eef4fc !important;
}

.footer a:active,
.footer-col a:active,
.footer-contact a:active,
.footer-findmore a:active {
  color: #c0d0e4 !important;
}

/* Footer menu hover: subtle slide + soft color emphasis */
body:not(.wp-admin).outcloud-standalone .footer-col a,
body:not(.wp-admin).outcloud-standalone .footer-col a:visited {
  position: relative;
  display: inline-flex;
  align-items: center;
  text-decoration: none !important;
  transition: color 0.24s ease, transform 0.24s ease, text-shadow 0.24s ease;
}

body:not(.wp-admin).outcloud-standalone .footer-col a:hover,
body:not(.wp-admin).outcloud-standalone .footer-col a:focus-visible {
  color: #eef4fc !important;
  transform: translateX(2px);
  text-shadow: 0 0 10px rgba(168, 192, 248, 0.16);
}

body:not(.wp-admin).outcloud-standalone .footer-col a:focus-visible {
  outline: none;
}

/* Footer IA: 4 nav columns + trust badges */
body:not(.wp-admin).outcloud-standalone .footer-grid {
  grid-template-columns: 1fr !important;
}

@media (min-width: 640px) {
  body:not(.wp-admin).outcloud-standalone .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1024px) {
  body:not(.wp-admin).outcloud-standalone .footer-grid {
    grid-template-columns: minmax(260px, 2fr) repeat(4, minmax(140px, 1fr)) !important;
    gap: 32px !important;
  }
}

body:not(.wp-admin).outcloud-standalone .footer-brand .footer-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

body:not(.wp-admin).outcloud-standalone .footer-brand .footer-trust-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid rgba(246, 186, 44, 0.24);
  background: rgba(246, 186, 44, 0.08);
  color: #d8e8f4;
  font-family: "DM Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
}

/* Dropdown nav interaction hardening (avoid sticky pressed/glow states) */
#main-nav .nav-dropdown > a {
  -webkit-tap-highlight-color: transparent !important;
}

#main-nav .nav-dropdown > a:focus {
  outline: none !important;
}

#main-nav .nav-dropdown > a:focus:not(:focus-visible),
#main-nav .nav-dropdown > a:active {
  background: transparent !important;
  box-shadow: none !important;
}

#main-nav .nav-dropdown > a:focus-visible {
  outline: 2px solid rgba(246, 186, 44, 0.6) !important;
  outline-offset: 2px !important;
}

/* Touch devices can keep :hover styles after tap; neutralize them */
@media (hover: none), (pointer: coarse) {
  #main-nav .nav-links a:hover,
  #main-nav .nav-dropdown-menu a:hover,
  #main-nav .nav-mobile a:hover,
  #main-nav .nav-mobile-submenu a:hover {
    background: transparent !important;
    box-shadow: none !important;
  }
}

/* Final nav unifier: force homepage header style across all templates */
@media screen {
  body:not(.wp-admin) #main-nav.nav {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 13000 !important;
    isolation: isolate !important;
    overflow: visible !important;
    transition: background 0.3s, box-shadow 0.3s !important;
  }

  body:not(.wp-admin) #main-nav.nav.scrolled {
    background: rgba(5, 11, 24, 0.88) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.06) !important;
  }

  body:not(.wp-admin) #main-nav .nav-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 68px !important;
    max-width: 1240px !important;
    margin: 0 auto !important;
    padding: 0 24px !important;
    overflow: visible !important;
  }

  @media (min-width: 768px) {
    body:not(.wp-admin) #main-nav .nav-inner {
      padding: 0 40px !important;
    }
  }

  @media (min-width: 1280px) {
    body:not(.wp-admin) #main-nav .nav-inner {
      padding: 0 60px !important;
    }
  }

  body:not(.wp-admin) #main-nav .nav-logo {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    flex-shrink: 0 !important;
  }

  body:not(.wp-admin) #main-nav .nav-logo img {
    height: 32px !important;
    width: auto !important;
    object-fit: contain !important;
  }

  body:not(.wp-admin) #main-nav .nav-links {
    display: none !important;
    align-items: center !important;
    gap: 4px !important;
    overflow: visible !important;
  }

  body:not(.wp-admin) #main-nav .nav-links a {
    font-size: 14px !important;
    color: #98afcc !important;
    padding: 7px 14px !important;
    border-radius: 10px !important;
    transition: color 0.2s, background 0.2s !important;
    background: transparent !important;
  }

  body:not(.wp-admin) #main-nav .nav-links a:hover,
  body:not(.wp-admin) #main-nav .nav-links a.active,
  body:not(.wp-admin) #main-nav .nav-dropdown.open > a {
    color: #eef4fc !important;
    background: rgba(255, 255, 255, 0.05) !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    overflow: visible !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown > a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    -webkit-tap-highlight-color: transparent !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown > a::after {
    content: "" !important;
    width: 6px !important;
    height: 6px !important;
    border-right: 1.5px solid currentColor !important;
    border-bottom: 1.5px solid currentColor !important;
    transform: rotate(45deg) translateY(-1px) !important;
    opacity: 0.8 !important;
    transition: transform 0.24s cubic-bezier(0.22, 1, 0.36, 1) !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown.open > a::after {
    transform: rotate(225deg) translateY(-1px) !important;
    opacity: 1 !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown-menu {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: 0 !important;
    min-width: 280px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    padding: 12px !important;
    border-radius: 16px !important;
    background: rgba(8, 15, 32, 0.96) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(8px) scale(0.985) !important;
    pointer-events: none !important;
    transform-origin: top left !important;
    transition: opacity 0.26s cubic-bezier(0.22, 1, 0.36, 1), transform 0.26s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.26s !important;
    z-index: 13010 !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown.open .nav-dropdown-menu {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) scale(1) !important;
    pointer-events: auto !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown-menu a {
    font-size: 13px !important;
    padding: 11px 12px !important;
    border-radius: 10px !important;
    color: #c0d0e4 !important;
    white-space: nowrap !important;
    border-bottom: none !important;
    transition: background 0.22s, color 0.22s !important;
    background: transparent !important;
  }

  body:not(.wp-admin) #main-nav .nav-dropdown-menu a:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #eef4fc !important;
  }

  body:not(.wp-admin) #main-nav .nav-cta,
  body:not(.wp-admin) #main-nav .btn.btn-primary,
  body:not(.wp-admin) #main-nav a.btn.btn-primary {
    display: none !important;
    border: 1px solid rgba(246, 186, 44, 0.62) !important;
    background: transparent !important;
    color: #f6ba2c !important;
    box-shadow: none !important;
  }

  body:not(.wp-admin) #main-nav .nav-cta:hover,
  body:not(.wp-admin) #main-nav .btn.btn-primary:hover,
  body:not(.wp-admin) #main-nav a.btn.btn-primary:hover {
    background: rgba(246, 186, 44, 0.08) !important;
    border-color: rgba(246, 186, 44, 0.9) !important;
  }

  body:not(.wp-admin) #main-nav .nav-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: column !important;
    gap: 5px !important;
    width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    color: #d7e0ee !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border: 0 !important;
    border-radius: 10px !important;
    box-shadow: none !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
  }

  body:not(.wp-admin) #main-nav .nav-toggle span {
    width: 22px !important;
    height: 2px !important;
    background: #d7e0ee !important;
    border-radius: 2px !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile {
    position: fixed !important;
    top: 68px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    padding: 18px 24px 24px !important;
    background: rgba(8, 15, 32, 0.96) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(-8px) !important;
    transition: opacity 0.22s, transform 0.22s, visibility 0.22s !important;
    overflow-y: auto !important;
    z-index: 13005 !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile.open {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile a {
    font-size: 15px !important;
    color: #98afcc !important;
    padding: 12px 8px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile a:hover {
    color: #eef4fc !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu-toggle {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    font-size: 15px !important;
    color: #98afcc !important;
    background: transparent !important;
    border: 0 !important;
    text-align: left !important;
    padding: 12px 8px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
    cursor: pointer !important;
    transition: color 0.2s !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu-toggle:hover {
    color: #eef4fc !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu-toggle::after {
    content: "" !important;
    width: 6px !important;
    height: 6px !important;
    border-right: 1.5px solid currentColor !important;
    border-bottom: 1.5px solid currentColor !important;
    transform: rotate(45deg) !important;
    opacity: 0.8 !important;
    transition: transform 0.22s !important;
    flex-shrink: 0 !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu-toggle.open::after {
    transform: rotate(225deg) !important;
    opacity: 1 !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile .nav-cta {
    margin-top: auto !important;
    width: 100% !important;
    justify-content: center !important;
    display: inline-flex !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu {
    max-height: 0 !important;
    overflow: hidden !important;
    opacity: 0 !important;
    margin-left: 0 !important;
    padding: 6px 0 6px 12px !important;
    border-left: none !important;
    display: grid !important;
    gap: 6px !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu.open {
    max-height: 320px !important;
    opacity: 1 !important;
    margin-bottom: 4px !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu a {
    display: block !important;
    width: 100% !important;
    white-space: normal !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 10px !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
    font-size: 14px !important;
    padding: 10px 10px 10px 12px !important;
    color: #98afcc !important;
  }

  body:not(.wp-admin) #main-nav .nav-mobile-submenu a:hover {
    border-color: rgba(255, 255, 255, 0.18) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: #eef4fc !important;
  }

  @media (max-width: 899px) {
    body:not(.wp-admin) #main-nav .nav-dropdown {
      display: none !important;
    }
    body:not(.wp-admin) #main-nav .nav-mobile {
      display: flex !important;
    }
  }

@media (min-width: 900px) {
  body:not(.wp-admin) #main-nav .nav-toggle {
    display: none !important;
  }
    body:not(.wp-admin) #main-nav .nav-links {
      display: flex !important;
    }
    body:not(.wp-admin) #main-nav .nav-mobile {
      display: none !important;
    }
    body:not(.wp-admin) #main-nav .nav-cta,
    body:not(.wp-admin) #main-nav .btn.btn-primary,
    body:not(.wp-admin) #main-nav a.btn.btn-primary {
      display: inline-flex !important;
    }
  }
}

/* Mobile dropdown layering fix:
   On iOS/Safari, backdrop-filter on a scrolled fixed header can clip/stack
   the mobile menu behind page content when opening after scroll. */
@media (max-width: 899px) {
  body:not(.wp-admin) #main-nav.nav.scrolled {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body:not(.wp-admin).nav-open #main-nav.nav,
  body:not(.wp-admin).nav-open #main-nav.nav.scrolled {
    background: rgba(5, 11, 24, 0.96) !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  body:not(.wp-admin).nav-open #main-nav .nav-mobile {
    z-index: 2147483000 !important;
  }
}
