/* ============================================================
   RETROCAST LANDING — landing.css
   Extracted from Landing Healen.html. Do not edit inline.
   ============================================================ */

:root {
  --ink:        #0d0e0a;
  --ink-2:      #1a1b15;
  --paper:      #f4f1e6;
  --paper-2:    #ebe7d8;
  --cream:      #faf7ee;
  --muted-ink:  #5b5d52;
  --muted-pap:  rgba(244,241,230,0.62);
  --line:       rgba(13,14,10,0.10);
  --line-pap:   rgba(244,241,230,0.16);
  --lime:       #d6ff3a;
  --lime-deep:  #b8df1c;
  --display: "Bricolage Grotesque", "Inter Tight", system-ui, sans-serif;
  --body:    "Inter Tight", system-ui, sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, monospace;
}
*, *::before, *::after { box-sizing: border-box; -webkit-font-smoothing: antialiased; }
html, body { margin: 0; padding: 0; }
body { font-family: var(--body); background: var(--paper); color: var(--ink); font-size: 16px; line-height: 1.5; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: 0; background: none; }
::selection { background: var(--lime); color: var(--ink); }

/* ============================================================
   TYPE PRIMITIVES
   ============================================================ */
.display {
  font-family: var(--display);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 0.96;
  text-wrap: balance;
  margin: 0;
}
.h-xl  { font-size: clamp(54px, 7.6vw, 124px); }
.h-l   { font-size: clamp(40px, 5.4vw, 84px); }
.h-m   { font-size: clamp(32px, 3.8vw, 56px); }
.h-s   { font-size: clamp(22px, 2vw, 28px); }

