/* ============================================================================
   DUBAI JEWELLERY — CERCLE PRIVÉ
   A cinematic luxury membership experience.
   Design system: obsidian + rose (dubaijewellery.ch brand #c11d99), Cormorant Garamond + Inter.
   NOTE: the --gold* tokens below now hold the brand ROSE ramp (names kept to avoid
   churn across 100+ references and the .btn-gold/.gold-text class names in index.html).
   ============================================================================ */

:root{
  --obsidian:#050505;
  --ink:#0b0a08;
  --ink-2:#121009;
  --panel:#0e0d0a;
  --gold:#c11d99;     /* brand rose (rgb 193,29,153) — dubaijewellery.ch */
  --gold-lt:#e86fc4;  /* light rose */
  --gold-br:#f4addd;  /* bright/highlight rose (lightest) */
  --gold-dp:#7e1264;  /* deep rose (darkest) */
  --ivory:#f4efe6;
  --ivory-dim:#cfc7b6;
  --muted:#8f886f;
  --line:rgba(193,29,153,.16);
  --line-2:rgba(193,29,153,.30);

  --serif:"Cormorant Garamond","Iowan Old Style",Garamond,serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;

  --grad-gold:linear-gradient(135deg,var(--gold-br) 0%,var(--gold) 45%,var(--gold-dp) 100%);
  --grad-text:linear-gradient(120deg,var(--gold-br),var(--gold) 45%,var(--gold-dp));
  --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1280px;
  --rail-clear:210px; /* footprint of the fixed #actRail (dot + active label + right offset) */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto !important}

body{
  background:var(--obsidian);
  color:var(--ivory);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.locked{overflow:hidden;height:100vh}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{cursor:pointer}
::selection{background:rgba(193,29,153,.28);color:#fff}

/* ---- Typographic primitives ---- */
.display{font-family:var(--serif);font-weight:500;line-height:1.02;letter-spacing:.3px}
h1.display{font-size:clamp(2.9rem,7vw,6.4rem)}
h2.display{font-size:clamp(2.4rem,5.2vw,4.6rem)}
.kicker{
  font-size:.7rem;font-weight:500;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:.8rem;
}
.gold-text{
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.lede{color:var(--ivory-dim);font-size:clamp(1rem,1.35vw,1.2rem);max-width:54ch;line-height:1.75}
em{font-style:italic}

/* ============================================================ FILM GRAIN + VIGNETTE */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-3%,2%)}40%{transform:translate(2%,-3%)}60%{transform:translate(-2%,1%)}80%{transform:translate(3%,2%)}100%{transform:translate(0,0)}}
.vignette{position:fixed;inset:0;z-index:8000;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 35%,transparent 55%,rgba(0,0,0,.55) 100%)}
#particles{position:fixed;inset:0;z-index:1;pointer-events:none}
@media (prefers-reduced-motion:reduce){.grain{animation:none;display:none}}

/* ============================================================ CUSTOM CURSOR */
.cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:10002;pointer-events:none;border-radius:50%;
  transform:translate(-50%,-50%);will-change:transform}
.cursor{width:34px;height:34px;border:1px solid var(--line-2);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s}
.cursor-dot{display:none} /* native cursor handles the point; ring is a soft accent */
.cursor{opacity:.6}
.cursor.hover{width:58px;height:58px;background:rgba(193,29,153,.08);border-color:var(--gold);opacity:1}
@media (hover:none){.cursor,.cursor-dot{display:none}}

/* ============================================================ LAYOUT */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.4rem,5vw,3rem)}
section{position:relative;z-index:2}
.center{text-align:center}

