/* =====================================================================
   PUJA PUNEET · A CELEBRATION OF TRANSFORMATION
   Redesigned to match the Desktop + Mobile style references.
   Warm "Aura" palette · Quiet luxury · Mobile-first.
   ===================================================================== */

:root {
  /* Palette (sampled from the reference mockups) */
  --ivory:        #F7F0E6;
  --ivory-deep:   #EFE4D4;
  --champagne:    #EAD9C2;
  --champagne-lt: #F6EDE0;
  --rose:         #E7C4AC;
  --rose-gold:    #C99B7E;
  --rose-gold-lt: #E2B79A;
  --copper:       #A86B47;
  --copper-deep:  #8A5436;
  --mocha:        #6E5645;
  --mocha-deep:   #4A3528;
  --espresso:     #2E2018;
  --espresso-ink: #1E140E;

  /* Glass */
  --glass-bg:     rgba(255, 250, 243, 0.62);
  --glass-bg-2:   rgba(255, 248, 238, 0.45);
  --glass-stroke: rgba(255, 255, 255, 0.72);
  --glass-edge:   rgba(201, 155, 126, 0.30);
  --glass-dark:   rgba(46, 32, 24, 0.42);
  --blur:         34px;

  /* Shadows */
  --shadow-sm:  0 4px 16px -6px rgba(46, 32, 24, 0.18);
  --shadow-md:  0 18px 50px -20px rgba(46, 32, 24, 0.30);
  --shadow-lg:  0 40px 90px -32px rgba(46, 32, 24, 0.42);
  --glow-rose:  0 0 60px -10px rgba(201, 155, 126, 0.55);

  /* Radii */
  --r-sm: 14px;
  --r-md: 20px;
  --r-lg: 28px;
  --r-xl: 36px;
  --r-pill: 999px;

  /* Rhythm */
  --pad-x: clamp(18px, 5vw, 72px);
  --section-y: clamp(72px, 12vw, 132px);
  --maxw: 1240px;

  /* Type. NOTE: the special numeral font (DM Serif Display) is applied ONLY to
     the hero countdown (.countdown__num) — everywhere else numbers use the same
     font as the surrounding text, so nothing looks mismatched. */
  --serif: "Playfair Display", Georgia, serif;
  --sans:  "DM Sans", system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
/* kill the blue tap-highlight flash + accidental blue selection on tap/click */
* { -webkit-tap-highlight-color: transparent; }
img, svg, button, a, label, .star, .nav, .nav__drawer, .drawer__item, .cvideo,
.carousel__btn, .carousel__dots, .nav__toggle, .countdown__cell, .fcard__icon,
.venue__ico, .tstep__num, .drawer__ico, [aria-hidden="true"] {
  -webkit-user-select: none; -moz-user-select: none; user-select: none;
  -webkit-touch-callout: none;
}
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: clip; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

/* ── Resize freeze: zero transitions while viewport is being dragged ── */
.is-resizing {
  scroll-behavior: auto !important; /* stop scroll-restore from animating into a "glide" jump */
}
.is-resizing *,
.is-resizing *::before,
.is-resizing *::after {
  transition-duration: 0.001ms !important;
  transition-delay:    0ms     !important;
  scroll-behavior: auto !important;
}
/* ── Settle: visible elements softly re-materialise after resize ends ── */
@keyframes settleIn {
  from { opacity: .5; filter: blur(2.5px); }
  to   { opacity: 1;  filter: blur(0); }
}
.is-settling { animation: settleIn .52s cubic-bezier(.22,1,.36,1) both; }
body {
  font-family: var(--sans); font-weight: 400; color: var(--espresso);
  background: var(--ivory); line-height: 1.6; overflow-x: hidden;
  -webkit-font-smoothing: antialiased; position: relative;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }
:focus-visible { outline: 2px solid var(--copper); outline-offset: 3px; border-radius: 6px; }

/* ===== AMBIENT BACKGROUND ===== */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -3;
  background:
    radial-gradient(120% 70% at 50% -10%, var(--champagne-lt) 0%, transparent 55%),
    radial-gradient(80% 60% at 100% 8%, rgba(231,196,172,0.45) 0%, transparent 52%),
    radial-gradient(90% 80% at 0% 100%, rgba(234,217,194,0.55) 0%, transparent 55%),
    linear-gradient(180deg, var(--ivory) 0%, var(--ivory-deep) 100%);
}
.atmosphere { position: fixed; inset: 0; z-index: -2; pointer-events: none; overflow: clip; contain: layout paint size; }
.orb { position: absolute; border-radius: 50%; filter: blur(64px); opacity: .5; will-change: transform; }
.orb--1 { width: 44vw; height: 44vw; top: -8vw; left: -10vw; background: radial-gradient(circle at 35% 35%, var(--rose-gold-lt), transparent 70%); animation: drift1 28s var(--ease) infinite alternate; }
.orb--2 { width: 38vw; height: 38vw; top: 46vh; right: -12vw; background: radial-gradient(circle at 60% 40%, rgba(168,107,71,.38), transparent 70%); animation: drift2 34s var(--ease) infinite alternate; }
.orb--3 { width: 32vw; height: 32vw; bottom: 4vh; left: 6vw; background: radial-gradient(circle at 50% 50%, rgba(234,217,194,.8), transparent 70%); animation: drift3 30s var(--ease) infinite alternate; }
@keyframes drift1 { to { transform: translate3d(6vw,5vh,0) scale(1.12); } }
@keyframes drift2 { to { transform: translate3d(-7vw,-4vh,0) scale(1.08); } }
@keyframes drift3 { to { transform: translate3d(5vw,-6vh,0) scale(1.15); } }

/* ===== PRIMITIVES ===== */
.glass {
  position: relative; background: var(--glass-bg);
  backdrop-filter: blur(var(--blur)) saturate(135%); -webkit-backdrop-filter: blur(var(--blur)) saturate(135%);
  border: 1px solid var(--glass-stroke); border-radius: var(--r-lg);
  box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,.85), inset 0 0 0 1px var(--glass-edge);
}
.glass::after { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; background: linear-gradient(160deg, rgba(255,255,255,.45) 0%, transparent 26%); }

.eyebrow { font-size: .7rem; font-weight: 500; letter-spacing: .3em; text-transform: uppercase; color: var(--copper); }
.italic { font-style: italic; }

.h-display { font-family: var(--serif); font-weight: 500; line-height: 1.05; letter-spacing: -.01em; color: var(--espresso); font-size: clamp(2rem, 6.5vw, 3.4rem); }
.h-display .italic { color: var(--copper-deep); font-weight: 400; }
.section-sub { color: var(--mocha); font-size: 1rem; max-width: 48ch; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: .6em; font-weight: 500; font-size: .92rem; letter-spacing: .02em; padding: .95em 1.7em; border-radius: var(--r-pill); transition: transform .45s var(--ease), box-shadow .45s var(--ease), filter .45s var(--ease), background .3s var(--ease); white-space: nowrap; }
.btn svg { width: 1.05em; height: 1.05em; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; transition: transform .45s var(--ease); }
.btn--solid { color: var(--ivory); background: linear-gradient(135deg, var(--mocha-deep) 0%, var(--copper-deep) 100%); box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255,255,255,.18); }
.btn--solid:hover { transform: translateY(-2px); filter: brightness(1.07); }
.btn--solid:hover svg { transform: translateX(3px); }
.btn--ghost { color: var(--espresso); background: rgba(255,255,255,.4); border: 1px solid var(--glass-edge); backdrop-filter: blur(12px); }
.btn--ghost:hover { transform: translateY(-2px); background: rgba(255,255,255,.65); }
.btn--gold { color: var(--ivory); background: linear-gradient(135deg, var(--copper), var(--rose-gold)); box-shadow: var(--shadow-md), var(--glow-rose); }
.btn--gold:hover { transform: translateY(-2px); filter: brightness(1.05); }
.btn--block { width: 100%; }

.pill-link { display: inline-flex; align-items: center; gap: .5em; font-weight: 500; font-size: .82rem; letter-spacing: .04em; color: var(--copper-deep); }
.pill-link svg { width: 1em; height: 1em; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; transition: transform .4s var(--ease); }
.pill-link:hover svg { transform: translateX(4px); }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s var(--ease), transform .9s var(--ease); will-change: opacity, transform; }
.reveal.is-in { opacity: 1; transform: none; }

.section-head { display: flex; flex-direction: column; gap: 14px; }
.section-head .eyebrow { margin-bottom: 2px; }

/* ===== NAV ===== */
.nav {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 60;
  display: flex; align-items: center; gap: 12px;
  padding: 14px var(--pad-x);
  background: rgba(247,240,230,.4); 
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.2);
  transition: all .4s var(--ease);
}
.nav.is-stuck { 
  background: rgba(247,240,230,.88); 
  backdrop-filter: blur(24px) saturate(140%); -webkit-backdrop-filter: blur(24px) saturate(140%); 
  box-shadow: var(--shadow-sm); 
  padding-top: 10px; padding-bottom: 10px; 
  border-bottom-color: var(--glass-stroke);
}
.nav__brand { display: flex; align-items: center; flex: 1; }
.nav__logo { height: clamp(56px, 7.5vw, 82px); width: auto; object-fit: contain; transition: height .4s var(--ease); }
.nav.is-stuck .nav__logo { height: clamp(48px, 6vw, 68px); }
.nav__links { display: none; gap: 30px; }
.nav__links a { font-size: .72rem; letter-spacing: .18em; font-weight: 500; text-transform: uppercase; color: var(--espresso); transition: color .3s var(--ease); }
.nav__links a:hover { color: var(--copper); }
.nav__cta { display: none; }
.nav__toggle { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--glass-bg); border: 1px solid var(--glass-stroke); backdrop-filter: blur(14px); box-shadow: var(--shadow-sm); }
.nav__toggle span { position: relative; width: 16px; height: 1.5px; background: var(--espresso); transition: .3s var(--ease); }
.nav__toggle span::before, .nav__toggle span::after { content: ""; position: absolute; left: 0; width: 16px; height: 1.5px; background: var(--espresso); transition: .3s var(--ease); }
.nav__toggle span::before { top: -5px; } .nav__toggle span::after { top: 5px; }
body.menu-open .nav__toggle span { background: transparent; }
body.menu-open .nav__toggle span::before { top: 0; transform: rotate(45deg); }
body.menu-open .nav__toggle span::after { top: 0; transform: rotate(-45deg); }

/* ===== nav right group — flex:1 mirror of brand, keeps ticker page-centered ===== */
.nav__right { flex: 1; display: flex; align-items: center; justify-content: flex-end; gap: 12px; }

