/* Phase 5F footer lock: explicit Blob3 composition and bottom-right footer placement.
   This file intentionally loads last so the footer cannot fall back to the old centered/light-mode layout. */

:root {
  --myteria-footer-card: rgba(12, 10, 30, .74);
  --myteria-footer-card-strong: rgba(18, 12, 44, .88);
  --myteria-footer-border: rgba(197, 138, 251, .34);
  --myteria-footer-link: rgba(252, 251, 253, .90);
}

/* The legacy decorative background blob is unreliable because some page sections clip or layer over it.
   The footer now owns its own Blob3 image, so hide only the old background copy of Blob3. */
.bg.-desktop .blobs > .blob-3 {
  display: none !important;
}

.main-footer,
.main-footer.legal-footer {
  position: relative !important;
  isolation: isolate !important;
  z-index: 20 !important;
  overflow: visible !important;
  width: min(520px, calc(100vw - 48px)) !important;
  max-width: 520px !important;
  min-height: auto !important;
  margin: clamp(70px, 8vw, 132px) clamp(28px, 6vw, 116px) 34px auto !important;
  padding: 24px 26px 22px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  text-align: right !important;
  border: 1px solid var(--myteria-footer-border) !important;
  border-radius: 28px !important;
  background:
    linear-gradient(180deg, var(--myteria-footer-card-strong), var(--myteria-footer-card)) !important;
  color: #FCFBFD !important;
  box-shadow:
    0 30px 80px rgba(0, 0, 0, .40),
    0 0 56px rgba(170, 82, 255, .22),
    inset 0 1px 0 rgba(255, 255, 255, .08) !important;
  backdrop-filter: blur(18px) saturate(1.20) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.20) !important;
  content-visibility: visible !important;
  contain: none !important;
  contain-intrinsic-size: auto !important;
}

.main-footer::before,
.main-footer.legal-footer::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  border-radius: inherit !important;
  background:
    radial-gradient(circle at 92% 100%, rgba(231, 126, 255, .24), transparent 46%),
    radial-gradient(circle at 0 0, rgba(123, 58, 240, .16), transparent 42%) !important;
  pointer-events: none !important;
}

.main-footer::after,
.main-footer.legal-footer::after {
  content: '' !important;
  position: absolute !important;
  right: -18px !important;
  bottom: -18px !important;
  width: 72% !important;
  height: 44% !important;
  z-index: -2 !important;
  border-radius: 999px !important;
  background: radial-gradient(ellipse at center, rgba(209, 92, 255, .32), transparent 68%) !important;
  filter: blur(8px) !important;
  pointer-events: none !important;
}

.footer-blob3 {
  display: block !important;
  position: absolute !important;
  right: clamp(-160px, -8vw, -72px) !important;
  bottom: clamp(-190px, -11vw, -92px) !important;
  z-index: -3 !important;
  width: clamp(460px, 52vw, 820px) !important;
  max-width: none !important;
  height: auto !important;
  opacity: .86 !important;
  transform: rotate(-1deg) !important;
  pointer-events: none !important;
  user-select: none !important;
}

.main-footer .footer-title,
.main-footer.legal-footer .footer-title,
.footer-title {
  margin: 0 0 14px !important;
  padding: 0 !important;
  min-height: 0 !important;
  display: block !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #fff !important;
  font-family: var(--font-heading, 'Montserrat', 'Inter', sans-serif) !important;
  font-size: 22px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .015em !important;
  text-transform: none !important;
  text-shadow: 0 0 22px rgba(197, 138, 251, .32) !important;
}

.main-footer .footer-nav,
.main-footer.legal-footer .footer-nav,
.footer-nav {
  width: auto !important;
  max-width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
  gap: 9px !important;
  margin: 0 !important;
}

.main-footer .footer-nav-item,
.main-footer.legal-footer .footer-nav-item,
.footer-nav-item {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 38px !important;
  width: auto !important;
  max-width: none !important;
  padding: 9px 13px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(197, 138, 251, .36) !important;
  background: rgba(123, 58, 240, .20) !important;
  color: var(--myteria-footer-link) !important;
  font-family: var(--font-heading, 'Montserrat', 'Inter', sans-serif) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: .035em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08) !important;
}

.main-footer .footer-nav-item::after,
.main-footer.legal-footer .footer-nav-item::after,
.footer-nav-item::after {
  content: '→' !important;
  display: inline-block !important;
  margin-left: 7px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  opacity: .78 !important;
  transform: translateY(-1px) !important;
}

.main-footer .footer-nav-item[href^="http"]::after,
.main-footer.legal-footer .footer-nav-item[href^="http"]::after,
.footer-nav-item[href^="http"]::after {
  content: '↗' !important;
}

.main-footer .footer-nav-item:hover,
.main-footer .footer-nav-item:focus-visible,
.main-footer.legal-footer .footer-nav-item:hover,
.main-footer.legal-footer .footer-nav-item:focus-visible,
.footer-nav-item:hover,
.footer-nav-item:focus-visible {
  transform: translateY(-2px) !important;
  background: rgba(197, 138, 251, .28) !important;
  border-color: rgba(226, 185, 255, .68) !important;
  color: #fff !important;
  box-shadow:
    0 13px 26px rgba(123, 58, 240, .24),
    inset 0 1px 0 rgba(255, 255, 255, .12) !important;
  outline: none !important;
}

.main-footer .footer-copy,
.main-footer.legal-footer .footer-copy,
.footer-copy {
  margin: 14px 0 0 !important;
  color: rgba(252, 251, 253, .72) !important;
  font-family: var(--font-body, 'Inter', sans-serif) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
}

/* Cart page: push the footer low enough that Blob3 sits behind the footer, not behind the cart panel. */
.page.-cart .main-footer,
body:has(.cart-layout) .main-footer {
  margin-top: clamp(72px, 9vw, 138px) !important;
}

@media screen and (max-width: 840px) {
  .main-footer,
  .main-footer.legal-footer {
    width: min(410px, calc(100vw - 30px)) !important;
    margin: 56px auto 24px !important;
    padding: 22px 18px 20px !important;
    align-items: center !important;
    text-align: center !important;
    border-radius: 26px !important;
  }

  .footer-blob3 {
    right: 50% !important;
    bottom: -165px !important;
    width: clamp(440px, 120vw, 620px) !important;
    transform: translateX(54%) rotate(-1deg) !important;
    opacity: .72 !important;
  }

  .main-footer .footer-title,
  .footer-title {
    font-size: 21px !important;
    margin-bottom: 14px !important;
  }

  .main-footer .footer-nav,
  .footer-nav {
    justify-content: center !important;
    gap: 8px !important;
  }

  .main-footer .footer-nav-item,
  .footer-nav-item {
    min-height: 38px !important;
    padding: 9px 12px !important;
    font-size: 11px !important;
  }
}

@media screen and (max-width: 430px) {
  .main-footer,
  .main-footer.legal-footer {
    width: calc(100vw - 24px) !important;
    padding: 20px 14px 18px !important;
  }

  .main-footer .footer-nav,
  .footer-nav {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .main-footer .footer-nav-item,
  .footer-nav-item {
    width: 100% !important;
  }
}