/* ============================================================ BUTTONS */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.7rem;
  font-size:.74rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  padding:1.15rem 2.3rem;border-radius:2px;overflow:hidden;
  transition:color .4s var(--ease),transform .4s var(--ease);will-change:transform;
}
.btn span{position:relative;z-index:2}
.btn-gold{color:#fff;background:var(--grad-gold);box-shadow:0 14px 40px -16px rgba(193,29,153,.6)}
.btn-gold::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,var(--gold-lt),var(--gold-br));opacity:0;transition:opacity .4s}
.btn-gold:hover::after{opacity:1}
.btn-gold:hover{transform:translateY(-2px)}
.btn-ghost{color:var(--ivory);border:1px solid var(--line-2)}
.btn-ghost::after{content:"";position:absolute;inset:0;z-index:1;background:rgba(193,29,153,.08);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.btn-ghost:hover::after{transform:scaleX(1)}
.btn-ghost:hover{color:var(--gold-br)}

/* ============================================================ NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .5s,backdrop-filter .5s,border-color .5s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(5,5,5,.72);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:86px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand b{font-family:var(--serif);font-size:1.55rem;font-weight:600;letter-spacing:1px}
.brand small{font-size:.52rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-top:5px}
.brand-logo{height:clamp(52px,6vw,66px);width:auto;display:block;border-radius:6px}
.foot-logo{height:78px;width:auto;display:block;margin-bottom:1.1rem;border-radius:8px}
.nav-links{display:flex;align-items:center;gap:2.6rem}
.nav-links a{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ivory-dim);transition:color .3s}
.nav-links a:hover{color:var(--gold-br)}
.nav-signin{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory-dim);white-space:nowrap;transition:color .3s}
.nav-signin:hover{color:var(--gold-br)}
.nav-join{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;background:var(--grad-gold);padding:.85rem 1.5rem;border-radius:2px}
.nav-toggle{display:none}
@media (max-width:900px){
  .nav-links{display:none}
  .nav-inner{height:72px}
}

/* ============================================================ HERO */
.hero{position:relative;height:100vh;min-height:680px;overflow:hidden;display:flex;align-items:center;z-index:3}
.hero-media{position:absolute;inset:-8% -4%;z-index:0;will-change:transform}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:70% 50%}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(5,5,5,.92) 0%,rgba(5,5,5,.6) 38%,rgba(5,5,5,.1) 70%,rgba(5,5,5,.5) 100%),
    linear-gradient(0deg,rgba(5,5,5,.9) 0%,transparent 40%)}
.hero-inner{position:relative;z-index:3;max-width:720px}
.hero .kicker{margin-bottom:1.7rem}
.hero h1{margin-bottom:1.8rem;line-height:1.12}
.hero h1 .line{display:block;overflow:hidden;padding-bottom:.04em} /* descender room inside the slide-up clip box */
.hero h1 .line > span{display:block}
.hero .lede{margin-bottom:2.6rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem}
.hero-cta .btn{flex:1;justify-content:center;max-width:300px}
.hero-meta{position:absolute;left:0;right:0;bottom:2.2rem;z-index:3;opacity:0;animation:fadeInMeta .6s ease 3.5s forwards}
@keyframes fadeInMeta{to{opacity:1}}
.hero-meta .wrap{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}
.scroll-cue{display:flex;align-items:center;gap:.8rem;font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.scroll-cue .rail{width:1px;height:48px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.scroll-cue .rail::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold);animation:railrun 2.2s var(--ease) infinite}
@keyframes railrun{0%{transform:translateY(-100%)}100%{transform:translateY(260%)}}
.hero-hall{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);text-align:right}
.hero-hall b{color:var(--gold);font-weight:500}

