/* Phase 5R - Live service production frontend polish
   Final override layer for the Wrangler/Pages storefront.
   Goals:
   - Remove placeholder-feeling UI/copy artifacts.
   - Keep the original Myteria shell: dark party background, scrolling blobs/party art, simple header/footer.
   - Remove cart shortcut icons from header/mobile while keeping Cart text navigation.
   - Make legal pages feel like first-class Myteria pages, not generic policy dumps.
   - Improve Safari/mobile scaling without re-enabling the legacy React runtime. */

:root {
  --mt-bg-deep: #1f0734;
  --mt-bg: #2a0a43;
  --mt-pink: #fa5bc7;
  --mt-purple: #7b3af0;
  --mt-purple-soft: #ac7bff;
  --mt-text: #ffffff;
  --mt-muted: rgba(255,255,255,.72);
  --mt-dark-on-pink: #180823;
  --mt-border: rgba(255,255,255,.10);
}

html,
body {
  background: var(--mt-bg-deep) !important;
  overflow-x: hidden !important;
}

html::before {
  background:
    linear-gradient(180deg, rgba(28, 7, 51, .48), rgba(33, 7, 53, .76)),
    url('/assets/images/brand/myteria-bg.webp') center top / cover no-repeat !important;
  filter: none !important;
}

html::after {
  background:
    radial-gradient(circle at 78% 10%, rgba(98, 55, 247, .22), transparent min(36vw, 620px)),
    radial-gradient(circle at 12% 34%, rgba(250, 91, 199, .13), transparent min(30vw, 520px)),
    linear-gradient(180deg, rgba(24, 5, 42, .18), rgba(24, 5, 42, .42)) !important;
}

#root,
main#root,
.legal-shell {
  overflow-x: clip !important;
  min-height: 100svh !important;
}

/* Header consistency */
.main-header {
  padding: clamp(24px, 3.6vw, 54px) 8% clamp(22px, 3.1vw, 44px) !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}

.main-header .main-title,
.main-title {
  width: clamp(166px, 13.2vw, 240px) !important;
  min-width: clamp(150px, 13.2vw, 210px) !important;
  max-width: 240px !important;
}

.main-header .main-title img,
.main-title img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-height: 82px !important;
  object-fit: contain !important;
  object-position: left center !important;
}

.main-header .header-nav {
  gap: clamp(28px, 3.1vw, 56px) !important;
  margin-right: clamp(18px, 2vw, 30px) !important;
}

.main-header .header-nav-item,
.main-header .header-nav-item:not(:last-child) {
  margin-right: 0 !important;
}

.main-header .header-nav-item {
  font-size: clamp(12px, .85vw, 14px) !important;
  font-weight: 800 !important;
  letter-spacing: .04em !important;
  text-shadow: 0 2px 14px rgba(0,0,0,.25) !important;
}

/* The cart icon shortcut was useful on earlier mobile mockups, but the production shell uses text nav/account context. */
.action.-cart.-mobile,
.main-header .action.-cart,
a.action.-cart.-mobile {
  display: none !important;
}

/* Remove cart glyphs from Buy buttons. */
.button.-card::after {
  content: none !important;
  display: none !important;
}

/* Keep logged-in account menu readable/clickable above shell artwork. */
.usr-box {
  z-index: 40 !important;
}

.usr-box .usr-dropdown,
.usr-dropdown {
  z-index: 1000 !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  background: rgba(22, 8, 42, .96) !important;
  border: 1px solid rgba(255,255,255,.13) !important;
}

