/*
  Dodo Tradez final responsive layer

  Desktop:
  Full nav visible.
  Hero buttons can sit over the hero image.

  Tablet and phone:
  Hamburger menu.
  Hero buttons sit below the hero image.
  Hero image remains fully visible.
*/

/* Base nav reset */
.site-nav {
  position: relative !important;
  min-height: 78px !important;
  height: auto !important;
  padding: 18px 38px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 22px !important;
  background: #000000 !important;
  border-bottom: 1px solid rgba(255,255,255,.10) !important;
  z-index: 1000 !important;
}

.site-nav .brand {
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

.desktop-nav {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 26px !important;
}

.desktop-nav a {
  color: #ffffff !important;
  text-decoration: none !important;
}

.desktop-nav .top-cta {
  min-width: 210px !important;
  min-height: 52px !important;
  padding: 0 28px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: #ff165d !important;
  color: #ffffff !important;
  font-weight: 900 !important;
}

.nav-toggle {
  display: none !important;
  width: 48px !important;
  height: 44px !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.05) !important;
  cursor: pointer !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: column !important;
  gap: 5px !important;
  padding: 0 !important;
}

.nav-toggle span {
  width: 22px !important;
  height: 2px !important;
  display: block !important;
  background: #ffffff !important;
  border-radius: 999px !important;
}

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

/* Hero base */
.hero {
  position: relative !important;
}

/* Tablet and below */
@media (max-width: 1180px) {
  .site-nav {
    padding: 16px 28px !important;
  }

  .desktop-nav {
    display: none !important;
  }

  .nav-toggle {
    display: inline-flex !important;
  }

  .mobile-menu {
    position: absolute !important;
    left: 18px !important;
    right: 18px !important;
    top: calc(100% + 10px) !important;

    display: none !important;
    flex-direction: column !important;
    gap: 10px !important;

    padding: 16px !important;
    border: 1px solid rgba(255,255,255,.14) !important;
    border-radius: 18px !important;
    background: rgba(0,0,0,.96) !important;
    box-shadow: 0 22px 60px rgba(0,0,0,.45) !important;
    z-index: 2000 !important;
  }

  .mobile-menu.is-open {
    display: flex !important;
  }

  .mobile-menu a {
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
    color: #ffffff !important;
    text-decoration: none !important;
    font-weight: 800 !important;
  }

  .mobile-menu a:hover {
    background: rgba(255,255,255,.08) !important;
  }

  .mobile-menu .mobile-cta {
    margin-top: 4px !important;
    background: #ff165d !important;
    color: #ffffff !important;
    border-radius: 999px !important;
  }

  .hero {
    overflow: visible !important;
    padding-bottom: 34px !important;
  }

  .hero-img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .hero-buttons {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    transform: none !important;

    width: auto !important;
    max-width: none !important;
    margin: 18px 28px 0 !important;
    padding: 0 !important;

    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 14px !important;

    z-index: 20 !important;
    pointer-events: auto !important;
  }

  .hero-buttons .btn {
    width: auto !important;
    min-width: 220px !important;
    max-width: none !important;
    min-height: 52px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;

    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    white-space: nowrap !important;
    pointer-events: auto !important;
  }
}

/* Phone */
@media (max-width: 720px) {
  .site-nav {
    min-height: 72px !important;
    padding: 14px 18px !important;
  }

  .site-nav .brand {
    font-size: 15px !important;
    letter-spacing: .18em !important;
  }

  .mobile-menu {
    left: 14px !important;
    right: 14px !important;
  }

  .hero {
    padding-bottom: 38px !important;
  }

  .hero-buttons {
    margin: 16px 18px 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: center !important;
    gap: 12px !important;
  }

  .hero-buttons .btn {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 52px !important;
  }
}

/* Very small phone */
@media (max-width: 430px) {
  .site-nav {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .site-nav .brand {
    font-size: 13px !important;
    letter-spacing: .16em !important;
  }

  .nav-toggle {
    width: 44px !important;
    height: 42px !important;
  }

  .hero-img {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .hero-buttons {
    margin-left: 14px !important;
    margin-right: 14px !important;
  }
}

/* Final hamburger position fix
   On tablet and phone, keep brand on the left and hamburger fixed on the right.
*/

@media (max-width: 1180px) {
  .site-nav {
    position: relative !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
  }

  .site-nav .brand {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    max-width: calc(100% - 64px) !important;
    justify-content: flex-start !important;
    text-align: left !important;
    white-space: nowrap !important;
    overflow: hidden !important;
  }

  .nav-toggle {
    position: relative !important;
    margin-left: auto !important;
    margin-right: 0 !important;
    flex: 0 0 48px !important;
    display: inline-flex !important;
  }

  .mobile-menu {
    left: 18px !important;
    right: 18px !important;
    top: calc(100% + 10px) !important;
  }
}

@media (max-width: 720px) {
  .site-nav {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 14px 18px !important;
  }

  .site-nav .brand {
    width: auto !important;
    max-width: calc(100% - 62px) !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  .nav-toggle {
    margin-left: auto !important;
    margin-right: 0 !important;
    flex: 0 0 46px !important;
  }
}

@media (max-width: 430px) {
  .site-nav {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .site-nav .brand {
    max-width: calc(100% - 58px) !important;
  }

  .nav-toggle {
    width: 44px !important;
    height: 42px !important;
    flex: 0 0 44px !important;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}
