/* ═══════════════════════════════════════════════════════════
   BESTIE — a character you carry
   Built on the Bestie Design System (colour worlds, Mattone +
   Aperçu Pro + DM Mono, soft geometry, the World Effect)
   ═══════════════════════════════════════════════════════════ */

@font-face { font-family: 'Mattone'; src: url('../fonts/Mattone-Regular.woff2') format('woff2'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Mattone'; src: url('../fonts/Mattone-Bold.woff2') format('woff2'); font-weight: 700; font-display: swap; }
@font-face { font-family: 'Mattone'; src: url('../fonts/Mattone-Black.woff2') format('woff2'); font-weight: 900; font-display: swap; }
@font-face { font-family: 'Apercu'; src: url('../fonts/apercu_regular_pro.otf') format('opentype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Apercu'; src: url('../fonts/apercu_medium_pro.otf') format('opentype'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'Apercu'; src: url('../fonts/apercu_bold_pro.otf') format('opentype'); font-weight: 700; font-display: swap; }

:root {
  --paper: #F4F2EE;
  --ink: #1A1A1A;
  --deep: #15171C;
  --warm-white: #FDFBF6;
  --asobu: #FF3D00;
  --ease: cubic-bezier(.2,.8,.2,1);
  --mattone: 'Mattone', 'Arial Black', sans-serif;
  --apercu: 'Apercu', 'Helvetica Neue', sans-serif;
  --mono: 'DM Mono', monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: auto; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }

body {
  font-family: var(--apercu);
  color: var(--ink);
  background: var(--paper);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

::selection { background: #E37EAF; color: #fff; }
img { user-select: none; -webkit-user-drag: none; }

/* ═══ NAV ═══ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 4vw;
  pointer-events: none;
}
.nav > * { pointer-events: auto; }
.nav-logo img { height: 30px; display: block; }
.nav-links {
  display: flex; align-items: center; gap: 6px;
  background: rgba(253,251,246,.72);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-radius: 100px; padding: 6px;
  box-shadow: 0 4px 18px rgba(30,34,48,.08);
}
.nav-links a {
  font-family: var(--mono); font-size: 12px; letter-spacing: .08em;
  text-decoration: none; color: var(--ink);
  padding: 9px 18px; border-radius: 100px;
  transition: background .25s var(--ease);
}
.nav-links a:hover { background: rgba(0,0,0,.06); }
.nav-links a.nav-cta { background: var(--ink); color: #fff; }
.nav-links a.nav-cta:hover { background: #000; }

/* ═══ HERO ═══ */
.hero {
  position: relative; height: 100vh; height: 100svh;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background: var(--paper);
  will-change: background-color;
}

/* intro lockup */
.hero-intro {
  position: absolute; inset: 0; z-index: 6;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 28px; text-align: center;
  will-change: transform, opacity;
}
.hero-eyebrow {
  font-family: var(--mono); font-size: 12px; letter-spacing: .34em;
  text-transform: uppercase; color: rgba(26,26,26,.55);
}
.hero-wordmark { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.hero-wordmark-img { width: min(58vw, 720px); display: block; filter: drop-shadow(0 18px 40px rgba(30,34,48,.10)); }
.hero-byline { display: flex; align-items: baseline; gap: 8px; }
.hero-by { font-family: var(--apercu); font-weight: 500; font-size: 15px; color: var(--ink); }
.hero-asobu { height: 15px; transform: translateY(1px); }
.hero-tagline {
  font-family: var(--mattone); font-weight: 700;
  font-size: clamp(18px, 2.2vw, 28px);
  letter-spacing: .01em; color: var(--ink);
}
.hero-cue {
  position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(26,26,26,.5);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.hero-cue-line {
  width: 1.5px; height: 44px; border-radius: 2px;
  background: linear-gradient(to bottom, transparent, rgba(26,26,26,.45));
  animation: cue 1.8s var(--ease) infinite;
}
@keyframes cue {
  0% { transform: scaleY(.2); transform-origin: top; opacity: 0; }
  40% { transform: scaleY(1); opacity: 1; }
  100% { transform: scaleY(.2); transform-origin: bottom; opacity: 0; }
}

/* one-shot load-in (CSS so it never fights the scrub timeline) */
@keyframes riseIn {
  from { opacity: 0; transform: translateY(34px); }
  to { opacity: 1; transform: translateY(0); }
}
.hero-eyebrow { animation: riseIn .9s var(--ease) .15s backwards; }
.hero-tagline { animation: riseIn .9s var(--ease) .55s backwards; }
.hero-cue { animation: riseIn .9s var(--ease) .9s backwards; }

/* floating cast teaser */
.hero-minis { position: absolute; inset: 0; z-index: 5; pointer-events: none; }
.hero-minis img {
  position: absolute; left: var(--mx); top: var(--my);
  height: 13vh; transform: rotate(var(--mr));
  filter: drop-shadow(0 12px 22px rgba(30,34,48,.14));
}

/* worlds */
.worlds { position: absolute; inset: 0; z-index: 3; will-change: transform; }
.world {
  position: absolute; inset: 0;
  display: grid; grid-template-columns: 1fr 1fr; align-items: center;
  visibility: hidden;
  will-change: clip-path;
}
.w-veil { position: absolute; inset: 0; z-index: 0; background: var(--w-bg); }
.ghost {
  position: absolute; z-index: 0;
  font-family: var(--mattone); font-weight: 900;
  font-size: 30vw; line-height: 1; letter-spacing: -.02em;
  color: var(--w-ink); opacity: .08;
  left: -3vw; top: 4vh; white-space: nowrap;
  will-change: transform;
  z-index: 1;
}
.world:nth-child(even) .ghost { left: auto; right: -3vw; top: auto; bottom: 2vh; }

.w-bottle {
  grid-column: 1; position: relative; z-index: 2;
  display: flex; justify-content: center; align-items: center;
  height: 100vh; height: 100svh;
  will-change: transform;
}
.world:nth-child(even) .w-bottle { grid-column: 2; grid-row: 1; }
.w-float { display: flex; justify-content: center; align-items: center; height: 100%; }
.w-bottle img {
  height: 78vh; max-height: 78svh; width: auto; display: block;
}
/* spotlight rule: no drop shadow — one very subtle white glow lifts the
   bottle off its matching ground */
.w-float { position: relative; }
.w-float::before {
  content: ''; position: absolute; z-index: -1;
  left: 50%; top: 55%; width: 64vh; height: 64vh;
  transform: translate(-50%, -50%);
  background: radial-gradient(closest-side, rgba(255,255,255,.32), transparent 72%);
  filter: blur(34px);
}

.w-copy {
  grid-column: 2; position: relative; z-index: 4;
  padding: 0 7vw; max-width: 640px;
  will-change: transform, opacity;
}
.world:nth-child(even) .w-copy { grid-column: 1; grid-row: 1; justify-self: end; text-align: right; }
.w-eyebrow {
  font-family: var(--mono); font-size: 12px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--w-accent); margin-bottom: 18px;
}
.w-name {
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(64px, 9vw, 132px); line-height: .95;
  letter-spacing: -.015em; color: var(--w-ink); margin-bottom: 22px;
  overflow: hidden; padding-bottom: .18em; margin-top: -.06em;
}
.w-name .ch { display: inline-block; will-change: transform; }
.w-line {
  font-size: clamp(17px, 1.45vw, 21px); line-height: 1.55;
  font-weight: 500; color: var(--w-ink); max-width: 26em; margin-bottom: 26px;
}
.world:nth-child(even) .w-line { margin-left: auto; }
.w-spec {
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  text-transform: uppercase; color: var(--w-accent);
  border-top: 1.5px solid color-mix(in srgb, var(--w-accent) 35%, transparent);
  display: inline-block; padding-top: 14px;
}

.spec-rail {
  position: absolute; z-index: 5; left: 26px; bottom: 40px;
  writing-mode: vertical-rl; transform: rotate(180deg);
  font-family: var(--mono); font-size: 10px; letter-spacing: .34em;
  text-transform: uppercase; color: rgba(26,26,26,.4);
}

/* ═══ THE BUBBLE COMPANION — a real soap bubble, stamped NEW ═══ */
.bubble-layer {
  position: absolute; inset: 0; z-index: 4;
  pointer-events: none;
  --bubble-c: #985E38;
}
.bub {
  position: absolute; left: 50%; top: 50%;
  margin: -13vmin 0 0 -13vmin;
  width: 26vmin; height: 26vmin;
  will-change: transform;
  opacity: 0;
}
.bub-main { z-index: 3; }
.bub-t1 { width: 9vmin; height: 9vmin; margin: -4.5vmin 0 0 -4.5vmin; z-index: 2; }
.bub-t2 { width: 5.5vmin; height: 5.5vmin; margin: -2.75vmin 0 0 -2.75vmin; z-index: 1; }
.bub-core {
  display: block; width: 100%; height: 100%;
  position: relative;
  border-radius: 51.5% 48.5% 51% 49% / 49% 51.5% 48.5% 51%;
  animation: blobmorph 8s ease-in-out infinite;
  /* the glassy film: clear centre, milky rim */
  background: radial-gradient(circle at 32% 28%,
    rgba(255,255,255,.34) 0%,
    rgba(255,255,255,.10) 24%,
    rgba(255,255,255,.02) 44%,
    rgba(255,255,255,.02) 60%,
    rgba(255,255,255,.10) 74%,
    rgba(255,255,255,.32) 87%,
    rgba(255,255,255,.08) 97%);
  box-shadow:
    inset 0 0 0 1.5px rgba(255,255,255,.38),
    inset -10px -14px 30px rgba(255,255,255,.20),
    inset 8px 10px 22px rgba(255,255,255,.14),
    0 18px 40px rgba(30,34,48,.12);
  backdrop-filter: blur(2px) saturate(1.2) brightness(1.04);
  -webkit-backdrop-filter: blur(2px) saturate(1.2) brightness(1.04);
}
/* iridescent rim — the soap-film rainbow */
.bub-irid {
  position: absolute; inset: 0;
  border-radius: inherit;
  background: conic-gradient(from 20deg,
    rgba(255,150,196,.55), rgba(150,214,255,.5), rgba(255,238,150,.45),
    rgba(186,150,255,.5), rgba(150,255,216,.45), rgba(255,170,150,.5),
    rgba(255,150,196,.55));
  -webkit-mask: radial-gradient(circle, transparent 56%, #000 74%, #000 88%, transparent 98%);
  mask: radial-gradient(circle, transparent 56%, #000 74%, #000 88%, transparent 98%);
  filter: blur(3px);
  animation: iridshift 7s linear infinite;
  opacity: .85;
}
@keyframes iridshift {
  to { filter: blur(3px) hue-rotate(360deg); }
}
/* glossy highlights */
.bub-hi {
  position: absolute; left: 13%; top: 8%;
  width: 38%; height: 19%;
  background: linear-gradient(to bottom, rgba(255,255,255,.85), rgba(255,255,255,.05));
  border-radius: 50%;
  transform: rotate(-26deg);
  filter: blur(1.5px);
}
.bub-hi2 {
  position: absolute; right: 13%; bottom: 11%;
  width: 16%; height: 8%;
  background: rgba(255,255,255,.55);
  border-radius: 50%;
  transform: rotate(-28deg);
  filter: blur(1.5px);
}
/* the badge — thin, understated */
.bub-new {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--mono); font-weight: 400;
  font-size: 3.4vmin; letter-spacing: .42em;
  text-indent: .42em; /* optically recentre the tracking */
  text-transform: uppercase;
  color: var(--bubble-c);
  transform: rotate(-8deg);
}
.bub-t1 .bub-core { animation-duration: 6s; }
.bub-t2 .bub-core { animation-duration: 4.6s; }
@keyframes blobmorph {
  0%, 100% { border-radius: 51.5% 48.5% 51% 49% / 49% 51.5% 48.5% 51%; }
  33% { border-radius: 48% 52% 47.5% 52.5% / 52% 48% 53% 47%; }
  66% { border-radius: 53% 47% 52.5% 47.5% / 47.5% 53% 47% 53%; }
}

/* ═══ MANIFESTO — full-viewport pinned ═══ */
.manifesto {
  position: relative; z-index: 10;
  background: var(--deep);
  min-height: 100vh; min-height: 100svh;
  display: flex; align-items: center;
  padding: 0 8vw;
  border-radius: 42px 42px 0 0;
  margin-top: -40px;
  overflow: hidden;
}
.manifesto-inner { max-width: 1200px; margin: 0 auto; position: relative; z-index: 2; }
.m-float {
  position: absolute; z-index: 1; height: 17vh;
  filter: drop-shadow(0 18px 30px rgba(0,0,0,.4));
  will-change: transform;
}
.m-f1 { left: 6vw; top: 12vh; transform: rotate(-7deg); }
.m-f2 { right: 7vw; top: 22vh; transform: rotate(6deg); height: 14vh; }
.m-f3 { left: 14vw; bottom: -4vh; transform: rotate(5deg); height: 15vh; }
.manifesto-kicker {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .3em;
  text-transform: uppercase; color: #FCB31C; margin-bottom: 42px;
}
.manifesto-text {
  font-family: var(--mattone); font-weight: 700;
  font-size: clamp(40px, 6.2vw, 96px); line-height: 1.08;
  letter-spacing: -.01em; color: #fff;
}
.manifesto-text .wd { opacity: .13; display: inline-block; }
.manifesto-sub {
  margin-top: 56px; max-width: 38em;
  font-size: clamp(17px, 1.5vw, 21px); line-height: 1.65;
  color: rgba(255,255,255,.62);
}
.manifesto-sub em { color: #E37EAF; font-style: normal; font-weight: 700; }
.manifesto-sub .wd { opacity: .13; display: inline-block; }

/* ═══ SEDUCTION — STACKING CARDS ═══ */
.seduction { position: relative; z-index: 10; background: var(--deep); }
.s-card {
  position: sticky; top: 0;
  height: 100vh; height: 100svh;
  display: flex; align-items: center;
  overflow: hidden;
  border-radius: 42px 42px 0 0;
  will-change: transform;
}
.s-look { background: #FCEEF4; color: #54223C; }
.s-feel { background: #332350; color: #fff; }
.s-function { background: #E0F0EF; color: #123E3D; }

.s-video {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: .5;
}
.s-scrim { position: absolute; inset: 0; background: linear-gradient(100deg, rgba(51,35,80,.92) 38%, rgba(51,35,80,.25) 75%); }

.s-inner {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1.1fr 1fr; align-items: center;
  width: 100%; padding: 0 7vw; gap: 4vw;
}
.s-kicker {
  font-family: var(--mono); font-size: 12px; letter-spacing: .28em;
  text-transform: uppercase; margin-bottom: 26px; opacity: .75;
}
.s-look .s-kicker { color: #BC4E7C; opacity: 1; }
.s-feel .s-kicker { color: #C9B8E8; }
.s-function .s-kicker { color: #2C7A79; opacity: 1; }
.s-title {
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(40px, 5.6vw, 88px); line-height: 1.02;
  letter-spacing: -.015em; margin-bottom: 30px;
}
.s-body { font-size: clamp(16.5px, 1.4vw, 20px); line-height: 1.62; max-width: 30em; opacity: .85; }
.s-pills { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 36px; }
.pill {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .14em;
  text-transform: uppercase;
  border: 1.5px solid currentColor; border-radius: 100px;
  padding: 10px 20px;
}

.s-visual { position: relative; height: 78vh; }
.s-shade {
  position: absolute; inset: 0; z-index: 3;
  background: #15171C; opacity: 0; pointer-events: none;
}
.s-solo {
  position: absolute; left: 50%; top: 50%;
  height: 64vh; transform: translate(-50%, -50%);
  filter: drop-shadow(0 30px 50px rgba(30,34,48,.22));
}
.s-cluster .s-b { position: absolute; filter: drop-shadow(0 24px 44px rgba(30,34,48,.18)); }
.s-b1 { height: 52vh; left: 8%; top: 14%; transform: rotate(-5deg); z-index: 2; }
.s-b2 { height: 45vh; left: 42%; top: 6%; transform: rotate(3deg); z-index: 1; }
.s-b3 { height: 41vh; left: 64%; top: 28%; transform: rotate(7deg); z-index: 3; }

/* ═══ ANATOMY — and yes, it's a very good bottle ═══ */
.anatomy {
  position: relative; z-index: 10;
  /* deep warm cocoa — tonally in Mochi's world, not flat black */
  background: radial-gradient(circle at 38% 42%, rgba(252,179,28,.07), transparent 60%), #261C10;
  color: #F4F2EE;
  height: 100vh; height: 100svh;
  overflow: hidden;
}
.anatomy-inner {
  position: relative;
  height: 100%;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 0 4vw;
  padding: 11vh 7vw 6vh;
  box-sizing: border-box;
}
.a-head { grid-column: 1 / -1; margin-bottom: 4vh; }
.a-kicker {
  font-family: var(--mono); font-size: 12px; letter-spacing: .28em;
  text-transform: uppercase; color: #FCB31C; margin-bottom: 16px;
}
.a-title {
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(32px, 3.8vw, 58px); line-height: 1.02;
  letter-spacing: -.015em; margin-bottom: 14px;
}
.a-title br { display: none; }
.a-sub { font-size: clamp(15px, 1.2vw, 18px); line-height: 1.55; color: rgba(244,242,238,.65); max-width: 40em; }

.a-stagewrap { position: relative; display: flex; gap: 3vw; align-items: center; min-height: 0; }
.a-stage {
  position: relative;
  height: 100%; max-height: 100%; aspect-ratio: 1028 / 2290;
  flex: none;
}
.a-part { position: absolute; display: block; will-change: transform, opacity; }
.a-callouts { position: relative; flex: 1; height: 100%; }
.a-callout {
  position: absolute; top: var(--cy); left: 0; right: 0;
  display: flex; align-items: center; gap: 14px;
}
.a-callout i {
  display: block; height: 1.5px; flex: 0 0 clamp(30px, 5vw, 90px);
  background: linear-gradient(to right, rgba(252,179,28,.9), rgba(252,179,28,.25));
  transform-origin: left center;
}
.a-callout span {
  font-family: var(--mono); font-size: clamp(10px, .85vw, 12.5px);
  letter-spacing: .14em; text-transform: uppercase;
  color: rgba(244,242,238,.85); line-height: 1.7;
}

.a-side { display: flex; flex-direction: column; justify-content: center; gap: 3vh; min-height: 0; }
.a-chips { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.a-chip {
  display: flex; align-items: center; gap: 13px;
  border: 1.5px solid rgba(244,242,238,.22);
  border-radius: 100px;
  padding: 12px 18px;
}
.a-chip svg {
  width: 21px; height: 21px; flex: none;
  fill: none; stroke: #FCB31C; stroke-width: 1.6;
  stroke-linecap: round; stroke-linejoin: round;
}
.a-chip span {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: rgba(244,242,238,.9);
}
.a-dims {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(244,242,238,.45);
  border-top: 1px solid rgba(244,242,238,.14); padding-top: 18px;
}
.a-punch {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(40px, 5.6vw, 92px); line-height: 1.06;
  letter-spacing: -.015em; color: #F4F2EE;
  pointer-events: none;
  z-index: 5;
}
.a-punch em { font-style: normal; color: #FCB31C; }

/* ═══ DRAWER — character spotlight ═══ */
.drawer-scrim {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(10,10,14,.45);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  opacity: 0; visibility: hidden;
}
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: 201;
  width: min(620px, 94vw);
  background: var(--d-bg, #F4F2EE);
  border-radius: 34px 0 0 34px;
  box-shadow: -30px 0 80px rgba(10,10,14,.3);
  transform: translateX(105%);
  visibility: hidden;
  overflow: hidden;
  display: flex; flex-direction: column;
}
.drawer-close {
  position: absolute; top: 22px; right: 26px; z-index: 5;
  width: 44px; height: 44px; border-radius: 50%;
  border: none; cursor: pointer;
  background: rgba(0,0,0,.12); color: var(--d-ink, #1A1A1A);
  font-size: 15px; line-height: 1;
  transition: transform .25s var(--ease), background .25s var(--ease);
}
.drawer-close:hover { transform: rotate(90deg) scale(1.08); background: rgba(0,0,0,.2); }
.drawer-ghost {
  position: absolute; z-index: 0;
  right: -6%; top: -2%;
  font-family: var(--mattone); font-weight: 900;
  font-size: 11rem; line-height: 1; letter-spacing: -.02em;
  color: var(--d-ink, #1A1A1A); opacity: .07;
  white-space: nowrap; pointer-events: none;
}
.drawer-body {
  position: relative; z-index: 2;
  padding: 9vh 44px 0;
}
.drawer-eyebrow {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .26em;
  text-transform: uppercase; color: var(--d-accent, #1A1A1A); margin-bottom: 14px;
}
.drawer-name {
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(52px, 9vmin, 84px); line-height: .95;
  letter-spacing: -.015em; color: var(--d-ink, #1A1A1A);
  margin-bottom: 18px; overflow: hidden; padding-bottom: .18em; margin-top: -.06em;
}
.drawer-name .ch { display: inline-block; }
.drawer-line {
  font-size: 16.5px; line-height: 1.6; font-weight: 500;
  color: var(--d-ink, #1A1A1A); max-width: 30em; margin-bottom: 22px;
}
.drawer-pills { display: flex; flex-wrap: wrap; gap: 10px; }
.drawer-pills .pill { color: var(--d-ink, #1A1A1A); font-size: 10.5px; padding: 8px 16px; }
.drawer-bottlewrap {
  position: relative; z-index: 1; flex: 1;
  display: flex; align-items: center; justify-content: center;
  padding: 3vh 0 5vh;
  min-height: 0;
}
.drawer-bottle {
  max-height: 100%; height: 46vh; width: auto;
  filter: drop-shadow(0 24px 44px rgba(20,22,30,.22));
}

/* ═══ CAST GRID ═══ */
.cast {
  position: relative; z-index: 10;
  background: var(--paper);
  border-radius: 42px 42px 0 0;
  padding: 16vh 5vw 14vh;
}
.cast-head { max-width: 1100px; margin: 0 auto 9vh; text-align: center; }
.cast-kicker {
  font-family: var(--mono); font-size: 12px; letter-spacing: .3em;
  text-transform: uppercase; color: #BC4E7C; margin-bottom: 24px;
}
.cast-title {
  font-family: var(--mattone); font-weight: 900;
  font-size: clamp(44px, 6.4vw, 100px); line-height: 1; letter-spacing: -.015em;
  margin-bottom: 28px;
}
.cast-sub { font-size: clamp(16.5px, 1.4vw, 20px); line-height: 1.6; max-width: 36em; margin: 0 auto; color: rgba(26,26,26,.66); }

.cast-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 18px; max-width: 1560px; margin: 0 auto;
}
.tile {
  position: relative; border-radius: 26px; overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--t-bg);
  display: flex; align-items: center; justify-content: center;
  padding: 14% 8% 8%;
  box-sizing: border-box;
  cursor: pointer;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
  opacity: 0; transform: translateY(40px);
}
.tile.in { opacity: 1; transform: translateY(0); }
.tile:hover { transform: translateY(-6px) !important; box-shadow: 0 24px 48px rgba(30,34,48,.16); }
.tile:focus-visible { outline: 3px solid var(--t-ink); outline-offset: 3px; }
.tile::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(255,255,255,.16), transparent 40%);
  pointer-events: none;
}
.tile img {
  max-height: 100%; max-width: 100%; width: auto; display: block;
  transition: transform .45s var(--ease);
  filter: drop-shadow(0 14px 24px rgba(30,34,48,.16));
}
.tile:hover img { transform: scale(1.05); }
.tile-label {
  position: absolute; top: 16px; left: 16px; right: 16px;
  display: flex; justify-content: space-between; align-items: baseline;
  z-index: 2;
}
.tile-name {
  font-family: var(--mattone); font-weight: 700; font-size: 19px;
  color: var(--t-ink); letter-spacing: -.01em;
}
.tile-species {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--t-ink); opacity: .65;
}

/* ═══ MARQUEE ═══ */
.marquee {
  position: relative; z-index: 10;
  background: #FCB31C; color: #54390A;
  overflow: hidden; padding: 26px 0;
}
.marquee-track {
  display: flex; gap: 64px; width: max-content;
  font-family: var(--mattone); font-weight: 700;
  font-size: clamp(20px, 2.2vw, 32px); white-space: nowrap;
  will-change: transform;
}
.marquee-track span { display: flex; align-items: center; gap: 64px; }

/* ═══ FOOTER — full-viewport finale ═══ */
.footer {
  position: relative; z-index: 10;
  background: var(--deep);
  min-height: 100vh; min-height: 100svh;
  padding: 12vh 6vw 48px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  overflow: hidden;
}
/* the stacked mark as a giant ghost texture (the packaging letterform move) */
.footer::before {
  content: ''; position: absolute; z-index: 0;
  right: -14vw; bottom: -16vh; width: 64vw; height: 92vh;
  background: #fff; opacity: .035;
  -webkit-mask: url('../img/brand/bestie-mark.svg') no-repeat center / contain;
  mask: url('../img/brand/bestie-mark.svg') no-repeat center / contain;
  transform: rotate(-8deg);
  pointer-events: none;
}
.hangtag, .footer-legal { position: relative; z-index: 1; }
.hangtag {
  background: var(--warm-white);
  border-radius: 34px;
  box-shadow: 0 8px 26px rgba(0,0,0,.14);
  padding: 64px 72px 52px;
  display: flex; flex-direction: column; align-items: center;
  text-align: center; max-width: 560px;
  transform: rotate(-1deg);
}
.ht-eyebrow {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .3em;
  text-transform: uppercase; color: rgba(26,26,26,.5); margin-bottom: 26px;
}
.ht-wordmark { width: 280px; margin-bottom: 18px; }
.ht-byline { display: flex; align-items: baseline; gap: 7px; margin-bottom: 28px; }
.ht-byline span { font-size: 14px; font-weight: 500; }
.ht-asobu { height: 13px; transform: translateY(1px); }
.ht-dots { display: flex; gap: 10px; margin-bottom: 30px; }
.ht-dots i { width: 11px; height: 11px; border-radius: 50%; display: block; }
.ht-headline {
  font-family: var(--mattone); font-weight: 700; font-size: 22px;
  line-height: 1.3; margin-bottom: 30px;
}
.ht-foot { font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: rgba(26,26,26,.55); }
.ht-contact {
  margin-top: 14px;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .12em;
  text-transform: uppercase; text-decoration: none;
  color: #BC4E7C;
  border-bottom: 1px solid rgba(188,78,124,.35);
  padding-bottom: 2px;
  transition: color .25s var(--ease), border-color .25s var(--ease);
}
.ht-contact:hover { color: #E37EAF; border-color: #E37EAF; }
.footer-legal a { color: rgba(255,255,255,.55); text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.2); }
.footer-legal a:hover { color: #fff; }
.footer-legal {
  margin-top: 64px; font-family: var(--mono); font-size: 10.5px;
  letter-spacing: .1em; color: rgba(255,255,255,.35); text-align: center;
}

/* ═══ CUSTOM CURSOR ═══ */
.cursor { display: none; }
@media (pointer: fine) {
  body.has-cursor, body.has-cursor a, body.has-cursor .tile { cursor: none; }
  .cursor { display: block; position: fixed; inset: 0; z-index: 999; pointer-events: none; }
  .cursor-dot {
    position: absolute; width: 8px; height: 8px; border-radius: 50%;
    background: #fff; mix-blend-mode: difference;
    transform: translate(-50%, -50%);
  }
  .cursor-ring {
    position: absolute; width: 38px; height: 38px; border-radius: 50%;
    border: 1.5px solid #fff; mix-blend-mode: difference;
    transform: translate(-50%, -50%) scale(var(--cs, 1));
    transition: transform .25s var(--ease);
  }
}

/* ═══ RESPONSIVE ═══ */
@media (max-width: 880px) {
  .nav { padding: 14px 3vw; }
  .nav-logo img { height: 22px; }
  .nav-links { padding: 5px; gap: 2px; }
  .nav-links a { font-size: 10.5px; padding: 8px 11px; letter-spacing: .04em; }

  .world { grid-template-columns: 1fr; grid-template-rows: minmax(0, 1fr) auto; }
  .w-bottle, .world:nth-child(even) .w-bottle {
    grid-column: 1; grid-row: 1;
    height: auto; min-height: 0; align-items: end; padding-top: 9vh;
  }
  .w-bottle img { height: 44svh; max-height: 100%; }
  .w-copy, .world:nth-child(even) .w-copy {
    grid-column: 1; grid-row: 2; text-align: center; justify-self: center;
    padding: 3svh 7vw 7svh; max-width: none;
  }
  .w-eyebrow { font-size: 10.5px; margin-bottom: 10px; }
  .w-name { font-size: clamp(44px, 13vw, 64px); margin-bottom: 12px; }
  .w-line { font-size: 14.5px; line-height: 1.5; margin: 0 auto 14px; }
  .world:nth-child(even) .w-line { margin: 0 auto 14px; }
  .w-spec { font-size: 9.5px; padding-top: 10px; }
  .ghost { font-size: 46vw; }
  .spec-rail { display: none; }
  .hero-minis img { height: 8vh; }
  .m-float { height: 10vh; }

  .s-inner { grid-template-columns: 1fr; gap: 0; padding-top: 10vh; }
  .s-visual { height: 38vh; order: 2; }
  .s-solo { height: 34vh; }
  .s-b1 { height: 28vh; } .s-b2 { height: 24vh; } .s-b3 { height: 22vh; }
  .s-card { align-items: flex-start; }
  .s-title { font-size: clamp(34px, 9vw, 54px); }

  .bub { width: 21vmin; height: 21vmin; margin: -10.5vmin 0 0 -10.5vmin; }
  .bub-t1 { width: 7.5vmin; height: 7.5vmin; margin: -3.75vmin 0 0 -3.75vmin; }
  .bub-t2 { width: 4.5vmin; height: 4.5vmin; margin: -2.25vmin 0 0 -2.25vmin; }
  .bub-new { font-size: 3vmin; }

  .anatomy { height: auto; min-height: 100svh; }
  .anatomy-inner { grid-template-columns: 1fr; grid-template-rows: none; height: auto; padding: 10vh 7vw 8vh; }
  .a-stagewrap { flex-direction: column; align-items: center; gap: 4vh; }
  .a-stage { height: 46vh; }
  .a-callouts { height: auto; width: 100%; }
  .a-callout { position: static; margin-bottom: 12px; }
  .a-side { margin-top: 5vh; }
  .a-chips { grid-template-columns: 1fr 1fr; gap: 9px; }
  .a-chip { padding: 10px 13px; gap: 9px; }
  .a-chip span { font-size: 9.5px; }
  .a-punch { width: 90vw; }

  .drawer { width: 94vw; border-radius: 28px 0 0 28px; }
  .drawer-body { padding: 8vh 28px 0; }
  .drawer-ghost { font-size: 7rem; }
  .drawer-bottle { height: 38vh; }

  .hangtag { padding: 48px 36px 40px; }
  .ht-wordmark { width: 210px; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-cue-line { animation: none; }
}
