/* Phase 5E design refresh: billing switch and Blob3 footer composition.
   This file intentionally loads after Phase 5C QA overrides. */

/* Billing switch: replace the bulky pill with a tighter glass rail and true sliding indicator. */
.section.-ranks .section-header {
  justify-content: flex-start !important;
  align-items: center !important;
  margin-bottom: clamp(26px, 4vw, 48px) !important;
}

.pricing-switch {
  --billing-pad: 6px;
  --billing-radius: 24px;
  isolation: isolate !important;
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(118px, 1fr) minmax(118px, 1fr) !important;
  align-items: stretch !important;
  width: min(340px, calc(100vw - 48px)) !important;
  min-width: 0 !important;
  gap: 0 !important;
  margin: 24px 0 10px !important;
  padding: var(--billing-pad) !important;
  border-radius: calc(var(--billing-radius) + var(--billing-pad)) !important;
  border: 1px solid rgba(197, 138, 251, .26) !important;
  background:
    linear-gradient(180deg, rgba(20, 15, 47, .86), rgba(9, 8, 26, .88)) !important;
  box-shadow:
    0 18px 45px rgba(0, 0, 0, .30),
    0 0 0 1px rgba(255,255,255,.025) inset,
    0 1px 0 rgba(255,255,255,.08) inset !important;
  overflow: hidden !important;
}

.pricing-switch::after {
  content: 'Billing' !important;
  position: absolute !important;
  left: 22px !important;
  top: -21px !important;
  color: rgba(252, 251, 253, .58) !important;
  font: 800 10px/1 'Inter', system-ui, sans-serif !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
  pointer-events: none !important;
}

