@import url('https://fonts.googleapis.com/css2?family=Afacad+Flux:wght@100..1000&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900&display=swap');
@import url('https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@latest/dist/tabler-icons.min.css');
@import url('https://cdn.jsdelivr.net/npm/flag-icons@7.2.3/css/flag-icons.min.css');

:root {
  --black: #070707;
  --midnight: #0A0A0B;
  --charcoal: #121315;
  --deep-jungle: #0D1714;
  --bronze-black: #18110D;
  --accent: #FF7A18;
  --burnt-gold: #B96322;
  --sunset-amber: #F5A623;
  --copper-glow: #C97933;
  --lagoon-cyan: #4FD8D3;
  --semporna-blue: #69BFF8;
  --palm-green: #8CCB72;
  --orchid-pink: #FF6EA8;
  --soft-lilac: #A77CFF;
  --warm-ivory: #F2EBDD;
  --mist-white: #F8F6F1;
  --muted-sand: #D6CCBD;

  --line: rgba(242, 235, 221, .14);
  --line-warm: rgba(255, 122, 24, .26);

  --c-success: #22c55e;
  --c-success-rgb: 34, 197, 94;

  --glass: rgba(12, 14, 13, .54);
  --glass-strong: rgba(10, 11, 10, .76);

  --font-head: 'Barlow Condensed', Impact, sans-serif;
  --font-ui: 'Afacad Flux', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --max: 1280px;
  --radius: 28px;
  color-scheme: dark;

  --anim-float: float 7s ease-in-out infinite;
  --ease-emphasis: cubic-bezier(.16, 1, .3, 1);
  --r-pill: 999px;

	--grad-irid-dark: 
		radial-gradient(circle at 18% 22%, rgba(160, 220, 255, 0.18), transparent 28%), 
		radial-gradient(circle at 78% 30%, rgba(255, 120, 230, 0.14), transparent 30%), 
		radial-gradient(circle at 45% 85%, rgba(255, 235, 140, 0.10), transparent 32%), 
		linear-gradient( 135deg, #1a1a1a 0%, #232323 28%, #171717 52%, #262626 76%, #1a1a1a 100% );

  --grad-irid-mid:
    linear-gradient(
      115deg, oklch(0.22 0.02 260) 0%, transparent 22%,
      color-mix(in oklch, oklch(0.7 0.15 200) 70%, oklch(0.18 0.02 260) 30%) 45%,
      color-mix(in oklch, oklch(0.75 0.18 320) 70%, oklch(0.18 0.02 260) 30%) 55%,
      transparent 78%, oklch(0.16 0.02 260) 100%),
    conic-gradient(from 45deg,
      color-mix(in oklch, oklch(0.8 0.12 60) 55%, oklch(0.16 0.02 260) 45%),
      color-mix(in oklch, oklch(0.7 0.15 180) 55%, oklch(0.16 0.02 260) 45%),
      color-mix(in oklch, oklch(0.8 0.12 300) 55%, oklch(0.16 0.02 260) 45%),
      color-mix(in oklch, oklch(0.8 0.12 60) 55%, oklch(0.16 0.02 260) 45%)
  );
  
  --grad-irid-light:
    linear-gradient(115deg, transparent 20%, oklch(0.7 0.15 200) 45%, oklch(0.75 0.18 320) 55%, transparent 80%),
    conic-gradient(from 45deg, oklch(0.8 0.12 60), oklch(0.7 0.15 180), oklch(0.8 0.12 300), oklch(0.8 0.12 60));
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  background: var(--black);
}

body {
  margin: 0;
  font-family: var(--font-ui);
  color: var(--warm-ivory);
  background:
    radial-gradient(circle at 13% 14%, rgba(185, 99, 34, .12), transparent 36vw),
    radial-gradient(circle at 86% 4%, rgba(79, 216, 211, .07), transparent 31vw),
    linear-gradient(180deg, #060606 0%, #0a0b09 36%, #070707 100%);
  overflow-x: hidden;
}

body.menu-open {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  display: block;
}

button,
input,
select,
textarea {
  font: inherit;
}

::selection {
  background: rgba(255, 122, 24, .35);
  color: var(--mist-white);
}

.hidden {
  display: none !important;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.nw-preloader {
  position: fixed;
  inset: 0;
  z-index: 5000;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 28px;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 28px;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 122, 24, .16), transparent 34%),
    linear-gradient(180deg, #080808 0%, #111 58%, #070707 100%);
  opacity: 1;
  visibility: visible;
  transition: opacity .34s var(--ease-emphasis), visibility .34s var(--ease-emphasis);
}

.nw-preloader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.nw-preloader-mark {
  display: grid;
  place-items: center;
  position: relative;
  width: clamp(72px, 12vw, 82px);
  height: clamp(72px, 12vw, 82px);
  border-radius: 28%;
}

.nw-preloader-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, .34));
  animation: jump 1.05s var(--ease-emphasis) infinite;
}

.nw-preloader-mark .shadow {
  position: absolute;
  left: 50%;
  bottom: -8px;
  z-index: -1;
  display: block;
  width: 84%;
  height: 16px;
  border-radius: 100%;
  background: radial-gradient(ellipse at center, rgba(0, 0, 0, .58) 0%, rgba(0, 0, 0, .24) 52%, transparent 76%);
  transform: translateX(-50%) scale(1);
  transform-origin: center;
  opacity: .4;
  animation: scale-shadow 1.05s var(--ease-emphasis) infinite;
}

.nw-preloader-range {
  position: relative;
  width: min(260px, 68vw);
  height: 8px;
  overflow: hidden;
  border-radius: var(--r-pill);
  background: rgba(255, 255, 255, .1);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, .08) inset;
}

.nw-preloader-range span {
  position: absolute;
  inset: 0 auto 0 0;
  width: 8%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ff6a00 0%, #ff9d2e 72%, #ffd18a 100%);
  box-shadow: 0 0 24px rgba(255, 122, 24, .45);
  transition: width .28s var(--ease-emphasis);
}

@keyframes jump {

  0%,
  100% {
    transform: translateY(0) scale(1);
  }

  45% {
    transform: translateY(-14px) scale(1.025);
  }
}

@keyframes scale-shadow {

  0%,
  100% {
    transform: translateX(-50%) scale(1);
    opacity: .4;
  }

  45% {
    transform: translateX(-50%) scale(.72);
    opacity: .24;
  }
}

#atmosphere,
.page-glow,
.grain {
  position: fixed;
  pointer-events: none;
}

#atmosphere {
  inset: 0;
  z-index: 0;
  opacity: .62;
  mix-blend-mode: screen;
}

.page-glow {
  width: 40vw;
  height: 40vw;
  left: -15vw;
  bottom: -18vw;
  z-index: 1;
  background: radial-gradient(circle, rgba(255, 122, 24, .24), rgba(185, 99, 34, .08) 38%, transparent 68%);
  filter: blur(22px);
}

.grain {
  inset: 0;
  z-index: 2;
  opacity: .22;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.container {
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
  position: relative;
  z-index: 3;
}

section {
  padding: 110px 0;
  position: relative;
}

.section-bg {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.section-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: linear-gradient(90deg, rgba(0, 0, 0, .86), rgba(0, 0, 0, .23) 55%, rgba(0, 0, 0, .76)), var(--bg);
  background-size: cover;
  background-position: top center;
  filter: saturate(1.06);
  transform: scale(1.02);
}

.section-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 8% 78%, rgba(255, 122, 24, .18), transparent 34%),
    radial-gradient(circle at 82% 10%, rgba(105, 191, 248, .08), transparent 28%),
    linear-gradient(180deg, rgba(7, 7, 7, .34), rgba(7, 7, 7, .86));
  pointer-events: none;
}

.persona-hero.section-bg::after {
  background:
    radial-gradient(circle at 8% 78%, rgba(255, 122, 24, .18), transparent 34%),
    linear-gradient(180deg, rgba(7, 7, 7, .04), rgba(7, 7, 7, .18));
}

/* Header */
.site-header {
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  width: min(1180px, calc(100% - 40px));
  min-height: 64px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
  padding: 0 18px 0 22px;
  border-radius: 999px;
  border: 1px solid rgba(242, 235, 221, .04);
  background: rgba(7, 7, 7, .22);
  backdrop-filter: blur(24px) saturate(1.18);
  box-shadow: 0 18px 60px rgba(0, 0, 0, .36), inset 0 1px rgba(255, 255, 255, .06);
  transition: .35s ease;
}

.site-header.scrolled {
  top: 10px;
  background: rgba(7, 7, 7, .78);
  box-shadow: 0 20px 70px rgba(0, 0, 0, .56), 0 0 0 1px rgba(255, 122, 24, .08);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 850;
  letter-spacing: .1em;
  text-transform: uppercase;
  white-space: nowrap;
}

.brand-logo {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  object-fit: cover;
  box-shadow: 0 0 28px rgba(255, 122, 24, .18);
}

.nav-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 34px;
  color: rgba(242, 235, 221, .82);
  font-size: .95rem;
}

.nav-links a,
.footer a:not(.brand) {
  transition: color .25s ease, background .25s ease, transform .25s ease, box-shadow .25s ease;
}

.nav-links a:hover,
.nav-links a:focus-visible,
.nav-links a.is-active {
  color: var(--accent);
  outline: 0;
}

.nav-menu {
  position: relative;
}

.nav-menu::after {
  content: "";
  position: absolute;
  left: -18px;
  right: -18px;
  top: 100%;
  height: 18px;
}

.nav-menu-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}

