/* =========================================================================
   EXISTENCE — Maison de Parfum
   Conversion-Optimized Luxury Landing Page
   Palette 60/30/10  ·  Onyx · Pearl · Gold
   ========================================================================= */

:root {
  --onyx:        #0A0A0A;
  --onyx-2:      #1A1A1A;
  --onyx-3:      #050505;
  --pearl:       #F8F6F1;
  --pearl-soft:  #EFEAE0;
  --pearl-warm:  #FFFAF0;
  --gold:        #C9A24A;
  --gold-deep:   #B8860B;
  --gold-light:  #F5E7C1;
  --gold-glow:   rgba(201,162,74,.18);
  --line:        #E5DFD2;
  --line-dark:   rgba(201,162,74,.18);
  --ink:         #2A2A2A;
  --muted:       #6E6A60;
  --error:       #C0392B;
  --success:     #2A8C5A;

  --font-display: "Cinzel", "Playfair Display", "Times New Roman", serif;
  --font-serif:   "Cormorant Garamond", "Times New Roman", serif;
  --font-sans:    "Inter", "Helvetica Neue", system-ui, sans-serif;

  --maxw: 1280px;
  --gap-xs: 8px;
  --gap-s: 16px;
  --gap-m: 24px;
  --gap-l: 40px;
  --gap-xl: 64px;
  --gap-2xl: 96px;
  --gap-3xl: 128px;

  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
html, body { background: var(--pearl); color: var(--ink); }
body {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: opacity .25s var(--ease), color .25s var(--ease); }
a:hover { opacity: .75; }
ul { list-style: none; }
em { font-style: italic; }

/* ========== Reusable section title style ========== */
.section-head { text-align: center; padding: var(--gap-2xl) var(--gap-m) var(--gap-l); max-width: 880px; margin: 0 auto; }
.section-eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .55em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 24px;
}
.section-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.1;
  letter-spacing: .04em;
  color: var(--onyx);
  margin-bottom: 20px;
}
.section-title--light { color: var(--pearl); }
.section-sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(15px, 1.4vw, 19px);
  color: var(--muted);
  font-weight: 400;
  max-width: 620px;
  margin: 0 auto;
}

/* =========================================================================
   URGENCY BAR (Cialdini: Scarcity)
   ========================================================================= */
.urgency {
  background: linear-gradient(90deg, var(--onyx) 0%, #1a1208 50%, var(--onyx) 100%);
  border-bottom: 1px solid var(--line-dark);
  color: var(--gold-light);
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: .15em;
  text-align: center;
  padding: 11px 12px;
  position: relative;
  z-index: 60;
}
.urgency__inner { display: inline-flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center; }
.urgency__pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 0 rgba(201,162,74,.6);
  animation: pulse 1.6s infinite;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(201,162,74,.55); }
  70%  { box-shadow: 0 0 0 12px rgba(201,162,74,0); }
  100% { box-shadow: 0 0 0 0 rgba(201,162,74,0); }
}
.urgency__text strong { color: var(--gold); font-weight: 600; letter-spacing: .25em; }
.urgency__countdown {
  font-family: var(--font-sans);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  background: rgba(201,162,74,.15);
  border: 1px solid var(--line-dark);
  padding: 4px 10px;
  letter-spacing: .12em;
  color: var(--gold);
}

/* =========================================================================
   NAV
   ========================================================================= */
.nav {
  position: sticky; top: 0;
  z-index: 50;
  background: rgba(10,10,10,.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: background .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease);
  color: var(--pearl);
}
.nav.is-scrolled {
  background: rgba(248,246,241,.94);
  border-bottom-color: var(--line);
  color: var(--onyx);
}
.nav__inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 18px 32px;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 32px;
}
.nav__brand {
  font-family: var(--font-display); font-weight: 600;
  font-size: 19px; letter-spacing: .35em;
}
.nav__links {
  display: flex; gap: 36px; justify-content: center;
  font-size: 12px; letter-spacing: .25em; font-weight: 500; text-transform: uppercase;
}
.nav__links a { position: relative; padding: 4px 0; }
.nav__links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 1px;
  background: var(--gold); transition: width .3s var(--ease);
}
.nav__links a:hover { opacity: 1; color: var(--gold); }
.nav__links a:hover::after { width: 100%; }
.nav__cta {
  justify-self: end;
  font-size: 11px; letter-spacing: .28em; text-transform: uppercase; font-weight: 500;
  padding: 11px 22px;
  background: var(--gold); color: var(--onyx);
  border: 1px solid var(--gold);
  transition: background .25s var(--ease), color .25s var(--ease);
}
.nav__cta:hover { background: var(--gold-deep); color: var(--pearl); border-color: var(--gold-deep); opacity: 1; }

/* =========================================================================
   HERO
   ========================================================================= */