/* ===== nav ticker — fixed-width, always at page center between two flex:1 columns ===== */
.nav__ticker {
  flex: 0 0 auto;
  width: clamp(190px, 38vw, 420px);
  position: relative;
  height: 1.5em;
  overflow: hidden;
  pointer-events: none;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.nav__ticker-line {
  position: absolute; left: 0; right: 0; top: 0;
  display: flex; align-items: center; justify-content: center;
  height: 1.5em; white-space: nowrap;
  font-family: var(--serif); font-style: italic;
  font-size: clamp(.62rem, 1.3vw, .9rem);
  letter-spacing: .015em; color: var(--copper-deep);
  opacity: 0; transform: translateY(100%); filter: blur(5px);
  animation: navTickerCycle 13.5s var(--ease) infinite;
}
.nav__ticker-line em { font-style: normal; color: var(--rose-gold); margin-left: .15em; }
.nav__ticker-line em:first-child { margin-left: 0; margin-right: .1em; }
.nav__ticker-line:nth-child(1) { animation-delay: 0s; }
.nav__ticker-line:nth-child(2) { animation-delay: 4.5s; }
.nav__ticker-line:nth-child(3) { animation-delay: 9s; }
@keyframes navTickerCycle {
  0%   { opacity: 0; transform: translateY(105%);  filter: blur(5px); }
  5%   { opacity: 1; transform: translateY(0);      filter: blur(0); }
  28%  { opacity: 1; transform: translateY(0);      filter: blur(0); }
  33%  { opacity: 0; transform: translateY(-105%);  filter: blur(5px); }
  100% { opacity: 0; transform: translateY(-105%);  filter: blur(5px); }
}
@media (prefers-reduced-motion: reduce) {
  .nav__ticker-line { animation: none; }
  .nav__ticker-line:nth-child(1) { opacity: 1; transform: none; filter: none; }
  .nav__ticker-line:nth-child(2), .nav__ticker-line:nth-child(3) { display: none; }
}
@media (max-width: 679px) {
  /* exactly 2 lines tall — text fills container, centers naturally in the nav */
  .nav__ticker {
    font-size: clamp(.62rem, 1.3vw, .9rem); /* sync so 2.8em resolves the same on container and lines */
    height: 2.8em;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
            mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
  }
  .nav__ticker-line {
    display: block;
    white-space: normal;
    text-align: center;
    height: 2.8em;
    line-height: 1.4;
    padding: 0 2px;
  }
}

/* ===== mobile drawer — soft floral menu (matches reference) ===== */
.nav__drawer {
  position: fixed; inset: 0; z-index: 55;
  background-image:
    linear-gradient(180deg, rgba(248,241,231,.72) 0%, rgba(248,241,231,.32) 42%, rgba(248,241,231,.08) 70%, rgba(248,241,231,0) 100%),
    url("menu-bg-mobile.webp");
  background-size: cover, cover;
  background-position: center top, bottom center;
  background-repeat: no-repeat, no-repeat;
  display: flex; flex-direction: column; justify-content: flex-start;
  padding: clamp(108px, 24vh, 150px) clamp(20px, 6vw, 34px) 14vh;
  opacity: 0; pointer-events: none;
  transition: opacity .45s var(--ease);
  overflow-y: auto; overscroll-behavior: contain;   /* drawer scrolls on its own; never the page behind */
}
body.menu-open { overflow: hidden; }                 /* lock the page so it can't scroll behind the menu */
body.menu-open .nav__drawer { opacity: 1; pointer-events: auto; }

.drawer__menu { display: flex; flex-direction: column; gap: 14px; width: 100%; max-width: 460px; margin: 0 auto; }

.drawer__item {
  display: flex; align-items: center; gap: 13px;
  padding: 8px 18px 8px 8px;
  border-radius: var(--r-lg);
  /* lighter, more translucent glass so the floral shows through (per reference) */
  background: linear-gradient(180deg, rgba(255,253,249,.34), rgba(252,245,236,.2));
  border: 1px solid rgba(255,255,255,.5);
  box-shadow: 0 8px 20px -16px rgba(168,107,71,.35), inset 0 1px 0 rgba(255,255,255,.7);
  -webkit-backdrop-filter: blur(9px); backdrop-filter: blur(9px);
  transform: translateY(14px); opacity: 0;
  transition: transform .5s var(--ease), opacity .5s var(--ease), box-shadow .35s var(--ease);
}
/* staggered entrance once the drawer is open */
body.menu-open .drawer__item { transform: none; opacity: 1; }
body.menu-open .drawer__item:nth-child(1) { transition-delay: .08s; }
body.menu-open .drawer__item:nth-child(2) { transition-delay: .14s; }
body.menu-open .drawer__item:nth-child(3) { transition-delay: .20s; }
body.menu-open .drawer__item:nth-child(4) { transition-delay: .26s; }
body.menu-open .drawer__item:nth-child(5) { transition-delay: .32s; }
.drawer__item:active { transform: scale(.985); box-shadow: 0 6px 16px -12px rgba(168,107,71,.5), inset 0 1px 0 rgba(255,255,255,.9); }

.drawer__ico {
  flex: none; width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center; color: var(--copper);
  background: linear-gradient(145deg, rgba(255,255,255,.6), rgba(238,224,206,.34));
  box-shadow: 0 3px 8px -5px rgba(168,107,71,.35), inset 0 1px 0 rgba(255,255,255,.8), inset 0 -2px 4px rgba(201,155,126,.16);
}
.drawer__ico svg { width: 19px; height: 19px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.drawer__label { font-family: var(--serif); font-weight: 500; font-size: clamp(1.05rem, 4.6vw, 1.22rem); color: var(--espresso); letter-spacing: .005em; }

@media (prefers-reduced-motion: reduce) {
  .drawer__item { transition: opacity .2s; transform: none; }
}

@media (min-width: 920px) {
  .nav__links { display: flex; }
  .nav__cta { display: inline-flex; }
  .nav__toggle { display: none; }
}

/* ===== HERO ===== */
.hero { position: relative; padding: clamp(96px, 15vh, 148px) var(--pad-x) clamp(56px, 9vw, 96px); overflow: hidden; }
.hero__grid { max-width: var(--maxw); margin: 0 auto; display: grid; gap: clamp(30px, 5vw, 56px); align-items: center; position: relative; z-index: 1; }
.hero__copy { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 22px; }
.hero__title { font-family: var(--serif); font-weight: 500; font-size: clamp(2.3rem, 8vw, 3.9rem); line-height: 1.06; letter-spacing: -.015em; }
.hero__title .italic { display: block; color: var(--copper-deep); font-weight: 400; }
.hero__lede { color: var(--mocha); font-size: clamp(1rem, 2.4vw, 1.16rem); max-width: 46ch; }
.hero__ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-top: 4px; }
.hero__trust { display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 6px; color: var(--mocha); font-size: .82rem; }
.hero__trust .dots { display: flex; }
.hero__trust .dots span { width: 32px; height: 32px; border-radius: 50%; margin-left: -9px; border: 2px solid var(--ivory); background-color: var(--rose-gold); background-size: cover; background-position: center; background-repeat: no-repeat; box-shadow: 0 3px 8px -3px rgba(46,32,24,.5); }
.hero__trust .dots span:first-child { margin-left: 0; }

.hero__visual { position: relative; }
.hero__photo { position: relative; margin: 0; aspect-ratio: 4 / 4.6; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--glass-stroke); }
.hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: 64% 36%; }
.hero__photo::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(180deg, transparent 52%, rgba(30,20,14,.34) 100%); }

.hero__countdown { position: relative; z-index: 3; margin: -36px auto 0; width: min(440px, 92%); padding: clamp(18px, 3.4vw, 24px); border-radius: var(--r-lg); background: linear-gradient(180deg, rgba(255,251,246,.95), rgba(246,237,224,.92)); backdrop-filter: blur(10px); box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255,255,255,.95), inset 0 0 0 1px var(--glass-edge); }

@media (min-width: 920px) {
  .hero__grid { grid-template-columns: 1.02fr 0.98fr; align-items: center; }
  .hero__copy { align-items: flex-start; text-align: left; }
  .hero__ctas, .hero__trust { justify-content: flex-start; }
  /* timer sits below the photo, overlapping it by ~60px at its top */
  .hero { padding-bottom: 210px; }
  .hero__countdown { position: absolute; left: 50%; top: calc(100% - 60px); bottom: auto; right: auto; transform: translateX(-50%); width: min(430px, 84%); margin: 0; }
}
.countdown__top { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.countdown__top .eyebrow { color: var(--copper); }
.countdown__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--rose-gold); box-shadow: var(--glow-rose); animation: glowPulse 2.6s ease-in-out infinite; }
@keyframes glowPulse { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
.countdown__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 9px; }
.countdown__cell {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 15px 6px 11px; border-radius: 18px; position: relative; overflow: hidden;
  background:
    radial-gradient(130% 90% at 50% -10%, rgba(255,255,255,.95), transparent 70%),
    linear-gradient(180deg, rgba(247,240,230,.96) 0%, rgba(231,196,172,.78) 100%);
  border: 1px solid rgba(255,255,255,.75);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.95), inset 0 0 0 1px rgba(201,155,126,.18), 0 8px 22px -12px rgba(168,107,71,.55);
}
.countdown__cell::before { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; background: radial-gradient(85% 65% at 50% 130%, rgba(201,155,126,.4), transparent 62%); }
.countdown__num {
  position: relative; font-family: var(--serif); font-weight: 400;
  font-size: clamp(1.8rem, 6.4vw, 2.4rem); line-height: 1; color: var(--mocha-deep);
  font-variant-numeric: tabular-nums; letter-spacing: .005em; white-space: nowrap;
  text-shadow: 0 1px 0 rgba(255,255,255,.65);
}
.countdown__lbl { position: relative; font-size: .54rem; letter-spacing: .2em; text-transform: uppercase; color: var(--copper-deep); font-weight: 600; }
.countdown__note { margin-top: 16px; display: flex; align-items: center; justify-content: center; gap: 8px; padding: 9px 14px; border-radius: var(--r-pill); background: rgba(255,255,255,.45); border: 1px solid var(--glass-edge); font-family: var(--serif); font-style: italic; font-size: .86rem; color: var(--mocha); }

/* ===== JOURNEY ===== */
.journey { padding: var(--section-y) var(--pad-x); }
.journey__inner { max-width: var(--maxw); margin: 0 auto; }
.journey__head { display: flex; flex-direction: column; gap: 16px; margin-bottom: 36px; }
.journey__head .btn { align-self: flex-start; }
/* alternating numbered timeline (16:9 media) */
.timeline { max-width: var(--maxw); margin: 0 auto; display: flex; flex-direction: column; gap: clamp(40px, 6vw, 76px); }
.tstep { display: grid; gap: clamp(16px, 3vw, 36px); align-items: center; }
.tstep__media { position: relative; margin: 0; aspect-ratio: 16 / 9; border-radius: var(--r-xl); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--glass-stroke); }
.tstep__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--ease); }
.tstep__media::after { content: ""; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(180deg, transparent 58%, rgba(46,32,24,.22)); }
.tstep:hover .tstep__media img { transform: scale(1.045); }
.tstep__body { display: flex; flex-direction: column; gap: 13px; }
.tstep__num { width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center; font-family: "Bodoni Moda", "Playfair Display", Georgia, serif; font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; font-size: 1.5rem; color: var(--rose-gold); border: 1px solid var(--glass-edge); background: radial-gradient(70% 70% at 50% 30%, rgba(255,255,255,.55), transparent 70%); box-shadow: inset 0 1px 0 rgba(255,255,255,.7); }
.tstep__body h3 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.45rem, 4vw, 2.1rem); line-height: 1.1; color: var(--espresso); }
.tstep__body p { color: var(--mocha); font-size: 1rem; max-width: 44ch; }

@media (min-width: 720px) {
  .journey__head { flex-direction: row; align-items: flex-end; justify-content: space-between; margin-bottom: 48px; }
  .journey__head .section-head { max-width: 60%; }
}
@media (min-width: 760px) {
  .tstep { grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 56px); }
  .tstep__body { padding: 0 clamp(8px, 2vw, 32px); }
  /* odd steps: image on the right, text on the left (matches the reference) */
  .tstep:nth-child(odd) .tstep__media { order: 2; }
}

/* ===== VOICES (dark band + carousel + live wall) ===== */
.voices { padding: var(--section-y) var(--pad-x); }
.voices__band { max-width: var(--maxw); margin: 0 auto; border-radius: var(--r-xl); padding: clamp(40px, 7vw, 80px) clamp(18px, 4vw, 56px); position: relative; overflow: hidden; background: radial-gradient(80% 70% at 50% 0%, rgba(168,107,71,.5) 0%, transparent 60%), linear-gradient(165deg, var(--mocha-deep) 0%, var(--espresso) 60%, var(--espresso-ink) 100%); box-shadow: var(--shadow-lg); }
.voices__band::before { content: ""; position: absolute; inset: 0; background: radial-gradient(40% 40% at 18% 30%, rgba(226,183,154,.18), transparent 70%), radial-gradient(40% 40% at 85% 75%, rgba(201,155,126,.18), transparent 70%); pointer-events: none; }
.voices__head { text-align: center; position: relative; margin-bottom: clamp(28px, 5vw, 48px); }
.voices__head .eyebrow { color: var(--rose-gold-lt); }
.voices__head h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(1.9rem, 6vw, 3rem); color: var(--ivory); margin-top: 10px; }
.voices__head h2 .italic { color: var(--rose-gold-lt); }
.voices__head p { color: rgba(247,240,230,.66); margin-top: 12px; font-size: .96rem; }

.carousel { position: relative; }
.carousel__stage { position: relative; height: clamp(420px, 78vw, 520px); perspective: 1500px; perspective-origin: 50% 45%; }
.cvideo { position: absolute; top: 50%; left: 50%; width: clamp(210px, 56vw, 300px); aspect-ratio: 9 / 16; border-radius: var(--r-lg); overflow: hidden; transform-style: preserve-3d; transition: transform 1s var(--ease), opacity 1s var(--ease), filter 1s var(--ease), box-shadow 1s var(--ease); will-change: transform, opacity, filter; border: 1px solid rgba(255,255,255,.18); box-shadow: var(--shadow-lg); background: linear-gradient(160deg, var(--rose-gold-lt), var(--copper)); cursor: pointer; }
.cvideo__media { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cvideo__poster { position: absolute; inset: 0; display: grid; place-items: center; background: radial-gradient(70% 60% at 50% 30%, rgba(255,250,243,.4), transparent 70%), linear-gradient(160deg, var(--rose-gold-lt), var(--copper)); color: rgba(255,255,255,.9); font-family: var(--serif); font-style: italic; font-size: 2.2rem; }
.cvideo__veil { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 42%, rgba(30,20,14,.72) 100%); }
.cvideo__badge { position: absolute; top: 12px; left: 12px; display: flex; align-items: center; gap: 6px; padding: 5px 10px; border-radius: var(--r-pill); background: rgba(30,20,14,.5); backdrop-filter: blur(8px); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ivory); }
.cvideo__badge .live-dot { width: 6px; height: 6px; border-radius: 50%; background: #6ee7a8; box-shadow: 0 0 8px #6ee7a8; animation: glowPulse 1.6s infinite; }
.cvideo__play { position: absolute; bottom: 14px; left: 14px; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,250,243,.9); box-shadow: var(--shadow-sm); }
.cvideo__play svg { width: 15px; height: 15px; fill: var(--copper-deep); }
.cvideo__cap { position: absolute; left: 14px; right: 14px; bottom: 14px; display: none; }