.nav-menu-toggle i {
  transition: transform .2s ease;
}

.nav-menu.is-open .nav-menu-toggle i {
  transform: rotate(180deg);
}

.nav-menu-panel {
  position: absolute;
  top: 100%;
  left: 50%;
  z-index: 55;
  min-width: 220px;
  display: grid;
  gap: 4px;
  padding: 18px 10px 10px;
  border-radius: 20px;
  border: 1px solid rgba(242, 235, 221, .13);
  background: rgba(7, 7, 7, .92);
  box-shadow: 0 22px 70px rgba(0, 0, 0, .48), inset 0 1px rgba(255, 255, 255, .07);
  backdrop-filter: blur(22px);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -6px);
  transition: opacity .2s ease, transform .2s ease;
}

.nav-menu-panel a {
  padding: 10px 12px;
  border-radius: 14px;
  white-space: nowrap;
}

.nav-menu.is-open .nav-menu-panel,
.nav-menu:focus-within .nav-menu-panel,
.nav-menu:hover .nav-menu-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.nav-toggle {
  display: none;
  border: 0;
  background: transparent;
  color: var(--warm-ivory);
  font-size: 1.8rem;
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.language-menu {
  position: relative;
}

.language-toggle {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(242, 235, 221, .1);
  background: rgba(255, 255, 255, .045);
  color: var(--warm-ivory);
  cursor: pointer;
  font-weight: 850;
}

.language-toggle i {
  color: var(--sunset-amber);
  font-size: 1rem;
  transition: transform .2s ease;
}

.language-menu.is-open .language-toggle i {
  transform: rotate(180deg);
}

.language-flag.fi {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  border-radius: 999px;
  background-size: cover;
  background-position: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 2px 8px rgba(0,0,0,.18);
}

.language-code {
  letter-spacing: .06em;
}

.language-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 60;
  min-width: 178px;
  display: grid;
  gap: 4px;
  padding: 8px;
  border-radius: 18px;
  border: 1px solid rgba(242, 235, 221, .13);
  background: rgba(7, 7, 7, .94);
  box-shadow: 0 22px 70px rgba(0, 0, 0, .48), inset 0 1px rgba(255, 255, 255, .07);
  backdrop-filter: blur(20px);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity .2s ease, transform .2s ease;
}

.language-menu.is-open .language-panel {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.language-panel button {
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 10px;
  border: 0;
  border-radius: 12px;
  color: rgba(242, 235, 221, .78);
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.language-panel .language-flag.fi {
  width: 18px;
  height: 18px;
  flex-basis: 18px;
}

.language-panel button[aria-checked="true"],
.language-panel button:hover,
.language-panel button:focus-visible {
  color: var(--warm-ivory);
  background: rgba(255, 122, 24, .12);
  outline: 0;
}

.nav-language {
  display: none;
}

.header-cta,
.btn {
  border: 0;
  color: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 24px;
  border-radius: 999px;
  font-weight: 750;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
  will-change: transform;
}

.header-cta,
.btn-primary {
  background: linear-gradient(135deg, var(--accent) 38%, #d06122 70%, var(--sunset-amber));
  box-shadow: 0 14px 40px rgba(255, 122, 24, .26), inset 0 1px rgba(255, 255, 255, .34);
}

.header-cta:hover,
.header-cta:focus-visible,
.btn-primary:hover,
.btn-primary:focus-visible {
  background: linear-gradient(135deg, var(--accent), var(--sunset-amber));
  transform: translateY(-2px);
  box-shadow: 0 14px 48px rgba(255, 122, 24, .42), inset 0 1px rgba(255, 255, 255, .35);
  outline: 0;
}

.btn-ghost {
  color: var(--warm-ivory);
  background: rgba(8, 10, 9, .45);
  border: 1px solid var(--line);
  backdrop-filter: blur(16px);
}

.btn-ghost:hover,
.btn-ghost:focus-visible {
  border-color: rgba(255, 122, 24, .34);
  box-shadow: 0 0 32px rgba(255, 122, 24, .14);
  transform: translateY(-2px);
  outline: 0;
}

/* Shared type */
.eyebrow {
  font-size: .78rem;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: rgba(245, 166, 35, .82);
  margin: 0 0 20px;
  font-weight: 850;
}

h1,
h2,
h3 {
  margin: 0;
}

h1,
h2 {
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: .015em;
  line-height: .83;
}

h1 {
  font-size: clamp(5rem, 10vw, 7.8rem);
  max-width: 760px;
  color: var(--warm-ivory);
  text-shadow: 0 2px 34px rgba(0, 0, 0, .45);
}

h1 .h1c,
h2 span {
  color: var(--accent);
}

.section-intro {
  max-width: 840px;
  margin-bottom: 48px;
}

.section-intro.centered {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.section-intro h2,
.pricing-head h2,
.shop-copy h2,
.waitlist-copy h2,
.creator-copy h2,
.calculator-panel h2 {
  font-size: clamp(4.4rem, 8.3vw, 9rem);
}

.creator-phone-copy h2 {
  font-size: clamp(4.2rem, 6.8vw, 7.6rem);
}

.section-intro p,
.pricing-head p,
.shop-copy p,
.waitlist-copy p,
.creator-copy p,
.creator-phone-copy p,
.calculator-panel p {
  color: rgba(242, 235, 221, .74);
  line-height: 1.55;
  font-size: 1.15rem;
}

/* Hero */
.hero {
  min-height: 100svh;
  padding: 112px 0 48px;
  display: grid;
  align-items: center;
}

.hero-grid {
  min-height: calc(100svh - 160px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .92fr);
  align-items: center;
  gap: 46px;
}

.hero-body {
  max-width: 620px;
  margin: 14px 0 0;
  font-size: 1.1rem;
  line-height: 1.5;
  color: rgba(242, 235, 221, .82);
}

.cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin: 28px 0 24px;
}

.hero-visual {
  position: relative;
  min-height: 600px;
  perspective: 1300px;
}

.phone-wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(410px, 82vw);
  z-index: 5;
}

.phone-shell {
  position: relative;
  transform: rotate(-3deg);
  animation: var(--anim-float);
  filter: drop-shadow(0 60px 90px rgba(0, 0, 0, .62)) drop-shadow(0 0 70px rgba(255, 122, 24, .18));
}

.phone-image {
  width: 100%;
  height: auto;
  border-radius: 38px;
}

.floating-card {
  position: absolute;
  z-index: 8;
  background: rgba(8, 10, 9, .64);
  border: 1px solid rgba(242, 235, 221, .14);
  backdrop-filter: blur(18px);
  box-shadow: 0 22px 55px rgba(0, 0, 0, .35), inset 0 1px rgba(255, 255, 255, .08);
}

.mini-card {
  min-width: 144px;
  padding: 15px 16px;
  border-radius: 18px;
  animation: var(--anim-float);
}

.mini-card span {
  display: block;
  color: rgba(242, 235, 221, .62);
  font-size: .76rem;
}

.mini-card strong {
  display: block;
  margin-top: 3px;
  color: var(--warm-ivory);
  font-size: 1.05rem;
}

.mini-card small {
  color: var(--sunset-amber);
}

.fc-trip {
  left: 2%;
  top: 12%;
}

.fc-expense {
  left: 2%;
  bottom: 26%;
  animation-delay: -1.1s;
}

.fc-xp {
  right: 0;
  top: 25%;
  animation-delay: -2.1s;
}

.fc-esim {
  right: 4%;
  bottom: 18%;
  animation-delay: -3s;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0) rotate(var(--r, 0deg));
  }

  50% {
    transform: translateY(-13px) rotate(var(--r, 0deg));
  }
}

/* Pain */
.pain {
  background: linear-gradient(180deg, #070707 0%, #0b0a08 54%, #070707 100%);
}

.pain::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 88% 20%, rgba(255, 122, 24, .1), transparent 28%), radial-gradient(circle at 4% 68%, rgba(79, 216, 211, .08), transparent 34%);
  pointer-events: none;
}

.pain-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}

.pain-card {
  min-height: 500px;
  padding: 28px;
  border-radius: var(--radius);
  border: 1px solid rgba(242, 235, 221, .13);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .38), inset 0 1px rgba(255, 255, 255, .08);
}

.pain-card.lifted {
  margin-top: 58px;
}

.pain-card span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .2em;
  font-weight: 850;
  font-size: .74rem;
}

.pain-card h3 {
  font-family: var(--font-head);
  font-size: clamp(2.45rem, 3.2vw, 2.6rem);
  line-height: .9;
  margin: 12px 0;
  text-transform: uppercase;
}

.pain-card p {
  margin: 0;
  color: rgba(242, 235, 221, .75);
  line-height: 1.42;
}

.bridge-copy {
  margin: 52px auto 0;
  text-align: center;
  color: rgba(242, 235, 221, .66);
  letter-spacing: .08em;
  font-size: 1.05rem;
}

/* Nomawa loop */
.loop {
  padding-top: 112px;
}

.loop .section-intro.centered {
  max-width: none;
}

.loop-title-nowrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 1.4vw, 18px);
  white-space: nowrap;
  font-size: clamp(3.2rem, 8.15vw, 8rem) !important;
  line-height: .86;
  color: var(--mist-white);
}

.loop-arrow {
  display: inline-grid;
  place-items: center;
  color: var(--burnt-gold) !important;
  transform: rotate(0deg);
}

.loop-arrow i {
  font-size: .68em;
}