.hero {
  position: relative;
  min-height: calc(100svh - 44px);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 120px 24px 100px;
  overflow: hidden;
  background: var(--onyx);
  color: var(--pearl);
  text-align: center;
}
.hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(circle at 50% 35%, rgba(201,162,74,.18), transparent 55%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 64px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0 1px, transparent 1px 64px),
    radial-gradient(ellipse at 50% 100%, #1a1208, var(--onyx) 70%);
  pointer-events: none;
}
.hero__content { position: relative; z-index: 1; max-width: 920px; }
.hero__pre {
  font-size: 11px;
  letter-spacing: .55em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 28px;
  font-weight: 500;
}
.hero__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(44px, 8.5vw, 132px);
  line-height: .95;
  letter-spacing: .08em;
  margin-bottom: 32px;
  word-break: keep-all;
  background: linear-gradient(180deg, #f5e7c1 0%, var(--gold) 55%, #8a6620 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.3));
}
.hero__tag {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(18px, 2.2vw, 28px);
  color: var(--pearl);
  opacity: .92;
  line-height: 1.4;
  margin-bottom: 28px;
}
.hero__proof {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 8px 20px;
  border: 1px solid rgba(201,162,74,.25);
  background: rgba(201,162,74,.06);
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--gold-light);
  margin-bottom: 36px;
}
.hero__proof strong { color: var(--gold); font-weight: 600; }
.hero__stars { color: var(--gold); letter-spacing: .15em; font-size: 14px; }
.hero__ctas { display: flex; gap: 16px; justify-content: center; margin-bottom: 28px; flex-wrap: wrap; }
.hero__trust {
  font-size: 12px;
  letter-spacing: .12em;
  color: rgba(248,246,241,.6);
  font-weight: 400;
}
.hero__scroll {
  position: absolute; left: 50%; bottom: 32px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  z-index: 1;
}
.hero__scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(180deg, transparent 0%, var(--gold) 100%);
  animation: scrollPulse 2s var(--ease) infinite;
}
.hero__scroll-text {
  font-size: 10px; letter-spacing: .55em; text-transform: uppercase;
  color: var(--gold); font-weight: 500;
}
@keyframes scrollPulse {
  0%, 100% { transform: scaleY(1); opacity: .5; }
  50%      { transform: scaleY(1.2); opacity: 1; }
}

/* =========================================================================
   BUTTONS
   ========================================================================= */
.btn {
  display: inline-block;
  font-family: var(--font-sans); font-size: 12px;
  font-weight: 500; letter-spacing: .3em; text-transform: uppercase;
  padding: 18px 32px;
  border: 1px solid transparent;
  cursor: pointer; user-select: none;
  transition: transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); opacity: 1; }
.btn--gold {
  background: var(--gold); color: var(--onyx); border-color: var(--gold);
  box-shadow: 0 6px 20px rgba(201,162,74,.25);
}
.btn--gold:hover { background: var(--gold-deep); color: var(--pearl); border-color: var(--gold-deep); box-shadow: 0 10px 28px rgba(201,162,74,.35); }
.btn--ghost { background: transparent; color: var(--pearl); border-color: var(--pearl); }
.btn--ghost:hover { background: var(--pearl); color: var(--onyx); }
.btn--ghost-dark { background: transparent; color: var(--onyx); border-color: var(--onyx); }
.btn--ghost-dark:hover { background: var(--onyx); color: var(--pearl); }
.btn--lg { padding: 22px 44px; font-size: 13px; }
.btn--gold-sm,
.btn--dark-sm {
  font-size: 11px; padding: 14px 22px; letter-spacing: .25em;
  width: 100%; text-align: center;
}
.btn--gold-sm { background: var(--gold); color: var(--onyx); border-color: var(--gold); }
.btn--gold-sm:hover { background: var(--gold-deep); color: var(--pearl); border-color: var(--gold-deep); }
.btn--dark-sm { background: var(--onyx); color: var(--pearl); border-color: var(--onyx); }
.btn--dark-sm:hover { background: var(--gold); color: var(--onyx); border-color: var(--gold); }

/* =========================================================================
   TRUST STRIP
   ========================================================================= */
.trust {
  background: var(--pearl);
  border-bottom: 1px solid var(--line);
  padding: 28px 24px;
}
.trust__row {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; justify-content: space-around; align-items: center; gap: 32px; flex-wrap: wrap;
}
.trust__row li {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-sans); color: var(--ink);
}
.trust__icon {
  width: 28px; height: 28px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--gold); color: var(--onyx);
  font-weight: 700; font-size: 13px;
  flex-shrink: 0;
}
.trust__row strong {
  display: block; font-size: 12px; letter-spacing: .25em; font-weight: 600; color: var(--onyx);
}
.trust__row small {
  display: block; font-size: 11px; color: var(--muted); letter-spacing: .04em;
}

/* =========================================================================
   PILLARS (3-up dark band)
   ========================================================================= */
.pillars {
  background: var(--onyx);
  color: var(--pearl);
  padding: 80px 24px;
  border-top: 1px solid var(--line-dark);
}
.pillars__inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px;
}
.pillar { text-align: center; padding: 0 16px; }
.pillar__icon {
  display: inline-block;
  color: var(--gold);
  font-size: 24px;
  margin-bottom: 18px;
}
.pillar h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: .35em;
  margin-bottom: 16px;
  color: var(--pearl);
}
.pillar p {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(248,246,241,.7);
  font-weight: 400;
}

/* =========================================================================
   WHY EXISTENCE — Comparison
   ========================================================================= */