.cvideo[data-pos="center"]   { transform: translate(-50%,-50%) translateZ(110px) scale(1); opacity: 1; filter: none; z-index: 5; box-shadow: var(--shadow-lg), 0 0 70px -10px rgba(226,183,154,.6); }
.cvideo[data-pos="left"]     { transform: translate(-50%,-50%) translateX(-70%) translateZ(-50px) rotateY(26deg) scale(.8); opacity: .85; filter: brightness(.8); z-index: 4; }
.cvideo[data-pos="right"]    { transform: translate(-50%,-50%) translateX(70%)  translateZ(-50px) rotateY(-26deg) scale(.8); opacity: .85; filter: brightness(.8); z-index: 4; }
.cvideo[data-pos="far-left"] { transform: translate(-50%,-50%) translateX(-112%) translateZ(-210px) rotateY(32deg) scale(.6); opacity: .35; filter: brightness(.65) blur(3px); z-index: 2; }
.cvideo[data-pos="far-right"]{ transform: translate(-50%,-50%) translateX(112%)  translateZ(-210px) rotateY(-32deg) scale(.6); opacity: .35; filter: brightness(.65) blur(3px); z-index: 2; }
.cvideo[data-pos="hidden"]   { transform: translate(-50%,-50%) translateZ(-300px) scale(.5); opacity: 0; filter: blur(6px); z-index: 1; pointer-events: none; }

/* fixed 3-line block: up to 2 lines of quote + 1 line of name/location. The
   name sits right under the quote (line 2 if short, line 3 if long); the block
   height never changes, so the carousel never resizes between stories. */
.carousel__caption { text-align: center; max-width: 540px; margin: clamp(18px,4vw,32px) auto 0; height: clamp(96px, 22vw, 116px); position: relative; }
.carousel__quote { position: relative; font-family: var(--serif); font-style: italic; font-size: clamp(1.15rem, 3.6vw, 1.55rem); line-height: 1.4; color: var(--ivory);
  overflow: hidden; max-height: 2.9em; cursor: pointer; }
.carousel__story { margin-top: 12px; color: rgba(247,240,230,.66); font-size: .92rem; }
.carousel__id { margin-top: 14px; display: inline-flex; align-items: center; gap: 10px; }
.carousel__name { font-family: var(--serif); color: var(--rose-gold-lt); font-size: 1rem; }
.carousel__city { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: rgba(247,240,230,.5); padding-left: 14px; position: relative; }
.carousel__city::before { content: ""; position: absolute; left: 0; top: 50%; width: 7px; height: 1px; background: var(--rose-gold-lt); }
.carousel__caption.is-swapping .carousel__quote,
.carousel__caption.is-swapping .carousel__story,
.carousel__caption.is-swapping .carousel__id { opacity: 0; transform: translateY(10px); }
.carousel__quote, .carousel__story, .carousel__id { transition: opacity .65s var(--ease), transform .65s var(--ease); }

.carousel__controls { display: flex; align-items: center; justify-content: center; gap: 18px; margin-top: clamp(20px,4vw,32px); }
.carousel__btn { width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,250,243,.1); border: 1px solid rgba(255,255,255,.25); backdrop-filter: blur(10px); transition: transform .4s var(--ease), background .4s var(--ease); }
.carousel__btn:hover { transform: translateY(-3px); background: rgba(255,250,243,.22); }
.carousel__btn svg { width: 19px; height: 19px; fill: none; stroke: var(--ivory); stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.carousel__dots { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; max-width: 200px; justify-content: center; }
.carousel__dots button { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,250,243,.28); transition: .4s var(--ease); }
.carousel__dots button[aria-selected="true"] { width: 22px; border-radius: 4px; background: linear-gradient(90deg, var(--rose-gold-lt), var(--copper)); }

.voices__share { display: flex; flex-direction: column; align-items: center; gap: 14px; margin-top: clamp(30px,5vw,44px); text-align: center; }
.voices__share p { font-family: var(--serif); font-style: italic; color: rgba(247,240,230,.8); font-size: 1.05rem; max-width: 30ch; }

/* ──────────────────────────────────────────────────────────
   VOICES — RESPONSIVE OVERRIDES
   Mobile  : single square card, crossfade, compact layout
   Tablet  : 3-card 3D, no far-left/far-right, reduced stage
   ────────────────────────────────────────────────────────── */

@media (max-width: 679px) {
  .voices { padding: clamp(48px,9vw,72px) var(--pad-x); }
  .voices__band { padding: clamp(24px,5vw,36px) clamp(14px,4vw,22px) clamp(28px,6vw,40px); border-radius: var(--r-lg); }
  .voices__head { margin-bottom: clamp(18px,4vw,28px); }
  .voices__head h2 { font-size: clamp(1.5rem,6vw,2rem); }
  .voices__head p  { font-size: .88rem; margin-top: 8px; }
  /* Carousel card + caption + controls rules now live in the dedicated
     "MOBILE CAROUSEL — 3 rotating cards" block near the end of this file. */
}

@media (min-width: 680px) and (max-width: 959px) {
  .carousel__stage { height: clamp(300px, 54vw, 420px); }
  .cvideo { width: clamp(150px, 35vw, 200px); }
  /* Hide far cards on tablet — stage isn't wide enough for 5 */
  .cvideo[data-pos="far-left"],
  .cvideo[data-pos="far-right"] { opacity: 0; pointer-events: none; }
  .carousel__caption { min-height: 100px; }
}

/* ===== MOMENTS (mosaic) ===== */
.moments { padding: var(--section-y) var(--pad-x); }
.moments__inner { max-width: var(--maxw); margin: 0 auto; display: grid; gap: 28px; }
.moments__head .btn { align-self: flex-start; margin-top: 8px; }
.mosaic { position: relative; display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.mtile { aspect-ratio: 1; border-radius: var(--r-md); overflow: hidden; position: relative; box-shadow: var(--shadow-sm); background: linear-gradient(150deg, var(--rose) 0%, var(--copper) 70%, var(--mocha-deep) 100%); }
.mtile::after { content: ""; position: absolute; inset: 0; background: radial-gradient(70% 60% at 40% 20%, rgba(255,245,232,.35), transparent 65%); }
.mtile--tall { grid-row: span 2; aspect-ratio: auto; }
.mtile__label { position: absolute; left: 12px; bottom: 11px; z-index: 1; font-family: var(--serif); font-style: italic; font-size: .8rem; color: rgba(255,250,243,.95); text-shadow: 0 2px 8px rgba(30,20,14,.6); }
.mosaic__quote { grid-column: 1 / -1; padding: 24px; border-radius: var(--r-lg); text-align: center; display: flex; flex-direction: column; gap: 6px; }
.mosaic__quote span { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--copper); }
.mosaic__quote strong { font-family: var(--serif); font-weight: 500; font-size: clamp(1.1rem, 3.4vw, 1.5rem); color: var(--espresso); }
@media (min-width: 760px) {
  .moments__inner { grid-template-columns: .85fr 1.15fr; align-items: center; }
  .mosaic { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; }
  .mosaic__quote { grid-column: 2 / 3; grid-row: 1 / 2; }
}

/* ===== FEATURE CARDS ===== */
.features { padding: clamp(48px, 7vw, 80px) var(--pad-x) var(--section-y); }
.features__grid { max-width: var(--maxw); margin: 0 auto; display: grid; gap: 14px; }
/* fcard reveal — starts 100px below, springs up with stagger */
.fcard.reveal { opacity: 0; transform: translateY(100px); transition: opacity 1.1s cubic-bezier(.22,1,.36,1), transform 1.1s cubic-bezier(.22,1,.36,1); }
.fcard.reveal.is-in { opacity: 1; transform: translateY(0); }
.fcard { padding: 28px 24px; border-radius: var(--r-lg); display: flex; flex-direction: column; gap: 12px; transition: transform .5s var(--ease), box-shadow .5s var(--ease);
  background: radial-gradient(120% 80% at 50% -5%, rgba(255,255,255,.6), transparent 55%), linear-gradient(165deg, rgba(255,250,243,.74) 0%, rgba(234,217,194,.5) 100%); }
.fcard:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }
.fcard__icon { width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(140deg, rgba(231,196,172,.6), rgba(168,107,71,.28)); color: var(--copper-deep); }
.fcard__icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.fcard h3 { font-family: var(--serif); font-weight: 500; font-size: 1.3rem; color: var(--espresso); }
.fcard p { color: var(--mocha); font-size: .92rem; flex: 1; }
@media (min-width: 820px) { .features__grid { grid-template-columns: repeat(3, 1fr); } }

/* ===== SOUL SHIFT (full-bleed scroll-driven PARALLAX + DOLLY) ===== */
.soulshift { padding: 0; position: relative; }
.soulshift__band { max-width: none; margin: 0; border-radius: 0; padding: clamp(72px, 10vw, 120px) clamp(22px, 5vw, 64px); text-align: center; position: relative; overflow: hidden; display: flex; flex-direction: column; align-items: center; gap: 15px;
  background-color: var(--espresso-ink);
  box-shadow: inset 0 0 160px -40px rgba(0,0,0,.7); }
/* image layer — oversized 28% top/bottom to accommodate parallax travel without exposing bg */
.soulshift__bg { position: absolute; top: -28%; left: 0; right: 0; bottom: -28%; z-index: 0; pointer-events: none;
  background-image: linear-gradient(180deg, rgba(22,14,9,.52) 0%, rgba(22,14,9,.30) 45%, rgba(22,14,9,.58) 100%), url("soulshift-bg.webp");
  background-size: cover; background-position: center center; transform-origin: center;
  will-change: transform; }
.soulshift__band > *:not(.soulshift__bg) { position: relative; z-index: 2; }
@media (prefers-reduced-motion: reduce) { .soulshift__bg { transform: none !important; } }
.soulshift__star { color: var(--rose-gold-lt); font-size: .9rem; opacity: .85; filter: drop-shadow(0 0 8px rgba(226,183,154,.8)); }
.soulshift__tag { display: inline-flex; align-items: center; padding: 9px 22px; border-radius: var(--r-pill); border: 1px solid rgba(226,183,154,.45); color: var(--rose-gold-lt); font-size: .64rem; letter-spacing: .26em; text-transform: uppercase; background: rgba(20,13,8,.28); backdrop-filter: blur(4px); }
.soulshift__title { font-family: var(--serif); font-weight: 500; font-size: clamp(2.6rem, 9vw, 4.6rem); line-height: 1.02; letter-spacing: -.005em; color: var(--ivory); margin-top: 8px; text-shadow: 0 2px 30px rgba(0,0,0,.55); }
.soulshift__title .italic { display: block; font-style: italic; font-weight: 400; color: var(--rose-gold-lt); }
.soulshift__div { color: var(--rose-gold-lt); font-size: .82rem; position: relative; margin: 6px 0; }
.soulshift__div::before, .soulshift__div::after { content: ""; position: absolute; top: 50%; width: clamp(40px, 8vw, 72px); height: 1px; background: linear-gradient(90deg, transparent, rgba(226,183,154,.55)); }
.soulshift__div::before { right: calc(100% + 14px); transform: scaleX(-1); }
.soulshift__div::after { left: calc(100% + 14px); }
.soulshift__lead { font-family: var(--serif); font-size: clamp(1.15rem, 3.2vw, 1.6rem); line-height: 1.4; color: var(--ivory); max-width: 30ch; text-shadow: 0 2px 18px rgba(0,0,0,.55); }
.soulshift__desc { color: rgba(247,240,230,.78); max-width: 52ch; font-size: 1rem; margin-top: 2px; }
.soulshift__count { margin-top: 24px; padding: clamp(22px,3.5vw,30px) clamp(28px,6vw,60px); border-radius: var(--r-lg); position: relative;
  background: rgba(20,13,8,.45); border: 1px solid rgba(226,183,154,.45); backdrop-filter: blur(8px);
  box-shadow: 0 0 55px -12px rgba(226,183,154,.55), inset 0 1px 0 rgba(255,255,255,.14);
  display: flex; flex-direction: column; align-items: center; gap: 16px; }