/* ============================================================ SECTION HEADINGS */
.sec-head{max-width:760px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head .kicker{margin-bottom:1.6rem}
.sec-head h2{margin-bottom:1.2rem}

/* ============================================================ JOURNEY (pinned cinematic) */
.journey{position:relative;background:var(--obsidian)}
.journey-stage{position:relative;height:100vh;overflow:hidden;display:flex;align-items:center}
.journey-bg{position:absolute;inset:0;background:
  radial-gradient(60% 80% at 80% 50%,rgba(193,29,153,.07),transparent 60%),
  radial-gradient(50% 60% at 10% 30%,rgba(140,106,34,.06),transparent 60%)}
.chapter{position:absolute;inset:0;display:flex;align-items:center;opacity:0;will-change:transform,opacity}
.chapter .wrap{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;width:100%}
.chapter .num{font-family:var(--serif);font-weight:500;font-size:clamp(7rem,22vw,19rem);line-height:1;
  padding-bottom:.16em;overflow:visible; /* gradient (clip:text) box must reach below the glyph baseline, or the digit's bottom renders transparent */
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.chapter .c-body .step-label{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.chapter .c-body h3{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4vw,3.4rem);line-height:1.05;margin-bottom:1.1rem}
.chapter .c-body p{color:var(--ivory-dim);max-width:42ch;line-height:1.75}
.journey-progress{position:absolute;left:0;right:0;bottom:0;z-index:5}
.journey-progress .wrap{display:flex;gap:.5rem;padding-bottom:2.4rem}
.jp-tick{flex:1;height:2px;background:rgba(193,29,153,.14);position:relative;overflow:hidden}
.jp-tick i{position:absolute;inset:0;background:var(--grad-gold);transform:scaleX(0);transform-origin:left}
@media (max-width:820px){
  .chapter .wrap{grid-template-columns:1fr;gap:1rem;text-align:left}
  .chapter .num{font-size:30vw}
}

/* ============================================================ SCRATCH (VIP card) */
.scratch{padding-block:clamp(7rem,12vw,11rem);overflow:hidden;
  background:
    radial-gradient(70% 60% at 50% 40%,rgba(193,29,153,.08),transparent 60%),
    linear-gradient(180deg,#050505,#0a0805 50%,#050505)}
.scratch .wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.scratch-copy h2{margin-bottom:1.3rem}
.scratch-copy .lede{margin-bottom:2rem}
.scratch-points{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:2.4rem}
.scratch-points li{display:flex;gap:.9rem;font-size:.92rem;color:var(--ivory-dim)}
.scratch-points svg{width:18px;height:18px;color:var(--gold);flex:0 0 auto;margin-top:3px}
.card-stage{position:relative;perspective:1400px}
.card-tilt{position:relative;border-radius:18px;overflow:hidden;transform-style:preserve-3d;will-change:transform;
  box-shadow:0 50px 110px -30px rgba(0,0,0,.9),0 0 0 1px var(--line)}
.card-tilt img{width:100%;display:block}
.card-tilt .glare{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(220px 220px at var(--mx,50%) var(--my,50%),rgba(255,255,255,.16),transparent 60%);opacity:.7}
.card-scratch{position:absolute;border-radius:50%;cursor:grab}
.card-scratch:active{cursor:grabbing}
.card-scratch canvas{width:100%;height:100%;display:block;border-radius:50%}
.scratch-reveal{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.scratch-reveal .rv-label{font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-dp)}
.scratch-reveal .rv-num{font-family:var(--serif);font-weight:600;font-size:1.9rem;color:#5a0e48;line-height:1}
.scratch-hint{margin-top:1.4rem;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;transition:opacity .4s}

/* ============================================================ VALUE BUILD */
.value{padding-block:clamp(7rem,12vw,11rem);background:linear-gradient(180deg,#050505,#0c0a06,#050505)}
.value .sec-head{margin-bottom:3.5rem}
.value-stage{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.value-meter{position:relative;border:1px solid var(--line);border-radius:20px;padding:2.6rem;
  background:linear-gradient(160deg,rgba(193,29,153,.05),transparent),var(--panel)}
.value-meter .vm-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.4rem}
.value-meter .vm-now{font-family:var(--serif);font-size:clamp(3rem,7vw,4.6rem);line-height:1}
.value-meter .vm-now .chf{font-size:1.1rem;color:var(--muted);letter-spacing:.1em;margin-right:.4rem;vertical-align:super}
.value-meter .vm-goal{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.value-meter .vm-goal b{color:var(--gold);font-weight:500;display:block;font-size:1.05rem;margin-top:.3rem;letter-spacing:.02em}
.vm-bar{height:8px;border-radius:99px;background:rgba(193,29,153,.12);overflow:hidden;margin-bottom:1.5rem}
.vm-bar i{display:block;height:100%;width:0;background:var(--grad-gold);box-shadow:0 0 18px rgba(193,29,153,.6)}
.vm-months{display:grid;grid-template-columns:repeat(12,1fr);gap:6px}
.vm-month{aspect-ratio:1;border-radius:6px;border:1px solid var(--line);display:grid;place-items:center;
  font-size:.66rem;color:var(--muted);transition:background .4s,color .4s,border-color .4s,transform .4s}
.vm-month.on{background:var(--grad-gold);color:#fff;border-color:transparent;transform:translateY(-2px)}
.value-copy h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:1.1rem;line-height:1.15}
.value-copy p{color:var(--ivory-dim);margin-bottom:1.2rem;max-width:46ch}
.value-copy .vc-tag{display:inline-flex;align-items:center;gap:.6rem;font-size:.74rem;letter-spacing:.04em;color:var(--gold);
  border:1px solid var(--line-2);padding:.7rem 1.1rem;border-radius:99px;margin-top:.6rem}
.value-copy .vc-tag svg{width:16px;height:16px}
@media (max-width:880px){.value-stage{grid-template-columns:1fr;gap:2.5rem}}

/* ============================================================ SHOWCASE (museum) */
.showcase{padding-block:clamp(7rem,12vw,11rem);overflow:hidden}
.showcase .sec-head{margin-bottom:3rem}
.museum{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 60px 120px -40px rgba(0,0,0,.9)}
.museum-img{width:100%;will-change:transform}
.museum-img img{width:100%;object-fit:cover}
.museum-scrim{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 90% at 50% 40%,transparent 40%,rgba(0,0,0,.5));}
.museum-spots{position:absolute;inset:0}
.spot{position:absolute;display:flex;flex-direction:column;gap:.4rem}
.spot .dot{width:13px;height:13px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(193,29,153,.18);position:relative}
.spot .dot::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);animation:ping 2.6s var(--ease) infinite}
@keyframes ping{0%{transform:scale(1);opacity:.8}100%{transform:scale(3.4);opacity:0}}
.spot .lbl{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ivory);white-space:nowrap;
  background:rgba(5,5,5,.6);backdrop-filter:blur(6px);border:1px solid var(--line);padding:.4rem .7rem;border-radius:99px}
.spot .lbl b{color:var(--gold);font-weight:500}
.showcase-legend{display:flex;flex-wrap:wrap;gap:2.4rem;margin-top:2.4rem;justify-content:center}
.showcase-legend .lg{text-align:center}
.showcase-legend .lg b{display:block;font-family:var(--serif);font-size:1.5rem;color:var(--gold-br)}
.showcase-legend .lg span{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ============================================================ WINNER */
.winner{position:relative;overflow:hidden}
.winner-media{position:relative;height:clamp(560px,92vh,900px)}
.winner-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 40%;will-change:transform}
.winner-scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.7),transparent 30%,rgba(5,5,5,.4) 60%,rgba(5,5,5,.95))}
.winner-confetti{position:absolute;inset:0;pointer-events:none;z-index:3}
.winner-inner{position:absolute;left:0;right:0;bottom:0;z-index:4;padding-bottom:clamp(3rem,7vw,6rem)}
.winner-inner .kicker{margin-bottom:1.4rem}
.winner-inner h2{margin-bottom:1rem;max-width:18ch}
.winner-inner .lede{margin-bottom:3rem}
.winner-stats{display:grid;grid-template-columns:repeat(3,auto);gap:clamp(2rem,5vw,5rem)}
.winner-stats .st b{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,5vw,4rem);line-height:1;display:block}
.winner-stats .st span{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.6rem;display:block}
@media (max-width:720px){.winner-stats{grid-template-columns:1fr;gap:1.6rem}}

