/* Escentie — parallax landing site
   Links brand tokens; adds layout, parallax & motion layers. */
@import url("assets/tokens/colors.css");
@import url("assets/tokens/typography.css");
@import url("https://fonts.googleapis.com/css2?family=Caudex:ital,wght@0,400;0,700;1,400;1,700&family=Montserrat:wght@300;400;500;600;700&family=Great+Vibes&display=swap");

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--cream-200);
  color: var(--text-primary);
  font-family: var(--font-serif);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  overflow-x: hidden;
}

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

/* ===== Tweakable feel: motion personality + mood + atmosphere ===== */
:root { --reveal-shift: 40px; --reveal-dur: .8s; --logo-dur: 5.5s; }
body[data-motion="calm"]      { --reveal-shift: 20px; --reveal-dur: 1.15s; --logo-dur: 9s; }
body[data-motion="lively"]    { --reveal-shift: 40px; --reveal-dur: .78s;  --logo-dur: 5.5s; }
body[data-motion="cinematic"] { --reveal-shift: 66px; --reveal-dur: 1.35s; --logo-dur: 7.5s; }

/* mood = whole-page lighting + brand gold. Default Golden Hour = base warm look. */
body[data-mood="golden"]   { --mood-color: #E8A24B; --mood-opacity: 0;   --mood-blend: soft-light; --gold-500: #D4A373; }
body[data-mood="garden"]   { --mood-color: #5E7A3E; --mood-opacity: .22; --mood-blend: soft-light; --gold-500: #C9A24B; }
body[data-mood="midnight"] { --mood-color: #221A38; --mood-opacity: .40; --mood-blend: multiply;   --gold-500: #E3C29C; }

.twk-note { font-family: ui-sans-serif, system-ui, -apple-system, sans-serif; font-size: 11px; line-height: 1.5; color: rgba(41,38,27,.55); margin: 6px 0 2px; }
.mood-veil { position: fixed; inset: 0; z-index: 90; pointer-events: none;
  mix-blend-mode: var(--mood-blend, soft-light); background: var(--mood-color, transparent);
  opacity: var(--mood-opacity, 0); transition: background .6s ease, opacity .6s ease; }
.atmosphere { position: fixed; inset: 0; z-index: 89; pointer-events: none; opacity: var(--haze, 0);
  transition: opacity .55s ease;
  background:
    radial-gradient(120% 70% at 50% -8%, rgba(245,235,224,.95), rgba(245,235,224,0) 58%),
    radial-gradient(110% 80% at 50% 118%, rgba(245,235,224,.55), rgba(245,235,224,0) 52%),
    radial-gradient(135% 120% at 50% 50%, rgba(0,0,0,0) 52%, rgba(42,26,17,.30)); }
@media (prefers-reduced-motion: reduce) {
  .mood-veil, .atmosphere { transition: none; }
}

.eyebrow {
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--text-accent); margin: 0;
}
.eyebrow.on-dark { color: var(--gold-400); }

h1, h2, h3 { font-family: var(--font-serif); font-weight: var(--weight-bold); line-height: var(--leading-tight); margin: 0; }
.wrap { width: min(1280px, 100% - 10vw); margin-inline: auto; }

.btn {
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; text-decoration: none;
  display: inline-flex; align-items: center; gap: .6em; padding: 1em 1.9em; border-radius: 999px;
  cursor: pointer; border: 1px solid transparent;
  transition: transform .24s ease, background .24s ease, color .24s ease, box-shadow .24s ease, border-color .24s ease;
}
.btn:active { transform: scale(.97); }
.btn-gold { background: var(--gold-500); color: var(--brown-900); box-shadow: 0 10px 30px -12px rgba(61,38,26,.5); }
.btn-gold:hover { background: var(--gold-600); transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--text-primary); border-color: var(--border-soft); }
.btn-ghost:hover { border-color: var(--brown-800); background: rgba(61,38,26,.04); }
.btn-ghost.on-dark { color: var(--cream-200); border-color: rgba(245,235,224,.35); }
.btn-ghost.on-dark:hover { border-color: var(--cream-200); background: rgba(245,235,224,.08); }

/* ---- section page tags (for easy reference) ---- */
.page-tag {
  display: none;
  position: absolute; top: clamp(5.5rem, 11vh, 7rem); left: clamp(1.5rem, 5vw, 4rem); z-index: 40;
  font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600;
  letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--brown-400);
  align-items: center; gap: .55em;
}
.page-tag::before { content: ""; width: 1.6em; height: 1px; background: currentColor; opacity: .6; }
.page-tag.on-dark { color: rgba(245,235,224,.55); }

