/* Phase 5L footer sanity reset.
   The Phase 5K blob became a giant pink wall. This brings Blob3 back to a footer accent:
   smaller, lower, and only covering the bottom-right content area. */

.main-footer,
.main-footer.legal-footer {
  min-height: clamp(420px, 28vw, 540px) !important;
  margin-top: clamp(56px, 5vw, 112px) !important;
  overflow: hidden !important;
  background: transparent !important;
}

.main-footer .footer-blob3,
.main-footer.legal-footer .footer-blob3,
.footer-blob3 {
  display: block !important;
  position: absolute !important;
  z-index: 0 !important;
  width: clamp(1180px, 62vw, 1580px) !important;
  max-width: none !important;
  height: auto !important;
  right: clamp(-360px, -11vw, -210px) !important;
  bottom: clamp(-520px, -22vw, -330px) !important;
  opacity: .97 !important;
  transform: rotate(-1deg) scale(1) !important;
  transform-origin: 68% 74% !important;
  pointer-events: none !important;
  user-select: none !important;
  filter: drop-shadow(0 -18px 46px rgba(205, 91, 255, .18)) !important;
}

.main-footer .footer-title,
.main-footer.legal-footer .footer-title,
.footer-title {
  z-index: 3 !important;
  right: clamp(44px, 5.2vw, 126px) !important;
  bottom: clamp(154px, 9vw, 210px) !important;
  width: min(430px, 30vw) !important;
  font-size: clamp(25px, 1.9vw, 38px) !important;
  line-height: 1 !important;
  text-align: center !important;
}

.main-footer .footer-tagline,
.main-footer.legal-footer .footer-tagline,
.footer-tagline {
  z-index: 3 !important;
  right: clamp(44px, 5.2vw, 126px) !important;
  bottom: clamp(118px, 7.1vw, 164px) !important;
  width: min(430px, 30vw) !important;
  font-size: clamp(13px, .92vw, 17px) !important;
  line-height: 1.2 !important;
  text-align: center !important;
}

.main-footer .footer-nav,
.main-footer.legal-footer .footer-nav,
.footer-nav {
  z-index: 3 !important;
  right: clamp(34px, 4.2vw, 108px) !important;
  bottom: clamp(66px, 4.6vw, 108px) !important;
  width: min(520px, 36vw) !important;
  gap: clamp(9px, .8vw, 16px) !important;
}

.main-footer .footer-nav-item,
.main-footer.legal-footer .footer-nav-item,
.footer-nav-item {
  min-height: 38px !important;
  padding: 8px clamp(13px, 1vw, 19px) !important;
  font-size: clamp(12px, .78vw, 15px) !important;
  border-width: 1.5px !important;
}

.main-footer .footer-nav-item::before,
.main-footer.legal-footer .footer-nav-item::before,
.footer-nav-item::before {
  width: 17px !important;
  height: 17px !important;
  font-size: 17px !important;
}

.main-footer .footer-copy,
.main-footer.legal-footer .footer-copy,
.footer-copy {
  z-index: 3 !important;
  right: clamp(44px, 5.2vw, 126px) !important;
  bottom: clamp(28px, 2.35vw, 52px) !important;
  width: min(430px, 30vw) !important;
  font-size: clamp(11px, .75vw, 14px) !important;
  line-height: 1.25 !important;
  text-align: center !important;
}

@media (max-width: 1180px) {
  .main-footer,
  .main-footer.legal-footer {
    min-height: clamp(420px, 52vw, 560px) !important;
    margin-top: clamp(50px, 7vw, 96px) !important;
  }

  .main-footer .footer-blob3,
  .main-footer.legal-footer .footer-blob3,
  .footer-blob3 {
    width: clamp(980px, 120vw, 1380px) !important;
    right: clamp(-610px, -48vw, -340px) !important;
    bottom: clamp(-430px, -34vw, -300px) !important;
  }

  .main-footer .footer-title,
  .main-footer .footer-tagline,
  .main-footer .footer-copy,
  .main-footer.legal-footer .footer-title,
  .main-footer.legal-footer .footer-tagline,
  .main-footer.legal-footer .footer-copy,
  .footer-title,
  .footer-tagline,
  .footer-copy {
    right: clamp(22px, 4vw, 64px) !important;
    width: min(390px, 44vw) !important;
  }

  .main-footer .footer-nav,
  .main-footer.legal-footer .footer-nav,
  .footer-nav {
    right: clamp(16px, 3vw, 52px) !important;
    width: min(440px, 50vw) !important;
  }
}

@media (max-width: 840px) {
  .main-footer,
  .main-footer.legal-footer {
    min-height: 455px !important;
    margin-top: 58px !important;
  }

  .main-footer .footer-blob3,
  .main-footer.legal-footer .footer-blob3,
  .footer-blob3 {
    width: 1040px !important;
    right: -570px !important;
    bottom: -318px !important;
    transform: rotate(-1deg) scale(1) !important;
  }

  .main-footer .footer-title,
  .main-footer.legal-footer .footer-title,
  .footer-title {
    right: 16px !important;
    bottom: 208px !important;
    width: min(360px, calc(100vw - 32px)) !important;
    font-size: 26px !important;
  }

  .main-footer .footer-tagline,
  .main-footer.legal-footer .footer-tagline,
  .footer-tagline {
    right: 16px !important;
    bottom: 176px !important;
    width: min(360px, calc(100vw - 32px)) !important;
    font-size: 14px !important;
  }

  .main-footer .footer-nav,
  .main-footer.legal-footer .footer-nav,
  .footer-nav {
    right: 16px !important;
    bottom: 88px !important;
    width: min(360px, calc(100vw - 32px)) !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 9px !important;
  }

  .main-footer .footer-copy,
  .main-footer.legal-footer .footer-copy,
  .footer-copy {
    right: 16px !important;
    bottom: 42px !important;
    width: min(360px, calc(100vw - 32px)) !important;
    font-size: 12px !important;
  }
}