/* ============================================================ BENEFITS (glass) */
.benefits{padding-block:clamp(7rem,12vw,11rem)}
.benefits .sec-head{margin-bottom:3.5rem}
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.ben-card{position:relative;border-radius:18px;padding:2.4rem;overflow:hidden;
  background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.012));
  border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(14px);
  transition:transform .5s var(--ease),border-color .5s,box-shadow .5s}
.ben-card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:var(--grad-gold);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s}
.ben-card:hover{transform:translateY(-8px);box-shadow:0 40px 80px -40px rgba(0,0,0,.9)}
.ben-card:hover::before{opacity:.7}
.ben-card .b-ic{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;margin-bottom:1.5rem;
  background:linear-gradient(160deg,rgba(193,29,153,.18),rgba(193,29,153,.04));border:1px solid var(--line)}
.ben-card .b-ic svg{width:24px;height:24px;color:var(--gold-br)}
.ben-card h3{font-family:var(--serif);font-weight:500;font-size:1.55rem;margin-bottom:.6rem}
.ben-card p{color:var(--ivory-dim);font-size:.92rem}
.ben-card .b-no{position:absolute;top:1.6rem;right:1.8rem;font-family:var(--serif);font-size:1rem;color:var(--line-2)}
@media (max-width:920px){.ben-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.ben-grid{grid-template-columns:1fr}}