/* ---------------- NAV (hidden per request) ---------------- */
.nav { display: none !important; }
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.5rem clamp(1.5rem, 5vw, 4rem);
  transition: background .4s ease, backdrop-filter .4s ease, padding .4s ease, box-shadow .4s ease;
}
.nav.scrolled { background: rgba(245,235,224,.82); backdrop-filter: blur(14px) saturate(1.1); padding-block: 1rem; box-shadow: 0 1px 0 var(--border-hairline); }
.nav.scrolled.over-dark { background: rgba(42,26,17,.6); box-shadow: 0 1px 0 rgba(245,235,224,.12); }
.nav__logo img { height: 30px; width: auto; }
.nav__logo .logo-brown { display: block; }
.nav__logo .logo-gold { display: none; }
.nav.over-dark .nav__logo .logo-brown { display: none; }
.nav.over-dark .nav__logo .logo-gold { display: block; }
.nav__links { display: flex; align-items: center; gap: clamp(1.2rem, 2.5vw, 2.4rem); }
.nav__links a {
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide); text-transform: uppercase; text-decoration: none; color: var(--text-primary); position: relative; transition: color .3s ease;
}
.nav.over-dark .nav__links a:not(.btn) { color: var(--cream-200); }
.nav__links a.nav-link::after { content: ""; position: absolute; left: 0; bottom: -.4em; height: 1px; width: 0; background: currentColor; transition: width .3s ease; }
.nav__links a.nav-link:hover::after { width: 100%; }
.nav:not(.scrolled) .nav__links a:not(.btn) { text-shadow: 0 1px 10px rgba(245,235,224,.75); }
.nav__links .btn { padding: .7em 1.4em; }
@media (max-width: 760px) { .nav__links .nav-link { display: none; } }

/* ---------------- HERO (video) ---------------- */
.hero { position: relative; min-height: 100vh; overflow: hidden; display: flex; align-items: center; background: #170B02; }
.hero__video { position: absolute; top: 0; right: 0; height: 100%; width: auto; max-width: 100%; object-fit: cover; object-position: center; z-index: 0; }
.hero__scrim { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(30,18,12,.78), rgba(30,18,12,.30) 48%, rgba(30,18,12,.12) 72%),
    linear-gradient(0deg, rgba(30,18,12,.72), rgba(30,18,12,0) 40%); }
.hero__inner { position: relative; z-index: 3; width: min(1280px, 100% - 10vw); margin-inline: auto; }
.hero__eyebrow { margin-bottom: 1.4rem; }
.hero__logoWrap { position: relative; display: inline-block; }
.hero__logo { width: clamp(320px, 48vw, 720px); height: auto; display: block; filter: drop-shadow(0 8px 22px rgba(0,0,0,.4)); }
.hero__tagline { font-family: var(--font-serif); font-style: italic; font-size: clamp(1.4rem, 3vw, 2.4rem); color: var(--text-accent); margin: 1.4rem 0 0; }
.hero__tagline--video { color: var(--gold-300); }
.hero__sub { margin: 1.2rem 0 2.2rem; color: var(--brown-600); max-width: 36ch; font-size: var(--text-md); }
.hero__sub--video { color: rgba(245,235,224,.84); }
.hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; }

@media (prefers-reduced-motion: reduce) {
  .hero__logo { animation: none; }
}
@media (max-width: 880px) {
  .hero { align-items: flex-end; padding-bottom: 14vh; }
  .hero__logo { width: clamp(220px, 62vw, 360px); }
}