.loop-scene {
  position: relative;
  margin: 124px 0;
  display: grid;
  grid-template-columns: 310px 1fr;
  gap: 40px;
  align-items: center;
}

.scene-copy {
  position: relative;
  z-index: 2;
}

.scene-copy.narrow {
  max-width: 320px;
}

.step-index {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(245, 166, 35, .42);
  border-radius: 50%;
  color: var(--sunset-amber);
  margin-bottom: 18px;
  background: rgba(0, 0, 0, .32);
}

.scene-copy h3 {
  font-family: var(--font-head);
  font-size: clamp(4rem, 6.6vw, 7.2rem);
  text-transform: uppercase;
  line-height: .85;
}

.scene-copy p {
  color: rgba(242, 235, 221, .72);
  line-height: 1.48;
  font-size: 1.08rem;
}

.small-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 42px;
  padding: 0 17px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(242, 235, 221, .14);
  color: var(--warm-ivory);
  cursor: pointer;
}

.scroll-x {
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 12px 0 22px;
  scroll-behavior: smooth;
}

.scroll-x::-webkit-scrollbar {
  display: none;
}

.auto-edge.is-edge-scrolling {
  cursor: ew-resize;
}

.trip-strip {
  display: flex;
  gap: 18px;
  padding: 0 48px;
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}

.trip-card {
  flex: 0 0 360px;
  min-height: 410px;
  padding: 22px;
  border-radius: 26px;
  border: 1px solid rgba(242, 235, 221, .12);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .38);
}

.trip-card span {
  align-self: flex-start;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 122, 24, .44);
  border: 1px solid rgba(255, 122, 24, .64);
  color: var(--mist-white);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
}

.trip-card h4 {
  margin: auto 0 7px;
  font-family: var(--font-head);
  font-size: clamp(3.4rem, 6vw, 4.0rem);
  line-height: 0.8;
  text-transform: uppercase;
}

.trip-card p,
.trip-card small {
  margin: 0;
  color: rgba(242, 235, 221, .8);
  max-width: 80%;
}

.scene-expenses {
  grid-template-columns: 360px 1fr;
}

.expense-stage {
  position: relative;
  min-height: 560px;
  display: grid;
  place-items: center;
}

.expense-panel {
  width: min(680px, 100%);
  padding: 22px;
  border-radius: 30px;
  background: rgba(7, 8, 7, .68);
  border: 1px solid rgba(242, 235, 221, .14);
  backdrop-filter: blur(20px);
  box-shadow: 0 38px 100px rgba(0, 0, 0, .48), inset 0 1px rgba(255, 255, 255, .08);
}

.expense-row {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  margin: 8px 0;
  border-radius: 18px;
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(255, 255, 255, .09);
}

.expense-row.big {
  padding: 16px 18px;
  margin: 10px 0;
  border-radius: 20px;
}

.expense-row i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 122, 24, .14);
  color: var(--sunset-amber);
  flex: 0 0 auto;
}

.expense-row span {
  flex: 1;
  color: var(--warm-ivory);
  font-weight: 700;
}

.expense-row small,
.expense-row em {
  display: block;
  font-style: normal;
  color: rgba(242, 235, 221, .55);
  font-size: .78rem;
  font-weight: 500;
}

.expense-row strong {
  text-align: right;
  color: var(--warm-ivory);
  font-size: 1.02rem;
}

.total-card {
  margin-top: 14px;
  padding: 18px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255, 122, 24, .12), rgba(255, 255, 255, .04));
  border: 1px solid rgba(255, 122, 24, .2);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 4px 18px;
}

.total-card span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .74rem;
  font-weight: 800;
}

.total-card strong {
  grid-column: 1;
  font-size: 1.35rem;
}

.total-card em {
  grid-column: 1;
  font-style: normal;
  color: rgba(242, 235, 221, .6);
}

.total-card svg {
  grid-row: 1/4;
  grid-column: 2;
  width: 190px;
  height: 58px;
}

.total-card path {
  fill: none;
  stroke: var(--warm-ivory);
  stroke-width: 3;
  stroke-linecap: round;
  opacity: .78;
}

.reward-float {
  position: absolute;
  z-index: 3;
  min-width: 160px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(8, 10, 9, .66);
  border: 1px solid rgba(242, 235, 221, .14);
  backdrop-filter: blur(16px);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .4);
  animation: var(--anim-float);
}

.reward-float i {
  color: var(--accent);
  font-size: 1.45rem;
}

.reward-float strong {
  display: block;
  margin-top: 6px;
}

.reward-float span {
  color: rgba(242, 235, 221, .64);
  font-size: .9rem;
}

.rf-one {
  top: 32px;
  right: 18%;
  animation-delay: -1.1s;
}

.rf-two {
  left: 8%;
  top: 48%;
  animation-delay: -2.1s;
}

.rf-three {
  right: 5%;
  bottom: -20px;
  animation-delay: -3s;
}

.scene-earn {
  grid-template-columns: 330px 1fr;
  margin: 184px 0;
}

.earn-cascade {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 14px;
  position: relative;
  z-index: 1;
}

.earn-cascade article {
  min-height: 220px;
  padding: 22px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 122, 24, .12), rgba(255, 255, 255, .045));
  border: 1px solid rgba(242, 235, 221, .13);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .35);
  backdrop-filter: blur(16px);
}

.earn-cascade article:nth-child(even) {
  transform: translateY(34px);
}

.earn-cascade i {
  color: var(--sunset-amber);
  font-size: 2rem;
  margin-bottom: auto;
}

.earn-cascade strong {
  font-family: var(--font-head);
  font-size: 2.6rem;
  line-height: .9;
  text-transform: uppercase;
}

.earn-cascade span {
  color: rgba(242, 235, 221, .66);
}

.text-link {
  color: var(--sunset-amber);
  font-weight: 800;
}

/* Personas */
.personas {
  padding-top: 70px;
}

.personas .section-intro {
  max-width: 1120px;
}

.personas .section-intro h2 {
  max-width: 980px;
  font-size: clamp(5.6rem, 11vw, 12rem);
}

.persona-grid.scroll-x {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  padding: 10px 48px 24px;
  mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 88%, transparent 100%);
}

.persona-card {
  flex: 0 0 clamp(280px, 29vw, 365px);
  min-height: 360px;
  padding: 22px;
  border-radius: 26px;
  border: 1px solid rgba(242, 235, 221, .13);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.persona-card h3 {
  font-family: var(--font-head);
  font-size: 3.6rem;
  line-height: .82;
  text-transform: uppercase;
}

.persona-card p {
  margin: 8px 0 0;
  color: rgba(242, 235, 221, .76);
}

.stamp-sticker {
  display: none;
}

/* Pillars */
.pillars {
  padding: 80px 0 120px;
}

.pillar-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 28px;
}

.pillar-card {
  min-height: 300px;
  padding: 32px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .035));
  border: 1px solid rgba(242, 235, 221, .14);
  box-shadow: inset 0 1px rgba(255, 255, 255, .08), 0 28px 85px rgba(0, 0, 0, .32);
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(8px);
}

.pillar-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  background: radial-gradient(circle at 20% 0%, rgba(255, 122, 24, .22), transparent 40%);
  opacity: .7;
  pointer-events: none;
}

.pillar-card.tilt-up {
  transform: translateY(-28px);
}

.pillar-card i,
.pillar-card h3,
.pillar-card p {
  position: relative;
  z-index: 1;
}

.pillar-card i {
  color: var(--sunset-amber);
  font-size: 2.2rem;
}

.pillar-card h3 {
  margin: 58px 0 10px;
  font-family: var(--font-head);
  font-size: 5rem;
  line-height: .85;
}

.pillar-card p {
  color: rgba(242, 235, 221, .66);
  font-size: 1.1rem;
}

/* Passport rewards */
.passport-section {
  padding: 120px 0;
}

.passport-section .section-intro h2 {
  font-size: clamp(4.5rem, 7.8vw, 9.5rem);
}

.passport-stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 28px;
  align-items: center;
}

.passport-art-card {
  position: relative;
  border-radius: 36px;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(28, 23, 18, .78), rgba(8, 8, 7, .86));
  border: 1px solid rgba(245, 166, 35, .22);
  box-shadow: 0 50px 120px rgba(0, 0, 0, .62), 0 0 120px rgba(255, 122, 24, .13), inset 0 1px rgba(255, 255, 255, .1);
}

.passport-art-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 10%, rgba(255, 122, 24, .17), transparent 34%), linear-gradient(180deg, transparent 55%, rgba(0, 0, 0, .18));
  pointer-events: none;
}

.passport-art-card img {
  width: 100%;
  height: auto;
  display: block;
}

.passport-metrics {
  display: grid;
  gap: 12px;
}

.passport-metrics div {
  display: grid;
  grid-template-columns: 38px 1fr;
  column-gap: 12px;
  align-items: start;
  padding: 18px;
  border-radius: 20px;
  background: rgba(7, 8, 7, .7);
  border: 1px solid rgba(242, 235, 221, .13);
  backdrop-filter: blur(16px);
}

.passport-metrics i {
  grid-row: 1/span 3;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: var(--sunset-amber);
  background: rgba(255, 122, 24, .12);
  border: 1px solid rgba(255, 122, 24, .18);
}

.passport-metrics span,
.passport-metrics em {
  display: block;
  color: rgba(242, 235, 221, .58);
  font-size: .82rem;
  font-style: normal;
}

.passport-metrics strong {
  display: block;
  margin-top: 4px;
  font-family: var(--font-head);
  font-size: 2.2rem;
  line-height: .9;
  text-transform: uppercase;
}