.label {
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted-ink);
}
.lede {
  font-family: var(--body);
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.5;
  color: var(--muted-ink);
  text-wrap: pretty;
  max-width: 56ch;
}
.on-ink .lede,    .on-ink   .label { color: var(--muted-pap); }
.on-ink .label    { color: rgba(244,241,230,0.55); }
.on-lime .label   { color: rgba(13,14,10,0.55); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 28px;
  border-radius: 999px;
  font-family: var(--display);
  font-weight: 500;
  font-size: 15.5px;
  letter-spacing: -0.005em;
  transition: transform .25s ease, background .25s ease, color .25s ease;
  will-change: transform;
}
.btn:hover { transform: translateY(-1px); }
.btn .arr {
  display: inline-block; width: 18px; height: 14px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 14'><path d='M1 7h15M10 1l6 6-6 6' stroke='black' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 14'><path d='M1 7h15M10 1l6 6-6 6' stroke='black' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
  transition: transform .25s ease;
}
.btn:hover .arr { transform: translateX(4px); }
.btn-lime  { background: var(--lime); color: var(--ink); }
.btn-lime:hover  { background: var(--lime-deep); }
.btn-ink   { background: var(--ink); color: var(--paper); }
.btn-ink:hover   { background: #000; }
.btn-pap   { background: var(--paper); color: var(--ink); }
.btn-pap:hover   { background: var(--cream); }
.btn-ghost-pap { background: transparent; color: var(--paper); border: 1px solid var(--line-pap); }
.btn-ghost-pap:hover { background: rgba(244,241,230,0.08); }
.btn-ghost-ink { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn-sm { padding: 10px 18px; font-size: 13.5px; }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-stagger > * { opacity: 0; transform: translateY(18px); transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal-stagger.in > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.in > *:nth-child(1){ transition-delay: .04s; }
.reveal-stagger.in > *:nth-child(2){ transition-delay: .12s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay: .20s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay: .28s; }
.reveal-stagger.in > *:nth-child(5){ transition-delay: .36s; }

/* ============================================================
   CINEMATIC PLACEHOLDER STILLS
   ============================================================ */
.still {
  position: relative; overflow: hidden; isolation: isolate;
  background: #1f201a;
  border-radius: inherit;
}
.still::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(120% 80% at 30% 20%, rgba(255,255,255,0.20), transparent 60%),
    radial-gradient(80% 60% at 80% 85%, rgba(0,0,0,0.55), transparent 70%),
    var(--still-grad, linear-gradient(135deg, #6a7a3a, #1a1c14));
  z-index: 0;
}
.still::after {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.35'/></svg>");
  mix-blend-mode: overlay; opacity: .35; pointer-events: none; z-index: 1;
}
.still > * { position: relative; z-index: 2; }
.still .letterbox { position: absolute; left: 0; right: 0; height: 28px; background: rgba(0,0,0,0.55); z-index: 2; }
.still .letterbox.t { top: 0; } .still .letterbox.b { bottom: 0; }
.still .corner {
  position: absolute; bottom: 14px; left: 14px;
  color: rgba(245,240,226,0.92);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
  z-index: 3; text-shadow: 0 2px 8px rgba(0,0,0,0.7);
}
.still .corner.r { left: auto; right: 14px; text-align: right; }
.still .center-title {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--display); font-weight: 500;
  font-size: clamp(20px, 2.2vw, 30px);
  color: rgba(245,240,226,0.95);
  letter-spacing: -0.015em; text-shadow: 0 4px 24px rgba(0,0,0,0.6);
  z-index: 3; padding: 32px; text-align: center; text-wrap: balance;
}

.palette-inception { --still-grad: linear-gradient(135deg, #adb6c0 0%, #2a3038 60%, #14171c 100%); }
.palette-matrix    { --still-grad: linear-gradient(135deg, #4a5a2a 0%, #0a1e10 60%, #04100a 100%); }
.palette-blade     { --still-grad: linear-gradient(135deg, #d4894a 0%, #5a2c14 60%, #1c0a04 100%); }
.palette-mad-max   { --still-grad: linear-gradient(135deg, #e09a4a 0%, #8a3014 60%, #2a0c04 100%); }
.palette-anni      { --still-grad: linear-gradient(135deg, #98c4a4 0%, #2c4a44 60%, #0e1a1c 100%); }
.palette-oppen     { --still-grad: linear-gradient(135deg, #d4be8a 0%, #4a3c1c 60%, #181208 100%); }
.palette-oceans    { --still-grad: linear-gradient(135deg, #d8b46a 0%, #4a3416 60%, #14100a 100%); }
.palette-no-time   { --still-grad: linear-gradient(135deg, #6a90b8 0%, #1c2a3c 60%, #08101c 100%); }

/* iconographic SVG art layered on still gradients (movie cards) */
.still-art {
  position: absolute; inset: 28px 0; z-index: 1; pointer-events: none;
  overflow: hidden;
}
.still-art svg { width: 100%; height: 100%; display: block; }
.movie-card .still .center-title {
  position: absolute; left: 0; right: 0; bottom: 56px; top: auto;
  display: block; padding: 0 22px;
  text-align: left; font-size: 26px; line-height: 1.05;
  letter-spacing: -0.02em; opacity: 0.96;
  text-shadow: 0 2px 18px rgba(0,0,0,0.55);
}

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 20px 32px;
  transition: background .3s ease, backdrop-filter .3s ease;
}
.nav.scrolled { background: rgba(13,14,10,0.78); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.nav-inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  color: var(--paper);
}
.nav-brand {
  font-family: var(--display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em;
  display: inline-flex; align-items: center; gap: 8px;
}
.nav-brand .glyph {
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--lime);
  display: inline-block;
}
.nav-links { display: flex; gap: 28px; font-size: 14.5px; opacity: .85; }
.nav-links a:hover { opacity: 1; color: var(--lime); }
.nav-cta { display: flex; gap: 10px; align-items: center; }

/* Nav auth state — user avatar shown when signed in */
.nav-user {
  display: none;
  align-items: center;
  gap: 10px;
  color: var(--paper);
  font-size: 13.5px;
}
.nav-user.visible { display: flex; }
.nav-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  border: 2px solid rgba(244,241,230,0.3);
  object-fit: cover;
}
.nav-user-name { font-family: var(--display); font-weight: 500; opacity: .85; }
.nav-signout {
  font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(244,241,230,0.55); cursor: pointer;
}
.nav-signout:hover { color: var(--lime); }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  background: var(--ink);
  color: var(--paper);
  min-height: 100vh;
  padding: 120px 32px 80px;
  display: flex; align-items: center;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background: url('images/hero.webp') center/cover no-repeat;
  z-index: 0;
}
.hero::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(13,14,10,0.86) 0%, rgba(13,14,10,0.55) 38%, rgba(13,14,10,0.05) 62%, rgba(13,14,10,0.0) 100%),
    linear-gradient(180deg, rgba(13,14,10,0.35) 0%, rgba(13,14,10,0.0) 30%, rgba(13,14,10,0.0) 70%, rgba(13,14,10,0.55) 100%);
  z-index: 1;
  pointer-events: none;
}
.hero-grid {
  position: relative;
  z-index: 2;
  max-width: 1280px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 80px;
  align-items: center;
  width: 100%;
}
.hero-copy { max-width: 720px; }
.hero-copy h1 { color: var(--paper); }
.hero-copy h1 em {
  font-style: normal;
  color: var(--lime);
}
.hero-copy .lede { margin-top: 28px; max-width: 46ch; }
.hero-trust {
  display: flex; gap: 24px; align-items: center; margin-top: 32px;
  color: var(--muted-pap); font-size: 13px;
}
.hero-trust .dots {
  display: inline-flex; gap: -8px;
}
.hero-trust .dots span {
  width: 28px; height: 28px; border-radius: 50%;
  border: 2px solid var(--ink);
  margin-left: -8px;
  background: var(--still-bg, var(--lime));
  display: inline-block;
}
.hero-trust .dots span:nth-child(1){ background: linear-gradient(135deg, #d4894a, #5a2c14); margin-left: 0; }
.hero-trust .dots span:nth-child(2){ background: linear-gradient(135deg, #98c4a4, #2c4a44); }
.hero-trust .dots span:nth-child(3){ background: linear-gradient(135deg, #6a90b8, #1c2a3c); }
.hero-trust .dots span:nth-child(4){ background: linear-gradient(135deg, #d4be8a, #4a3c1c); }

/* ============================================================
   PHONE (kept for reference, stage hidden in production)
   ============================================================ */
.phone-stage {
  position: relative;
  display: grid; place-items: center;
  perspective: 1400px;
}
.phone {
  --pw: 320px; --ph: 660px;
  width: var(--pw);
  height: var(--ph);
  background: #0a0b07;
  border-radius: 46px;
  padding: 12px;
  position: relative;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.04),
    0 60px 100px -30px rgba(0,0,0,0.75),
    0 24px 60px -20px rgba(0,0,0,0.6);
  transform: rotate(-3deg);
}
.phone::before {
  content: "";
  position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
  width: 96px; height: 24px; background: #000; border-radius: 14px;
  z-index: 5;
}
.phone-screen {
  width: 100%; height: 100%;
  background: #14150f;
  border-radius: 36px;
  overflow: hidden;
  position: relative;
}
.phone-screen .still { position: absolute; inset: 0; border-radius: 0; }
.phone-stickies {
  position: absolute; inset: 0; z-index: 4;
  padding: 60px 16px 80px;
}
.sticky {
  position: absolute;
  width: 92px; padding: 8px 10px;
  border-radius: 4px;
  font-size: 9px;
  line-height: 1.25;
  color: var(--ink);
  box-shadow: 0 6px 14px rgba(0,0,0,0.35);
  transform: rotate(var(--r, -2deg));
  font-family: var(--body);
  font-weight: 500;
}
.sticky b { font-weight: 700; }
.sticky.s-lime { background: var(--lime); }
.sticky.s-pink { background: #ffb3d1; }
.sticky.s-blue { background: #b3d8ff; }
.sticky.s-paper { background: #fff8e0; }
.phone-toolbar {
  position: absolute; left: 12px; right: 12px; bottom: 28px;
  z-index: 5;
  background: rgba(13,14,10,0.85); backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 999px;
  height: 40px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 12px;
  color: var(--paper);
  font-size: 10px;
}
.phone-toolbar .pill-mini {
  background: var(--lime); color: var(--ink);
  padding: 4px 10px; border-radius: 999px;
  font-family: var(--mono); font-size: 9px;
  letter-spacing: .08em; text-transform: uppercase;
  font-weight: 500;
}
.phone-toolbar .icons {
  display: flex; gap: 8px; opacity: .75;
}
.phone-toolbar .icons span {
  width: 14px; height: 14px; background: currentColor;
  -webkit-mask: var(--m) center/contain no-repeat;
          mask: var(--m) center/contain no-repeat;
}

/* ============================================================
   TICKER
   ============================================================ */
.ticker {
  background: var(--lime); color: var(--ink);
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  overflow: hidden;
  white-space: nowrap;
  padding: 18px 0;
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(20px, 2.2vw, 32px);
  letter-spacing: -0.02em;
}
.ticker-track {
  display: inline-flex; gap: 56px;
  animation: tick 28s linear infinite;
}
.ticker-track > span { display: inline-flex; align-items: center; gap: 56px; }
.ticker-track .dot { width: 12px; height: 12px; border-radius: 50%; background: var(--ink); display: inline-block; }
@keyframes tick {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ============================================================
   STEP BLOCKS
   ============================================================ */
.block {
  padding: clamp(80px, 10vw, 140px) 32px;
  position: relative;
  overflow: hidden;
}
.block .inner {
  max-width: 1280px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.block.flip .inner > .block-copy { order: 2; }
.block.flip .inner > .block-visual { order: 1; }

.block-copy .label { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 22px; }
.block-copy .label .num {
  background: currentColor; color: transparent;
  width: 22px; height: 22px; border-radius: 50%;
  display: inline-grid; place-items: center;
  font-size: 11px; font-weight: 700;
  -webkit-text-fill-color: var(--paper);
}
.on-ink  .block-copy .label .num { -webkit-text-fill-color: var(--ink); }
.on-lime .block-copy .label .num { -webkit-text-fill-color: var(--lime); background: var(--ink); }
.block-copy h2 { margin: 0 0 24px; }
.block-copy .lede { margin-bottom: 32px; }
.block-copy ul { list-style: none; padding: 0; margin: 0 0 36px; display: flex; flex-direction: column; gap: 12px; max-width: 44ch; }
.block-copy ul li {
  display: flex; gap: 12px; align-items: flex-start;
  font-size: 15.5px;
}
.block-copy ul li::before {
  content: ""; flex: 0 0 18px;
  width: 18px; height: 18px; margin-top: 4px;
  border-radius: 50%;
  background: var(--lime);
}
.on-lime .block-copy ul li::before { background: var(--ink); }

.block.on-ink   { background: var(--ink); color: var(--paper); }
.block.on-lime  { background: var(--lime); color: var(--ink); }
.block.on-paper { background: var(--paper); color: var(--ink); }
.block.on-cream { background: var(--cream); color: var(--ink); }

.block.on-ink h2 { color: var(--paper); }
.block.on-ink h2 em { font-style: normal; color: var(--lime); }
.block.on-lime h2 em { font-style: normal; color: var(--ink); border-bottom: 4px solid var(--ink); padding-bottom: 2px; }
.block.on-paper h2 em, .block.on-cream h2 em { font-style: normal; background: var(--lime); padding: 0 6px; border-radius: 6px; }

/* block visual */
.visual-card {
  aspect-ratio: 4/5;
  border-radius: 36px;
  overflow: hidden;
  position: relative;
  background: #14150f;
}
.visual-card .still { position: absolute; inset: 0; border-radius: 0; }
.visual-card.with-phone {
  display: grid; place-items: center;
  background: var(--still-card-bg, #14150f);
}
.visual-card.with-phone .phone { transform: rotate(-2deg) scale(0.78); }
.visual-card .floating-tag {
  position: absolute; z-index: 5;
  background: var(--cream); color: var(--ink);
  border-radius: 999px;
  padding: 10px 16px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: .08em; text-transform: uppercase;
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
}
.floating-tag.tl { top: 24px; left: 24px; }
.floating-tag.tr { top: 24px; right: 24px; background: var(--lime); }
.floating-tag.br { bottom: 24px; right: 24px; }

/* On-worlds variant for Step 2 */
.on-worlds { position: relative; color: var(--ink); }
.on-worlds .inner { position: relative; z-index: 1; }
.on-worlds .label { color: rgba(13,14,10,0.6); }
.on-worlds .label .num { -webkit-text-fill-color: var(--lime); background: var(--ink); }
.on-worlds h2 em { font-style: normal; color: var(--ink); border-bottom: 4px solid var(--lime); padding-bottom: 2px; }
.on-worlds .block-copy ul li::before { background: var(--ink); }

/* ============================================================
   PROBLEM SECTION
   ============================================================ */
.problem {
  background: var(--cream);
  padding: clamp(100px, 12vw, 160px) 32px;
}
.problem-head {
  max-width: 1280px; margin: 0 auto 56px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 60px;
  align-items: end;
}
.problem-head h2 { margin: 0; }
.problem-grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px;
}
.problem-card {
  background: var(--paper);
  border-radius: 28px;
  padding: 32px;
  grid-column: span 3;
  display: flex; flex-direction: column;
  min-height: 220px;
}
.problem-card.large { grid-column: span 6; min-height: 260px; background: var(--ink); color: var(--paper); }
.problem-card.large h3 em { color: var(--lime); font-style: normal; }
.problem-card.span-2 { grid-column: span 2; }
.problem-card .num {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  opacity: .55;
}
.problem-card h3 {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(22px, 2vw, 32px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 16px 0 14px;
  text-wrap: balance;
}
.problem-card p {
  font-size: 14.5px; color: var(--muted-ink); margin: 0;
  margin-top: auto;
  max-width: 32ch;
}
.problem-card.large p { color: var(--muted-pap); max-width: 50ch; }

/* ============================================================
   MOVIE THEMES — 16:9 carousel
   ============================================================ */
.movies-section { padding: clamp(80px, 10vw, 140px) 0; background: var(--paper); }
.movies-section .head { max-width: 1280px; margin: 0 auto 56px; padding: 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; }

.movies-rail-wrap { position: relative; overflow: hidden; }
/* Transform-based carousel — same pattern as quotes carousel.
   No scroll-snap: programmatic scrollTo is unreliable across browsers. */
.movies-rail {
  display: flex; gap: 0;
  transition: transform 0.55s cubic-bezier(.25,.46,.45,.94);
  will-change: transform;
}
.movie-slide.is-more::before { background: none !important; }

.movie-slide {
  flex: 0 0 100vw;
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--ms-bg, #1a1a18);
  color: var(--paper);
  display: block;
  cursor: pointer;
}
.movie-slide::before {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.0) 30%, rgba(0,0,0,0.55) 100%),
    linear-gradient(90deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.0) 55%);
}
.movie-slide > * { position: relative; z-index: 2; }
.ms-meta-tl, .ms-meta-tr {
  position: absolute; top: 32px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: rgba(244,241,230,0.78);
}
.ms-meta-tl { left: 40px; }
.ms-meta-tr {
  right: 40px;
  background: rgba(244,241,230,0.1);
  border: 1px solid rgba(244,241,230,0.2);
  padding: 6px 12px; border-radius: 999px;
  backdrop-filter: blur(8px);
}
.ms-title {
  position: absolute; left: 40px; bottom: 36px; right: 40px;
  margin: 0;
  font-family: var(--display); font-weight: 500;
  font-size: clamp(40px, 5.6vw, 96px); line-height: 0.95;
  letter-spacing: -0.025em;
  color: var(--paper);
  text-wrap: balance;
  text-shadow: 0 4px 32px rgba(0,0,0,0.4);
}
.ms-title em { font-style: italic; font-weight: 400; opacity: 0.75; }
.ms-tagline {
  position: absolute; left: 40px; right: 40px; bottom: 16px;
  font-size: 13px; letter-spacing: 0.02em; color: rgba(244,241,230,0.65);
  font-family: var(--display);
}

.movies-controls {
  max-width: 1280px; margin: 32px auto 0; padding: 0 32px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.ms-progress {
  flex: 1; height: 1px; background: rgba(13,14,10,0.18); position: relative; overflow: hidden;
}
.ms-progress-bar { position: absolute; left: 0; top: 0; bottom: 0; background: var(--ink); width: 6%; transition: width .25s ease, transform .25s ease; }
.ms-counter { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-ink); white-space: nowrap; }
.ms-arrows { display: flex; gap: 8px; }
.ms-arrow {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid rgba(13,14,10,0.2);
  background: transparent; color: var(--ink);
  font-size: 18px; cursor: pointer;
  display: grid; place-items: center;
  transition: background .2s ease, border-color .2s ease;
}
.ms-arrow:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* Carousel loading state */
.ms-loading {
  flex: 0 0 100vw;
  width: 100vw;
  aspect-ratio: 16 / 9;
  display: grid; place-items: center;
  background: var(--ink-2);
  color: rgba(244,241,230,0.35);
  font-family: var(--mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
}

/* ============================================================
   QUOTES
   ============================================================ */
.quotes-section { background: var(--ink); color: var(--paper); padding: clamp(80px, 10vw, 140px) 32px; }
.quotes-shell { max-width: 1100px; margin: 0 auto; }
.quotes-head { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: end; margin-bottom: 56px; }
.quotes-track { overflow: hidden; border-radius: 36px; background: var(--ink-2); border: 1px solid var(--line-pap); }
.quotes-rail { display: flex; transition: transform .65s cubic-bezier(.2,.7,.2,1); }
.quote-card {
  flex: 0 0 100%;
  padding: 56px 64px 48px;
  display: grid; grid-template-columns: 1fr; gap: 28px;
  min-height: 320px;
}
.quote-card .qmark {
  font-family: var(--display); font-weight: 700;
  font-size: 80px; line-height: 0.6;
  color: var(--lime);
  height: 36px;
}
.quote-card .quote {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(24px, 2.6vw, 38px);
  line-height: 1.18;
  letter-spacing: -0.018em;
  color: var(--paper);
  margin: 0;
  max-width: 26ch;
  text-wrap: pretty;
}
.quote-card .attr {
  border-top: 1px solid var(--line-pap);
  padding-top: 18px;
  display: flex; justify-content: space-between; gap: 24px;
}
.quote-card .attr b { font-family: var(--display); font-weight: 600; font-size: 16px; }
.quote-card .attr span { color: var(--muted-pap); font-size: 13.5px; }

.quotes-controls {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 28px;
}
.qc-arrow {
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(244,241,230,0.10);
  border: 1px solid var(--line-pap);
  color: var(--paper);
  display: grid; place-items: center;
  font-size: 18px;
  transition: background .25s ease;
}
.qc-arrow:hover { background: var(--lime); color: var(--ink); border-color: var(--lime); }
.qc-counter { font-family: var(--mono); font-size: 13px; letter-spacing: 0.1em; color: var(--muted-pap); }
.qc-arrows { display: flex; gap: 10px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-section { background: var(--paper); padding: clamp(80px, 10vw, 140px) 32px; }
.faq-shell { max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.4fr; gap: 100px; align-items: start; }
.faq-head { position: sticky; top: 100px; }
.faq-head h2 { margin: 0 0 24px; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--line); padding: 24px 0; }
.faq-item:last-child { border-bottom: 1px solid var(--line); }
.faq-q {
  list-style: none;
  width: 100%;
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  text-align: left;
  cursor: pointer;
  font-family: var(--display); font-weight: 500; font-size: clamp(18px, 1.5vw, 22px);
  letter-spacing: -0.01em;
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q .plus {
  width: 32px; height: 32px; flex: 0 0 32px;
  border-radius: 50%; background: var(--paper-2);
  display: grid; place-items: center;
  font-size: 18px; line-height: 1;
  transition: transform .3s ease, background .3s ease;
}
.faq-item[open] .plus { transform: rotate(45deg); background: var(--lime); }
.faq-a {
  font-size: 15.5px; color: var(--muted-ink); line-height: 1.6;
  padding: 16px 60px 0 0; max-width: 60ch;
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta-section { background: var(--ink); padding: 32px; }
.cta-frame {
  border-radius: 44px;
  overflow: hidden;
  height: clamp(480px, 64vw, 640px);
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
}
.cta-frame .still { position: absolute; inset: 0; border-radius: 0; }
.cta-frame::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(13,14,10,0.30) 0%, rgba(13,14,10,0.30) 40%, rgba(13,14,10,0.85) 100%);
  z-index: 2;
}
.cta-content {
  position: relative; z-index: 3;
  height: 100%;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 64px clamp(32px, 6vw, 96px);
  color: var(--paper);
}
.cta-content h2 { margin: 0 0 28px; max-width: 18ch; color: var(--paper); }
.cta-content h2 em { font-style: normal; color: var(--lime); }
.cta-content .ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--ink); color: var(--paper); padding: 80px 32px 32px; }
.footer-grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px;
}
.footer-brand .nav-brand { font-size: 28px; }
.footer-brand p { font-size: 14.5px; color: var(--muted-pap); margin: 18px 0 24px; max-width: 32ch; }
.footer-col h4 {
  font-family: var(--mono); font-weight: 400; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(244,241,230,0.5);
  margin: 8px 0 18px;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.footer-col a { font-size: 14.5px; opacity: .85; }
.footer-col a:hover { color: var(--lime); opacity: 1; }

.footer-wordmark {
  overflow: hidden;
  border-top: 1px solid var(--line-pap);
  padding-top: 32px;
  margin: 0 auto;
  max-width: 1280px;
}
.footer-wordmark .word {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(110px, 20vw, 290px);
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--lime);
  text-align: center;
  margin: 0 0 12px;
  user-select: none;
}
.footer-meta {
  max-width: 1280px; margin: 0 auto;
  border-top: 1px solid var(--line-pap);
  padding: 24px 0 0;
  display: flex; justify-content: space-between;
  font-size: 12.5px;
  color: rgba(244,241,230,0.45);
}
.footer-meta .links { display: flex; gap: 22px; }
.footer-meta a:hover { color: var(--lime); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px) {
  .nav-links { display: none; }
  .hero { padding: 100px 20px 60px; min-height: auto; }
  .hero-grid { grid-template-columns: 1fr; gap: 56px; }
  .phone-stage { order: 2; }
  .block { padding: 80px 20px; }
  .block .inner, .block.flip .inner { grid-template-columns: 1fr; gap: 48px; }
  .block.flip .inner > .block-copy { order: 1; }
  .block.flip .inner > .block-visual { order: 2; }
  .problem-head, .quotes-head, .movies-section .head { grid-template-columns: 1fr; gap: 24px; }
  .problem-grid { grid-template-columns: repeat(2, 1fr); }
  .problem-card, .problem-card.large, .problem-card.span-2 { grid-column: span 2; }
  .faq-shell { grid-template-columns: 1fr; gap: 40px; }
  .faq-head { position: static; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .quote-card { padding: 36px 28px 28px; }
}

@media (max-width: 640px) {
  .ms-meta-tl { font-size: 10px; left: 20px; }
  .ms-meta-tr { right: 20px; }
  .ms-title { left: 20px; right: 20px; bottom: 28px; }
  .ms-tagline { left: 20px; right: 20px; }
  .movies-controls { padding: 0 20px; }
  /* Nav must fit a 360px phone: drop the redundant ghost "Sign in"
     (the app screen shows sign-in anyway) and tighten the primary CTA. */
  .nav-cta .btn-ghost-pap { display: none; }
  .btn-sm { padding: 9px 14px; font-size: 12.5px; }
}