/* ---------------- BRAND NARRATIVE ---------------- */
.about { position: relative; min-height: 100vh; overflow: hidden; color: var(--cream-100); display: flex; align-items: center;
  background: radial-gradient(120% 110% at 16% 40%, #241408, #1A0D03 60%, #170B02); }
.about__photo { position: absolute; right: clamp(-6%, -2vw, 0%); bottom: 0; height: 100vh; width: auto; max-width: 60%;
  object-fit: contain; object-position: bottom right; z-index: 1; filter: drop-shadow(0 30px 60px rgba(0,0,0,.45)); }
.about__veil { position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(90deg, rgba(30,18,12,.92) 0%, rgba(30,18,12,.55) 38%, rgba(30,18,12,0) 62%); }
.about__inner { position: relative; z-index: 3; display: flex; flex-direction: column;
  justify-content: center; align-items: flex-start; gap: 1.4rem; width: min(1280px, 100% - 10vw); margin-inline: auto; padding-block: 12vh; }
.about .eyebrow { color: var(--gold-400); }
.about__title { font-size: clamp(2.6rem, 7vw, 6rem); font-style: italic; font-weight: 400; line-height: .98; max-width: 16ch; }
.about__body { font-size: clamp(1.1rem, 1.8vw, 1.55rem); max-width: 34ch; color: var(--cream-100); }
.about__sign { font-family: var(--font-sans); font-size: var(--text-sm); letter-spacing: var(--tracking-wider);
  text-transform: uppercase; color: var(--gold-300); display: flex; align-items: center; gap: .8rem; margin-top: .6rem; }
.about__sign img { width: 30px; opacity: .9; }
@media (max-width: 820px) {
  .about__photo { max-width: 88%; opacity: .42; right: -10%; }
  .about__veil { background: linear-gradient(0deg, rgba(30,18,12,.9), rgba(30,18,12,.55)); }
}

/* ---------------- ESSENCE INTRO (full-screen video) ---------------- */
.essence { position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center;
  overflow: hidden; background: #2A1A11; }
.essence__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0;
  filter: blur(34px) brightness(.62) saturate(1.05); transform: scale(1.12); }
.essence__bgveil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(120% 90% at 50% 40%, rgba(42,26,17,.22), rgba(42,26,17,.62) 80%); }
.essence__photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 2; }
.essence__overlay { position: absolute; z-index: 3; top: auto; bottom: 0; left: 0; right: 0; text-align: center; pointer-events: none;
  padding: clamp(5rem, 16vh, 11rem) 1rem clamp(2.4rem, 7vh, 5rem);
  background: linear-gradient(0deg, rgba(26,15,9,.74) 0%, rgba(26,15,9,.5) 40%, rgba(26,15,9,0) 100%); }
.essence__title { font-family: var(--font-script); font-weight: 400; font-size: clamp(3.2rem, 8vw, 6.4rem); line-height: .95;
  color: var(--gold-300); text-shadow: 0 2px 4px rgba(0,0,0,.6), 0 8px 34px rgba(0,0,0,.7); }
.essence__sub { font-family: var(--font-serif); font-style: italic; font-size: clamp(1.3rem, 2.6vw, 2rem);
  color: rgba(252,247,240,.96); margin-top: .6rem; text-shadow: 0 2px 4px rgba(0,0,0,.55), 0 6px 22px rgba(0,0,0,.65); }
@media (max-width: 820px) {
  .essence__photo { height: 100%; width: 100%; max-width: 100%; min-height: 100vh; object-fit: cover; object-position: center 42%; border-radius: 0; }
  /* anchor caption flush to the section bottom so no blurry marble strip floats below it */
  .essence__overlay { top: auto; bottom: 0; padding-bottom: clamp(2.6rem, 8vh, 4.5rem);
    background: linear-gradient(0deg, rgba(26,15,9,.82) 0%, rgba(26,15,9,.55) 45%, rgba(26,15,9,0) 100%); }
}