.level-strip {
  display: flex;
  gap: 14px;
  margin-top: 34px;
}

.level-strip span {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 18px 22px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .055);
  border: 1px solid rgba(242, 235, 221, .12);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .8rem;
  color: rgba(242, 235, 221, .68);
}

.level-strip i {
  color: var(--sunset-amber);
  font-size: 1rem;
}

.level-strip .active {
  background: rgba(255, 122, 24, .06);
  border-color: rgba(255, 122, 24, .18);
  color: var(--sunset-amber);
}

.level-strip .locked {
  background: rgba(255, 255, 255, .02);
  border-color: rgba(242, 235, 221, .06);
  color: rgba(242, 235, 221, .3);
}

.level-strip .locked i {
  color: rgba(242, 235, 221, .3);
}

/* Shop */
.shop {
  padding: 120px 0;
}

.shop-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 44px;
  align-items: center;
}

.shop-copy h2 {
  font-size: clamp(4.2rem, 6.8vw, 7.6rem);
}

.shop-copy .shop-title-small {
  display: inline-block;
  font-size: .66em;
  line-height: .9;
}

.shop-carousel {
  min-width: 0;
}

.shop-shelf {
  display: flex;
  gap: 18px;
  padding: 0 42px 8px;
  mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 88%, transparent 100%);
}

.shop-card {
  flex: 0 0 230px;
  min-height: 350px;
  padding: 22px;
  border-radius: 26px;
  border: 1px solid rgba(242, 235, 221, .12);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  box-shadow: 0 8px 80px rgba(0, 0, 0, .4);
}

.shop-card i {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  color: var(--sunset-amber);
  font-size: 1.6rem;
  background: rgba(255, 122, 24, .12);
  border: 1px solid rgba(255, 122, 24, .18);
  margin-bottom: auto;
}

.shop-card h3 {
  font-family: var(--font-head);
  font-size: 2.3rem;
  line-height: .9;
  text-transform: uppercase;
  margin: 18px 0 6px;
}

.shop-card p {
  color: rgba(242, 235, 221, .66);
  margin: 0;
}

.shop-controls {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 20px;
}

.circle-arrow {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(242, 235, 221, .18);
  background: rgba(7, 8, 7, .72);
  color: var(--warm-ivory);
  backdrop-filter: blur(18px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .42), inset 0 1px rgba(255, 255, 255, .08);
  font-size: 1rem;
  cursor: pointer;
  transition: transform .25s ease, border-color .25s ease, color .25s ease, background .25s ease;
}

.circle-arrow:hover,
.circle-arrow:focus-visible {
  transform: translateY(-1px) scale(1.04);
  border-color: rgba(255, 122, 24, .44);
  color: var(--sunset-amber);
  background: rgba(17, 13, 10, .82);
  outline: 0;
}

/* Stories */
.stories {
  padding: 105px 0;
  background: linear-gradient(180deg, #070707, #0d0b09);
}

.story-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.story-card {
  min-height: 260px;
  padding: 20px;
  border-radius: 24px;
  border: 1px solid rgba(242, 235, 221, .12);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.story-card:nth-child(even) {
  transform: translateY(34px);
}

.story-card p {
  margin: 0 0 10px;
  font-size: 1.1rem;
  max-width: 210px;
}

.story-card span.xp {
  color: var(--accent);
  background: rgba(255, 122, 24, .12);
  border: 1px solid rgba(255, 122, 24, .18);
  border-radius: 14px;
  padding: 4px 8px;
}

.story-card span.xp i {
  color: var(--accent);
  font-size: 1rem;
}

.story-card span.miles {
  color: var(--c-success);
  background: rgba(var(--c-success-rgb), .12);
  border: 1px solid rgba(var(--c-success-rgb), .18);
  border-radius: 14px;
  padding: 4px 8px;
}

.story-card span.miles i {
  color: var(--c-success);
  font-size: 1rem;
}

/* Creator */
.creator {
  padding: 240px 0;
}

.creator-grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(420px, 1fr);
  gap: 62px;
  align-items: center;
}

.creator-copy h2 {
  max-width: 760px;
}

.creator-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.creator-cards {
  position: relative;
  min-height: 560px;
}

.creator-card {
  position: absolute;
  width: min(430px, 88%);
  min-height: 250px;
  padding: 26px;
  border-radius: 30px;
  background: rgba(7, 8, 7, .64);
  border: 1px solid rgba(242, 235, 221, .13);
  backdrop-filter: blur(18px);
  box-shadow: 0 32px 100px rgba(0, 0, 0, .48), inset 0 1px rgba(255, 255, 255, .08);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;

}

.creator-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: radial-gradient(circle at 14% 8%, rgba(255, 122, 24, .24), transparent 35%), linear-gradient(135deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02));
}

.creator-card::after {
  content: "";
  position: absolute;
  inset: -40% -20% auto auto;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(245, 166, 35, .12);
  filter: blur(30px);
}

.creator-card i {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  color: var(--sunset-amber);
  background: rgba(255, 122, 24, .12);
  border: 1px solid rgba(255, 122, 24, .18);
  font-size: 1.8rem;
  margin-bottom: auto;
}

.creator-card span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-weight: 850;
  font-size: .74rem;
}

.creator-card h3 {
  margin: 8px 0;
  font-family: var(--font-head);
  font-size: 2.8rem;
  line-height: .86;
  text-transform: uppercase;
}

.creator-card p {
  margin: 0;
  color: rgba(242, 235, 221, .67);
  max-width: 300px;
}

.invite-card {
  left: 4%;
  top: 0;
  transform: rotate(-4deg);
}

.reel-card {
  right: 0;
  top: 190px;
  transform: rotate(4deg);
  z-index: 5;
}

.crew-card {
  left: 14%;
  bottom: -30px;
  transform: rotate(-1.5deg);
}

.creator-card:hover {
  z-index: 6;
  border-color: rgba(245, 166, 35, .44);
}

.invite-card:hover {
  transform: scale(1.02) rotate(-4deg);
}

.reel-card:hover {
  transform: scale(1.02) rotate(4deg);
}

.crew-card:hover {
  transform: scale(1.02) rotate(-1.5deg);
}

/* Pricing */
.pricing {
  padding: 120px 0;
}

.pricing-head {
  display: grid;
  grid-template-columns: 1fr 430px;
  gap: 30px;
  align-items: end;
  margin-bottom: 36px;
}

.pricing-head h2 {
  max-width: 760px;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.price-card {
  min-height: 550px;
  padding: 24px;
  border-radius: 26px;
  border: 1px solid rgba(242, 235, 221, .14);
  display: flex;
  flex-direction: column;
  box-shadow: 0 28px 90px rgba(0, 0, 0, .42);
}

.price-card.featured {
  border: 2px solid rgba(255, 122, 24, .45);
  box-shadow: 0 0 52px rgba(255, 122, 24, .14), 0 32px 90px rgba(0, 0, 0, .44);
}

.price-card span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 850;
}

.price-card h3 {
  font-family: var(--font-head);
  font-size: 5.6rem;
  line-height: .82;
  text-transform: uppercase;
  margin: 18px 0 0;
}

.price-card p {
  margin: 6px 0 24px;
  color: rgba(242, 235, 221, .72);
}

.price-card ul {
  list-style: none;
  padding: 0;
  margin: auto 0 0;
  display: grid;
  gap: 10px;
}

.price-card li {
  color: rgba(242, 235, 221, .76);
  display: flex;
  gap: 9px;
  align-items: flex-start;
}

.price-card li::before {
  content: "✦";
  color: var(--sunset-amber);
  font-size: .8rem;
  margin-top: 3px;
}

.price-card strong {
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid rgba(242, 235, 221, .12);
  font-size: 1.8rem;
}

.price-card em {
  font-size: .95rem;
  color: rgba(242, 235, 221, .6);
  font-style: normal;
}

.value-recap {
  margin: 48px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  padding: 18px;
  border-radius: 24px;
  /* background: rgba(7, 8, 7, .64);
  border: 1px solid rgba(242, 235, 221, .13);
  backdrop-filter: blur(16px); */
}

.value-recap span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 13px;
  border-radius: 999px;
  color: rgba(242, 235, 221, .72);
  border: 1px solid rgba(242, 235, 221, .09);
  background: rgba(255, 255, 255, .035);
  font-size: .9rem;
}

.value-recap i {
  color: var(--sunset-amber);
  font-size: 1.05rem;
}

/* Waitlist */
.waitlist {
  padding: 120px 0 98px;
  overflow: hidden;
}

.waitlist-grid {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(420px, .78fr);
  gap: 64px;
  align-items: center;
}

.waitlist-copy {
  text-align: left;
}

.waitlist-copy h2 {
  max-width: 720px;
}

.waitlist-open {
  margin-top: 24px;
}

.waitlist-form {
  margin-top: 24px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.waitlist-form label {
  flex: 1 1 210px;
  min-width: 180px;
  display: grid;
  gap: 7px;
}

.waitlist-form label span {
  color: rgba(242, 235, 221, .56);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .14em;
}

.waitlist-form input,
.waitlist-form select {
  height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(242, 235, 221, .13);
  background: rgba(7, 8, 7, .68);
  color: var(--warm-ivory);
  padding: 0 18px;
  outline: none;
  backdrop-filter: blur(16px);
}

.waitlist-form select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23F2EBDD' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 18px center / 18px 18px,
    rgba(7, 8, 7, .68);
}

.waitlist-form select::-ms-expand {
  display: none;
}