/* ============================================================ FAQ */
.faq{padding-block:clamp(7rem,12vw,11rem);background:linear-gradient(180deg,#050505,#0a0805,#050505)}
.faq h2{max-width:18ch;text-wrap:balance}
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.7rem 0;font-family:var(--serif);font-size:clamp(1.15rem,2vw,1.5rem);font-weight:500;color:var(--ivory);transition:color .3s}
.faq-q:hover{color:var(--gold-br)}
.faq-q .pm{position:relative;width:18px;height:18px;flex:0 0 auto}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--gold);transition:transform .4s var(--ease)}
.faq-q .pm::before{top:50%;left:0;width:100%;height:1px;transform:translateY(-50%)}
.faq-q .pm::after{left:50%;top:0;height:100%;width:1px;transform:translateX(-50%)}
.faq-item.open .pm::after{transform:translateX(-50%) scaleY(0)}
.faq-a{overflow:hidden;height:0}
.faq-a p{color:var(--ivory-dim);padding-bottom:1.7rem;max-width:60ch;line-height:1.8}
@media (max-width:820px){.faq-grid{grid-template-columns:1fr;gap:2rem}}

/* ============================================================ FINAL */
.final{position:relative;height:100vh;min-height:680px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.final-media{position:absolute;inset:-6%;z-index:0;will-change:transform}
.final-media img{width:100%;height:100%;object-fit:cover;object-position:50% 55%}
.final-scrim{position:absolute;inset:0;z-index:1;
  background:radial-gradient(70% 70% at 50% 60%,rgba(5,5,5,.35),rgba(5,5,5,.86) 70%),linear-gradient(0deg,rgba(5,5,5,.95),transparent 50%)}
.final-glow{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:60vw;height:60vw;z-index:1;pointer-events:none;
  background:radial-gradient(circle,rgba(193,29,153,.16),transparent 60%);filter:blur(20px)}
.final-inner{position:relative;z-index:3;max-width:820px;padding-inline:1.5rem}
.final-inner .kicker{margin-bottom:1.8rem;justify-content:center}
.final-inner h2{margin-bottom:1.6rem}
.final-inner .lede{margin:0 auto 2.8rem}
.final-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.final-cta .btn{flex:1;max-width:320px;justify-content:center}

/* ============================================================ FOOTER */
footer{border-top:1px solid var(--line);padding-block:3.5rem 2.5rem;background:var(--obsidian)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem}
.foot-brand b{font-family:var(--serif);font-size:1.6rem;font-weight:600}
.foot-brand small{display:block;font-size:.54rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-top:6px}
.foot-brand p{color:var(--muted);font-size:.86rem;max-width:34ch;margin-top:1.2rem}
.foot-col h6{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.foot-col a{display:block;color:var(--ivory-dim);font-size:.86rem;padding:.35rem 0;transition:color .3s}
.foot-col a:hover{color:var(--gold-br)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:3rem;padding-top:1.8rem;
  border-top:1px solid var(--line);font-size:.74rem;color:var(--muted)}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ============================================================ REVEAL UTILITIES */
.reveal{opacity:0;transform:translateY(34px)}
.reveal-line{display:block;overflow:hidden}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important}
  *{animation-duration:.001s !important}
}