.why { background: var(--pearl-soft); padding-bottom: 100px; }
.compare {
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; align-items: stretch;
  border: 1px solid var(--line); background: var(--pearl);
}
.compare__col { padding: 48px 44px; }
.compare__col--us {
  background: linear-gradient(180deg, #fff 0%, var(--pearl-warm) 100%);
  border-right: 1px solid var(--line);
  position: relative;
}
.compare__col--us::before {
  content: "★ EXISTENCE"; position: absolute; top: 0; left: 0;
  background: var(--gold); color: var(--onyx);
  font-size: 10px; letter-spacing: .35em; font-weight: 600;
  padding: 6px 14px;
}
.compare__col--them { background: #f4f1ea; opacity: .85; }
.compare__title {
  font-family: var(--font-display); font-weight: 600;
  font-size: 24px; letter-spacing: .15em;
  margin: 18px 0 28px; color: var(--onyx);
}
.compare__col--them .compare__title { color: var(--muted); }
.compare__col ul { display: flex; flex-direction: column; gap: 14px; }
.compare__col li {
  display: flex; align-items: flex-start; gap: 14px;
  font-size: 15px; color: var(--ink); font-weight: 400;
  line-height: 1.5;
}
.compare__col li span {
  flex-shrink: 0;
  width: 22px; height: 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.compare__col--us li span { background: var(--gold); color: var(--onyx); }
.compare__col--them li {
  text-decoration: line-through; text-decoration-color: rgba(192,57,43,.35);
  color: var(--muted);
}
.compare__col--them li span {
  background: rgba(192,57,43,.15); color: var(--error);
}
.compare__divider {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  letter-spacing: .15em; color: var(--gold);
  background: var(--onyx);
  width: 56px;
}
.compare__divider span { writing-mode: vertical-rl; transform: rotate(180deg); }

/* =========================================================================
   COLLECTION (cards)
   ========================================================================= */
.collection {
  background: var(--pearl);
  padding-bottom: 120px;
}
.cards {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 24px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 56px 40px;
}
.card {
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  display: flex; flex-direction: column;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
  overflow: hidden;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(10,10,10,.12);
  border-color: rgba(201,162,74,.35);
}
.card--flag {
  border: 1px solid var(--gold);
  background: linear-gradient(180deg, #fff 0%, var(--pearl-warm) 100%);
  box-shadow: 0 8px 28px rgba(201,162,74,.12);
}
.card__badge {
  position: absolute; top: 16px; right: 16px; z-index: 2;
  background: var(--onyx); color: var(--gold);
  font-size: 10px; letter-spacing: .3em; font-weight: 600;
  padding: 7px 14px;
}
.card__badge--soft {
  background: rgba(201,162,74,.95); color: var(--onyx);
}
.card__stock {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  font-size: 10px; letter-spacing: .15em; font-weight: 500;
  color: var(--error);
  background: rgba(255,255,255,.95);
  padding: 7px 12px;
  border: 1px solid rgba(192,57,43,.2);
}
.card__media {
  background:
    radial-gradient(ellipse at 50% 100%, rgba(201,162,74,.22), transparent 60%),
    var(--pearl-soft);
  padding: 44px 32px 24px;
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 4/3;
}
.card__media img {
  max-height: 320px;
  width: auto;
  object-fit: contain;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.18));
  transition: transform .6s var(--ease);
}
.card:hover .card__media img { transform: scale(1.04); }

.card__body {
  padding: 36px 32px 36px;
  display: flex; flex-direction: column; gap: 18px;
  flex-grow: 1;
}
.card__eyebrow {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--gold-deep);
  font-size: 14px;
}
.card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(24px, 2.4vw, 30px);
  letter-spacing: .15em;
  color: var(--onyx);
  line-height: 1.15;
}
.card__desc {
  font-size: 15px; line-height: 1.65;
  color: var(--ink); font-weight: 300;
}
.card__notes {
  display: flex; flex-direction: column; gap: 8px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
}
.card__notes li {
  display: grid; grid-template-columns: 60px 1fr; gap: 16px;
  font-size: 13px; line-height: 1.5; color: var(--ink);
}
.card__notes li span {
  font-size: 10px; letter-spacing: .3em; font-weight: 500;
  color: var(--muted); padding-top: 2px;
}
.card__meta {
  font-size: 11px; letter-spacing: .3em; text-transform: uppercase;
  color: var(--muted); font-weight: 400;
}
.card__price {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 0;
}
.card__price-now {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 26px;
  letter-spacing: .04em;
  color: var(--onyx);
}
.card__price-per {
  font-size: 11px;
  font-weight: 500;
  color: var(--gold-deep);
  letter-spacing: .15em;
  text-transform: uppercase;
}
.card__price-anchor {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.4;
}

/* =========================================================================
   LIVE TICKER (Social Proof)
   ========================================================================= */
.ticker {
  max-width: 720px; margin: 0 auto var(--gap-xl);
  background: rgba(42,140,90,.06);
  border: 1px solid rgba(42,140,90,.18);
  padding: 14px 24px;
  display: flex; align-items: center; gap: 14px; justify-content: center;
  font-size: 13px; color: var(--ink);
}
.ticker__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 0 rgba(42,140,90,.55);
  animation: pulse-green 1.6s infinite;
}
@keyframes pulse-green {
  0%   { box-shadow: 0 0 0 0 rgba(42,140,90,.55); }
  70%  { box-shadow: 0 0 0 10px rgba(42,140,90,0); }
  100% { box-shadow: 0 0 0 0 rgba(42,140,90,0); }
}

/* =========================================================================
   QUIZ CTA
   ========================================================================= */
.quiz {
  background: linear-gradient(180deg, var(--pearl) 0%, var(--pearl-soft) 100%);
  padding: 80px 24px 100px;
  text-align: center;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.quiz__inner { max-width: 760px; margin: 0 auto; }
.quiz__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.18;
  letter-spacing: .04em;
  color: var(--onyx);
  margin: 16px 0 24px;
}
.quiz__sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 19px;
  color: var(--muted);
  margin-bottom: 36px;
  line-height: 1.5;
}
.quiz__micro {
  margin-top: 18px;
  font-size: 12px; letter-spacing: .12em;
  color: var(--muted); text-transform: uppercase;
}

/* =========================================================================
   BUNDLE
   ========================================================================= */