.waitlist-form input:focus,
.waitlist-form select:focus {
  border-color: rgba(255, 122, 24, .44);
  box-shadow: 0 0 0 4px rgba(255, 122, 24, .11);
}

.waitlist-form button {
  border: 0;
  cursor: pointer;
  align-self: end;
}

.avatar-proof {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 18px;
  color: rgba(242, 235, 221, .66);
}

.avatar-proof span {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid #121315;
  margin-right: -8px;
  background: linear-gradient(135deg, var(--accent), var(--lagoon-cyan));
}

.avatar-proof span:nth-child(2) {
  background: linear-gradient(135deg, var(--orchid-pink), var(--sunset-amber));
}

.avatar-proof span:nth-child(3) {
  background: linear-gradient(135deg, var(--palm-green), var(--semporna-blue));
}

.avatar-proof span:nth-child(4) {
  background: linear-gradient(135deg, var(--soft-lilac), var(--burnt-gold));
  margin-right: 10px;
}

.waitlist-personas {
  position: relative;
  min-height: 520px;
}

.waitlist-persona-card {
  position: absolute;
  width: min(420px, 88%);
  min-height: 260px;
  padding: 24px;
  border-radius: 28px;
  border: 1px solid rgba(242, 235, 221, .14);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .44), inset 0 1px rgba(255, 255, 255, .08);
}

.waitlist-persona-card span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .18em;
  font-weight: 850;
  font-size: .74rem;
}

.waitlist-persona-card strong {
  margin-top: 8px;
  font-family: var(--font-head);
  font-size: 3rem;
  line-height: .86;
  text-transform: uppercase;
  max-width: 260px;
}

.wp-one {
  left: 8%;
  top: 0;
  transform: rotate(-5deg);
}

.wp-two {
  right: 0;
  top: 10px;
  transform: rotate(5deg);
}

.wp-three {
  left: 30px;
  bottom: 0;
  transform: rotate(-2deg);
}

.wp-one:hover {
  transform: scale(1.02) rotate(-5deg);
}

.wp-two:hover {
  transform: scale(1.02) rotate(5deg);
}

.wp-three:hover {
  transform: scale(1.02) rotate(-2deg);
}

/* Waitlist modal */
body.modal-open {
  overflow: hidden;
}

.waitlist-modal[hidden] {
  display: none;
}

.waitlist-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
}

.waitlist-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(2, 3, 3, .72);
  backdrop-filter: blur(14px);
  cursor: pointer;
}

.waitlist-dialog {
  position: relative;
  z-index: 1;
  width: min(720px, 100%);
  max-height: min(760px, calc(100svh - 48px));
  overflow: auto;
  padding: 34px;
  border-radius: 30px;
  border: 1px solid rgba(242, 235, 221, .16);
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 122, 24, .2), transparent 35%),
    linear-gradient(180deg, rgba(14, 16, 15, .96), rgba(7, 8, 7, .94));
  box-shadow: 0 38px 120px rgba(0, 0, 0, .62), inset 0 1px rgba(255, 255, 255, .08);
}

.modal-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(242, 235, 221, .14);
  background: rgba(255, 255, 255, .05);
  color: var(--warm-ivory);
  cursor: pointer;
}

.modal-close:hover,
.modal-close:focus-visible {
  border-color: rgba(255, 122, 24, .38);
  color: var(--sunset-amber);
  outline: 0;
}

.modal-kicker {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .24em;
  font-size: .76rem;
  font-weight: 850;
}

.waitlist-dialog h2 {
  margin-top: 12px;
  padding-right: 44px;
  font-family: var(--font-head);
  font-size: clamp(3.4rem, 7vw, 5.0rem);
  line-height: .86;
  text-transform: uppercase;
}

.waitlist-dialog p {
  max-width: 520px;
  color: rgba(242, 235, 221, .72);
  line-height: 1.5;
}

.modal-waitlist-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.modal-waitlist-form label {
  min-width: 0;
}

.modal-waitlist-form .waitlist-submit,
.waitlist-status {
  grid-column: 1 / -1;
}

.modal-waitlist-form input,
.modal-waitlist-form select {
  width: 100%;
}

.modal-waitlist-form .waitlist-submit {
  min-height: 56px;
  margin: 20px 0 0;
}

.waitlist-status {
  min-height: 22px;
  color: rgba(242, 235, 221, .68);
  font-weight: 700;
}

.waitlist-status.error {
  color: #ffb4a8;
}

.waitlist-status.success {
  color: var(--palm-green);
}

/* Creator page */
.route-root[hidden] {
  display: none;
}

.creator-hero {
  min-height: 100vh;
  min-height: 100svh;
  padding: 128px 0 58px;
  display: grid;
  align-items: end;
}

.creator-hero .container {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .52fr);
  gap: 44px;
  align-items: end;
}

.creator-route .creator-hero::before {
  background-image: linear-gradient(90deg, rgba(0, 0, 0, .72), rgba(0, 0, 0, .2) 54%, rgba(0, 0, 0, .54)), var(--bg);
  background-position: center;
  opacity: 1;
}

.destinations-hero {
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: 128px 0 58px;
}

.destinations-hero::before {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, .2), rgba(0, 0, 0, .74)), var(--bg);
  background-position: center;
  opacity: 1;
}
.destinations-hero::after,
.creator-route .creator-hero::after {
  content: none;
}

.destinations-hero .container {
  max-width: 980px;
  margin-left: max(24px, calc((100vw - var(--max)) / 2));
  margin-right: auto;
  text-align: left;
}

.destinations-hero h1 {
  max-width: 840px;
  font-size: clamp(3.9rem, 8.4vw, 8.4rem);
  line-height: .82;
  letter-spacing: 0;
  text-transform: uppercase;
}

.destinations-hero .hero-body {
  max-width: 640px;
}

.destinations-picks,
.destinations-personas {
  padding: 124px 0;
}

.destinations-picks::before,
.destinations-personas::before {
  background-image: linear-gradient(180deg, rgba(8, 8, 8, .88), rgba(8, 8, 8, .72)), var(--bg);
}

.destinations-shop {
  padding: 124px 0;
  background: linear-gradient(180deg, #070707, #0d0b09 55%, #070707);
}

.destinations-shop .section-intro h2 span {
  display: inline-block;
  margin-top: 8px;
  color: var(--accent);
  font-size: .62em;
  line-height: .9;
}

.destination-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.destination-card-grid .trip-card {
  min-height: 430px;
  width: 100%;
  flex: none;
}

.destination-card-grid .trip-card:nth-child(even) {
  transform: translateY(28px);
}

.destination-card-grid .trip-card h4 {
  margin: 0;
}

.destination-title-block {
  margin-top: auto;
  margin-bottom: 18px;
}

.destination-country {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  color: rgba(242, 235, 221, .88);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .78rem;
  line-height: 1;
  font-weight: 900;
}

.destination-country .fi {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  display: block;
  padding: 0;
  border-radius: 999px;
  border: 0;
  background-color: transparent;
  background-size: cover;
  background-position: center;
  box-shadow: none;
}

.trip-card .destination-country span:not(.fi) {
  align-self: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font-size: inherit;
  line-height: 1;
  letter-spacing: inherit;
  font-weight: inherit;
  text-transform: inherit;
  box-shadow: none;
}

.destinations-final-cta {
  padding: 124px 0;
}

.destination-final-grid {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, .62fr);
  gap: 52px;
  align-items: center;
}

.destination-final-copy h2 {
  max-width: 760px;
  font-size: clamp(4rem, 8vw, 8.4rem);
  line-height: .82;
  text-transform: uppercase;
}

.destination-final-stack {
  display: grid;
  gap: 16px;
}

.destination-final-stack .waitlist-persona-card {
  position: relative;
  width: 100%;
  min-height: 190px;
  padding: 22px;
  transform: rotate(var(--tilt, 0deg));
}

.destination-final-stack .waitlist-persona-card:hover,
.destination-final-stack .waitlist-persona-card:focus-within {
  transform: rotate(var(--tilt, 0deg)) scale(1.035);
}

.destination-final-stack .waitlist-persona-card:nth-child(1) {
  --tilt: -3deg;
}

.destination-final-stack .waitlist-persona-card:nth-child(2) {
  --tilt: 2.2deg;
  margin-left: 20px;
}

.destination-final-stack .waitlist-persona-card:nth-child(3) {
  --tilt: -1.6deg;
  margin-left: -10px;
}

.destination-final-stack .waitlist-persona-card strong {
  font-size: clamp(2.6rem, 4vw, 4.2rem);
}

.persona-hero,
.info-hero {
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: 128px 0 58px;
}

.persona-hero::before {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, .2), rgba(0, 0, 0, .74)), var(--bg);
  background-position: center;
  opacity: 1;
}

.info-hero::before {
  background-image: linear-gradient(180deg, rgba(0, 0, 0, .18), rgba(0, 0, 0, .78)), var(--bg);
  background-position: center;
  opacity: 1;
}

.persona-hero .container,
.info-hero .container {
  max-width: 920px;
  margin-left: max(24px, calc((100vw - var(--max)) / 2));
  margin-right: auto;
}

.persona-hero h1,
.info-hero h1 {
  max-width: 880px;
  font-size: clamp(4rem, 9vw, 9.2rem);
  line-height: .82;
  text-transform: uppercase;
}

.persona-pain,
.persona-story {
  padding: 124px 0;
}

.persona-pain::before,
.persona-story::before {
  background-image: linear-gradient(180deg, rgba(8, 8, 8, .9), rgba(8, 8, 8, .72)), var(--bg);
}