.soulshift__count-lbl { font-size: .62rem; letter-spacing: .26em; text-transform: uppercase; color: var(--rose-gold-lt); }
.ss-grid { display: flex; gap: clamp(16px, 4.5vw, 40px); justify-content: center; }
.ss-cell { display: flex; flex-direction: column; align-items: center; gap: 8px; position: relative; width: clamp(48px, 14vw, 74px); }
.ss-cell:not(:last-child)::after { content: ""; position: absolute; right: calc(-1 * clamp(8px, 2.25vw, 20px)); top: 8%; height: 70%; width: 1px; background: linear-gradient(rgba(226,183,154,0), rgba(226,183,154,.55), rgba(226,183,154,0)); }
.ss-num { font-family: var(--serif); font-weight: 400; font-size: clamp(1.7rem, 6.4vw, 3.3rem); line-height: 1; color: var(--ivory); font-variant-numeric: tabular-nums; text-shadow: 0 0 26px rgba(226,183,154,.45); white-space: nowrap; }
.ss-lbl { font-size: .56rem; letter-spacing: .24em; text-transform: uppercase; color: rgba(247,240,230,.6); }
.soulshift__btn { margin-top: 16px; text-transform: uppercase; letter-spacing: .14em; font-size: .82rem; padding: 1.05em 2.2em; }
.soulshift__fine { color: rgba(247,240,230,.62); font-size: .88rem; font-family: var(--serif); margin-top: 6px; }
.soulshift__fine em { font-style: italic; }

/* ===== SOUL SHIFT POPUP (the showpiece) ===== */
.ssmodal { position: fixed; inset: 0; z-index: 130; display: grid; place-items: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity .45s var(--ease); }
.ssmodal.is-open { opacity: 1; pointer-events: auto; }
.ssmodal__scrim { position: absolute; inset: 0; background: rgba(20,13,8,.62); backdrop-filter: blur(10px); }
.ssmodal__card { position: relative; width: min(540px, 100%); border-radius: var(--r-xl); padding: clamp(34px,6vw,56px) clamp(26px,5vw,48px); text-align: center; overflow: hidden;
  background: radial-gradient(95% 70% at 50% -12%, rgba(168,107,71,.6), transparent 60%), linear-gradient(170deg, var(--mocha-deep) 0%, var(--espresso) 70%, var(--espresso-ink) 100%);
  border: 1px solid rgba(226,183,154,.3);
  box-shadow: var(--shadow-lg), 0 0 90px -20px rgba(201,155,126,.65), inset 0 1px 0 rgba(255,255,255,.12);
  transform: translateY(22px) scale(.95); transition: transform .55s var(--ease); }
.ssmodal.is-open .ssmodal__card { transform: none; }
.ssmodal__glow { position: absolute; top: -45%; left: 50%; transform: translateX(-50%); width: 130%; height: 85%; pointer-events: none; background: radial-gradient(circle, rgba(226,183,154,.32), transparent 62%); animation: ssGlow 6s ease-in-out infinite; }
@keyframes ssGlow { 0%,100% { opacity: .55; } 50% { opacity: 1; } }
.ssmodal__card > * { position: relative; }
.ssmodal__close { position: absolute; top: 14px; right: 14px; width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: rgba(247,240,230,.12); border: 1px solid rgba(255,255,255,.2); z-index: 3; }
.ssmodal__close svg { width: 16px; height: 16px; fill: none; stroke: var(--ivory); stroke-width: 1.8; stroke-linecap: round; }
.ssmodal__seal { font-size: 2.3rem; color: var(--rose-gold-lt); filter: drop-shadow(0 0 16px rgba(226,183,154,.85)); display: inline-block; animation: ssFloat 4s ease-in-out infinite; }
@keyframes ssFloat { 0%,100% { transform: translateY(0) rotate(0); } 50% { transform: translateY(-7px) rotate(10deg); } }
.ssmodal__eyebrow { margin-top: 14px; font-size: .66rem; letter-spacing: .3em; text-transform: uppercase; color: var(--rose-gold-lt); }
.ssmodal__title { font-family: var(--serif); font-weight: 500; font-size: clamp(1.9rem, 6vw, 2.8rem); color: var(--ivory); margin-top: 10px; line-height: 1.1; }
.ssmodal__title .italic { color: var(--rose-gold-lt); }
.ssmodal__body { color: rgba(247,240,230,.78); font-size: 1.02rem; margin: 16px auto 0; max-width: 40ch; }
.ssmodal__body b { color: var(--rose-gold-lt); font-weight: 600; }
.ssmodal__rule { display: block; width: 64px; height: 1px; margin: 24px auto; background: linear-gradient(90deg, transparent, var(--rose-gold), transparent); }
.ssmodal__note { font-family: var(--serif); font-style: italic; color: rgba(247,240,230,.72); font-size: 1.05rem; max-width: 34ch; margin: 0 auto 26px; }

/* ===== VENUE ===== */
.venue { padding: 0 var(--pad-x) var(--section-y); }
.venue__inner { max-width: var(--maxw); margin: 0 auto; }
.venue .section-head { margin-bottom: clamp(28px, 5vw, 44px); }
.venue__card { padding: clamp(20px, 4vw, 34px); border-radius: var(--r-xl); display: grid; gap: clamp(22px, 4vw, 36px); }
.venue__details { display: flex; flex-direction: column; gap: 18px; padding: clamp(6px,2vw,14px); }
.venue__row { display: flex; align-items: flex-start; gap: 14px; }
.venue__ico { width: 42px; height: 42px; flex: none; border-radius: 13px; display: grid; place-items: center; color: var(--copper-deep); background: linear-gradient(140deg, rgba(231,196,172,.6), rgba(168,107,71,.25)); }
.venue__ico svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.55; stroke-linecap: round; stroke-linejoin: round; }
.venue__row > div { display: flex; flex-direction: column; gap: 3px; }
.venue__lbl { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--copper); }
/* one uniform font + colour for every venue value (no numeral-font tint that
   made the date look duller than the rest). */
.venue__row strong { font-family: var(--serif); font-weight: 500; font-size: 1.12rem; color: var(--espresso); line-height: 1.2; }
.venue__sub { font-size: .82rem; color: var(--mocha); }
.venue__btn { align-self: flex-start; margin-top: 8px; }
.venue__map { position: relative; min-height: 300px; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--glass-stroke); background: rgba(255,255,255,.3); }
.venue__map iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }
@media (min-width: 820px) {
  .venue__card { grid-template-columns: 1fr 1.12fr; align-items: stretch; }
  .venue__map { min-height: 400px; }
}

/* ===== FAQ ===== */
.faq { padding: var(--section-y) var(--pad-x); }
.faq__inner { max-width: var(--maxw); margin: 0 auto; display: grid; gap: 28px; }
.faq__head { text-align: center; }
.faq__body { display: grid; gap: 24px; }
.faq__list { display: grid; gap: 12px; }
.faq__item { border-radius: var(--r-md); overflow: hidden; transition: box-shadow .4s var(--ease); }
.faq__item.is-open { box-shadow: var(--shadow-md), var(--glow-rose); }
.faq__q { width: 100%; text-align: left; list-style: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 18px 22px; font-family: var(--serif); font-size: 1.05rem; color: var(--espresso); background: none; border: 0; }
.faq__plus { position: relative; flex: none; align-self: flex-start; margin-top: 3px; width: 18px; height: 18px; transition: transform .45s var(--ease); }
.faq__item.is-open .faq__plus { transform: rotate(180deg); }
.faq__plus::before, .faq__plus::after { content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); background: var(--copper); border-radius: 2px; transition: transform .45s var(--ease); }
.faq__plus::before { width: 14px; height: 1.6px; } .faq__plus::after { width: 1.6px; height: 14px; }
.faq__item.is-open .faq__plus::after { transform: translate(-50%,-50%) scaleY(0); }
/* smooth height reveal — JS animates height to/from the content size */
.faq__a { height: 0; overflow: hidden; transition: height .45s var(--ease); }
.faq__a-in p { color: var(--mocha); font-size: .92rem; padding: 0 22px 20px; opacity: 0; transform: translateY(-6px); transition: opacity .4s var(--ease) .08s, transform .45s var(--ease) .08s; }
.faq__item.is-open .faq__a-in p { opacity: 1; transform: none; }
.faq__quote { padding: 32px; border-radius: var(--r-lg); text-align: center; display: flex; flex-direction: column; gap: 10px; align-self: center; background: radial-gradient(70% 60% at 50% 0%, rgba(231,196,172,.5), transparent 70%), var(--glass-bg); }
.faq__quote .mark { font-family: var(--serif); font-size: 3rem; color: var(--rose-gold); line-height: .6; }
.faq__quote strong { font-family: var(--serif); font-weight: 500; font-size: clamp(1.2rem,3.6vw,1.6rem); color: var(--espresso); }
.faq__quote span { font-size: .78rem; color: var(--mocha); }
@media (min-width: 860px) { .faq__body { grid-template-columns: 1.4fr .9fr; align-items: start; } .faq__list { grid-template-columns: 1fr 1fr; grid-column: 1; } }

/* ===== FOOTER ===== */
/* ===== FOOTER (full-bleed dark) ===== */
.closing { position: relative; overflow: hidden; padding: clamp(34px,6vw,60px) var(--pad-x) clamp(32px,5vw,52px);
  background: radial-gradient(80% 60% at 50% 0%, rgba(168,107,71,.35) 0%, transparent 60%),
              linear-gradient(175deg, var(--mocha-deep) 0%, var(--espresso) 55%, var(--espresso-ink) 100%); }
/* ambient glow orb behind brand */
.closing__glow { position: absolute; top: -80px; left: 50%; transform: translateX(-50%); width: 520px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(226,183,154,.18), transparent 68%); pointer-events: none; }

/* brand block */
.closing__brand { display: flex; flex-direction: column; align-items: center; gap: 18px; margin-bottom: clamp(36px,5vw,56px); position: relative; }
.closing__logo { height: clamp(64px,9vw,90px); width: auto; object-fit: contain; filter: brightness(0) invert(1) sepia(1) saturate(.4) hue-rotate(10deg) brightness(1.1); opacity: .9; }
.closing__tagline { font-family: var(--serif); font-style: italic; font-size: clamp(.88rem,1.8vw,1.05rem); color: var(--rose-gold-lt); letter-spacing: .04em; }

/* divider */
.closing__hr { max-width: var(--maxw); margin: 0 auto clamp(28px,4vw,44px); height: 1px; background: linear-gradient(90deg, transparent, rgba(226,183,154,.35) 30%, rgba(226,183,154,.35) 70%, transparent); position: relative; }

/* three-col grid */
.closing__cols { max-width: var(--maxw); margin: 0 auto clamp(28px,4vw,44px); display: grid; gap: 32px; position: relative; }
.fcol h4 { font-size: .62rem; letter-spacing: .24em; text-transform: uppercase; color: var(--rose-gold-lt); margin-bottom: 16px; }
.fcol a, .fcol p { display: block; color: rgba(247,240,230,.62); font-size: .88rem; line-height: 1.5; margin-bottom: 9px; transition: color .3s var(--ease); }
.fcol a:hover { color: var(--ivory); }
.fcol--center { text-align: left; }
.fsocial { display: flex; gap: 10px; margin-top: 14px; }
.fsocial a { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: rgba(247,240,230,.08); border: 1px solid rgba(255,255,255,.15); transition: background .3s var(--ease), border-color .3s var(--ease); margin: 0; }
.fsocial a:hover { background: rgba(226,183,154,.18); border-color: rgba(226,183,154,.4); }
.fsocial svg { width: 16px; height: 16px; fill: rgba(247,240,230,.75); }

/* bottom fine bar */
.closing__fine { max-width: var(--maxw); margin: 0 auto; display: flex; flex-wrap: wrap; gap: 8px 18px; justify-content: space-between; color: rgba(247,240,230,.38); font-size: .73rem; position: relative; }
.closing__fine em { font-style: italic; font-family: var(--serif); color: rgba(201,155,126,.6); }

@media (min-width: 680px) { .closing__cols { grid-template-columns: 1fr 1fr; } }
@media (min-width: 960px) { .closing__cols { grid-template-columns: 1fr 1fr 1fr; } }