.bundle {
  background: var(--onyx);
  color: var(--pearl);
  padding: 100px 24px;
  text-align: center;
  position: relative; overflow: hidden;
}
.bundle::before, .bundle::after {
  content: ""; position: absolute; width: 460px; height: 460px; border-radius: 50%;
  background: radial-gradient(circle, var(--gold-glow) 0%, transparent 60%);
  pointer-events: none;
}
.bundle::before { top: -160px; left: -120px; }
.bundle::after { bottom: -180px; right: -120px; }
.bundle__inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.bundle__eyebrow {
  font-size: 11px; letter-spacing: .55em; text-transform: uppercase;
  color: var(--gold); font-weight: 500; margin-bottom: 24px;
}
.bundle__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 6vw, 80px);
  letter-spacing: .03em;
  background: linear-gradient(180deg, #f5e7c1 0%, var(--gold) 55%, #8a6620 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 24px;
}
.bundle__desc {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.45;
  color: rgba(248,246,241,.85);
  margin-bottom: 28px;
}
.bundle__hero-line {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  letter-spacing: .35em;
  color: var(--onyx);
  background: var(--gold);
  padding: 10px 24px;
  margin-bottom: 28px;
  text-transform: uppercase;
}
.bundle__price { display: flex; flex-direction: column; align-items: center; gap: 6px; margin-bottom: 16px; }
.bundle__price-was {
  font-size: 18px; color: var(--muted); text-decoration: line-through;
  letter-spacing: .12em;
}
.bundle__price-now {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(40px, 5vw, 56px);
  color: var(--gold-light);
  letter-spacing: .02em;
}
.bundle__price-save {
  display: inline-block;
  font-size: 13px; font-weight: 600; letter-spacing: .35em;
  background: var(--error); color: var(--pearl);
  padding: 6px 16px;
  margin-top: 8px;
}
.bundle__scarcity {
  font-size: 13px; color: var(--gold-light);
  letter-spacing: .12em;
  background: rgba(201,162,74,.08);
  border: 1px dashed var(--line-dark);
  padding: 10px 20px;
  display: inline-block;
  margin-bottom: 28px;
}
.bundle__micro {
  margin-top: 22px;
  font-size: 12px; letter-spacing: .15em;
  color: rgba(248,246,241,.55);
}

/* =========================================================================
   MAISON / STORY
   ========================================================================= */
.maison {
  background: var(--onyx-2);
  color: var(--pearl);
  padding: 120px 24px;
}
.maison__grid {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 3fr 2fr; gap: 80px;
  align-items: center;
}
.maison__copy p {
  font-size: 16px;
  line-height: 1.85;
  margin-bottom: 18px;
  color: rgba(248,246,241,.82);
}
.maison__copy p:nth-of-type(1) {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  color: var(--gold);
  margin: 16px 0 28px;
}
.maison__sign {
  font-family: var(--font-serif) !important;
  font-style: italic;
  font-size: 15px !important;
  color: var(--gold) !important;
  margin-top: 24px !important;
}
.maison__visual { display: flex; align-items: center; justify-content: center; }
.maison__monogram {
  width: 360px; height: 360px;
  border: 1px solid var(--gold);
  position: relative;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle, rgba(201,162,74,.08) 0%, transparent 70%);
}
.maison__monogram::before, .maison__monogram::after {
  content: ""; position: absolute; width: 24px; height: 24px;
  border: 1px solid var(--gold);
}
.maison__monogram::before { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.maison__monogram::after  { bottom: -1px; right: -1px; border-left: none; border-top: none; }
.maison__monogram span {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 220px;
  background: linear-gradient(180deg, #f5e7c1 0%, var(--gold) 55%, #8a6620 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}

/* =========================================================================
   FOUNDER NOTE
   ========================================================================= */
.founder {
  background: var(--pearl);
  padding: 100px 24px;
  text-align: center;
  border-bottom: 1px solid var(--line);
}
.founder__inner { max-width: 820px; margin: 0 auto; }
.founder__quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 1.55;
  color: var(--onyx);
  margin: 32px 0;
  padding: 0 12px;
  position: relative;
}
.founder__quote::before, .founder__quote::after {
  content: '"';
  font-family: var(--font-display);
  font-size: 80px;
  color: var(--gold);
  line-height: 0;
  vertical-align: -0.4em;
}
.founder__quote::before { margin-right: 8px; }
.founder__quote::after { margin-left: 8px; }
.founder__sign {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: .35em;
  color: var(--gold-deep);
  font-weight: 500;
  margin-bottom: 32px;
}

/* =========================================================================
   RITUAL / 4 STEPS
   ========================================================================= */
.ritual { background: var(--pearl); padding-bottom: 120px; }
.steps {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 24px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.step {
  padding: 56px 36px;
  border-right: 1px solid var(--line);
}
.step:last-child { border-right: none; }
.step__num {
  display: block;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 56px;
  color: var(--gold);
  margin-bottom: 24px;
  line-height: 1;
}
.step h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--onyx);
  margin-bottom: 16px;
}
.step p {
  font-size: 14px; line-height: 1.65; color: var(--ink); font-weight: 300;
}

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.testimonials {
  background: var(--pearl-soft);
  padding-bottom: 100px;
}
.quotes {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 24px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
.quote {
  background: #fff;
  border: 1px solid var(--line);
  padding: 36px 30px 28px;
  position: relative;
  display: flex; flex-direction: column; gap: 14px;
}
.quote__verified {
  display: inline-flex; align-self: flex-start;
  font-size: 10px; letter-spacing: .15em;
  color: var(--success); font-weight: 600;
  text-transform: uppercase;
  background: rgba(42,140,90,.08);
  padding: 4px 10px;
}
.quote__stars {
  color: var(--gold); letter-spacing: .15em; font-size: 14px;
}
.quote blockquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
  font-weight: 400;
}
.quote figcaption {
  font-size: 11px; letter-spacing: .25em; text-transform: uppercase;
  color: var(--muted); font-weight: 400;
  border-top: 1px solid var(--line);
  padding-top: 14px;
  margin-top: 8px;
}
.quote figcaption strong { color: var(--onyx); font-weight: 600; }

/* =========================================================================
   GUARANTEE
   ========================================================================= */
.guarantee {
  background: var(--onyx);
  color: var(--pearl);
  padding: 100px 24px;
  position: relative; overflow: hidden;
}
.guarantee::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(201,162,74,.12), transparent 60%);
  pointer-events: none;
}
.guarantee__inner {
  position: relative; z-index: 1;
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: auto 1fr; gap: 64px; align-items: center;
}
.guarantee__seal {
  flex-shrink: 0;
  width: 240px; height: 240px;
  border: 2px solid var(--gold);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  background: radial-gradient(circle, rgba(201,162,74,.1) 0%, transparent 70%);
}
.guarantee__seal::before {
  content: ""; position: absolute; inset: 12px;
  border: 1px solid var(--gold);
  border-radius: 50%;
}
.guarantee__seal-inner {
  text-align: center; color: var(--gold);
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.guarantee__num {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 80px;
  line-height: 1;
}
.guarantee__label {
  font-size: 11px; letter-spacing: .35em; font-weight: 600;
}
.guarantee__copy h2 {
  margin-bottom: 24px;
}
.guarantee__copy p {
  font-size: 16px; line-height: 1.7;
  color: rgba(248,246,241,.82);
  margin-bottom: 24px;
}
.guarantee__copy strong { color: var(--gold); font-weight: 600; }
.guarantee__list {
  display: flex; flex-direction: column; gap: 10px;
  margin-bottom: 32px;
}
.guarantee__list li {
  font-size: 15px;
  color: rgba(248,246,241,.92);
  letter-spacing: .03em;
}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq { background: var(--pearl); padding-bottom: 120px; }
.faq__list {
  max-width: 880px; margin: 0 auto;
  padding: 0 24px;
}
.faq details {
  border-bottom: 1px solid var(--line);
  padding: 24px 8px;
}
.faq details:first-child { border-top: 1px solid var(--line); }
.faq summary {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: .08em;
  color: var(--onyx);
  cursor: pointer;
  list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--font-display);
  font-size: 22px; font-weight: 400;
  color: var(--gold);
  transition: transform .3s var(--ease);
}
.faq details[open] summary::after { content: "−"; transform: rotate(180deg); }
.faq details p {
  margin-top: 14px;
  font-size: 15px; line-height: 1.7;
  color: var(--ink);
  max-width: 720px;
  font-weight: 300;
}