.persona-feature-grid {
  margin-bottom: 0;
}

.persona-loop-section,
.persona-shop,
.info-content {
  padding: 124px 0;
  background: linear-gradient(180deg, #070707, #0d0b09 55%, #070707);
}

.persona-story-grid {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(300px, .52fr);
  gap: 42px;
  align-items: center;
}

.persona-story-card {
  min-height: 500px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 28px;
  border-radius: var(--radius);
  border: 1px solid rgba(242, 235, 221, .13);
  box-shadow: 0 30px 90px rgba(0, 0, 0, .38), inset 0 1px rgba(255, 255, 255, .08);
}

.persona-story-card .stamp-sticker {
  width: max-content;
  margin-bottom: 12px;
}

.persona-story-card blockquote {
  max-width: 30ch;
  margin: 0;
  color: var(--warm-ivory);
  font-size: 1.6em;
  line-height: 1.42;
  font-style: italic;
}

.persona-story-card blockquote::before,
.persona-story-card blockquote::after {
  color: var(--sunset-amber);
  font-family: var(--font-head);
  font-size: 1.6em;
  line-height: 0;
}

.persona-story-card blockquote::before {
  content: open-quote;
  margin-right: 4px;
}

.persona-story-card blockquote::after {
  content: close-quote;
  margin-left: 4px;
}

.info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.creator-route .creator-hero .container {
  grid-template-columns: minmax(0, 1fr);
}

.creator-hero h1 {
  max-width: 860px;
}

.creator-hero-copy {
  padding-bottom: 0;
}

.creator-stat-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.creator-stat-row span {
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(242, 235, 221, .1);
  color: rgba(242, 235, 221, .68);
}

.creator-stat-row i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: var(--sunset-amber);
  background: rgba(255, 122, 24, .13);
}

.creator-stat-row strong {
  display: block;
  color: var(--warm-ivory);
  font-family: var(--font-head);
  font-size: 2.4rem;
  line-height: .8;
}

.creator-stat-row em {
  font-style: normal;
  line-height: 1.25;
}

.creator-phone-section {
  padding: 128px 0;
  background: linear-gradient(180deg, #070707, #0d0b09 55%, #070707);
}

.creator-phone-grid {
  display: grid;
  grid-template-columns: minmax(320px, .62fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

.creator-phone-stage {
  position: relative;
  min-height: 640px;
  display: grid;
  place-items: center;
}

.creator-phone-stage .phone-wrap {
  position: relative;
  left: auto;
  top: auto;
  transform: none;
  width: min(360px, 82vw);
}

.creator-float {
  position: absolute;
  z-index: 8;
  width: min(200px, 44vw);
  padding: 18px;
  border-radius: 22px;
  background: rgba(8, 10, 9, .7);
  border: 1px solid rgba(242, 235, 221, .14);
  backdrop-filter: blur(16px);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .42);
  animation: var(--anim-float);
}

.creator-float span {
  color: var(--sunset-amber);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .72rem;
  font-weight: 850;
}

.creator-float strong {
  display: block;
  margin-top: 6px;
  font-size: 1.2rem;
}

.creator-float small {
  color: rgba(242, 235, 221, .62);
}

.cf-one {
  right: 0;
  bottom: 24%;
  animation-delay: -1.4s;
}

.cf-two {
  left: 8%;
  bottom: 2%;
  animation-delay: -2.4s;
}

.cf-three {
  left: 0%;
  bottom: -10%;
  animation-delay: -3.4s;
}

.creator-phone-copy .creator-stat-row {
  margin: 26px 0 26px;
}

.creator-detail-grid,
.creator-reward-grid,
.creator-faq-list {
  display: grid;
  gap: 12px;
}

.creator-detail-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 180px;
}

.creator-reward-grid {
  display: grid;
  gap: 18px;
}

.creator-reward-grid {
  grid-template-columns: repeat(2, 1fr);
}

.creator-persona-intro {
  margin-top: 0;
}

.creator-info-card,
.creator-reward-card,
.creator-faq-card {
  padding: 24px;
  border-radius: 26px;
  border: 1px solid rgba(242, 235, 221, .13);
  background: linear-gradient(180deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .035));
  box-shadow: 0 24px 70px rgba(0, 0, 0, .32);
  backdrop-filter: blur(8px);
}

.creator-info-card.featured {
  background: var(--grad-irid-mid);
  border: 1px solid var(--burnt-gold);
}

.creator-info-card i,
.creator-reward-card i {
  color: var(--sunset-amber);
  font-size: 2rem;
}

.creator-info-card h3,
.creator-reward-card h3,
.creator-faq-card h3 {
  margin-top: 18px;
  font-family: var(--font-head);
  font-size: 3rem;
  line-height: .88;
  text-transform: uppercase;
}

.creator-info-card p,
.creator-reward-card p,
.creator-faq-card p {
  color: rgba(242, 235, 221, .72);
  line-height: 1.5;
}

.creator-faq-list {
  max-width: 860px;
  margin: 0 auto;
}

.creator-faq-card {
  padding: 0;
  overflow: hidden;
}

.creator-faq-card summary {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 0 22px;
  cursor: pointer;
  color: var(--warm-ivory);
  font-weight: 850;
  font-size: 1.1rem;
  list-style: none;
}

.creator-faq-card summary::-webkit-details-marker {
  display: none;
}

.creator-faq-card summary i {
  color: var(--sunset-amber);
  transition: transform .2s ease;
}

.creator-faq-card[open] summary i {
  transform: rotate(180deg);
}

.creator-faq-card p {
  margin: 0;
  padding: 0 22px 22px;
}

.reel-section .creator-reward-card {
  min-height: 260px;
}

.reel-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .46fr);
  gap: 44px;
  align-items: center;
}

.reel-copy .section-intro {
  margin-bottom: 28px;
}

.reel-photo-stack {
  position: relative;
  min-height: 640px;
}


.reel-photo-stack .waitlist-persona-card strong {
  font-size: 2.2rem;
}


.rpc-one {
  top: 0;
  right: -80px;
  transform: rotate(3deg);
}

.rpc-two {
  top: 0px;
  right: -24px;
  transform: rotate(-4deg);
}

.rpc-three {
  bottom: 0;
  right: -64px;
  transform: rotate(2deg);
}

.creator-calculator {
  padding: 120px 0;
}

.calculator-panel {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(320px, .72fr);
  gap: 30px;
  padding: 28px;
  border-radius: 30px;
  border: 1px solid rgba(242, 235, 221, .14);
  background: rgba(7, 8, 7, .68);
  backdrop-filter: blur(18px);
  box-shadow: 0 34px 100px rgba(0, 0, 0, .44);
}

.calculator-fields {
  display: grid;
  gap: 16px;
}

.calculator-fields label,
.creator-application-form label {
  display: grid;
  gap: 7px;
}

.calculator-fields span,
.creator-application-form label span {
  color: rgba(242, 235, 221, .58);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 800;
}

.calculator-fields span {
  font-size: 1.0rem;
}

.calculator-fields input,
.calculator-fields select,
.creator-application-form input,
.creator-application-form select,
.creator-application-form textarea {
  width: 100%;
  min-height: 54px;
  border-radius: 20px;
  border: 1px solid rgba(242, 235, 221, .13);
  background: rgba(7, 8, 7, .7);
  color: var(--warm-ivory);
  padding: 0 18px;
  outline: none;
}

.calculator-fields select,
.creator-application-form select {
  appearance: none;
  background-color: rgba(7, 8, 7, .7);
  background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23F2EBDD' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 16px;
  padding-right: 46px;
}

.calculator-fields input[type="range"] {
  min-height: 30px;
  padding: 0;
  border: 0;
  background: transparent;
  accent-color: var(--accent);
}

.calculator-fields input[type="range"]::-webkit-slider-runnable-track {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 122, 24, .8), rgba(242, 235, 221, .14));
}

.calculator-fields input[type="range"]::-webkit-slider-thumb {
  width: 22px;
  height: 22px;
  margin-top: -7px;
  border-radius: 50%;
  border: 2px solid var(--warm-ivory);
  background: var(--accent);
  box-shadow: 0 8px 20px rgba(0, 0, 0, .35);
  appearance: none;
}

.calculator-fields input[type="range"]::-moz-range-track {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 122, 24, .8), rgba(242, 235, 221, .14));
}

.calculator-fields input[type="range"]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--warm-ivory);
  background: var(--accent);
  box-shadow: 0 8px 20px rgba(0, 0, 0, .35);
}

.range-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.range-head output {
  color: var(--warm-ivory);
  font-weight: 850;
  letter-spacing: 0;
}

.creator-application-form textarea {
  min-height: 110px;
  padding-top: 15px;
  resize: vertical;
}

.calculator-fields input:focus,
.calculator-fields select:focus,
.creator-application-form input:focus,
.creator-application-form select:focus,
.creator-application-form textarea:focus {
  border-color: rgba(255, 122, 24, .44);
  box-shadow: 0 0 0 4px rgba(255, 122, 24, .11);
}

.calculator-results {
  display: grid;
  align-content: stretch;
  gap: 20px;
  padding: 26px;
  border-radius: 26px;
  background: linear-gradient(135deg, rgba(255, 122, 24, .14), rgba(255, 255, 255, .04));
  border: 1px solid rgba(255, 122, 24, .2);
}

.calculator-results span {
  color: rgba(242, 235, 221, .62);
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .75rem;
  font-weight: 850;
}