/* ---------------- KOLEKSI VARIAN — halaman per varian ---------------- */
.vpage { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; background: var(--cream-200); }
.hpanel__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center right; z-index: 0; }
.vpage::before { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(90deg, rgba(250,244,236,.94) 0%, rgba(250,244,236,.64) 28%, rgba(250,244,236,.12) 52%, rgba(250,244,236,0) 66%); }
.hpanel__panel { position: relative; z-index: 2; width: min(1280px, 100% - 10vw); margin-inline: auto;
  display: flex; flex-direction: column; justify-content: space-between; height: min(80vh, 760px); }
.poster__top, .poster__bottom { display: flex; flex-direction: column; align-items: flex-start; }
.poster__name { font-family: var(--font-serif); font-weight: 700; line-height: .92; margin: 0; max-width: 7ch; font-size: clamp(3rem, 6.4vw, 6rem); padding-bottom: .14em;
  background: linear-gradient(180deg, #E3C29C 0%, #C79A55 55%, #A8784A 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: #B98A46; }
.poster__logo { height: clamp(32px, 4vw, 56px); width: auto; margin: 1rem 0 0; }
.poster__rule { display: flex; align-items: center; gap: .8rem; width: clamp(230px, 26vw, 360px); margin: 1.2rem 0; }
.poster__rule::before, .poster__rule::after { content: ""; flex: 1; height: 1px; background: var(--gold-500); opacity: .7; }
.poster__rule img { height: 26px; width: auto; flex: none; }
.poster__rule--plain { width: clamp(190px, 22vw, 300px); height: 1px; background: var(--gold-500); opacity: .55; margin: 1rem 0; }
.poster__notes { font-family: var(--font-sans); font-weight: 600; font-size: var(--text-sm); letter-spacing: .02em; color: var(--brown-700); margin: 0; }
.poster__emblem { height: clamp(30px, 3.4vw, 44px); width: auto; margin: 0 0 1rem; }
.poster__statement { font-family: var(--font-sans); font-weight: 600; font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--gold-700); line-height: 1.6; margin: 0; }
.poster__spec { font-family: var(--font-sans); font-weight: 600; font-size: var(--text-2xs); color: var(--brown-700); line-height: 1.55; margin: 1rem 0 0; }
.poster__more { margin-top: 1.3rem; font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 700; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--gold-700); background: none; border: none; padding: 0; cursor: pointer; }
.poster__more:hover { color: var(--brown-900); }
.poster__name--caps { text-transform: uppercase; letter-spacing: .01em; max-width: 100%; font-size: clamp(3.4rem, 7.2vw, 6.6rem); }
.poster__name--solo { max-width: 100%; white-space: nowrap; font-size: clamp(3.4rem, 7.6vw, 7rem); }
@media (max-width: 820px){
  .hpanel__panel { height: auto; gap: 2.4rem; padding: 12vh 0; }
  .poster__top > *, .poster__bottom > * { max-width: 26ch; }
  .vpage::before { background: linear-gradient(90deg, rgba(250,244,236,.96) 0%, rgba(250,244,236,.8) 40%, rgba(250,244,236,.2) 72%, rgba(250,244,236,0) 92%); }
}