/* ===== SHARE MODAL ===== */
.modal { position: fixed; inset: 0; z-index: 120; display: grid; place-items: center; padding: 18px; opacity: 0; pointer-events: none; transition: opacity .4s var(--ease); overscroll-behavior: contain; touch-action: none; }
.modal.is-open { opacity: 1; pointer-events: auto; }
.modal__scrim { position: absolute; inset: 0; background: rgba(30,20,14,.55); backdrop-filter: blur(8px); }
.modal__card { position: relative; width: min(400px, 100%); max-height: 90vh; overflow-y: auto; overscroll-behavior: contain; touch-action: pan-y; border-radius: var(--r-xl); padding: clamp(13px,3.4vw,20px); background: linear-gradient(180deg, rgba(255,251,245,.96), rgba(246,237,224,.96)); border: 1px solid var(--glass-stroke); box-shadow: var(--shadow-lg); transform: translateY(18px) scale(.98); transition: transform .45s var(--ease); }
.modal.is-open .modal__card { transform: none; }
.modal__close { position: absolute; top: 14px; right: 14px; width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; background: rgba(255,255,255,.6); border: 1px solid var(--glass-edge); }
.modal__close svg { width: 16px; height: 16px; fill: none; stroke: var(--espresso); stroke-width: 1.8; stroke-linecap: round; }
.modal__seal { font-size: 1.3rem; color: var(--rose-gold); filter: drop-shadow(0 0 8px rgba(201,155,126,.6)); }
.modal__eyebrow { margin: 4px 0 3px; }
.modal__title { font-family: var(--serif); font-weight: 500; font-size: clamp(1.25rem, 4vw, 1.55rem); line-height: 1.2; color: var(--espresso); }
.modal__title .italic { color: var(--copper-deep); }
.modal__prompt { display: none; }
.modal__note { font-size: .62rem; line-height: 1.35; margin-top: 2px; }
.modal__guide { margin: 20px 0; display: grid; gap: 10px; padding: 18px; border-radius: var(--r-md); background: rgba(255,255,255,.5); border: 1px solid var(--glass-edge); }
.modal__guide li { display: flex; gap: 10px; align-items: flex-start; font-size: .85rem; color: var(--mocha); }
.modal__guide svg { flex: none; width: 17px; height: 17px; margin-top: 1px; fill: none; stroke: var(--copper-deep); stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.modal__guide b { color: var(--espresso); font-weight: 600; }

.uploader { display: grid; gap: 9px; margin-top: 11px; }
#shareSubmit { padding-top: .7em; padding-bottom: .7em; }
.drop { position: relative; border: 1.6px dashed var(--rose-gold); border-radius: var(--r-md); padding: 26px 18px; text-align: center; cursor: pointer; transition: border-color .3s var(--ease), background .3s var(--ease); background: rgba(255,255,255,.35); }
.drop:hover, .drop.is-drag { border-color: var(--copper); background: rgba(231,196,172,.25); }
.drop input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.drop__icon { width: 48px; height: 48px; margin: 0 auto 10px; border-radius: 50%; display: grid; place-items: center; background: linear-gradient(135deg, var(--rose-gold-lt), var(--copper)); color: var(--ivory); }
.drop__icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.drop h4 { font-family: var(--serif); font-size: 1.05rem; color: var(--espresso); margin-bottom: 4px; }
.drop p { font-size: .8rem; color: var(--mocha); }
.drop__hint { margin-top: 6px; font-size: .72rem; color: var(--copper); }

.preview { display: none; position: relative; border-radius: var(--r-md); overflow: hidden; background: var(--espresso); aspect-ratio: 9/16; max-height: 320px; margin: 0 auto; }
.preview.is-on { display: block; }
.preview video, .preview img { width: 100%; height: 100%; object-fit: cover; }
.preview__clear { position: absolute; top: 8px; right: 8px; width: 32px; height: 32px; border-radius: 50%; background: rgba(30,20,14,.6); display: grid; place-items: center; backdrop-filter: blur(6px); }
.preview__clear svg { width: 14px; height: 14px; fill: none; stroke: var(--ivory); stroke-width: 2; stroke-linecap: round; }
.preview__meta { position: absolute; left: 8px; bottom: 8px; font-size: .68rem; color: var(--ivory); background: rgba(30,20,14,.55); padding: 4px 9px; border-radius: var(--r-pill); backdrop-filter: blur(6px); }

/* ===== SHARE CHOICES (record / photo) ===== */
.share-choices { display: grid; gap: 12px; }
@media (min-width: 440px) { .share-choices { grid-template-columns: 1fr 1fr; } }
.choice { position: relative; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 6px; padding: 15px 14px; border-radius: var(--r-md); cursor: pointer; border: 1.5px solid var(--glass-edge); background: rgba(255,255,255,.42); transition: border-color .3s var(--ease), background .3s var(--ease), transform .3s var(--ease); }
.choice:hover { border-color: var(--rose-gold); background: rgba(231,196,172,.22); transform: translateY(-2px); }
.choice--rec { background: linear-gradient(160deg, rgba(231,196,172,.45), rgba(168,107,71,.16)); border-color: rgba(201,155,126,.5); }
.choice.is-disabled { display: none; }
.choice input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.choice__icon { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; color: var(--ivory); background: linear-gradient(135deg, var(--rose-gold-lt), var(--copper)); box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.4); }
.choice__icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.choice__t { font-family: var(--serif); font-size: 1.05rem; color: var(--espresso); }
.choice__s { font-size: .72rem; color: var(--mocha); }