.calculator-results strong {
  display: block;
  font-family: var(--font-head);
  font-size: clamp(3.6rem, 8vw, 7rem);
  color: var(--c-success);
  text-shadow: 0 0 28px rgba(var(--c-success-rgb), .18);
}

.calculator-results .converted-count {
  font-size: clamp(2.8rem, 5vw, 4.6rem);
  color: var(--mist-white);
}
.calculator-results .yearly-profit {
  font-size: clamp(2.8rem, 5vw, 4.6rem);
}

.calculator-results p {
  margin: 0;
  color: rgba(242, 235, 221, .68);
}

.calculator-disclaimer {
  align-self: end;
  padding-top: 8px;
  color: rgba(242, 235, 221, .5) !important;
  font-size: .88rem !important;
  font-style: italic;
  line-height: 1.35;
}

.creator-final-cta {
  text-align: left;
  padding: 240px 0;
}
.creator-final-cta::after {
  background-position: center;
}
.creator-final-cta::after {
  content: none;
}

.creator-final-cta h2 {
  max-width: 740px;
  font-size: clamp(4rem, 9vw, 8rem);
}

.creator-application-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 24px;
}

.creator-application-form label[for="creatorMessage"],
.creator-application-form .creator-submit,
.creator-status {
  grid-column: 1 / -1;
}

.form-consent {
  grid-column: 1 / -1;
  display: flex !important;
  align-items: center;
  gap: 10px;
  color: rgba(242, 235, 221, .74);
  font-size: .86rem;
  line-height: 1.35;
}

.form-consent input {
  width: 18px;
  min-width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--sunset-amber);
}

.form-consent a {
  color: var(--sunset-amber);
  text-decoration: none;
}

.creator-final-cta .cta-row {
  justify-content: start;
}

.legal-hero {
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: 128px 0 58px;
  background: radial-gradient(circle at 14% 0%, rgba(255, 122, 24, .16), transparent 36%), var(--black);
}

.legal-hero .container,
.legal-doc {
  max-width: 960px;
}

.legal-hero h1 {
  max-width: 900px;
  font-size: clamp(3.4rem, 8vw, 7.4rem);
  line-height: .84;
  text-transform: uppercase;
}

.legal-document {
  padding: 36px 0 110px;
}

.legal-doc {
  color: rgba(242, 235, 221, .78);
}

.legal-doc h2,
.legal-doc h3 {
  color: var(--warm-ivory);
  font-family: var(--font-head);
  text-transform: uppercase;
  letter-spacing: 0;
}

.legal-doc h2 {
  margin: 34px 0 12px;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: .9;
}

.legal-doc h3 {
  margin: 22px 0 8px;
  font-size: 1.45rem;
}

.legal-doc p,
.legal-doc li {
  line-height: 1.65;
}

.legal-doc ul {
  display: grid;
  gap: 8px;
  padding-left: 22px;
}

/* Image cards and hover zooms */
.pain-card,
.trip-card,
.persona-card,
.shop-card,
.story-card,
.persona-story-card,
.price-card,
.waitlist-persona-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: none !important;
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}

.creator-card {
  transition: border-color .3s ease, box-shadow .3s ease, transform .3s ease;
}

.pain-card::before,
.trip-card::before,
.persona-card::before,
.shop-card::before,
.story-card::before,
.persona-story-card::before,
.price-card::before,
.waitlist-persona-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background: var(--img) center/cover;
  transition: transform .75s cubic-bezier(.2, .8, .2, 1), filter .75s cubic-bezier(.2, .8, .2, 1);
}

.pain-card::after,
.trip-card::after,
.persona-card::after,
.shop-card::after,
.story-card::after,
.persona-story-card::after,
.price-card::after,
.waitlist-persona-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(0, 0, 0, .06) 32%, rgba(0, 0, 0, .84));
  pointer-events: none;
}

.reel-photo-stack .waitlist-persona-card::after,
.destination-final-stack .waitlist-persona-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .05), rgba(0, 0, 0, .44));
}

.pain-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .06) 32%, rgba(0, 0, 0, .6) 60%, rgba(0, 0, 0, .84));
}

.persona-story-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .06) 32%, rgba(0, 0, 0, .6) 60%, rgba(0, 0, 0, .84));
}

.shop-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .6) 0%, rgba(0, 0, 0, .06) 40%, rgba(0, 0, 0, .84));
}

.price-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .44) 30%, rgba(0, 0, 0, .9));
}

.waitlist-persona-card::after {
  background: linear-gradient(180deg, rgba(0, 0, 0, .05), rgba(0, 0, 0, .86));
}

.pain-card:hover::before,
.trip-card:hover::before,
.persona-card:hover::before,
.shop-card:hover::before,
.story-card:hover::before,
.persona-story-card:hover::before,
.waitlist-persona-card:hover::before {
  transform: scale(1.065);
}

.price-card:hover {
  border-color: rgba(255, 122, 24, .36);
  box-shadow: 0 34px 110px rgba(0, 0, 0, .5), 0 0 45px rgba(255, 122, 24, .12);
}
.price-card:hover::before {
  transform: scale(1.08);
  filter: blur(8px) saturate(1.12);
}

.trip-card:hover,
.persona-card:hover,
.shop-card:hover,
.story-card:hover,
.waitlist-persona-card:hover {
  border-color: rgba(245, 166, 35, .44);
}

.waitlist-persona-card:hover {
  z-index: 3;
}