/* ---------------- COLLECTION ---------------- */
.collection { position: relative; padding-block: clamp(7rem, 13vh, 12rem) clamp(6rem, 12vh, 11rem); background: var(--cream-200); }
.collection__head { text-align: center; margin-bottom: clamp(3rem, 6vh, 5rem); }
.collection__head .eyebrow { margin-bottom: 1rem; }
.collection__head h2 { font-size: clamp(2.4rem, 5vw, 4rem); letter-spacing: -0.01em; }
.collection__head p { color: var(--brown-500); max-width: 46ch; margin: 1.1rem auto 0; }
.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 1.8rem); }
@media (max-width: 1024px){ .cards { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }
@media (max-width: 560px){ .cards { grid-template-columns: 1fr; } }
.card { position: relative; background: var(--cream-50); border: 1px solid var(--border-hairline);
  border-radius: 14px; padding: 1.4rem 1.4rem 1.8rem; overflow: hidden; cursor: pointer;
  transition: transform .42s cubic-bezier(.2,.7,.2,1), box-shadow .42s ease; }
.card:hover { transform: translateY(-8px); box-shadow: 0 30px 50px -24px rgba(61,38,26,.4); }
.card__photo { position: relative; aspect-ratio: 4/5; border-radius: 10px; overflow: hidden; background: var(--cream-300); margin-bottom: 1.2rem; }
.card__photo img, .card__photo video { width: 100%; height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.2,.7,.2,1); will-change: transform; }
.card:hover .card__photo img, .card:hover .card__photo video { transform: scale(1.06); }
.card__view { position: absolute; inset: auto 0 0 0; padding: 1.6rem .9rem .8rem; z-index: 2;
  font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--cream-50); opacity: 0; transform: translateY(6px);
  background: linear-gradient(transparent, rgba(42,26,17,.7)); transition: opacity .35s ease, transform .35s ease; }
.card:hover .card__view { opacity: 1; transform: none; }
.card__name { font-size: var(--text-xl); margin-bottom: .5rem; }
.card__notes { font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--gold-700); margin: 0 0 .7rem; line-height: 1.5; }
.card__statement { font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 500; letter-spacing: var(--tracking-wider);
  text-transform: uppercase; color: var(--brown-600); margin: 0 0 1rem; line-height: 1.7; min-height: 3.4em; }
.card__edp { font-family: var(--font-sans); font-size: var(--text-2xs); letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--brown-400); margin: 0; }
.card__foot { display: flex; flex-direction: column; align-items: stretch; gap: .85rem; margin-top: 1.1rem; padding-top: 1rem; border-top: 1px solid var(--border-hairline); }
.card__shops { display: flex; gap: .5rem; }
.shop-link { flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: .45em;
  font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 700; letter-spacing: var(--tracking-wide);
  padding: .5em .4em; border-radius: 999px; color: var(--brown-900); background: var(--cream-50); border: 1px solid var(--border-hairline);
  text-decoration: none; cursor: pointer; transition: transform .25s ease, box-shadow .25s ease; }
.shop-link:hover { transform: translateY(-2px); box-shadow: 0 8px 18px -10px rgba(61,38,26,.5); }
.shop-link img { width: 17px; height: 17px; object-fit: contain; flex-shrink: 0; }
.card__price { font-family: var(--font-sans); font-weight: var(--weight-semibold); font-size: var(--text-base); }
.card__price small { color: var(--brown-400); font-weight: 400; }
.card__detail { font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--gold-700); }