/* ===== IN-BROWSER RECORDER ===== */
.recorder { display: flex; flex-direction: column; gap: 16px; }
.recorder[hidden] { display: none; }
.recorder__stage { position: relative; width: 100%; max-width: 264px; aspect-ratio: 9 / 16; max-height: 46vh; margin: 0 auto; border-radius: var(--r-md); overflow: hidden; background: #1c130d; box-shadow: var(--shadow-md); }
.recorder__stage video { width: 100%; height: 100%; object-fit: cover; }
.recorder__stage video.is-mirror { transform: scaleX(-1); }
.recorder__x { position: absolute; top: 10px; right: 10px; z-index: 3; width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center; background: rgba(30,20,14,.55); backdrop-filter: blur(6px); }
.recorder__x svg { width: 15px; height: 15px; fill: none; stroke: var(--ivory); stroke-width: 2; stroke-linecap: round; }
.recorder__rec { position: absolute; top: 10px; left: 10px; z-index: 3; display: flex; align-items: center; gap: 6px; font-size: .6rem; letter-spacing: .14em; color: var(--ivory); background: rgba(30,20,14,.55); backdrop-filter: blur(6px); padding: 4px 10px; border-radius: var(--r-pill); }
.recorder__rec span { width: 7px; height: 7px; border-radius: 50%; background: #ef4444; animation: glowPulse 1.2s infinite; }
.recorder__rec[hidden] { display: none; }
.recorder__controls { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.recorder__controls[hidden] { display: none; }
.recorder__controls.recorder__review { flex-direction: row; justify-content: center; }
.recorder__hint { text-align: center; font-size: .76rem; color: var(--mocha); }
.recorder__count { font-family: var(--serif); font-weight: 600; font-size: 1.55rem; line-height: 1; color: var(--copper-deep); font-variant-numeric: tabular-nums; }
.recorder__count[hidden] { display: none; }
.recbtn { width: 66px; height: 66px; border-radius: 50%; background: #fff; border: 4px solid rgba(168,107,71,.55); display: grid; place-items: center; box-shadow: var(--shadow-md); transition: transform .2s var(--ease); }
.recbtn:hover { transform: scale(1.05); }
.recbtn::before { content: ""; width: 28px; height: 28px; border-radius: 50%; background: #d6483b; transition: all .25s var(--ease); }
.recbtn.is-recording::before { width: 22px; height: 22px; border-radius: 6px; }
.recorder__review .btn { flex: 1; max-width: 200px; }

/* ===== DETAILS (revealed after capture) + SUCCESS ===== */
.share-details { display: grid; gap: 8px; }
.share-details[hidden] { display: none; }
.share-details__lead { font-family: var(--serif); font-style: italic; font-size: 1.02rem; color: var(--copper-deep); text-align: center; margin-top: 2px; }

.share-success { display: none; flex-direction: column; align-items: center; text-align: center; gap: 14px; padding: 10px 4px 4px; }
.share-success__seal { font-size: 1.5rem; color: var(--rose-gold); filter: drop-shadow(0 0 10px rgba(201,155,126,.6)); }
.share-success__title { font-family: var(--serif); font-weight: 500; font-size: clamp(1.5rem, 5vw, 2rem); color: var(--espresso); }
.share-success__msg { color: var(--mocha); font-size: .98rem; max-width: 40ch; }
.share-success__msg b { color: var(--copper-deep); }
.share-success .btn { margin-top: 8px; }

.modal__card.is-success .modal__eyebrow,
.modal__card.is-success .modal__title,
.modal__card.is-success .modal__prompt,
.modal__card.is-success .modal__guide,
.modal__card.is-success #shareForm { display: none; }
.modal__card.is-success .share-success { display: flex; }

.field { display: flex; flex-direction: column; gap: 4px; }
.field label { font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--copper); }
.field input, .field textarea { width: 100%; padding: 8px 12px; border-radius: var(--r-sm); background: rgba(255,255,255,.6); border: 1px solid var(--glass-edge); font: inherit; color: var(--espresso); resize: vertical; transition: border-color .3s var(--ease), box-shadow .3s var(--ease); }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--rose-gold); box-shadow: var(--glow-rose); }
.field__row { display: grid; gap: 12px; }
@media (min-width: 480px) { .field__row { grid-template-columns: 1fr 1fr; } }

.upload-status { font-size: .84rem; color: var(--copper-deep); min-height: 1.1em; display: flex; align-items: center; gap: 8px; }
.upload-status .spinner { width: 14px; height: 14px; border-radius: 50%; border: 2px solid rgba(168,107,71,.3); border-top-color: var(--copper); animation: spin .8s linear infinite; display: none; }
.upload-status.is-busy .spinner { display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.progress { height: 5px; border-radius: var(--r-pill); background: rgba(168,107,71,.15); overflow: hidden; display: none; }
.progress.is-on { display: block; }
.progress__bar { height: 100%; width: 0; background: linear-gradient(90deg, var(--copper), var(--rose-gold)); transition: width .3s var(--ease); }

.modal__note { font-size: .72rem; color: var(--mocha); text-align: center; }
.toast { position: fixed; left: 50%; bottom: 24px; transform: translateX(-50%) translateY(20px); z-index: 130; padding: 14px 22px; border-radius: var(--r-pill); background: linear-gradient(135deg, var(--copper-deep), var(--mocha-deep)); color: var(--ivory); font-size: .88rem; box-shadow: var(--shadow-lg); opacity: 0; pointer-events: none; transition: opacity .4s var(--ease), transform .4s var(--ease); display: flex; align-items: center; gap: 8px; }
.toast.is-on { opacity: 1; transform: translateX(-50%); }
.toast svg { width: 16px; height: 16px; fill: none; stroke: var(--rose-gold-lt); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* =====================================================================
   ✦ STAR ANIMATION SYSTEM — every star breathes / drifts / twinkles,
   with a different motion depending on where it sits.
   ===================================================================== */
.star { display: inline-block; line-height: 1; transform-origin: center center; backface-visibility: hidden; will-change: transform; }
/* Individual transform properties (scale / rotate / translate) COMPOSE — so a
   gentle pulse and a slow continuous rotation run together, butter-smooth, and
   the star is never momentarily static (which read as "stuck"). */
@keyframes starScale  { 0%,100% { scale: .86; }   50% { scale: 1.13; } }
@keyframes starFade   { 0%,100% { opacity: .62; }  50% { opacity: 1; } }
@keyframes starGlow   { 0%,100% { opacity:.58; filter: drop-shadow(0 0 0 transparent); } 50% { opacity:1; filter: drop-shadow(0 0 7px rgba(226,183,154,.85)); } }
@keyframes starRotate { to { rotate: 360deg; } }
@keyframes starLift   { 0%,100% { translate: 0 1px; } 50% { translate: 0 -5px; } }
@keyframes divGlow    { 0%,100%{ filter: drop-shadow(0 0 0 transparent); opacity:.72; } 50%{ filter: drop-shadow(0 0 9px rgba(226,183,154,.9)); opacity:1; } }

.star--breathe { animation: starScale 3.8s ease-in-out infinite, starFade 3.8s ease-in-out infinite, starRotate 22s linear infinite; }
.star--twinkle { animation: starScale 2.9s ease-in-out infinite, starGlow 2.9s ease-in-out infinite, starRotate 26s linear infinite; }
.star--float   { animation: starLift 4.4s ease-in-out infinite, starFade 4.4s ease-in-out infinite, starRotate 24s linear infinite; }
.star--wiggle  { animation: starGlow 3.2s ease-in-out infinite, starRotate 18s linear infinite; }
.star--spin    { animation: starRotate 14s linear infinite, starFade 4s ease-in-out infinite; }
/* dedicated star elements that already carry their own class */
.nav__ticker-line em { display: inline-block; transform-origin: center; animation: starScale 3.4s ease-in-out infinite, starGlow 3.4s ease-in-out infinite, starRotate 26s linear infinite; }
.soulshift__star { display: inline-block; animation: starLift 5s ease-in-out infinite, starFade 5s ease-in-out infinite, starRotate 24s linear infinite; }
.soulshift__div  { display: inline-block; animation: divGlow 3.8s ease-in-out infinite; }   /* glow only → its side-line ::before/::after stay put */
.modal__seal { display: inline-block; animation: starLift 4s ease-in-out infinite, starRotate 22s linear infinite; }
.share-success__seal { display: inline-block; animation: starScale 3s ease-in-out infinite, starFade 3s ease-in-out infinite, starRotate 20s linear infinite; }
.countdown__dot { animation: starFade 2.6s ease-in-out infinite, starScale 4s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) {
  .star, .nav__ticker-line em, .soulshift__star, .soulshift__div, .modal__seal, .share-success__seal, .countdown__dot { animation: none !important; }
}
/* keep stars and their adjacent word together so a trailing ✦ never orphans to its own line */
.nav__ticker-line .tk { white-space: nowrap; }

/* =====================================================================
   LIQUID-GLASS BEVEL — a soft luminous highlight travels around the edge
   stroke of every shape (Apple-glass feel). The ring only ANIMATES while
   on-screen (.edge-on, toggled by JS) so mobile never pays for off-screen
   shapes; off-screen it stays a static gold bevel.
   ===================================================================== */
@property --liq { syntax: "<angle>"; inherits: false; initial-value: 0deg; }
@keyframes liqRotate { to { --liq: 360deg; } }

.liquid { position: relative; }
/* `.liquid` forces position:relative for the bevel ring — restore the
   hero countdown's desktop float (it must stay absolutely positioned). */
@media (min-width: 920px) { .hero__countdown.liquid { position: absolute; } }
.liquid:not(.glass)::after,
.glass.liquid::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit;
  padding: 1.4px; pointer-events: none; z-index: 2;
  background: conic-gradient(from var(--liq),
      transparent 0deg, transparent 190deg,
      rgba(255,246,235,.15) 235deg,
      var(--rose-gold-lt) 290deg,
      rgba(255,250,243,.95) 320deg,
      var(--rose-gold-lt) 345deg,
      transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: .9;
}
.liquid.edge-on:not(.glass)::after,
.glass.liquid.edge-on::before { animation: liqRotate 7s linear infinite; animation-delay: var(--liq-delay, 0s); }
/* circular shapes inherit 50% radius via border-radius:inherit automatically */
@media (prefers-reduced-motion: reduce) {
  .liquid.edge-on:not(.glass)::after, .glass.liquid.edge-on::before { animation: none; }
}

/* =====================================================================
   AMBIENT SECTION AURA — slow drifting warm gradient so the beige
   sections breathe instead of sitting flat.
   ===================================================================== */
.journey, .features, .venue, .faq { position: relative; isolation: isolate; }
.journey::before, .features::before, .venue::before, .faq::before {
  content: ""; position: absolute; inset: 0; z-index: -1; pointer-events: none; opacity: .6;
  background:
    radial-gradient(38% 48% at 14% 18%, rgba(231,196,172,.42), transparent 62%),
    radial-gradient(34% 44% at 86% 72%, rgba(201,155,126,.28), transparent 62%),
    radial-gradient(30% 40% at 62% 12%, rgba(234,217,194,.5), transparent 62%);
  background-size: 200% 200%;
  animation: auraDrift 30s ease-in-out infinite alternate;
}
.features::before { animation-duration: 36s; animation-direction: alternate-reverse; }
.venue::before    { animation-duration: 33s; }
.faq::before      { animation-duration: 28s; animation-direction: alternate-reverse; }
@keyframes auraDrift {
  0%   { background-position: 0% 0%, 100% 100%, 50% 0%; }
  50%  { background-position: 100% 50%, 0% 40%, 80% 100%; }
  100% { background-position: 40% 100%, 60% 0%, 20% 60%; }
}
/* a fourth, livelier orb for the whole page */
.orb--4 { width: 30vw; height: 30vw; top: 120vh; right: 4vw; background: radial-gradient(circle at 45% 45%, rgba(201,155,126,.34), transparent 70%); animation: drift4 32s var(--ease) infinite alternate; }
@keyframes drift4 { to { transform: translate3d(-6vw,7vh,0) scale(1.14); } }
@media (prefers-reduced-motion: reduce) {
  .journey::before, .features::before, .venue::before, .faq::before, .orb--4 { animation: none; }
}

/* =====================================================================
   COUNTDOWN TIMER — keeps the ORIGINAL light colour theme; only the digit
   font changes to Bodoni Moda (Playfair has no tabular figures, so the
   digits were uneven). Colours/glass come from the base .hero__countdown
   / .countdown__* rules earlier in this file.
   ===================================================================== */
.countdown__grid { gap: 10px; }
.countdown__num {
  font-family: "DM Serif Display", "Bodoni Moda", "Playfair Display", Georgia, serif;
  font-weight: 400; letter-spacing: .07em;
  font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1;
}
/* keep the soulshift timer digits equal-width too */
.ss-num { font-family: "Bodoni Moda", "Playfair Display", Georgia, serif; font-weight: 400; letter-spacing: .02em; font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
/* DM Serif Display digits aren't monospaced — give each ticking digit a fixed
   advance so the live countdown never shifts as the numbers change. */
.countdown__num .cd-d { display: inline-block; width: .74em; text-align: center; }
.ss-num .cd-d { display: inline-block; width: .62em; text-align: center; }

/* =====================================================================
   JOURNEY IMAGES — smooth dissolve-in (blur + scale → crisp) as each
   step scrolls into view.
   ===================================================================== */
.tstep .tstep__media img {
  opacity: 0; transform: scale(1.08); filter: blur(14px);
  transition: opacity 1.1s var(--ease), transform 1.5s var(--ease), filter 1.1s var(--ease);
  will-change: opacity, transform, filter;
}
.tstep.is-in .tstep__media img { opacity: 1; transform: scale(1); filter: blur(0); }
.tstep:hover .tstep__media img { transform: scale(1.05); filter: blur(0); }
@media (prefers-reduced-motion: reduce) {
  .tstep .tstep__media img { opacity: 1; transform: none; filter: none; transition: none; }
}

/* =====================================================================
   SINGLE PHOTO CHOICE (video recorder removed)
   ===================================================================== */
.share-choices { grid-template-columns: 1fr !important; }
.choice--photo { background: linear-gradient(160deg, rgba(231,196,172,.45), rgba(168,107,71,.16)); border-color: rgba(201,155,126,.5);
  flex-direction: row; align-items: center; text-align: left; gap: 12px; padding: 9px 14px; }
.choice--photo .choice__icon { width: 36px; height: 36px; flex: none; }
.choice--photo .choice__icon svg { width: 18px; height: 18px; }
.choice__txt { display: flex; flex-direction: column; gap: 1px; }
.share-details__lead { display: none; }
.choice.err { border-color: #c0492f; box-shadow: 0 0 0 1px #c0492f; }
.choice__opt { color: var(--copper); font-style: italic; }

/* =====================================================================
   SOUL SHIFT — show the FULL background frame (no side cropping) and a
   stronger parallax travel. Dark gradient stays full-bleed; the photo is
   contained so its left & right edges are always visible.
   ===================================================================== */
.soulshift__bg {
  top: -38%; bottom: -38%;
  background-image:
    linear-gradient(180deg, rgba(22,14,9,.5) 0%, rgba(22,14,9,.26) 45%, rgba(22,14,9,.56) 100%),
    url("soulshift-bg.webp");
  background-size: cover, contain;
  background-repeat: no-repeat, no-repeat;
  background-position: center center, center center;
}

/* =====================================================================
   FOOTER — curved wave transition + animated closing crest
   ===================================================================== */
.closing__wave { position: absolute; top: 1px; left: 0; width: 100%; height: clamp(56px, 8vw, 110px); transform: translateY(-100%); line-height: 0; pointer-events: none; z-index: 1; }
.closing__wave svg { width: 100%; height: 100%; display: block; }
.closing__wave path { fill: var(--mocha-deep); }

.closing__crest { position: relative; width: 132px; height: 132px; margin: 0 auto clamp(14px,3vw,26px); display: grid; place-items: center; z-index: 2; }
.crest__star { font-size: 2.5rem; color: var(--rose-gold-lt); filter: drop-shadow(0 0 16px rgba(226,183,154,.85)); display: inline-block; animation: starScale 3.4s ease-in-out infinite, starFade 3.4s ease-in-out infinite, starRotate 20s linear infinite; z-index: 3; }
.crest__rays {
  position: absolute; width: 132px; height: 132px; border-radius: 50%;
  background: repeating-conic-gradient(from 0deg, rgba(226,183,154,0) 0deg 7deg, rgba(226,183,154,.4) 8deg 9deg, rgba(226,183,154,0) 10deg 18deg);
  -webkit-mask: radial-gradient(circle, transparent 28%, #000 32%, #000 58%, transparent 62%);
          mask: radial-gradient(circle, transparent 28%, #000 32%, #000 58%, transparent 62%);
  animation: starRotate 26s linear infinite; opacity: .7;
}
.crest__ring { position: absolute; width: 76px; height: 76px; border-radius: 50%; border: 1px solid rgba(226,183,154,.4); box-shadow: inset 0 0 26px -6px rgba(226,183,154,.5); animation: crestPulse 4.2s ease-in-out infinite; }
@keyframes crestPulse { 0%,100% { transform: scale(.9); opacity: .45; } 50% { transform: scale(1.06); opacity: .9; } }
.crest__sparkles i { position: absolute; width: 3px; height: 3px; border-radius: 50%; background: var(--rose-gold-lt); box-shadow: 0 0 7px rgba(226,183,154,.95); animation: starGlow 3s ease-in-out infinite, starScale 3s ease-in-out infinite; }
.crest__sparkles i:nth-child(1){ top: 4%;  left: 50%; animation-delay: 0s; }
.crest__sparkles i:nth-child(2){ top: 18%; left: 84%; animation-delay: .4s; }
.crest__sparkles i:nth-child(3){ top: 50%; left: 96%; animation-delay: .8s; }
.crest__sparkles i:nth-child(4){ top: 82%; left: 84%; animation-delay: 1.2s; }
.crest__sparkles i:nth-child(5){ top: 96%; left: 50%; animation-delay: 1.6s; }
.crest__sparkles i:nth-child(6){ top: 82%; left: 16%; animation-delay: 2s; }
.crest__sparkles i:nth-child(7){ top: 50%; left: 4%;  animation-delay: 2.4s; }
.crest__sparkles i:nth-child(8){ top: 18%; left: 16%; animation-delay: 2.8s; }
@media (prefers-reduced-motion: reduce) {
  .crest__star, .crest__rays, .crest__ring, .crest__sparkles i { animation: none; }
}

/* =====================================================================
   MOBILE CAROUSEL — 3 rotating cards (centre + left + right), smaller,
   true 3D rotation just like desktop (replaces the old single-card view).
   ===================================================================== */
@media (max-width: 679px) {
  .carousel__stage {
    height: 94vw; max-height: 470px;
    perspective: 1100px; perspective-origin: 50% 46%;
  }
  .cvideo {
    width: 56vw; max-width: 250px;
    aspect-ratio: 9 / 16;
    border-radius: var(--r-lg);
    transition:
      transform 0.82s cubic-bezier(.34,1.04,.64,1),
      opacity   0.6s  cubic-bezier(0,0,.2,1),
      filter    0.6s  ease,
      box-shadow 0.6s ease;
  }
  .cvideo[data-pos="center"] {
    transform: translate(-50%,-50%) translateZ(60px) scale(1);
    opacity: 1; filter: none; border-radius: var(--r-lg); z-index: 5;
    box-shadow: var(--shadow-lg), 0 0 50px -10px rgba(226,183,154,.55);
    pointer-events: auto;
  }
  .cvideo[data-pos="left"] {
    transform: translate(-50%,-50%) translateX(-56%) translateZ(-46px) rotateY(30deg) scale(.78);
    opacity: .5; filter: brightness(.68); z-index: 3; pointer-events: auto;
  }
  .cvideo[data-pos="right"] {
    transform: translate(-50%,-50%) translateX(56%) translateZ(-46px) rotateY(-30deg) scale(.78);
    opacity: .5; filter: brightness(.68); z-index: 3; pointer-events: auto;
  }
  .cvideo[data-pos="far-left"],
  .cvideo[data-pos="far-right"],
  .cvideo[data-pos="hidden"] {
    transform: translate(-50%,-50%) scale(.58);
    opacity: 0; filter: blur(2px); z-index: 1; pointer-events: none;
  }

  .carousel__caption { min-height: 0; margin-top: 22px; padding: 0 6px; }
  .carousel__quote   { font-size: clamp(.96rem,4.4vw,1.1rem); line-height: 1.5; }
  .carousel__story   { font-size: .84rem; margin-top: 8px; }
  .carousel__id      { margin-top: 10px; gap: 8px; }
  .carousel__name    { font-size: .9rem; }
  .carousel__controls { margin-top: 18px; gap: 12px; }
  .carousel__btn      { width: 42px; height: 42px; }
  .carousel__btn svg  { width: 16px; height: 16px; }
  .carousel__dots button { width: 6px; height: 6px; }
  .carousel__dots button[aria-selected="true"] { width: 18px; }
  .voices__share { margin-top: 24px; gap: 12px; }
  .voices__share p { font-size: .92rem; }
}

/* =====================================================================
   TESTIMONIAL CARDS — image-only: no play icon (we never play video now)
   ===================================================================== */
.cvideo__play { display: none !important; }

/* =====================================================================
   SOUL SHIFT — dedicated PORTRAIT background on mobile so the image
   fills the screen (the landscape desktop image looked tiny). Same
   strong parallax (driven by the same JS layer).
   ===================================================================== */
@media (max-width: 679px) {
  .soulshift__bg {
    top: -8%; bottom: -8%;                  /* small overflow = parallax room with minimal side crop */
    background-image:
      linear-gradient(180deg, rgba(22,14,9,.44) 0%, rgba(22,14,9,.2) 45%, rgba(22,14,9,.52) 100%),
      url("soulshift-bg-mobile.webp");
    background-size: cover, cover;           /* image aspect now matches the section → fills with no black gap, edges intact */
    background-position: center, center;
    background-repeat: no-repeat, no-repeat;
  }
}

/* =====================================================================
   MOBILE TYPE & SPACING — 2026 refinement: smaller, calmer headings and
   more breathing room. Desktop is deliberately left untouched.
   ===================================================================== */
@media (max-width: 679px) {
  body { line-height: 1.62; }
  .eyebrow { font-size: .62rem; letter-spacing: .26em; }

  /* Hero */
  .hero { padding-top: clamp(90px, 22vw, 118px); padding-bottom: clamp(40px, 9vw, 60px); }
  .hero__copy { gap: 18px; }
  .hero__title { font-size: clamp(1.82rem, 8vw, 2.3rem); line-height: 1.14; }
  .hero__lede { font-size: .93rem; line-height: 1.66; max-width: 32ch; }
  .hero__ctas { margin-top: 6px; }
  .hero__trust { font-size: .74rem; gap: 10px; }
  .hero__grid { gap: 26px; }

  /* Display headings everywhere */
  .h-display { font-size: clamp(1.6rem, 7vw, 2rem); line-height: 1.14; }
  .section-head { gap: 10px; }

  /* Journey — calmer type, more air between steps */
  .journey { padding-top: clamp(54px, 13vw, 78px); padding-bottom: clamp(54px, 13vw, 78px); }
  .timeline { gap: clamp(46px, 12vw, 66px); }
  .journey__head { margin-bottom: 28px; gap: 14px; }
  .tstep__num { width: 50px; height: 50px; font-size: 1.22rem; }
  .tstep__body { gap: 11px; }
  .tstep__body h3 { font-size: clamp(1.3rem, 6.2vw, 1.58rem); line-height: 1.16; }
  .tstep__body p { font-size: .9rem; line-height: 1.62; }

  /* Soul Shift — the big title was overwhelming on small screens */
  .soulshift__band { padding: clamp(58px, 14vw, 86px) clamp(22px, 6vw, 40px); gap: 15px; }
  .soulshift__tag { font-size: .57rem; letter-spacing: .2em; padding: 8px 16px; }
  .soulshift__title { font-size: clamp(1.95rem, 9vw, 2.5rem); line-height: 1.07; }
  .soulshift__lead { font-size: clamp(1.02rem, 4.6vw, 1.18rem); line-height: 1.45; max-width: 26ch; }
  .soulshift__desc { font-size: .91rem; line-height: 1.62; max-width: 38ch; }
  .soulshift__count { padding: clamp(20px,5vw,26px) clamp(22px,7vw,44px); }
  .soulshift__fine { font-size: .82rem; }

  /* Feature cards / venue / FAQ — smaller heads, more breathing room */
  .features { padding: clamp(40px,10vw,60px) var(--pad-x) clamp(54px,13vw,78px); }
  .fcard { padding: 24px 22px; }
  .fcard h3 { font-size: 1.18rem; }
  .fcard p { font-size: .9rem; line-height: 1.6; }
  .venue { padding-bottom: clamp(54px,13vw,78px); }
  .venue__row strong { font-size: 1.04rem; }
  .venue__card { padding: clamp(18px,5vw,28px); }
  .faq { padding: clamp(54px,13vw,78px) var(--pad-x); }
  .faq__q { font-size: .98rem; padding: 16px 18px; }
  .faq__a-in p { font-size: .9rem; line-height: 1.6; }
  .faq__quote { padding: 26px; }

  /* Footer — calmer */
  .closing__tagline { font-size: clamp(.84rem, 3.8vw, .98rem); }
  .fcol a, .fcol p { font-size: .86rem; }
}

/* =====================================================================
   SOUL SHIFT — "YOUR NEW WORLD" immersive page (admin-gated)
   ===================================================================== */
.world { position: fixed; inset: 0; z-index: 140; overflow-y: auto; opacity: 0; pointer-events: none;
  transition: opacity .5s var(--ease); background: var(--espresso-ink); -webkit-overflow-scrolling: touch; }
.world.is-open { opacity: 1; pointer-events: auto; }
.world__bg { position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(95% 60% at 50% -10%, rgba(168,107,71,.55), transparent 60%),
    radial-gradient(40% 40% at 12% 20%, rgba(226,183,154,.16), transparent 70%),
    radial-gradient(40% 40% at 88% 82%, rgba(201,155,126,.16), transparent 70%),
    linear-gradient(170deg, var(--mocha-deep) 0%, var(--espresso) 60%, var(--espresso-ink) 100%); }
.world__close { position: fixed; top: 16px; right: 16px; z-index: 3; width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center; background: rgba(247,240,230,.12); border: 1px solid rgba(255,255,255,.22); backdrop-filter: blur(8px); }
.world__close svg { width: 18px; height: 18px; fill: none; stroke: var(--ivory); stroke-width: 1.8; stroke-linecap: round; }
.world__inner { position: relative; z-index: 1; max-width: 1000px; margin: 0 auto;
  padding: clamp(60px, 11vh, 104px) clamp(20px, 5vw, 48px) clamp(56px, 9vh, 92px);
  text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px;
  transform: translateY(22px); transition: transform .6s var(--ease); }
.world.is-open .world__inner { transform: none; }
.world__seal { font-size: 2.2rem; color: var(--rose-gold-lt); filter: drop-shadow(0 0 16px rgba(226,183,154,.8)); }
.world__eyebrow { font-size: .68rem; letter-spacing: .3em; text-transform: uppercase; color: var(--rose-gold-lt); }
.world__title { font-family: var(--serif); font-weight: 500; font-size: clamp(2.1rem, 8vw, 3.8rem); line-height: 1.05; color: var(--ivory); text-shadow: 0 2px 30px rgba(0,0,0,.5); }
.world__title .italic { display: block; font-style: italic; color: var(--rose-gold-lt); }
.world__lead { color: rgba(247,240,230,.82); font-size: clamp(1rem, 2.6vw, 1.16rem); max-width: 46ch; line-height: 1.55; }

.world__feats { display: grid; gap: 14px; grid-template-columns: 1fr; width: 100%; max-width: 760px; margin-top: 16px; }
@media (min-width: 680px) { .world__feats { grid-template-columns: repeat(3, 1fr); } }
.wfeat { padding: 20px 18px; border-radius: var(--r-lg); background: rgba(247,240,230,.06); border: 1px solid rgba(226,183,154,.22); }
.wfeat > span { font-size: 1.05rem; color: var(--rose-gold-lt); }
.wfeat b { display: block; font-family: var(--serif); font-weight: 500; font-size: 1.08rem; color: var(--ivory); margin: 8px 0 4px; }
.wfeat p { color: rgba(247,240,230,.66); font-size: .85rem; }

.world__pricelabel { margin-top: 30px; font-size: .64rem; letter-spacing: .24em; text-transform: uppercase; color: var(--rose-gold-lt); display: flex; align-items: center; gap: 4px; }
.world__pricing { display: grid; gap: 16px; grid-template-columns: 1fr; width: 100%; max-width: 880px; margin-top: 8px; }
@media (min-width: 740px) { .world__pricing { grid-template-columns: repeat(3, 1fr); align-items: stretch; } }
.wprice { position: relative; padding: 28px 22px; border-radius: var(--r-lg); text-align: center;
  background: linear-gradient(180deg, rgba(255,250,243,.08), rgba(255,250,243,.03));
  border: 1px solid rgba(226,183,154,.25); display: flex; flex-direction: column; gap: 5px; }
.wprice--featured { background: linear-gradient(180deg, rgba(226,183,154,.22), rgba(168,107,71,.12));
  border-color: rgba(226,183,154,.6); box-shadow: 0 0 50px -16px rgba(226,183,154,.6); }
.wprice__tag { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); white-space: nowrap;
  font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: var(--espresso);
  background: linear-gradient(135deg, var(--rose-gold-lt), var(--copper)); padding: 4px 13px; border-radius: 999px; }
.wprice h3 { font-family: var(--serif); font-weight: 500; font-size: 1.3rem; color: var(--ivory); }
.wprice__price { font-family: var(--serif); font-size: 1.95rem; color: var(--rose-gold-lt); line-height: 1.1; }
.wprice__sub { font-size: .76rem; color: rgba(247,240,230,.6); margin-bottom: 6px; }
.wprice ul { display: flex; flex-direction: column; gap: 7px; margin-top: 8px; text-align: left; }
.wprice li { color: rgba(247,240,230,.78); font-size: .84rem; padding-left: 20px; position: relative; }
.wprice li::before { content: "✦"; position: absolute; left: 0; top: 2px; color: var(--rose-gold-lt); font-size: .66rem; }

.world__cta { margin-top: 30px; text-transform: uppercase; letter-spacing: .12em; font-size: .84rem; padding: 1.05em 2.4em; }
.world__fine { color: rgba(247,240,230,.62); font-size: .85rem; font-family: var(--serif); margin-top: 4px; }
@media (prefers-reduced-motion: reduce) { .world, .world__inner { transition: opacity .2s; transform: none; } }

/* =====================================================================
   VOICES v2 — compact carousel, read-more, sliding dots, story modal,
   all-stories gallery, required fields
   ===================================================================== */
/* "Read more" is appended INLINE right after the truncated text (…text Read more),
   so it never overlaps the words. JS trims the feedback to fit 2 lines. */
.carousel__more { cursor:pointer; color:var(--rose-gold-lt); font-style:normal; white-space:nowrap;
  text-decoration:underline; text-underline-offset:3px; font-size:.82em; }
.carousel__more[hidden]{ display:none; }
.voices__all { color: var(--ivory); border-color: rgba(255,255,255,.25); background: rgba(255,250,243,.08); }
.voices__all:hover { background: rgba(255,250,243,.16); }
.voices__all svg { width:1em; height:1em; fill:none; stroke:currentColor; stroke-width:1.6; }

/* sliding dot indicator */
.carousel__dots { position: relative; flex-wrap: nowrap; gap: 9px; max-width: none; }
.carousel__dots button { width:8px; height:8px; border-radius:50%; background:rgba(255,250,243,.3); transition:background .4s ease; }
.carousel__dots button[aria-selected="true"] { width:8px; border-radius:50%; background:rgba(255,250,243,.3); }
.carousel__dot-slider { position:absolute; top:50%; left:0; height:8px; width:24px; border-radius:999px;
  background:linear-gradient(90deg,var(--rose-gold-lt),var(--copper)); transform:translateY(-50%);
  transition:transform .5s cubic-bezier(.4,0,.2,1), width .5s cubic-bezier(.4,0,.2,1); pointer-events:none; box-shadow:0 0 10px -2px rgba(226,183,154,.7); }

/* ONE STORY modal */
.storymodal { position:fixed; inset:0; z-index:150; display:grid; place-items:center; padding:18px; opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.storymodal.is-open { opacity:1; pointer-events:auto; }
.storymodal__scrim { position:absolute; inset:0; background:rgba(20,13,8,.64); backdrop-filter:blur(8px); }
.storymodal__card { position:relative; width:min(400px,100%); max-height:90vh; overflow-y:auto; border-radius:var(--r-xl);
  background:linear-gradient(170deg,var(--mocha-deep),var(--espresso) 70%,var(--espresso-ink)); border:1px solid rgba(226,183,154,.3);
  box-shadow:var(--shadow-lg); transform:translateY(16px) scale(.97); transition:transform .45s var(--ease); }
.storymodal.is-open .storymodal__card { transform:none; }
.storymodal__close { position:absolute; top:12px; right:12px; z-index:3; width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:rgba(247,240,230,.14);border:1px solid rgba(255,255,255,.22); }
.storymodal__close svg{ width:16px;height:16px;fill:none;stroke:var(--ivory);stroke-width:1.8;stroke-linecap:round; }
.storymodal__media { width:100%; aspect-ratio:1/1; overflow:hidden; background:radial-gradient(70% 60% at 50% 30%,rgba(255,250,243,.35),transparent 70%),linear-gradient(160deg,var(--rose-gold-lt),var(--copper)); display:grid; place-items:center; }
.storymodal__media img { width:100%;height:100%;object-fit:cover; }
.storymodal__media .poster { font-family:var(--serif); font-style:italic; font-size:3rem; color:rgba(255,255,255,.92); }
.storymodal__body { padding:22px 22px 26px; text-align:center; }
.storymodal__quote { font-family:var(--serif); font-style:italic; font-size:1.08rem; line-height:1.5; color:var(--ivory); }
.storymodal__id { margin-top:14px; display:inline-flex; align-items:center; gap:10px; }
.storymodal__name { font-family:var(--serif); color:var(--rose-gold-lt); }
.storymodal__city { font-size:.6rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(247,240,230,.5); padding-left:12px; position:relative; }
.storymodal__city::before { content:""; position:absolute; left:0; top:50%; width:6px; height:1px; background:var(--rose-gold-lt); }

/* ALL STORIES gallery */
.allstories { position:fixed; inset:0; z-index:138; overflow-y:auto; opacity:0; pointer-events:none; transition:opacity .45s var(--ease); -webkit-overflow-scrolling:touch;
  background:radial-gradient(120% 50% at 50% -5%, #fff, transparent 55%), linear-gradient(180deg, var(--ivory) 0%, var(--ivory-deep) 100%); }
.allstories.is-open { opacity:1; pointer-events:auto; }
.allstories__leaf { display: none; }
.allstories__leaf--tl { top:-7%; left:-5%; transform:rotate(180deg); }
.allstories__leaf--br { bottom:-7%; right:-5%; }
.allstories__bar { position:sticky; top:0; z-index:5; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px clamp(16px,5vw,40px); background:rgba(247,240,230,.82); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); border-bottom:1px solid var(--glass-edge); }
.allstories__bar h3 { font-family:var(--serif); font-weight:500; font-size:1.25rem; color:var(--espresso); }
.allstories__count { color:var(--copper); font-size:.82rem; font-family:var(--sans); }
.allstories__close { flex:none; width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--glass-bg);border:1px solid var(--glass-edge); transition:background .3s; }
.allstories__close:hover { background:#fff; }
.allstories__close svg { width:16px;height:16px;fill:none;stroke:var(--espresso);stroke-width:1.8;stroke-linecap:round; }
.allstories__intro { position:relative; z-index:1; text-align:center; padding:clamp(26px,6vw,54px) 20px clamp(6px,2vw,16px); }
.allstories__intro h2 { font-family:var(--serif); font-weight:500; font-size:clamp(1.9rem,6vw,3.4rem); color:var(--espresso); line-height:1.05; }
.allstories__intro h2 .italic { color:var(--copper-deep); }
.allstories__div { display:block; margin:14px auto; color:var(--rose-gold); font-size:.8rem; position:relative; width:max-content; }
.allstories__div::before, .allstories__div::after { content:""; position:absolute; top:50%; width:clamp(40px,8vw,80px); height:1px; background:linear-gradient(90deg,transparent,rgba(201,155,126,.6)); }
.allstories__div::before { right:calc(100% + 12px); transform:scaleX(-1); }
.allstories__div::after { left:calc(100% + 12px); }
.allstories__intro p { color:var(--mocha); font-size:clamp(.86rem,2.2vw,1rem); }
.allstories__grid { position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; padding:clamp(18px,3vw,30px) clamp(14px,4vw,32px); display:grid; gap:16px; grid-template-columns:repeat(auto-fill,minmax(238px,1fr)); }
.astory { display:flex; gap:12px; padding:12px; border-radius:var(--r-lg); text-align:left; cursor:pointer; width:100%; font:inherit; color:inherit;
  background:linear-gradient(180deg,rgba(255,253,249,.92),rgba(252,245,236,.82)); border:1px solid rgba(255,255,255,.8);
  box-shadow:0 12px 30px -20px rgba(168,107,71,.5), inset 0 1px 0 rgba(255,255,255,.9);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.astory:hover { transform:translateY(-3px); box-shadow:0 18px 36px -20px rgba(168,107,71,.55); }
.astory__media { flex:none; width:74px; height:92px; border-radius:var(--r-md); overflow:hidden; background:radial-gradient(70% 60% at 50% 30%,rgba(255,250,243,.4),transparent 70%),linear-gradient(150deg,var(--rose-gold-lt),var(--copper)); display:grid; place-items:center; }
.astory__media img { width:100%;height:100%;object-fit:cover; }
.astory__media .poster { font-family:var(--serif); font-style:italic; font-size:1.7rem; color:#fff; }
.astory__body { flex:1; min-width:0; display:flex; flex-direction:column; position:relative; padding-bottom:16px; }
.astory__name { font-family:var(--serif); font-weight:600; font-size:1rem; color:var(--espresso); line-height:1.1; }
.astory__city { font-size:.6rem; letter-spacing:.12em; text-transform:uppercase; color:var(--copper); margin-top:2px; }
.astory__mark { font-family:var(--serif); font-size:1.3rem; color:var(--rose-gold); line-height:.5; margin-top:8px; }
.astory__quote { font-size:.8rem; color:var(--mocha); line-height:1.45; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; margin-top:3px; }
.astory__lotus { position:absolute; bottom:0; left:0; width:18px; height:18px; fill:none; stroke:var(--rose-gold); stroke-width:1.2; opacity:.7; }
.allstories__pager { position:relative; z-index:1; display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap; padding:6px 16px clamp(34px,7vw,56px); }
.allstories__pager .pg { min-width:34px; height:34px; padding:0 10px; border-radius:999px; border:1px solid var(--glass-edge); background:var(--glass-bg); color:var(--espresso); font:inherit; font-size:.85rem; cursor:pointer; display:grid; place-items:center; transition:background .2s, color .2s; }
.allstories__pager .pg:hover:not(:disabled):not(.is-active) { background:#fff; }
.allstories__pager .pg.is-active { background:linear-gradient(135deg,var(--copper),var(--rose-gold)); color:#fff; border-color:transparent; }
.allstories__pager .pg:disabled { opacity:.4; cursor:default; }
.allstories__pager .pg--dots { border:none; background:none; cursor:default; }
.allstories__empty { position:relative; z-index:1; text-align:center; color:var(--mocha); padding:50px 20px; font-family:var(--serif); font-style:italic; }

/* required fields + counter */
.field label .req { color:var(--rose-gold); font-style:normal; }
.field__count { font-size:.66rem; color:var(--mocha); text-align:right; margin-top:2px; }
.field__count.is-max { color:var(--copper-deep); font-weight:600; }
.field.err input, .field.err textarea { border-color:#c0492f; }

/* MOBILE: compact carousel (~20% shorter) + tidy heading */
@media (max-width: 679px) {
  .voices__band { padding-top: clamp(28px,6vw,40px); }
  .voices__head { margin-bottom: clamp(14px,3.5vw,22px); }
  .carousel__stage { height: 76vw; max-height: 380px; perspective: 1000px; }
  .cvideo { width: 50vw; max-width: 212px; aspect-ratio: 9 / 13; }
  .cvideo[data-pos="left"]  { transform: translate(-50%,-50%) translateX(-55%) translateZ(-42px) rotateY(28deg) scale(.76); }
  .cvideo[data-pos="right"] { transform: translate(-50%,-50%) translateX(55%) translateZ(-42px) rotateY(-28deg) scale(.76); }
  .carousel__caption { margin-top: 16px; }
  .carousel__quote { font-size: clamp(.94rem,4.2vw,1.06rem); }
  .carousel__controls { margin-top: 14px; }
  .voices__share { flex-direction: column; }
  .voices__all { font-size: .82rem; }
}

/* =====================================================================
   FIXES v65 — mobile spacing, compact testimonial, smaller controls,
   desktop FAQ single-open + no sibling stretch, all-stories florals
   ===================================================================== */
/* (1) Mobile: drop the hero content below the header (more breathing room) */
@media (max-width: 679px) {
  .hero { padding-top: clamp(116px, 30vw, 150px); }
}
/* (2)(3)(4) Mobile: compact testimonial so it fits one screen + smaller buttons & arrows */
@media (max-width: 679px) {
  .voices__band { padding-top: clamp(22px,5vw,32px); }
  .voices__head { margin-bottom: clamp(10px,3vw,16px); }
  .voices__head h2 { font-size: clamp(1.35rem,5.4vw,1.75rem); }
  .carousel__stage { height: 60vw; max-height: 300px; }
  .cvideo { width: 44vw; max-width: 188px; aspect-ratio: 9 / 12; }
  .carousel__caption { margin-top: 12px; }
  .carousel__quote { font-size: clamp(.9rem,4vw,1rem); line-height: 1.45; }
  .carousel__story { font-size: .82rem; }
  .carousel__controls { margin-top: 10px; gap: 14px; }
  .carousel__btn { width: 34px; height: 34px; }       /* arrows smaller */
  .carousel__btn svg { width: 14px; height: 14px; }
  .voices__share { margin-top: 16px; gap: 10px; }
  .voices__share .btn { padding: .78em 1.4em; font-size: .82rem; }   /* smaller buttons */
  .voices__all svg { width: .95em; height: .95em; }
}
/* (4) Smoother, smaller sliding dot everywhere */
.carousel__dots { gap: 8px; }
.carousel__dots button { width: 7px; height: 7px; }
.carousel__dot-slider { height: 7px; transition: transform .55s cubic-bezier(.45,.05,.25,1), width .55s cubic-bezier(.45,.05,.25,1); }
/* (6) All-stories: hide the corner florals on desktop (kept on mobile) */
@media (min-width: 680px) { .allstories__leaf { display: none; } }
/* (7) Desktop FAQ: don't let an open item stretch its row-mate */
@media (min-width: 860px) { .faq__list { align-items: start; } }
/* (8) Contact block in the FAQ */
.faq__contact { padding: 26px 28px; border-radius: var(--r-lg); text-align: center; margin-top: 14px;
  background: radial-gradient(70% 60% at 50% 0%, rgba(231,196,172,.45), transparent 70%), var(--glass-bg); border: 1px solid var(--glass-edge); }
.faq__contact-lead { font-family: var(--serif); font-weight: 500; font-size: 1.2rem; color: var(--espresso); }
.faq__contact-sub { color: var(--mocha); font-size: .88rem; margin-top: 4px; }
.faq__contact-links { display: flex; flex-direction: column; gap: 10px; margin-top: 16px; }
.faq__contact-links a { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-size: .9rem; color: var(--copper-deep); font-weight: 500; padding: 10px 14px; border-radius: var(--r-pill); background: rgba(255,255,255,.55); border: 1px solid var(--glass-edge); transition: background .3s var(--ease), transform .3s var(--ease); }
.faq__contact-links a:hover { background: #fff; transform: translateY(-2px); }
.faq__contact-links svg { width: 17px; height: 17px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }

/* Contact = its own brown band before the footer (flows into the footer brown) */
.contactband { position: relative;
  background: radial-gradient(85% 75% at 50% 0%, rgba(168,107,71,.30), transparent 62%), var(--mocha-deep);
  padding: clamp(46px,7vw,86px) var(--pad-x) clamp(58px,8vw,104px); }
.contactband .faq__contact { background: none; border: 0; border-radius: 0; padding: 0; margin: 0 auto; max-width: 560px; }
.contactband .faq__contact-lead { color: var(--ivory); font-size: clamp(1.4rem, 4.2vw, 2rem); }
.contactband .faq__contact-sub { color: rgba(247,240,230,.72); }
.contactband .faq__contact-links { max-width: 420px; margin: 22px auto 0; }
.contactband .faq__contact-links a { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.2); color: var(--ivory); }
.contactband .faq__contact-links a:hover { background: rgba(255,255,255,.16); }
.contactband .faq__contact-links svg { stroke: var(--rose-gold-lt); }

/* (9) Carousel dots — plain round dots; the active one is simply highlighted
   (no oversized sliding beige pill). */
.carousel__dot-slider { display: none !important; }
.carousel__dots button { width: 8px !important; height: 8px !important; border-radius: 50% !important; }
.carousel__dots button[aria-selected="true"] {
  background: linear-gradient(135deg, var(--rose-gold-lt), var(--copper)) !important;
  box-shadow: 0 0 8px -1px rgba(226,183,154,.75);
}