.pricing-switch::before {
  content: '' !important;
  position: absolute !important;
  z-index: 0 !important;
  top: var(--billing-pad) !important;
  bottom: var(--billing-pad) !important;
  left: var(--billing-pad) !important;
  width: calc((100% - (var(--billing-pad) * 2)) / 2) !important;
  border-radius: var(--billing-radius) !important;
  background:
    radial-gradient(circle at 24% 0%, rgba(255, 255, 255, .30), transparent 36%),
    linear-gradient(135deg, #7B3AF0 0%, #A94CFF 54%, #C58AFB 100%) !important;
  box-shadow:
    0 12px 26px rgba(123, 58, 240, .42),
    0 0 28px rgba(197, 138, 251, .24),
    inset 0 1px 0 rgba(255, 255, 255, .25) !important;
  transform: translateX(0) !important;
  transition: transform .28s cubic-bezier(.2,.85,.2,1), box-shadow .2s ease !important;
  pointer-events: none !important;
}

.pricing-switch:has(.pricing-switch-option.-lifetime.-selected)::before,
.pricing-switch:has(.pricing-switch-option.-lifetime[aria-pressed="true"])::before {
  transform: translateX(100%) !important;
}

.pricing-switch-option {
  position: relative !important;
  z-index: 1 !important;
  min-height: 58px !important;
  margin: 0 !important;
  padding: 10px 16px 9px !important;
  border-radius: var(--billing-radius) !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(252, 251, 253, .62) !important;
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 4px !important;
  font-family: 'Montserrat', 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: -.015em !important;
  text-align: center !important;
  text-shadow: none !important;
  transform: none !important;
}

.pricing-switch-option::after {
  display: block !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: .115em !important;
  text-transform: uppercase !important;
  color: rgba(252, 251, 253, .44) !important;
}

.pricing-switch-option.-monthly::after { content: 'Recurring' !important; }
.pricing-switch-option.-lifetime::after { content: 'One-time' !important; }

.pricing-switch-option.-selected,
.pricing-switch-option[aria-pressed="true"] {
  background: transparent !important;
  box-shadow: none !important;
  color: #fff !important;
  transform: none !important;
}

.pricing-switch-option.-selected::after,
.pricing-switch-option[aria-pressed="true"]::after {
  color: rgba(255, 255, 255, .76) !important;
}

.pricing-switch-option:not(.-selected):hover,
.pricing-switch-option[aria-pressed="false"]:hover {
  color: rgba(252, 251, 253, .88) !important;
  background: rgba(255, 255, 255, .045) !important;
}

.pricing-switch-option:focus-visible {
  outline: 3px solid rgba(197, 138, 251, .46) !important;
  outline-offset: 3px !important;
}

@supports not selector(:has(*)) {
  .pricing-switch-option.-selected,
  .pricing-switch-option[aria-pressed="true"] {
    background: linear-gradient(135deg, #7B3AF0, #C58AFB) !important;
    box-shadow: 0 12px 26px rgba(123, 58, 240, .34) !important;
  }
}

/* Footer: compact bottom-right overlay that sits on Blob3 instead of becoming a giant pink/light card. */
.main-footer {
  position: relative !important;
  z-index: 5 !important;
  width: min(430px, calc(100% - 42px)) !important;
  margin: clamp(44px, 7vw, 92px) clamp(22px, 7vw, 112px) 28px auto !important;
  padding: 18px 18px 16px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  text-align: right !important;
  border: 1px solid rgba(197, 138, 251, .30) !important;
  border-radius: 26px !important;
  background:
    linear-gradient(180deg, rgba(18, 12, 44, .70), rgba(11, 9, 28, .66)) !important;
  color: #FCFBFD !important;
  box-shadow:
    0 24px 64px rgba(0, 0, 0, .32),
    0 0 44px rgba(197, 138, 251, .18),
    inset 0 1px 0 rgba(255, 255, 255, .08) !important;
  backdrop-filter: blur(14px) saturate(1.18) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.18) !important;
  content-visibility: visible !important;
  contain-intrinsic-size: auto !important;
}

.main-footer::before {
  content: '' !important;
  position: absolute !important;
  inset: -28px -34px -42px -18px !important;
  z-index: -1 !important;
  border-radius: 34px !important;
  background:
    radial-gradient(circle at 82% 82%, rgba(226, 115, 255, .30), transparent 46%),
    radial-gradient(circle at 10% 0%, rgba(123, 58, 240, .16), transparent 42%) !important;
  pointer-events: none !important;
}

.main-footer .footer-title,
.footer-title {
  margin: 0 0 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 34px !important;
  padding: 7px 13px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(197, 138, 251, .26) !important;
  background: rgba(255, 255, 255, .07) !important;
  color: #fff !important;
  font-family: var(--font-heading, 'Montserrat', 'Inter', sans-serif) !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: .035em !important;
  text-transform: none !important;
}

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

.main-footer .footer-nav-item,
.footer-nav-item {
  position: relative !important;
  min-height: 36px !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(197, 138, 251, .26) !important;
  background: rgba(123, 58, 240, .16) !important;
  color: rgba(252, 251, 253, .88) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .035em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

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

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

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

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

/* Keep Blob3 visibly underneath the footer, lower and less intrusive. */
.bg.-desktop {
  pointer-events: none !important;
  overflow: hidden !important;
}

.bg.-desktop .blobs .blob-3,
.bg.-desktop .blob-3,
.blobs .blob-3 {
  right: max(-150px, -8vw) !important;
  bottom: max(-170px, -12vw) !important;
  width: clamp(430px, 48vw, 780px) !important;
  opacity: .60 !important;
  transform: none !important;
}

.bg.-desktop .blobs .blob-1,
.bg.-desktop .blob-1 { opacity: .34 !important; }
.bg.-desktop .blobs .blob-2,
.bg.-desktop .blob-2 { opacity: .32 !important; }

/* Cart/footer composition: keep the footer attached to the bottom-right Blob3 without covering the cart panel. */
.page.-cart .main-footer,
main:has(.cart-layout) .main-footer,
body:has(.cart-layout) .main-footer {
  margin-top: clamp(34px, 6vw, 72px) !important;
}

/* Mobile footer: no giant light panel; keep compact, centered, and dark. */
@media screen and (max-width: 840px) {
  .section.-ranks .section-header {
    justify-content: center !important;
    margin-bottom: 20px !important;
  }
  .pricing-switch {
    width: min(360px, calc(100vw - 32px)) !important;
    margin: 6px auto 0 !important;
    padding: 5px !important;
  }
  .pricing-switch::after {
    left: 16px !important;
    top: -18px !important;
    font-size: 9px !important;
  }
  .pricing-switch-option {
    min-height: 52px !important;
    padding: 9px 10px !important;
    font-size: 14px !important;
  }
  .pricing-switch-option::after {
    font-size: 8.5px !important;
    letter-spacing: .09em !important;
  }

  .main-footer {
    width: min(390px, calc(100% - 28px)) !important;
    margin: 34px auto 18px !important;
    padding: 18px 14px 16px !important;
    align-items: center !important;
    text-align: center !important;
    border-radius: 24px !important;
  }
  .main-footer .footer-title,
  .footer-title {
    font-size: 17px !important;
  }
  .main-footer .footer-nav,
  .footer-nav {
    justify-content: center !important;
    gap: 7px !important;
  }
  .main-footer .footer-nav-item,
  .footer-nav-item {
    width: auto !important;
    max-width: none !important;
    min-height: 35px !important;
    padding: 8px 11px !important;
    font-size: 11px !important;
  }
  .main-footer .footer-copy,
  .footer-copy {
    font-size: 11px !important;
  }
}

@media screen and (max-width: 430px) {
  .pricing-switch {
    width: min(330px, calc(100vw - 26px)) !important;
  }
  .pricing-switch-option {
    font-size: 13px !important;
  }
  .main-footer .footer-nav,
  .footer-nav {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
  }
  .main-footer .footer-nav-item,
  .footer-nav-item {
    width: 100% !important;
  }
}