/* =========================================================================
   CONTACT — Final CTA
   ========================================================================= */
.contact {
  background: var(--onyx);
  color: var(--pearl);
  padding: 100px 24px;
  text-align: center;
}
.contact__inner { max-width: 720px; margin: 0 auto; }
.contact__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 60px);
  line-height: 1.15;
  letter-spacing: .04em;
  color: var(--pearl);
  margin: 18px 0 20px;
}
.contact__sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: rgba(248,246,241,.7);
  margin-bottom: 36px;
}
.contact__btns { display: flex; justify-content: center; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.contact__phone {
  font-size: 14px; letter-spacing: .15em;
  color: rgba(248,246,241,.65);
  margin-bottom: 24px;
}
.contact__phone strong { color: var(--gold); letter-spacing: .12em; font-weight: 600; }
.contact__links {
  display: flex; gap: 32px; justify-content: center; align-items: center; flex-wrap: wrap;
  font-size: 11px; letter-spacing: .35em; text-transform: uppercase; font-weight: 500;
  color: var(--gold); padding-top: 28px;
  border-top: 1px solid rgba(201,162,74,.25);
}

/* =========================================================================
   FOOTER
   ========================================================================= */
.footer {
  background: var(--onyx-3);
  color: var(--pearl);
  padding: 80px 24px 0;
}
.footer__inner {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: 2fr 3fr; gap: 80px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(201,162,74,.15);
}
.footer__brand p { color: rgba(248,246,241,.65); line-height: 1.8; font-size: 14px; }
.footer__wordmark {
  font-family: var(--font-display); font-weight: 600;
  font-size: 22px; letter-spacing: .35em;
  color: var(--pearl) !important;
  margin-bottom: 12px;
}
.footer__tag { margin-bottom: 16px; }
.footer__contact { font-size: 13px !important; line-height: 1.7 !important; }
.footer__cols {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px;
}
.footer__cols h4 {
  font-family: var(--font-display); font-weight: 600;
  font-size: 12px; letter-spacing: .35em;
  text-transform: uppercase; color: var(--gold);
  margin-bottom: 18px;
}
.footer__cols ul { display: flex; flex-direction: column; gap: 10px; }
.footer__cols a {
  font-size: 14px; color: rgba(248,246,241,.72);
}
.footer__cols a:hover { color: var(--gold); }
.footer__bar {
  max-width: var(--maxw); margin: 0 auto;
  padding: 28px 0;
  display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap;
  font-size: 11px; letter-spacing: .15em;
  color: rgba(248,246,241,.4); text-transform: uppercase;
}

/* =========================================================================
   STICKY MOBILE CTA BAR
   ========================================================================= */
.mcta {
  display: none;
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
  background: var(--onyx);
  border-top: 1px solid var(--line-dark);
  box-shadow: 0 -8px 24px rgba(0,0,0,.25);
  padding: 8px;
  gap: 8px;
}
.mcta__btn {
  flex: 1;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 12px;
  font-size: 13px; letter-spacing: .15em;
  text-transform: uppercase; font-weight: 600;
  text-align: center;
}
.mcta__btn--wa {
  background: var(--gold); color: var(--onyx);
}
.mcta__btn--shop {
  background: transparent; color: var(--gold);
  border: 1px solid var(--gold);
}
.mcta__icon { font-size: 16px; }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 960px) {
  .nav__inner { grid-template-columns: 1fr auto; padding: 14px 20px; }
  .nav__links { display: none; }
  .nav__cta { padding: 9px 16px; font-size: 10px; letter-spacing: .2em; }

  .urgency { font-size: 10px; padding: 8px 12px; letter-spacing: .08em; }
  .urgency__inner { gap: 8px; }

  .trust__row { flex-direction: column; gap: 16px; align-items: stretch; max-width: 360px; }
  .trust__row li { justify-content: flex-start; }

  .pillars__inner { grid-template-columns: 1fr; gap: 48px; }

  .compare { grid-template-columns: 1fr; }
  .compare__col--us { border-right: none; border-bottom: 1px solid var(--line); }
  .compare__divider {
    width: 100%; height: 44px;
  }
  .compare__divider span { writing-mode: horizontal-tb; transform: none; }

  .cards { grid-template-columns: 1fr; gap: 32px; }

  .maison__grid { grid-template-columns: 1fr; gap: 56px; text-align: center; }
  .maison__copy p { text-align: left; }
  .maison__monogram { width: 280px; height: 280px; }
  .maison__monogram span { font-size: 180px; }

  .steps { grid-template-columns: 1fr 1fr; }
  .step { border-right: none; }
  .step:nth-child(odd) { border-right: 1px solid var(--line); }
  .step:nth-child(1), .step:nth-child(2) { border-bottom: 1px solid var(--line); }

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

  .guarantee__inner { grid-template-columns: 1fr; gap: 36px; text-align: center; }
  .guarantee__seal { margin: 0 auto; width: 200px; height: 200px; }
  .guarantee__num { font-size: 64px; }
  .guarantee__list { text-align: left; max-width: 480px; margin: 0 auto 32px; }

  .footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .footer__cols { grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .footer__bar { flex-direction: column; align-items: flex-start; }

  .mcta { display: flex; }
  body { padding-bottom: 70px; }
}

@media (max-width: 600px) {
  .section-head { padding: 64px 20px 28px; }
  .hero { padding: 96px 20px 80px; }
  .hero__title { letter-spacing: .04em; }
  .hero__ctas { flex-direction: column; gap: 12px; align-items: stretch; }
  .hero__ctas .btn { width: 100%; text-align: center; }
  .hero__proof { font-size: 11px; padding: 8px 14px; }
  .hero__trust { font-size: 10px; }

  .pillars { padding: 56px 20px; }
  .pillars__inner { gap: 36px; }

  .why, .collection, .quiz, .ritual, .testimonials, .faq { padding-left: 16px; padding-right: 16px; }
  .compare__col { padding: 32px 24px; }
  .compare__col--us::before { font-size: 9px; padding: 5px 10px; }

  .cards { padding: 0 16px; gap: 28px; }
  .card__body { padding: 28px 22px; }
  .card__notes li { grid-template-columns: 50px 1fr; gap: 10px; font-size: 12px; }

  .ticker { font-size: 11px; padding: 12px 16px; max-width: 92%; }

  .quiz { padding: 60px 20px 80px; }
  .quiz__sub { font-size: 16px; }

  .bundle { padding: 64px 20px; }
  .bundle__hero-line { font-size: 13px; padding: 8px 14px; letter-spacing: .25em; }
  .bundle__price-now { font-size: 38px; }
  .bundle__price-was { font-size: 14px; }
  .bundle__desc { font-size: 17px; }

  .maison { padding: 80px 20px; }
  .maison__monogram { width: 220px; height: 220px; }
  .maison__monogram span { font-size: 140px; }

  .founder { padding: 64px 20px; }
  .founder__quote { font-size: 18px; }
  .founder__quote::before, .founder__quote::after { font-size: 56px; }

  .steps { grid-template-columns: 1fr; }
  .step { padding: 40px 24px; border-right: none !important; border-bottom: 1px solid var(--line); }
  .step:last-child { border-bottom: none; }

  .quotes { padding: 0 16px; }
  .quote { padding: 28px 22px 22px; }

  .guarantee { padding: 64px 20px; }
  .guarantee__seal { width: 160px; height: 160px; }
  .guarantee__num { font-size: 50px; }

  .faq__list { padding: 0 12px; }
  .faq summary { font-size: 15px; gap: 16px; }

  .contact { padding: 72px 20px; }
  .contact__btns { flex-direction: column; }
  .contact__btns .btn { width: 100%; }
  .contact__links { gap: 18px; font-size: 10px; }

  .footer__cols { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer__bar { font-size: 9px; }
}

/* =========================================================================
   ★ LUXURY ANIMATIONS LAYER — added v3
   ========================================================================= */

/* No-cursor body during loading */
body.is-loading { overflow: hidden; }

/* ── LOADER ─────────────────────────────────────────────── */
.loader {
  position: fixed; inset: 0; z-index: 200;
  background: var(--onyx);
  display: flex; align-items: center; justify-content: center;
  transition: opacity 1.1s var(--ease) .2s, visibility 1.1s var(--ease) .2s;
}
body.is-loaded .loader { opacity: 0; visibility: hidden; pointer-events: none; }
.loader__inner {
  position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  text-align: center;
}
.loader__monogram {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 96px;
  line-height: 1;
  letter-spacing: 0;
  background: linear-gradient(180deg, #f5e7c1 0%, var(--gold) 55%, #8a6620 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  opacity: 0;
  transform: translateY(8px);
  animation: loaderMono 1.6s var(--ease) .15s forwards;
}
.loader__line {
  display: block;
  width: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
  animation: loaderLine 1.6s var(--ease) .9s forwards;
}
.loader__word {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .55em;
  color: var(--gold);
  opacity: 0;
  animation: loaderWord 1.0s var(--ease) 1.4s forwards;
}
@keyframes loaderMono {
  0%   { opacity: 0; transform: translateY(8px); letter-spacing: .25em; filter: blur(4px); }
  100% { opacity: 1; transform: translateY(0); letter-spacing: 0; filter: blur(0); }
}
@keyframes loaderLine {
  0%   { width: 0; }
  100% { width: 220px; }
}
@keyframes loaderWord {
  0%   { opacity: 0; transform: translateY(4px); }
  100% { opacity: 1; transform: translateY(0); }
}

/* ── HERO TITLE LETTER-BY-LETTER ─────────────────────────── */
.hero__title {
  display: inline-block;
  background: none !important;  /* override base styles' gradient */
  -webkit-text-fill-color: initial;
  color: var(--gold);
}
.hero__title .letter {
  display: inline-block;
  opacity: 0;
  transform: translateY(40px) rotateX(40deg);
  transform-origin: 50% 100%;
  animation: heroLetter 1.4s cubic-bezier(.16,1,.3,1) forwards;
  animation-delay: calc(.2s + var(--i) * 80ms);

  /* Gold gradient + shimmer applied per-letter so the clip works */
  background: linear-gradient(
    100deg,
    #f5e7c1 0%,
    var(--gold) 35%,
    #fff7e0 50%,
    var(--gold) 65%,
    #8a6620 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
@keyframes heroLetter {
  0%   { opacity: 0; transform: translateY(40px) rotateX(40deg); filter: blur(6px); background-position: 0% 50%; }
  60%  { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) rotateX(0); filter: blur(0); background-position: 200% 50%; }
}
/* Continuous shimmer once revealed */
body.is-loaded .hero__title .letter {
  animation:
    heroLetter 1.4s cubic-bezier(.16,1,.3,1) calc(.2s + var(--i) * 80ms) forwards,
    heroShimmer 12s linear calc(2.5s + var(--i) * 80ms) infinite;
}
@keyframes heroShimmer {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* ── HERO BACKGROUND KEN BURNS ───────────────────────────── */
.hero__bg {
  animation: kenBurns 28s ease-in-out infinite alternate;
  transform-origin: 50% 50%;
}
@keyframes kenBurns {
  0%   { transform: scale(1) translate(0, 0); }
  100% { transform: scale(1.1) translate(-2%, -1%); }
}

/* Hero vignette overlay (depth) */
.hero__vignette {
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 50%, transparent 35%, rgba(0,0,0,.35) 80%, rgba(0,0,0,.55) 100%);
}

/* ── REFINED URGENCY BAR ────────────────────────────────── */
.urgency {
  background: linear-gradient(90deg, var(--onyx-3) 0%, #1a1208 50%, var(--onyx-3) 100%);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  font-weight: 400;
  padding: 9px 12px;
  color: rgba(245,231,193,.78);
}
.urgency__pulse {
  width: 5px; height: 5px;
}
.urgency__countdown {
  background: transparent;
  border: 1px solid rgba(201,162,74,.35);
  padding: 3px 9px;
  font-size: 10.5px;
  letter-spacing: .15em;
  color: var(--gold);
}

/* ── FILM GRAIN ─────────────────────────────────────────── */
.grain {
  position: fixed; inset: 0; z-index: 100;
  pointer-events: none;
  opacity: .055;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
  animation: grainShift .8s steps(8) infinite;
}
@keyframes grainShift {
  0%   { transform: translate(0,0); }
  10%  { transform: translate(-2%,-3%); }
  20%  { transform: translate(-4%, 2%); }
  30%  { transform: translate( 4%,-1%); }
  40%  { transform: translate(-2%, 4%); }
  50%  { transform: translate(-4%, 2%); }
  60%  { transform: translate( 1%,-4%); }
  70%  { transform: translate( 3%, 1%); }
  80%  { transform: translate(-2%,-2%); }
  90%  { transform: translate( 2%, 4%); }
  100% { transform: translate(0,0); }
}

/* ── CUSTOM GOLD CURSOR (desktop) ────────────────────────── */
.cursor, .cursor--ring {
  position: fixed; top: 0; left: 0; z-index: 250;
  pointer-events: none;
  transform: translate3d(-50%, -50%, 0);
  border-radius: 50%;
  display: none;
}
.cursor {
  width: 6px; height: 6px;
  background: var(--gold);
  transition: width .25s var(--ease), height .25s var(--ease), opacity .25s var(--ease);
}
.cursor--ring {
  width: 36px; height: 36px;
  border: 1px solid rgba(201,162,74,.55);
  background: transparent;
  transition: width .35s var(--ease), height .35s var(--ease), border-color .35s var(--ease), transform .15s linear;
}
@media (hover: hover) and (pointer: fine) {
  .cursor, .cursor--ring { display: block; }
  body, a, button, .btn { cursor: none; }
  .cursor.is-active { width: 10px; height: 10px; }
  .cursor--ring.is-active { width: 56px; height: 56px; border-color: var(--gold); }
}

/* ── SCROLL REVEAL ──────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity .9s cubic-bezier(.16,1,.3,1),
    transform 1.05s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
.reveal.is-revealed {
  opacity: 1;
  transform: translateY(0);
}
.reveal[data-reveal="left"]  { transform: translateX(-32px); }
.reveal[data-reveal="right"] { transform: translateX(32px); }
.reveal[data-reveal="left"].is-revealed,
.reveal[data-reveal="right"].is-revealed { transform: translateX(0); }
.reveal[data-reveal="zoom"]  { transform: scale(.96); }
.reveal[data-reveal="zoom"].is-revealed { transform: scale(1); }

/* Sequenced reveals for groups (cards, pillars, steps, quotes) */
.cards .card,
.pillars__inner .pillar,
.steps .step,
.quotes .quote,
.trust__row li {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity .8s cubic-bezier(.16,1,.3,1),
    transform 1s cubic-bezier(.16,1,.3,1);
}
.cards.is-revealed .card,
.pillars__inner.is-revealed .pillar,
.steps.is-revealed .step,
.quotes.is-revealed .quote,
.trust__row.is-revealed li {
  opacity: 1; transform: translateY(0);
}
.cards.is-revealed .card:nth-child(1),
.pillars__inner.is-revealed .pillar:nth-child(1),
.steps.is-revealed .step:nth-child(1),
.quotes.is-revealed .quote:nth-child(1),
.trust__row.is-revealed li:nth-child(1) { transition-delay: 0ms; }
.cards.is-revealed .card:nth-child(2),
.pillars__inner.is-revealed .pillar:nth-child(2),
.steps.is-revealed .step:nth-child(2),
.quotes.is-revealed .quote:nth-child(2),
.trust__row.is-revealed li:nth-child(2) { transition-delay: 120ms; }
.cards.is-revealed .card:nth-child(3),
.pillars__inner.is-revealed .pillar:nth-child(3),
.steps.is-revealed .step:nth-child(3),
.quotes.is-revealed .quote:nth-child(3),
.trust__row.is-revealed li:nth-child(3) { transition-delay: 240ms; }
.cards.is-revealed .card:nth-child(4),
.steps.is-revealed .step:nth-child(4),
.quotes.is-revealed .quote:nth-child(4),
.trust__row.is-revealed li:nth-child(4) { transition-delay: 360ms; }
.quotes.is-revealed .quote:nth-child(5),
.trust__row.is-revealed li:nth-child(5) { transition-delay: 480ms; }
.quotes.is-revealed .quote:nth-child(6) { transition-delay: 600ms; }

/* Section heads auto-reveal */
.section-head { opacity: 0; transform: translateY(28px); transition: opacity 1s var(--ease-out), transform 1.1s var(--ease-out); }
.section-head.is-revealed { opacity: 1; transform: translateY(0); }

/* Smoother button transitions */
.btn { transition: transform .45s var(--ease-out), background .45s var(--ease-out), color .45s var(--ease-out), border-color .45s var(--ease-out), box-shadow .45s var(--ease-out), letter-spacing .45s var(--ease-out); }
.btn:hover { transform: translateY(-1px); letter-spacing: .35em; }
.btn--gold:hover {
  box-shadow: 0 14px 40px rgba(201,162,74,.45), 0 0 0 1px rgba(201,162,74,.6);
}

/* Card hover refinement */
.card { transition: transform .8s cubic-bezier(.16,1,.3,1), box-shadow .8s cubic-bezier(.16,1,.3,1), border-color .6s var(--ease-out); }
.card:hover { transform: translateY(-8px); }
.card__media img { transition: transform 1.4s cubic-bezier(.16,1,.3,1); }
.card:hover .card__media img { transform: scale(1.06); }

/* Bundle title shimmer */
.bundle__title {
  background: linear-gradient(100deg, #f5e7c1 0%, var(--gold) 35%, #fff7e0 50%, var(--gold) 65%, #8a6620 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: heroShimmer 14s linear infinite;
}

/* Maison monogram — slow rotate gold ring */
.maison__monogram {
  position: relative;
  overflow: visible;
}
.maison__monogram::after {
  content: "";
  position: absolute;
  inset: -16px;
  border-top: 1px solid rgba(201,162,74,.4);
  border-bottom: 1px solid rgba(201,162,74,.05);
  border-left: 1px solid rgba(201,162,74,.2);
  border-right: 1px solid rgba(201,162,74,.2);
  border-radius: 50%;
  animation: ringRotate 32s linear infinite;
}
@keyframes ringRotate {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* FAQ smooth open */
.faq details { transition: background .4s var(--ease-out); }
.faq details[open] { background: linear-gradient(180deg, transparent 0%, rgba(201,162,74,.03) 100%); }
.faq summary::after { transition: transform .55s cubic-bezier(.16,1,.3,1); }

/* Selection style */
::selection { background: var(--gold); color: var(--onyx); }

/* Scrollbar styling (subtle, luxury) */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--pearl); }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--gold) 0%, var(--gold-deep) 100%); border-radius: 0; }
html { scrollbar-color: var(--gold) var(--pearl); scrollbar-width: thin; }

/* Reduced motion — accessibility */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
  .reveal, .cards .card, .pillars__inner .pillar, .steps .step, .quotes .quote, .trust__row li, .section-head {
    opacity: 1 !important; transform: none !important;
  }
  .grain { display: none; }
}

/* Touch device: hide custom cursor, restore default */
@media (hover: none), (pointer: coarse) {
  .cursor, .cursor--ring { display: none !important; }
  body { cursor: auto; }
}