/* ---------------- LUX TRAVEL SIZE ---------------- */
.travel { position: relative; overflow: hidden; padding: 0; min-height: 100vh;
  background: radial-gradient(115% 110% at 24% 45%, #FFFFFF 0%, #FCF7F0 42%, #F3ECF7 100%); }
.travel__grid { width: 100%; max-width: none; margin: 0; display: grid;
  grid-template-columns: 1fr 1fr; align-items: stretch; gap: 0; min-height: 100vh; }
.travel__media { position: relative; margin: 0; border-radius: 16px; overflow: hidden;
  box-shadow: 0 36px 72px -32px rgba(61,38,26,.42); }
.travel__media img { width: 100%; height: clamp(360px, 66vh, 640px); object-fit: cover; object-position: center top; display: block; }
.travel__media--full { align-self: stretch; margin: 0; background: transparent; box-shadow: none; border-radius: 0; overflow: visible; position: relative; z-index: 3; display: flex; justify-content: flex-end; align-items: flex-end; pointer-events: none; }
.travel__media--full img { height: 100%; width: auto; max-width: 120%; object-fit: contain; object-position: right bottom; display: block; }
.travel__copy { max-width: 40ch; align-self: center; padding: clamp(2rem, 5vw, 5rem); position: relative; z-index: 1; }
.travel__copy .eyebrow { margin-bottom: 1rem; }
.travel__title { font-family: var(--font-serif); font-size: clamp(2.4rem, 5vw, 4rem); font-style: italic; font-weight: 400;
  line-height: 1.0; color: var(--brown-800); }
.travel__sub { color: var(--brown-600); font-size: var(--text-md); margin-top: 1.2rem; }
.travel__colors { display: flex; gap: clamp(.7rem, 1.5vw, 1.1rem); margin-top: 2rem; }
.travel__colors figure { margin: 0; flex: 1; background: var(--cream-50); border: 1px solid var(--border-hairline);
  border-radius: 12px; overflow: hidden; padding: .5rem; transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease; }
.travel__colors figure:hover { transform: translateY(-4px); box-shadow: 0 18px 30px -18px rgba(61,38,26,.4); }
.travel__colors img { width: 100%; height: 88px; object-fit: contain; display: block; }
.travel__note { font-family: var(--font-sans); font-size: var(--text-2xs); letter-spacing: .02em; color: var(--brown-500); margin-top: 1.5rem; line-height: 1.6; }
@media (max-width: 820px) {
  .travel__grid { grid-template-columns: 1fr; gap: 2.2rem; }
  .travel__copy { max-width: none; }
  .travel__media img { height: 54vh; }
  .travel__media--full { display: block; }
  .travel__media--full img { width: 100%; height: auto; }
}

/* ---------------- MODAL ---------------- */
.modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 5vh 4vw; }
.modal[hidden] { display: none; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(42,26,17,.55); backdrop-filter: blur(6px); opacity: 0; transition: opacity .4s ease; }
.modal.open .modal__backdrop { opacity: 1; }
.modal__card { position: relative; z-index: 1; display: grid; grid-template-columns: .9fr 1.1fr; max-width: 920px; width: 100%;
  max-height: 90vh; background: var(--cream-50); border-radius: 16px; overflow: hidden;
  box-shadow: 0 50px 90px -30px rgba(42,26,17,.6); transform: translateY(24px) scale(.97); opacity: 0;
  transition: transform .45s cubic-bezier(.2,.7,.2,1), opacity .45s ease; }
.modal.open .modal__card { transform: none; opacity: 1; }
.modal__media { position: relative; background: radial-gradient(120% 100% at 50% 30%, var(--cream-100), var(--cream-300)); }
.modal__media img, .modal__media video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.modal__body { padding: clamp(2rem, 4vw, 3.2rem); overflow-y: auto; min-height: 0; max-height: 90vh; }
.modal__notes { margin-bottom: 1rem; }
.modal__name { font-size: clamp(2rem, 4vw, 3rem); letter-spacing: -0.01em; }
.modal__tag { font-family: var(--font-serif); font-style: italic; color: var(--text-accent); font-size: var(--text-lg); margin: .5rem 0 1.4rem; }
.modal__narr { color: var(--brown-600); font-size: var(--text-md); }
.modal__narr p { margin: 0 0 1em; }
.modal__narr p:last-child { margin-bottom: 0; }
.modal__foot { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 2rem; padding-top: 1.4rem; border-top: 1px solid var(--border-hairline); }
.modal__price { font-family: var(--font-sans); font-weight: 600; font-size: var(--text-lg); }
.modal__price small { color: var(--brown-400); font-weight: 400; font-size: var(--text-sm); }
.modal__close { position: absolute; top: 1rem; right: 1rem; z-index: 3; width: 42px; height: 42px; border-radius: 50%;
  border: none; background: rgba(245,235,224,.9); color: var(--brown-800); font-size: 1.5rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: background .24s ease, transform .24s ease; }
.modal__close:hover { background: var(--cream-200); transform: rotate(90deg); }
.modal__add { display: inline-block; text-decoration: none; font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--brown-900); background: var(--gold-500); border: none; padding: .85em 1.5em; border-radius: 999px; cursor: pointer; transition: background .24s ease, transform .24s ease; }
.modal__add:hover { background: var(--gold-600); transform: translateY(-1px); }
.modal__reel { display: inline-flex; align-items: center; gap: .55em; margin-top: 1.2rem;
  font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wide);
  text-transform: uppercase; color: var(--gold-700); text-decoration: none; transition: color .24s ease; }