/* Footer */
.footer {
  padding: 70px 0 28px;
  background: linear-gradient(180deg, #080808, #050505);
  border-top: 1px solid rgba(242, 235, 221, .08);
  position: relative;
  z-index: 3;
  overflow: hidden;
}

.footer p,
.footer-social-row,
.footer-bottom {
  color: rgba(242, 235, 221, .62);
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 32px;
}

.footer nav {
  display: grid;
  gap: 9px;
  align-content: start;
}

.footer h4 {
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: rgba(245, 166, 35, .72);
  font-size: .72rem;
}

.footer a:not(.brand) {
  color: rgba(242, 235, 221, .62);
  border-radius: 10px;
}

.footer a:not(.brand):hover,
.footer a:not(.brand):focus-visible,
.footer a:not(.brand).is-active {
  color: var(--accent);
  outline: 0;
}

.footer a:not(.brand):active {
  color: var(--sunset-amber);
  transform: translateY(1px);
}

.socials {
  display: flex;
  gap: 12px;
  align-items: center;
}

.socials a {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: rgba(242, 235, 221, .72);
  background: rgba(255, 255, 255, .00);
  border: 1px solid rgba(242, 235, 221, .00);
  font-size: 1.2rem;
}

.socials a:hover,
.socials a:focus-visible {
  color: var(--sunset-amber) !important;
  border-color: rgba(255, 122, 24, .38);
  box-shadow: 0 0 28px rgba(255, 122, 24, .16);
  transform: translateY(-2px);
  outline: 0;
}

.socials a:active {
  transform: translateY(0) scale(.96);
  background: rgba(255, 122, 24, .12);
}

.footer-social-row {
  margin-top: 18px;
  padding-top: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.footer-megaword {
  width: 100%;
  margin: 64px auto;
  font-family: var(--font-ui);
  font-size: clamp(6.2rem, 24vw, 17rem);
  line-height: .76;
  letter-spacing: 0;
  text-align: center;
  font-weight: 800;
  color: rgba(242, 235, 221, .90);
  text-transform: uppercase;
  user-select: none;
}

.footer-bottom {
  margin-top: 18px;
  padding-top: 0;
  display: flex;
  justify-content: center;
  text-align: center;
  gap: 20px;
  flex-wrap: wrap;
  color: rgba(242, 235, 221, .42);
  font-size: .86rem;
}

/* Motion */
.float {
  animation: var(--anim-float);
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .75s ease, transform .75s ease;
}

.reveal.in {
  opacity: 1;
  transform: translateY(0);
}

.delay-1 {
  transition-delay: .12s;
}

.delay-2 {
  transition-delay: .22s;
}

.delay-3 {
  transition-delay: .32s;
}

@media (max-height:820px) and (min-width:900px) {
  .hero {
    padding-top: 84px;
    padding-bottom: 24px;
  }

  .hero-grid {
    min-height: calc(100svh - 108px);
  }

  .hero h1 {
    font-size: clamp(4.2rem, 7.6vw, 7.8rem);
  }

  .hero-body {
    font-size: .96rem;
    max-width: 560px;
  }

  .hero-visual {
    min-height: 500px;
  }

  .phone-wrap {
    width: min(330px, 45vw);
  }
}

@media (max-width:1100px) {
  .hero {
    min-height: auto;
    padding-top: 116px;
  }

  .hero-grid,
  .creator-hero .container,
  .creator-phone-grid,
  .calculator-panel,
  .loop-scene,
  .scene-expenses,
  .scene-earn,
  .shop-grid,
  .passport-stage,
  .pricing-head,
  .creator-grid,
  .waitlist-grid,
  .persona-story-grid {
    grid-template-columns: 1fr;
  }

  .hero-grid {
    min-height: 0;
  }

  .hero-visual {
    min-height: 650px;
  }

  .phone-wrap {
    left: 50%;
  }

  .pain-grid,
  .pricing-grid,
  .story-grid,
  .pillar-grid,
  .creator-detail-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .creator-reward-grid,
  .creator-faq-list,
  .info-grid {
    grid-template-columns: 1fr;
  }

  .destination-final-grid {
    grid-template-columns: 1fr;
  }

  .reel-grid {
    grid-template-columns: 1fr;
  }

  .reel-photo-stack {
    min-height: 520px;
  }

  .creator-cards {
    min-height: 500px;
  }

  .waitlist-personas {
    min-height: 460px;
  }

  .footer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width:820px) {
  .site-header {
    grid-template-columns: auto auto;
    min-height: 60px;
    width: calc(100% - 24px);
    padding-left: 14px;
    padding-right: 12px;
  }

  .nav-toggle {
    display: block;
    justify-self: end;
    font-size: 1.4rem;
  }

  .header-actions {
    display: none;
  }

  .nav-links {
    position: fixed;
    inset: 75px 12px auto;
    display: grid;
    justify-items: center;
    gap: 4px;
    padding: 18px;
    border-radius: 24px;
    background: rgba(7, 7, 7, .94);
    border: 1px solid rgba(242, 235, 221, .12);
    transform: translateY(-12px);
    opacity: 0;
    pointer-events: none;
    transition: .25s ease;
  }

  .nav-links.open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .nav-links a {
    width: min(310px, 100%);
    padding: 13px;
    border-radius: 14px;
    text-align: center;
  }

  .nav-menu,
  .nav-links .language-menu {
    width: 310px;
    max-width: 100%;
    justify-self: center;
  }

  .nav-menu-toggle {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    padding: 0 13px;
    border-radius: 14px;
    position: relative;
    text-align: center;
  }

  .nav-menu-toggle i {
    position: absolute;
    right: 13px;
  }

  .nav-menu::after {
    display: none;
  }

  .nav-menu-panel {
    position: static;
    min-width: 0;
    width: 100%;
    padding: 4px 0 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    display: none;
  }

  .nav-menu-panel a {
    justify-self: center;
    text-align: center;
  }

  .nav-menu.is-open .nav-menu-panel,
  .nav-menu:hover .nav-menu-panel {
    display: grid;
    transform: none;
  }

  .nav-menu:not(.is-open) .nav-menu-panel {
    display: none !important;
  }

  .nav-links .language-toggle {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    border-radius: 14px;
    padding: 0 13px;
    position: relative;
    text-align: center;
  }

  .nav-links .language-toggle i {
    position: absolute;
    right: 13px;
    margin-left: 0;
  }

  .nav-links .language-panel {
    position: static;
    width: 100%;
    min-width: 0;
    left: auto;
    right: auto;
    margin-top: 4px;
    border: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    display: none;
    opacity: 1;
    pointer-events: auto;
    transform: none;
  }

  .nav-links .language-panel button {
    width: 100%;
    justify-content: center;
  }

  .nav-links .language-menu.is-open .language-panel {
    display: grid;
  }

  .nav-language {
    display: flex;
  }

  .nav-links .nav-language {
    display: grid;
  }

  .container {
    width: min(100% - 28px, var(--max));
  }

  section {
    padding: 82px 0;
  }

  h1 {
    font-size: clamp(4.2rem, 17vw, 6.4rem);
  }

  .section-intro h2,
  .pricing-head h2,
  .shop-copy h2,
  .waitlist-copy h2,
  .creator-copy h2,
  .creator-phone-copy h2,
  .calculator-panel h2 {
    font-size: clamp(3.8rem, 15vw, 6rem);
  }

  .eyebrow {
    letter-spacing: .28em;
  }

  .hero {
    padding: 98px 0 32px;
  }

  .hero-grid {
    gap: 30px;
  }

  .hero-copy {
    max-width: 100%;
    padding: 0 2px;
  }

  .hero-body {
    max-width: 100%;
    font-size: 1rem;
    line-height: 1.45;
  }

  .cta-row {
    margin: 22px 0 18px;
  }

  .hero-visual {
    min-height: 560px;
  }

  .phone-wrap {
    width: min(330px, 88vw);
    top: 50%;
  }

  .floating-card {
    display: none;
  }

  .loop-title-nowrap {
    display: grid;
    justify-items: center;
    gap: 8px;
    white-space: normal;
    font-size: clamp(3.2rem, 18vw, 6.5rem) !important;
  }

  .loop-arrow {
    transform: rotate(90deg);
    margin: -8px 0;
  }

  .loop-arrow i {
    font-size: .42em;
  }

  .trip-strip {
    padding: 0 22px;
  }

  .trip-card {
    flex-basis: 280px;
    min-height: 360px;
  }

  .destination-card-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .destination-card-grid .trip-card {
    min-height: 360px;
  }

  .destination-card-grid .trip-card:nth-child(even) {
    transform: none;
  }

  .destinations-hero {
    padding: 112px 0 44px;
  }

  .persona-hero,
  .info-hero {
    padding: 112px 0 44px;
  }

  .destinations-hero h1,
  .persona-hero h1,
  .info-hero h1 {
    font-size: clamp(3.4rem, 15vw, 5.6rem);
  }

  .expense-stage {
    min-height: auto;
    display: block;
  }

  .reward-float {
    position: relative;
    inset: auto !important;
    margin: 12px 0;
  }

  .total-card {
    grid-template-columns: 1fr;
  }

  .total-card svg {
    grid-column: 1;
    grid-row: auto;
    width: 100%;
    margin-top: 12px;
  }

  .earn-cascade {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .earn-cascade article {
    min-height: 180px;
  }

  .earn-cascade article:nth-child(even) {
    transform: none;
  }

  .persona-grid.scroll-x,
  .shop-shelf {
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, minmax(260px, 1fr));
    grid-auto-columns: minmax(240px, 78vw);
    gap: 14px;
    width: calc(100vw - 28px);
    padding: 36px 24px 36px;
    overflow-x: auto;
    mask-image: linear-gradient(90deg, #000 0 88%, transparent 100%);
  }

  .persona-card,
  .shop-card {
    min-height: 260px;
    flex: initial;
  }

  .persona-card:nth-child(odd),
  .shop-card:nth-child(odd) {
    transform: translateX(24px);
  }

  .persona-card:nth-child(even),
  .shop-card:nth-child(even) {
    transform: translateX(-18px);
  }

  .persona-card h3 {
    font-size: 3.1rem;
  }

  .shop-controls {
    padding-right: 4px;
  }

  .pillar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .pillar-card {
    min-height: 220px;
    padding: 22px;
  }

  .pillar-card.tilt-up {
    transform: none;
  }

  .pillar-card h3 {
    font-size: 3.8rem;
    margin-top: 42px;
  }

  .passport-metrics {
    grid-template-columns: 1fr;
  }

  .story-grid,
  .pricing-grid {
    grid-template-columns: 1fr;
  }

  .creator-cards {
    min-height: auto;
    display: grid;
    gap: 14px;
  }

  .creator-card,
  .invite-card,
  .reel-card,
  .crew-card {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    min-height: 230px;
    transform: none;
  }

  .invite-card:hover,
  .reel-card:hover,
  .crew-card:hover {
    transform: translateY(-2px);
  }

  .waitlist-personas {
    min-height: auto;
    display: grid;
    gap: 12px;
  }

  .waitlist-persona-card,
  .wp-one,
  .wp-two,
  .wp-three {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    min-height: 210px;
    transform: none;
  }

  .wp-one:hover,
  .wp-two:hover,
  .wp-three:hover {
    transform: translateY(-2px);
  }

  .waitlist-form {
    display: grid;
  }

  .waitlist-form label {
    min-width: 0;
  }

  .waitlist-form button {
    width: 100%;
  }

  .waitlist-dialog {
    padding: 26px 18px;
    border-radius: 24px;
  }

  .modal-waitlist-form {
    grid-template-columns: 1fr;
  }

  .waitlist-dialog h2 {
    padding-right: 38px;
  }

  .creator-hero {
    min-height: 100svh;
    padding-top: 112px;
  }

  .creator-hero-copy {
    padding-bottom: 0;
  }

  .creator-stat-row {
    grid-template-columns: 1fr;
  }

  .creator-phone-stage {
    min-height: 540px;
  }

  .creator-float {
    position: relative;
    inset: auto !important;
    width: 100%;
    margin: 10px 0;
  }

  .creator-phone-stage {
    display: block;
  }

  .creator-phone-stage .phone-wrap {
    margin: 0 auto 18px;
  }

  .creator-detail-grid,
  .creator-application-form {
    grid-template-columns: 1fr;
  }

  .reel-photo-stack {
    min-height: auto;
  }

  .footer-social-row {
    display: grid;
    text-align: left;
  }

  .footer-social-row {
    justify-items: center;
    text-align: center;
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

}

@media (max-width:560px) {
  .site-header {
    top: 10px;
    width: calc(100% - 18px);
  }

  .brand {
    letter-spacing: .12em;
  }

  .brand-logo {
    width: 26px;
    height: 26px;
  }

  .hero {
    padding-top: 92px;
  }

  h1 {
    font-size: clamp(3.65rem, 16vw, 5.35rem);
  }

  .hero-visual {
    min-height: 470px;
  }

  .phone-wrap {
    width: min(300px, 86vw);
  }

  .pain-grid {
    grid-template-columns: 1fr;
  }

  .pain-card {
    min-height: 480px;
  }

  .pain-card.lifted {
    margin-top: 0;
  }

  .price-card {
    min-height: auto;
  }

  .price-card strong {
    margin-top: 30px;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px 18px;
  }

  .footer-bottom {
    display: grid;
  }

  .footer-megaword {
    font-size: clamp(4rem, 25vw, 5rem);
    max-width: 100vw;
    overflow: hidden;
  }
}

@media (prefers-reduced-motion:reduce) {

  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }

  #atmosphere {
    display: none;
  }
}