/* Background decorations scroll with the document. */
.bg,
.bg.-desktop,
.legal-bg {
  position: absolute !important;
  inset: 0 !important;
  height: 100% !important;
  min-height: 100% !important;
  overflow: hidden !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

.steve,
.legal-bg .steve {
  top: clamp(96px, 10vw, 165px) !important;
  right: clamp(-24px, 4vw, 78px) !important;
  width: clamp(420px, 37vw, 660px) !important;
  opacity: .72 !important;
  transform: none !important;
  filter: saturate(.96) brightness(.9) !important;
}

.blob-1,
.legal-bg .blob-1 {
  top: clamp(-40px, -2vw, -8px) !important;
  right: clamp(-34px, -1.2vw, 0px) !important;
  width: clamp(640px, 53vw, 1040px) !important;
  min-width: 560px !important;
  opacity: .96 !important;
  transform: none !important;
}

.blob-2,
.legal-bg .blob-2 {
  left: clamp(-52px, -3vw, -20px) !important;
  top: clamp(330px, 30vw, 520px) !important;
  width: clamp(240px, 22vw, 430px) !important;
  opacity: .72 !important;
}

.blob-3,
.legal-bg .blob-3 {
  right: clamp(-18px, -1vw, 0px) !important;
  bottom: clamp(-12px, -1vw, 0px) !important;
  width: clamp(520px, 42vw, 820px) !important;
  opacity: .96 !important;
  transform: none !important;
}

/* Homepage copy polish */
.slide-badge {
  letter-spacing: .08em !important;
}

.slide-heading {
  max-width: 760px !important;
}

.slide-content {
  max-width: 620px !important;
}

/* Footer: simple original-store style, no glass card, no giant blob experiment. */
.main-footer {
  width: auto !important;
  min-height: auto !important;
  margin: clamp(72px, 8vw, 128px) 8% 0 auto !important;
  padding: clamp(74px, 8vw, 118px) 0 clamp(28px, 3vw, 54px) !important;
  max-width: min(520px, 42vw) !important;
  text-align: right !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  color: var(--mt-dark-on-pink) !important;
}

.main-footer .footer-title {
  color: var(--mt-dark-on-pink) !important;
  font-family: Inter, Montserrat, sans-serif !important;
  font-size: clamp(22px, 1.65vw, 30px) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  margin: 0 0 14px !important;
  text-shadow: none !important;
}

.main-footer .footer-nav {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  margin: 0 !important;
}

.main-footer .footer-nav-item {
  color: var(--mt-dark-on-pink) !important;
  display: inline-block !important;
  font-size: clamp(12px, .84vw, 14px) !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: .02em !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-decoration: none !important;
  opacity: 1 !important;
}

.main-footer .footer-nav-item:hover,
.main-footer .footer-nav-item:focus-visible {
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
}

.main-footer::after {
  content: "© Myteria 2026. All Rights Reserved." !important;
  display: block !important;
  color: var(--mt-dark-on-pink) !important;
  font-size: clamp(12px, .84vw, 14px) !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  margin-top: 20px !important;
}

/* Legal pages should feel like Myteria pages, not generic policy pages. */
body.legal-page {
  background: var(--mt-bg-deep) !important;
  color: #fff !important;
}

body.legal-page .legal-shell {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
  isolation: isolate !important;
}

body.legal-page .legal-hero,
body.legal-page .legal-card {
  position: relative !important;
  z-index: 2 !important;
  width: min(1120px, 84vw) !important;
  margin-left: 8% !important;
  margin-right: auto !important;
}

body.legal-page .legal-hero {
  padding: clamp(36px, 5vw, 74px) 0 clamp(18px, 3vw, 34px) !important;
}

body.legal-page .legal-kicker {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 32px !important;
  padding: 8px 18px !important;
  border-radius: 8px !important;
  background: linear-gradient(135deg, #7b3af0, #b94dff) !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  margin-bottom: 22px !important;
  box-shadow: 0 14px 34px rgba(123,58,240,.28) !important;
}

body.legal-page .legal-hero h1 {
  color: #ff62d7 !important;
  font-family: Montserrat, Inter, sans-serif !important;
  font-size: clamp(42px, 5vw, 84px) !important;
  line-height: .98 !important;
  font-weight: 900 !important;
  letter-spacing: -.04em !important;
  margin: 0 0 18px !important;
  max-width: 860px !important;
}

body.legal-page .legal-updated,
body.legal-page .legal-hero p:not(.legal-kicker):not(.legal-updated) {
  color: rgba(255,255,255,.78) !important;
  font-size: clamp(15px, 1.2vw, 18px) !important;
  line-height: 1.72 !important;
  max-width: 760px !important;
}

body.legal-page .legal-updated {
  color: rgba(255,255,255,.52) !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  font-size: 12px !important;
  margin-bottom: 18px !important;
}

body.legal-page .legal-card {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
  padding-bottom: 36px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

body.legal-page .legal-card section {
  background: rgba(16, 4, 34, .72) !important;
  border: 1px solid rgba(172, 123, 255, .18) !important;
  border-radius: 20px !important;
  padding: clamp(20px, 2vw, 30px) !important;
  box-shadow: 0 20px 50px rgba(0,0,0,.18) !important;
}

body.legal-page .legal-card section.-wide {
  grid-column: 1 / -1 !important;
}

body.legal-page .legal-card h2 {
  color: #fff !important;
  font-family: Montserrat, Inter, sans-serif !important;
  font-size: clamp(18px, 1.4vw, 24px) !important;
  line-height: 1.2 !important;
  margin: 0 0 12px !important;
}

body.legal-page .legal-card p,
body.legal-page .legal-card li {
  color: rgba(255,255,255,.76) !important;
  font-size: 15px !important;
  line-height: 1.68 !important;
}

body.legal-page .legal-card ul {
  margin: 12px 0 0 !important;
  padding-left: 20px !important;
}

body.legal-page .legal-note {
  color: rgba(255,255,255,.58) !important;
  font-size: 13px !important;
}

body.legal-page .main-footer {
  margin-top: clamp(56px, 7vw, 96px) !important;
}

/* Product/card surface consistency: reduce glassiness without flattening the brand. */
.card,
.box,
.hero-card,
.side-card,
.history-panel,
.locked-card {
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}

/* Mobile / Safari */
@supports (-webkit-touch-callout: none) {
  html,
  body {
    min-height: -webkit-fill-available !important;
  }

  #root,
  main#root,
  .legal-shell {
    min-height: -webkit-fill-available !important;
  }
}

@media (max-width: 980px) {
  .main-header {
    padding: 22px 6% 24px !important;
  }

  .main-header .header-nav {
    display: none !important;
  }

  .main-header .main-title,
  .main-title {
    width: clamp(138px, 39vw, 190px) !important;
    min-width: 138px !important;
  }

  .steve,
  .legal-bg .steve {
    top: 80px !important;
    right: -120px !important;
    width: 460px !important;
    opacity: .38 !important;
  }

  .blob-1,
  .legal-bg .blob-1 {
    right: -180px !important;
    top: -40px !important;
    width: 620px !important;
    min-width: 620px !important;
  }

  .blob-2,
  .legal-bg .blob-2 {
    left: -120px !important;
    top: 440px !important;
    width: 320px !important;
  }

  .blob-3,
  .legal-bg .blob-3 {
    right: -210px !important;
    bottom: -20px !important;
    width: 610px !important;
  }

  .main-footer {
    max-width: none !important;
    margin: 72px 6% 0 auto !important;
    padding: 86px 0 34px !important;
    text-align: right !important;
  }

  body.legal-page .legal-hero,
  body.legal-page .legal-card {
    width: 88vw !important;
    margin-left: 6% !important;
  }

  body.legal-page .legal-card {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .main-header {
    align-items: flex-start !important;
    padding: 18px 5% 18px !important;
  }

  .main-header .header-rhs {
    gap: 8px !important;
  }

  .usr-box span:not(.material-icons) {
    max-width: 96px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .main-footer {
    margin: 64px 5% 0 !important;
    padding: 78px 0 32px !important;
    text-align: center !important;
    color: #fff !important;
  }

  .main-footer .footer-title,
  .main-footer .footer-nav-item,
  .main-footer::after {
    color: #fff !important;
    text-shadow: 0 2px 16px rgba(0,0,0,.34) !important;
  }

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

  .main-footer .footer-nav-item {
    font-size: 12px !important;
  }

  .blob-3,
  .legal-bg .blob-3 {
    right: -260px !important;
    bottom: -40px !important;
    width: 620px !important;
    opacity: .78 !important;
  }

  body.legal-page .legal-hero,
  body.legal-page .legal-card {
    width: 90vw !important;
    margin-left: 5% !important;
  }

  body.legal-page .legal-hero {
    padding-top: 30px !important;
  }

  body.legal-page .legal-card section {
    border-radius: 16px !important;
    padding: 18px !important;
  }
}