/* ============================================================ RESPONSIVE */
@media (max-width:880px){
  .scratch .wrap{grid-template-columns:1fr;gap:3rem}
  .card-stage{max-width:460px;margin-inline:auto}
  .hero-media img{object-position:64% 50%}
}
@media (max-width:560px){
  .hero-meta .wrap{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .hero-hall{text-align:left}
}

/* ============================================================ OVERTURE (preloader + enter gate) */
#overture{position:fixed;inset:0;z-index:10000;background:#030303;overflow:hidden}
#overture.gone{pointer-events:none}
.ov-panel{position:absolute;left:0;width:100%;height:50.6vh;background:#030303;z-index:1;will-change:transform}
.ov-panel.top{top:0}
.ov-panel.bottom{bottom:0}
.ov-inner{position:absolute;inset:0;z-index:3;display:grid;place-items:center;text-align:center;padding:2rem}
.ov-mark{font-family:var(--serif);font-weight:600;font-size:1.45rem;letter-spacing:2px;color:var(--gold);opacity:0;margin-bottom:2.6rem}
.ov-mark small{display:block;font-family:var(--sans);font-size:.5rem;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.ov-line{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3.6vw,3rem);line-height:1.3;color:var(--ivory);max-width:18ch}
.ov-line .w{display:inline-block;opacity:0;transform:translateY(22px);filter:blur(8px);will-change:transform,opacity,filter}
.ov-line .w.gold{color:var(--gold)}
.ov-prog{margin:3rem auto 0;width:190px;height:1px;background:rgba(193,29,153,.18);position:relative;overflow:hidden}
.ov-prog i{position:absolute;inset:0;width:0;background:var(--grad-gold)}
.ov-pct{margin-top:1rem;font-size:.58rem;letter-spacing:.34em;color:var(--muted);font-variant-numeric:tabular-nums;opacity:.7}
.ov-enter{margin-top:2.4rem;height:54px;display:flex;justify-content:center;align-items:center}
.ov-enter button{opacity:0;transform:translateY(10px);pointer-events:none;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);
  border:1px solid var(--line-2);padding:1.05rem 2.6rem;border-radius:2px;transition:background .45s var(--ease),color .45s var(--ease)}
.ov-enter button.ready{pointer-events:auto}
.ov-enter button:hover{background:var(--grad-gold);color:#fff;border-color:transparent}

/* ============================================================ ACT RAIL (film chapters) */
.act-rail{position:fixed;right:1.7rem;top:50%;transform:translateY(-50%);z-index:160;display:flex;flex-direction:column;gap:1.05rem;opacity:0;transition:opacity .8s var(--ease)}
.act-rail.show{opacity:1}
.act-rail a{display:flex;align-items:center;justify-content:flex-end;gap:.85rem;color:var(--muted)}
.act-rail .rn{font-size:.56rem;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap;opacity:0;transform:translateX(8px);transition:opacity .35s,transform .35s,color .35s}
.act-rail .rd{width:7px;height:7px;border-radius:50%;border:1px solid var(--line-2);flex:0 0 auto;transition:all .35s var(--ease)}
.act-rail a:hover .rn{opacity:1;transform:none;color:var(--ivory-dim)}
.act-rail a.active .rn{opacity:1;transform:none;color:var(--gold)}
.act-rail a.active .rd{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 4px rgba(193,29,153,.14)}
@media (max-width:960px){.act-rail{display:none}}
/* Reserve clearance so content never sits under the fixed act-rail.
   Padded SYMMETRICALLY (padding-inline) so the composition stays balanced/centred
   — not shifted left — while its right edge still clears the rail. Applied at
   section level so backgrounds stay full-bleed. Tapers to 0 once the natural
   centred page margins already clear the rail, so there's no layout jump. */
@media (min-width:961px){
  .chapter,
  .scratch,
  .value,
  .benefits,
  .faq,
  .interstitial,
  .dj-countdown,
  .dj-selection,
  .dj-winners{
    padding-inline:max(0px, calc(var(--rail-clear) - max(0px, (100vw - var(--maxw)) / 2)));
  }
}

/* ============================================================ DUBAI · LIVE DATA SECTIONS (Gold Club :4000) */
.dj-mono{font-family:ui-monospace,"SF Mono",Menlo,monospace}

/* The Next Reveal — live countdown */
.dj-countdown{padding-block:clamp(7rem,12vw,11rem);background:radial-gradient(60% 60% at 50% 35%,rgba(193,29,153,.06),transparent 60%)}
.dj-countdown .wrap{text-align:center}
.dj-countdown h2{margin:1.2rem 0 2.8rem}
.dj-clock{display:inline-flex;gap:clamp(.7rem,1.8vw,1.5rem)}
.dj-clock .cu{min-width:clamp(78px,11vw,140px);padding:1.6rem 1rem;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(160deg,rgba(193,29,153,.05),transparent),var(--panel)}
.dj-clock .cu b{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,5vw,4rem);line-height:1.05;
  font-variant-numeric:tabular-nums;padding-bottom:.08em;
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.dj-clock .cu span{display:block;margin-top:.7rem;font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.dj-clock-date{margin-top:1.9rem;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
@media(max-width:560px){.dj-clock{flex-wrap:wrap;justify-content:center}}

/* The Selection — how the winner is chosen */
.dj-selection{padding-block:clamp(7rem,12vw,11rem)}
.dj-selection .sec-head{margin-bottom:3.5rem}
.dj-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.dj-steps article{position:relative;border:1px solid var(--line);border-radius:18px;padding:2.4rem 2rem;
  background:linear-gradient(165deg,rgba(255,255,255,.035),transparent)}
.dj-steps .ds-no{font-family:var(--serif);font-size:1.05rem;color:var(--gold);letter-spacing:.06em}
.dj-steps h3{font-family:var(--serif);font-weight:500;font-size:1.7rem;line-height:1.15;margin:.7rem 0 .8rem}
.dj-steps p{color:var(--ivory-dim);font-size:.92rem;line-height:1.7}
.dj-formula{margin-top:1.6rem;border:1px dashed var(--line-2);border-radius:12px;padding:1.2rem 1.4rem;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:.76rem;color:var(--gold-lt);text-align:center;
  word-break:break-word;line-height:1.8;overflow-x:auto}
@media(max-width:820px){.dj-steps{grid-template-columns:1fr}}

/* Past Winners — real, from the API */
.dj-winners{padding-block:clamp(7rem,12vw,11rem);background:linear-gradient(180deg,#050505,#0a0805,#050505)}
.dj-winners .sec-head{margin-bottom:3rem}
.dj-winner-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.dj-winner{display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:center;
  border:1px solid var(--line);border-radius:16px;padding:1.5rem 1.8rem;
  background:linear-gradient(165deg,rgba(255,255,255,.035),transparent);transition:border-color .4s}
.dj-winner:hover{border-color:var(--line-2)}
.dj-winner .medal{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:var(--grad-gold);color:#fff;font:600 .62rem/1.1 ui-monospace,monospace;text-align:center;letter-spacing:.5px}
.dj-winner .medal small{display:block;font-size:8px;opacity:.85;letter-spacing:1px}
.dj-winner .wn{font-family:var(--serif);font-weight:600;font-size:1.4rem;color:var(--ivory)}
.dj-winner .wm{font-size:.78rem;color:var(--muted);margin-top:3px}
.dj-winner .wh{font-family:ui-monospace,monospace;font-size:11px;color:var(--ivory-dim);opacity:.7;margin-top:6px;word-break:break-all}
.dj-winner .verify{display:inline-flex;align-items:center;gap:.55rem;white-space:nowrap;
  border:1px solid var(--line-2);border-radius:99px;padding:.7rem 1.1rem;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-br);transition:background .3s,border-color .3s}
.dj-winner .verify:hover{background:rgba(193,29,153,.08);border-color:var(--gold);text-decoration:none}
.dj-winner .verify .ok{width:7px;height:7px;border-radius:50%;background:#6fb78a}
.dj-winners .state{grid-column:1/-1;text-align:center;padding:46px;border:1px dashed var(--line-2);border-radius:16px;color:var(--muted);font-size:.92rem}
@media(max-width:760px){.dj-winner-list{grid-template-columns:1fr}.dj-winner{grid-template-columns:auto 1fr}.dj-winner .verify{grid-column:1/-1;justify-self:start;margin-top:.6rem}}

/* ============================================================ INTERSTITIAL STATEMENTS */
.interstitial{min-height:92vh;display:grid;place-items:center;text-align:center;position:relative;overflow:hidden}
.interstitial::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 50%,rgba(193,29,153,.06),transparent 60%)}
.interstitial .wrap{position:relative;z-index:2;max-width:960px}
.interstitial .st-kicker{margin-bottom:2rem;justify-content:center}
.interstitial h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,6vw,5.2rem);line-height:1.26;letter-spacing:.4px}
.interstitial .ln{display:block;overflow:hidden;padding-bottom:.04em} /* line-height + pad keep descenders (j, g, p, y) inside the clip box */
.interstitial .ln > span{display:block} /* initial hide is owned by GSAP (yPercent), not CSS, to avoid transform conflicts */
.interstitial .em{font-style:italic;color:transparent;background:var(--grad-text);-webkit-background-clip:text;background-clip:text}

/* ============================================================ MASK REVEAL */
[data-mask]{clip-path:inset(0 0 100% 0)}

/* ============================================================ REDUCED MOTION fallbacks */
.reduced #overture{display:none}
.reduced .ov-line .w,.reduced .interstitial .ln > span{opacity:1 !important;transform:none !important;filter:none !important}
.reduced [data-mask]{clip-path:none}
.reduced .act-rail{opacity:1}
.reduced .hero-meta{opacity:1;animation:none}
.reduced #particles,.reduced .winner-confetti,.reduced .grain{display:none}
.reduced .journey-stage{height:auto;display:block;padding-block:5rem}
.reduced .chapter{position:relative;opacity:1 !important;transform:none !important;min-height:auto;padding-block:3rem}
.reduced .chapter .wrap{grid-template-columns:1fr;gap:1rem}