.modal__reel:hover { color: var(--gold-600); }
.modal__reel svg { flex: none; }
@media (max-width: 720px){ .modal__card { grid-template-columns: 1fr; max-height: 88vh; } .modal__media { height: 38vh; } .modal__media img, .modal__media video { position: relative; } }

/* ---------------- EDITORIAL + JANJI ---------------- */
.editorial { position: relative; overflow: hidden;
  background: linear-gradient(180deg, #2A1A11, #3D261A 60%, #2A1A11); padding-block: clamp(4rem, 8vh, 7rem); }
.editorial__word { position: absolute; z-index: 1; left: 50%; top: 20%; transform: translate(-50%,-50%);
  font-family: var(--font-serif); font-weight: 700; font-size: clamp(5rem, 24vw, 26rem); line-height: .8;
  color: var(--gold-500); opacity: .12; white-space: nowrap; pointer-events: none; letter-spacing: -0.03em; }
.editorial__inner { position: relative; z-index: 3; width: min(1280px, 100% - 10vw); margin-inline: auto;
  display: grid; grid-template-columns: 1fr 1fr; align-items: end; gap: clamp(2rem, 5vw, 5rem); }
.editorial__media { display: flex; justify-content: center; align-items: flex-end; }
.editorial__model { width: min(40vw, 460px); filter: drop-shadow(0 30px 70px rgba(0,0,0,.5)); display: block; }
.editorial__copy { max-width: 34ch; align-self: center; }
.editorial__copy .eyebrow { color: var(--gold-400); margin-bottom: 1rem; }
.editorial__copy h2 { color: var(--cream-100); font-style: italic; font-weight: 400; font-size: clamp(1.9rem, 3.6vw, 3.2rem); line-height: 1.04; }
.editorial__copy p { color: rgba(245,235,224,.8); font-size: var(--text-md); margin: 1.4rem 0 0; }
.editorial__claims { position: relative; z-index: 3; width: min(1280px, 100% - 10vw); margin: clamp(0.2rem, 0.6vh, 0.8rem) auto 0;
  padding-top: clamp(1rem, 2vh, 1.6rem); border-top: 1px solid rgba(245,235,224,.16);
  display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(1.6rem, 5vw, 4.5rem); text-align: center; }
@media (max-width: 760px){
  .editorial__inner { grid-template-columns: 1fr; text-align: center; gap: 1.4rem; }
  .editorial__copy { max-width: none; }
  .editorial__model { width: min(60vw, 320px); }
  .editorial__claims { gap: 1.4rem 2.5rem; }
}

/* claims strip */
.claims { position: relative; background: var(--brown-900); color: var(--cream-100); padding-block: 3.4rem; }
.claims__row { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(2rem, 6vw, 5rem); text-align: center; }
.claim { display: flex; flex-direction: column; gap: .35rem; }
.claim b { font-family: var(--font-serif); font-size: var(--text-2xl); color: var(--gold-400); font-weight: 700; }
.claim span { font-family: var(--font-sans); font-size: var(--text-2xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: rgba(245,235,224,.7); }

/* ---------------- CLOSING ---------------- */
.closing { position: relative; padding-block: clamp(7rem, 17vh, 13rem); text-align: center; overflow: hidden;
  background: radial-gradient(120% 100% at 50% 0%, var(--cream-50), var(--cream-200) 60%, var(--cream-300)); }
.closing__monogram { width: 64px; margin: 0 auto 1.8rem; opacity: .8; }
.closing .eyebrow { margin-bottom: 1.2rem; }
.closing h2 { font-size: clamp(2.4rem, 6vw, 4.6rem); font-style: italic; font-weight: 400; line-height: 1.04; max-width: 16ch; margin-inline: auto; }
.closing p { color: var(--brown-600); max-width: 40ch; margin: 1.6rem auto 2.6rem; }
.closing__qr { display: inline-flex; align-items: center; gap: 1.2rem; margin-top: 3rem; padding: 1rem 1.6rem 1rem 1rem;
  background: var(--cream-50); border: 1px solid var(--border-hairline); border-radius: 16px; text-decoration: none;
  box-shadow: 0 18px 40px -24px rgba(61,38,26,.5); transition: transform .3s ease, box-shadow .3s ease; }
.closing__qr:hover { transform: translateY(-3px); box-shadow: 0 26px 50px -24px rgba(61,38,26,.55); }
.closing__qr img { width: 96px; height: 96px; border-radius: 8px; display: block; }
.closing__qrtext { display: flex; flex-direction: column; align-items: flex-start; gap: .25rem; text-align: left; }
.closing__qrlabel { font-family: var(--font-sans); font-size: var(--text-2xs); font-weight: 600; letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--gold-700); }
.closing__qrlink { font-family: var(--font-serif); font-size: var(--text-lg); color: var(--text-primary); }
.closing__qrnote { font-family: var(--font-sans); font-size: var(--text-2xs); color: var(--brown-500); }
@media (max-width: 560px) {
  .closing__qr { display: flex; width: min(100%, 30rem); margin-inline: auto; gap: 1rem; padding: .9rem 1rem; }
  .closing__qr img { width: 78px; height: 78px; }
  .closing__qrtext { min-width: 0; flex: 1; }
  .closing__qrlink { font-size: var(--text-base); overflow-wrap: anywhere; word-break: break-word; }
}

/* ---------------- FOOTER ---------------- */
.footer { background: var(--brown-900); color: var(--cream-200); padding-block: clamp(3.5rem, 8vh, 6rem); }
.footer__border { width: 100%; height: 26px; object-fit: cover; object-position: center; opacity: .55; margin-bottom: 3rem; filter: brightness(1.4); }
.footer__grid { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 2.5rem; align-items: flex-start; }
.footer__brand img { height: 34px; margin-bottom: 1.1rem; }
.footer__brand p { font-style: italic; color: rgba(245,235,224,.7); max-width: 26ch; font-size: var(--text-base); }
.footer__col h4 { font-family: var(--font-sans); font-size: var(--text-2xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--gold-400); margin: 0 0 1rem; font-weight: 600; }
.footer__col a { display: block; color: rgba(245,235,224,.82); text-decoration: none; font-size: var(--text-base); margin-bottom: .6rem; transition: color .24s ease; }
.footer__col a:hover { color: var(--gold-300); }
.footer__base { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-top: 3.5rem; padding-top: 1.6rem; border-top: 1px solid rgba(245,235,224,.14); font-family: var(--font-sans); font-size: var(--text-2xs); letter-spacing: .04em; color: rgba(245,235,224,.55); }
.footer__social { display: flex; flex-wrap: wrap; gap: 1.2rem; }
.footer__social a { color: rgba(245,235,224,.7); text-decoration: none; transition: color .24s ease; }
.footer__social a:hover { color: var(--gold-300); }

/* ---------------- REVEAL (in & out) ----------------
   Base state is VISIBLE (so content is never stuck hidden). The scroll loop
   sets inline opacity/transform: 0 when out of the viewport band, 1 when in —
   giving fade-out on leave and fade-in on enter, animated by this transition. */
.reveal { opacity: 1; transform: none; transition: opacity var(--reveal-dur, .9s) cubic-bezier(.2,.7,.2,1), transform var(--reveal-dur, .9s) cubic-bezier(.2,.7,.2,1); }
.reveal[data-delay="1"]{ transition-delay: .08s; }
.reveal[data-delay="2"]{ transition-delay: .16s; }
.reveal[data-delay="3"]{ transition-delay: .24s; }
.reveal[data-delay="4"]{ transition-delay: .32s; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none; }
  [data-parallax] { transform: none !important; }
}
