/* Custom overrides on top of Webflow CSS */

/* ============================================
   INLINE NAVIGATION BAR (replaces dropdown)
   ============================================ */

/* Nav wrapper z-index applies everywhere */
.nav-wrapper {
  z-index: 100 !important;
}

/* ============================================
   DESKTOP-ONLY OVERRIDES (>= 769px)
   ============================================ */

@media screen and (min-width: 769px) {
  .nav-wrapper {
    margin-top: 0 !important;
    padding: 0.5rem 0 !important;
    position: absolute !important;
    inset: 0% 0% auto !important;
  }

  .navbar-container-wrapper {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    align-items: center;
  }

  .navbar-component-grid {
    grid-template: none !important;
    grid-template-columns: auto 1fr !important;
    grid-template-rows: auto !important;
    align-items: center !important;
    gap: 2rem !important;
  }

  .navbar-component-grid > .link-block {
    grid-area: 1 / 1 / 2 / 2 !important;
    align-self: center !important;
  }

  .navbar-component-grid > .navbar {
    grid-area: 1 / 2 / 2 / 3 !important;
    align-self: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
  }

  .image-6 {
    width: 220px !important;
    margin-top: 0 !important;
    margin-left: 0 !important;
  }

  .link-block,
  .link-block.w--current {
    width: auto !important;
  }

  .navbar {
    position: static !important;
    padding-bottom: 0 !important;
    padding-top: 0 !important;
    background: transparent !important;
    width: 100% !important;
  }

  .nav-inner-grid .link-button,
  .nav-inner-grid .link-button.w--current {
    height: auto !important;
    margin-bottom: 0 !important;
    margin-top: 0 !important;
    overflow: visible !important;
  }

  .navbar .nav-menu {
    display: flex !important;
    position: static !important;
    background: transparent !important;
    padding: 0 !important;
    overflow: visible !important;
    height: auto !important;
    width: auto !important;
  }

  .navbar-content-wrapper {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }

  .nav-inner-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.25rem 1.5rem !important;
    align-items: center !important;
    justify-content: flex-end !important;
  }

  .nav-inner-grid > .link-button {
    grid-area: unset !important;
  }

  .nav-inner-grid .link-flex {
    gap: 0.25rem;
  }

  .nav-inner-grid .arrow-item {
    display: none !important;
  }

  .nav-inner-grid .link-text-wrapper {
    height: auto !important;
    overflow: visible !important;
  }

  .nav-inner-grid .link-text {
    font-size: 1.15rem !important;
    text-transform: none !important;
    font-family: 'Poppins', sans-serif !important;
    font-weight: 500 !important;
  }

  .nav-inner-grid .link-text-wrapper .link-text:nth-child(2) {
    display: none !important;
  }

  .nav-inner-grid .link-text-wrapper,
  .nav-inner-grid .link-flex,
  .nav-inner-grid .link-button {
    transform: none !important;
    transition: none !important;
  }

  .nav-inner-grid .link-button:hover {
    opacity: 0.7;
  }

  .menu-button {
    display: none !important;
  }

  ._3d-container {
    margin-top: 0 !important;
    transform: scale(0.85) !important;
  }

  .main-wrapper {
    padding-top: 5rem !important;
  }

  .body .main-wrapper {
    padding-top: 0 !important;
  }
}




/* ============================================
   HERO BUTTONS
   ============================================ */

/* Even spacing for 2 hero buttons */
.button-wrapper {
  gap: 1rem;
}

/* Fix Our Services button */
.medium-main-button {
  width: auto !important;
  justify-content: center !important;
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
  margin-right: 0 !important;
}

.medium-main-button .text-button {
  margin-right: 0 !important;
  align-self: center !important;
}

/* ============================================
   PARTNER LOGOS
   ============================================ */

.partner-logo {
  max-width: 12.5rem;
  height: auto;
}

.partner-grid-wrapper > .text-size-regular {
  font-size: 1.1rem;
}

.partner-component-grid {
  gap: 1.5rem !important;
}

/* ============================================
   LOGO DECORATIONS (scattered throughout site)
   ============================================ */

.logo-decoration {
  display: block;
  margin: 0 auto;
  opacity: 1;
  max-width: 350px;
  height: auto;
  padding: 1rem 0;
}

.logo-decoration.left {
  margin-left: 10%;
  margin-right: auto;
}

.logo-decoration.right {
  margin-right: 10%;
  margin-left: auto;
}

/* ============================================
   SPACING FIXES
   ============================================ */

/* Space between navbar and hero content */
.section-home-header {
  padding-top: 1rem !important;
}

/* Reduce oversized spacers */
.spacer-huge {
  height: 3rem !important;
}




/* ============================================
   MOBILE RESPONSIVE (<= 768px)
   Only undo desktop nav customizations.
   Let Webflow handle everything else.
   ============================================ */

@media screen and (max-width: 768px) {
  /* Mobile menu open state */
  .w-nav-button.w--open ~ .nav-menu,
  .menu-button.w--open ~ .nav-menu {
    display: block !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    background: #fff !important;
    border: 4px solid var(--black) !important;
    border-radius: 18px !important;
    padding: 1rem !important;
    box-shadow: 3px 3px 0 0 var(--black) !important;
    z-index: 100 !important;
  }

  .w--open ~ .nav-menu .nav-inner-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.75rem !important;
  }

  .w--open ~ .nav-menu .arrow-item {
    display: block !important;
  }

  .w--open ~ .nav-menu .link-text-wrapper .link-text:nth-child(2) {
    display: block !important;
  }

  .w--open ~ .nav-menu .link-text-wrapper,
  .w--open ~ .nav-menu .link-flex,
  .w--open ~ .nav-menu .link-button {
    transform: unset !important;
    transition: unset !important;
  }

  /* Hide footer logo on mobile */
  .footer-logo-decoration {
    display: none !important;
  }

  /* Hide decorative logo on mobile */
  .logo-decoration {
    display: none !important;
  }
}


