/* =========================================================
   Beach Bums clean nav + sticky footer fix
   Fixes the double-bar look by making only the header itself
   the dark rounded pill and leaving the inner container clear.
   ========================================================= */

html,
body {
  min-height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1 0 auto;
}

.footer,
footer {
  flex-shrink: 0;
  margin-top: auto;
}

/* Desktop floating pill nav */
header.nav,
.nav {
  position: fixed !important;
  top: 16px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  width: min(calc(100% - 32px), 1180px) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  z-index: 9999 !important;
  overflow: visible !important;
  background: rgba(6, 25, 42, 0.92) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 999px !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.28) !important;
  backdrop-filter: blur(18px) saturate(135%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(135%) !important;
}

header.nav .container,
header.nav .nav-inner,
.nav .container,
.nav .nav-inner {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-radius: inherit !important;
  width: 100% !important;
  max-width: none !important;
  min-height: 72px !important;
  padding: 10px 22px !important;
}

header.nav .brand img,
.nav .brand img {
  width: 52px !important;
  height: 52px !important;
}

header.nav .nav-links a,
.nav .nav-links a {
  border-radius: 999px !important;
}

header.nav .nav-links a.active,
.nav .nav-links a.active {
  background: rgba(43, 197, 216, .18) !important;
  color: #fff !important;
}

header.nav .nav-cta .btn,
.nav .nav-cta .btn {
  white-space: nowrap;
}

.nav + *,
header.nav + * {
  margin-top: 118px;
}

.nav + .hero,
header.nav + .hero {
  margin-top: 0;
  padding-top: 118px;
}

/* Address page: keep the map/results hidden until a real address result is ready */
body.address-page:not(.is-day-flow):not(.has-address-results) #resultsWrap {
  display: none !important;
}

body.address-page:not(.is-day-flow):not(.has-address-results) .order-wrap {
  min-height: calc(100vh - 240px);
}

body.address-page .order-wrap {
  padding-bottom: 42px;
}

body.address-page #addressSection {
  border-radius: 26px !important;
}

/* Mobile nav stays clean, but not double-layered */
@media (max-width: 768px) {
  header.nav,
  .nav {
    top: 12px !important;
    left: 14px !important;
    right: 14px !important;
    transform: none !important;
    width: auto !important;
    max-width: none !important;
    border-radius: 24px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  header.nav .container,
  header.nav .nav-inner,
  .nav .container,
  .nav .nav-inner {
    min-height: 76px !important;
    border-radius: 24px !important;
    background: rgba(6, 25, 42, .94) !important;
    border: 1px solid rgba(255,255,255,.16) !important;
    box-shadow: 0 16px 36px rgba(0,0,0,.26) !important;
    backdrop-filter: blur(16px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(16px) saturate(130%) !important;
  }

  .nav + *,
  header.nav + * {
    margin-top: 108px;
  }

  .nav + .hero,
  header.nav + .hero {
    padding-top: 108px;
  }
}

/* =========================================================
   PHONE HEADER FLOW FIX
   Mobile header now sits in the page flow instead of fixed on
   top of content. This stops it from covering hero/pricing/blog
   sections and makes the phone view feel cleaner.
   ========================================================= */
@media (max-width: 768px) {
  html, body {
    width: 100% !important;
    overflow-x: hidden !important;
  }

  body {
    padding-top: 0 !important;
  }

  header.nav,
  .nav {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    width: calc(100% - 24px) !important;
    max-width: none !important;
    margin: 10px auto 14px !important;
    padding: 0 !important;
    z-index: 50 !important;
    border-radius: 24px !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  header.nav .container,
  header.nav .nav-inner,
  .nav .container,
  .nav .nav-inner {
    min-height: 74px !important;
    padding: 12px 14px !important;
    border-radius: 24px !important;
    background: rgba(6, 25, 42, .96) !important;
    border: 1px solid rgba(255, 255, 255, .16) !important;
    box-shadow: 0 10px 26px rgba(0, 0, 0, .22) !important;
  }

  header.nav .brand img,
  .nav .brand img {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
  }

  header.nav .brand h1,
  header.nav .brand strong,
  header.nav .brand .brand-title,
  header.nav .brand > div > div:first-child,
  .nav .brand h1,
  .nav .brand strong,
  .nav .brand .brand-title,
  .nav .brand > div > div:first-child {
    font-size: 18px !important;
    line-height: 1.05 !important;
  }

  header.nav .brand span,
  header.nav .brand small,
  header.nav .brand .brand-subtitle,
  header.nav .brand .muted,
  .nav .brand span,
  .nav .brand small,
  .nav .brand .brand-subtitle,
  .nav .brand .muted {
    font-size: 12px !important;
    line-height: 1.15 !important;
  }

  header.nav .mobile-toggle,
  header.nav .hamburger,
  header.nav .menu-toggle,
  header.nav .nav-toggle {
    width: 44px !important;
    height: 44px !important;
    border-radius: 14px !important;
  }

  .nav + *,
  header.nav + *,
  .nav + .hero,
  header.nav + .hero,
  .nav + .page-hero,
  header.nav + .page-hero {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  .hero {
    min-height: auto !important;
    padding: 22px 0 34px !important;
  }

  .page-hero {
    padding-top: 8px !important;
  }

  .page-hero-card {
    margin-top: 0 !important;
  }

  /* Keep opened mobile menu below the header, not over the logo */
  header.nav .nav-links {
    top: calc(100% + 10px) !important;
    z-index: 60 !important;
  }
}
