*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--gold:#C9A96E;--cream:#FAF7F2;--bg:#EDE8DE;--muted:#9A8E7A;}
html,body{width:100%;height:100%;overflow:hidden;background:#030202;-webkit-font-smoothing:antialiased;cursor:none}
#cur{position:fixed;width:8px;height:8px;border-radius:50%;background:#aaa;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);mix-blend-mode:difference}
#cur-r{position:fixed;width:28px;height:28px;border-radius:50%;border:1px solid rgba(180,180,180,.3);pointer-events:none;z-index:99998;transform:translate(-50%,-50%)}

/* ── STAGE 1 ── */
#stage-logo{
  position:fixed;inset:0;z-index:60;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:#030202;
  transition:opacity 1.2s ease;
}
#stage-logo.exit{opacity:0;pointer-events:none}
.eyebrow{font-family:'DM Sans',system-ui,sans-serif;font-size:clamp(9px,2.8vw,12px);letter-spacing:.36em;text-transform:uppercase;font-weight:500;color:rgba(250,246,238,.98);margin-bottom:clamp(20px,5vw,28px);opacity:0;animation:fadeUp .8s .4s forwards;text-shadow:0 0 36px rgba(201,169,110,.22),0 0 14px rgba(255,252,248,.18),0 3px 18px rgba(0,0,0,.42)}
.logo-wrap{width:min(88vw,580px);opacity:0;animation:fadeUp .7s .8s forwards}
.logo-sub{margin-top:14px;font-size:7px;letter-spacing:.7em;text-transform:uppercase;color:transparent;animation:fadeGold 1s 3.5s forwards}
.logo-sub:empty{display:none;margin-top:0}
@keyframes fadeGold{to{color:rgba(140,140,140,.38)}}
.hint{position:absolute;bottom:36px;font-size:8px;letter-spacing:.44em;text-transform:uppercase;color:var(--muted);opacity:0;animation:fadeUp .8s 4s forwards,breathe 2.5s 4.5s infinite;cursor:pointer}

/* ── STAGE 2 ── */
#stage-env{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#030202;opacity:0;pointer-events:none;transition:opacity .8s ease}
#stage-env.active{opacity:1;pointer-events:all}
#stage-env.exit{opacity:0;pointer-events:none}
.env-label{font-size:8px;letter-spacing:.62em;text-transform:uppercase;color:var(--gold);margin-bottom:44px;opacity:0}
#stage-env.active .env-label{animation:fadeUp .7s .2s forwards}
.env-wrap{width:min(300px,82vw);opacity:0}
#stage-env.active .env-wrap{animation:scaleIn .7s .4s cubic-bezier(.2,1,.4,1) forwards}
@keyframes scaleIn{from{opacity:0;transform:scale(.88) translateY(14px)}to{opacity:1;transform:scale(1) translateY(0)}}
.envelope{width:100%;aspect-ratio:1.618;position:relative;filter:drop-shadow(0 20px 55px rgba(0,0,0,.7));transform-style:preserve-3d;transition:transform .25s ease}
.env-body{position:absolute;inset:0;border-radius:2px;background:linear-gradient(155deg,#28200F,#1C1710 45%,#110E08);border:1px solid rgba(201,169,110,.18);overflow:hidden}
.env-body::after{content:'';position:absolute;inset:0;background:linear-gradient(130deg,rgba(201,169,110,.06),transparent 55%)}
.env-flap{position:absolute;top:0;left:0;right:0;height:52%;transform-origin:top center;transition:transform .85s cubic-bezier(.4,0,.2,1);z-index:10}
.env-flap svg{width:100%;height:100%;display:block}
.env-fl,.env-fr{position:absolute;bottom:0;height:58%;width:50%;pointer-events:none}
.env-fl{left:0;background:linear-gradient(225deg,transparent 49%,rgba(201,169,110,.04) 50%);border-right:1px solid rgba(201,169,110,.06)}
.env-fr{right:0;background:linear-gradient(315deg,transparent 49%,rgba(201,169,110,.04) 50%);border-left:1px solid rgba(201,169,110,.06)}
.seal{position:absolute;top:47%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;background:conic-gradient(from 0deg,#B87A28,#EBC85A,#C9852E,#EBC85A,#B87A28);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 3px rgba(201,169,110,.2),0 4px 26px rgba(201,169,110,.5);z-index:20;font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:rgba(8,5,2,.9);cursor:pointer;animation:sealPulse 3.5s ease infinite}
@keyframes sealPulse{0%,100%{box-shadow:0 0 0 3px rgba(201,169,110,.2),0 4px 26px rgba(201,169,110,.4)}50%{box-shadow:0 0 0 3px rgba(201,169,110,.35),0 4px 36px rgba(201,169,110,.65),0 0 70px rgba(201,169,110,.18)}}
.c{position:absolute;width:11px;height:11px;opacity:.4}
.c-tl{top:8px;left:8px;border-top:1px solid var(--gold);border-left:1px solid var(--gold)}
.c-tr{top:8px;right:8px;border-top:1px solid var(--gold);border-right:1px solid var(--gold)}
.c-bl{bottom:8px;left:8px;border-bottom:1px solid var(--gold);border-left:1px solid var(--gold)}
.c-br{bottom:8px;right:8px;border-bottom:1px solid var(--gold);border-right:1px solid var(--gold)}
.env-tap{margin-top:28px;font-size:9px;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);opacity:0}
#stage-env.active .env-tap{animation:fadeUp .8s 1.2s forwards,breathe 3s 2s infinite}

/* ── WIPE ── */
#wipe{position:fixed;inset:0;z-index:80;display:flex;pointer-events:none}
.wp{flex:1;background:#030202;transform:scaleY(0);transform-origin:top}
.wp:nth-child(2){transition-delay:.05s}.wp:nth-child(3){transition-delay:.1s}.wp:nth-child(4){transition-delay:.15s}.wp:nth-child(5){transition-delay:.2s}
#wipe.down .wp{transform:scaleY(1);transition:transform .55s cubic-bezier(.7,0,.3,1)}
#wipe.up .wp{transform:scaleY(0);transform-origin:bottom;transition:transform .65s cubic-bezier(.7,0,.3,1)}
#wipe.up .wp:nth-child(2){transition-delay:.06s}#wipe.up .wp:nth-child(3){transition-delay:.12s}#wipe.up .wp:nth-child(4){transition-delay:.18s}#wipe.up .wp:nth-child(5){transition-delay:.24s}

/* ── CARD ── */
#card{position:fixed;inset:0;z-index:40;overflow-y:scroll;overflow-x:hidden;opacity:0;pointer-events:none;background:var(--bg)}
#card.visible{opacity:1;pointer-events:all}
#card::-webkit-scrollbar{width:2px}#card::-webkit-scrollbar-thumb{background:var(--gold)}
.page{min-height:100vh;background:var(--bg)}
.hdr{padding:38px 22px 0;display:flex;align-items:baseline;justify-content:space-between;clip-path:inset(0 0 100% 0);transition:clip-path .7s .1s cubic-bezier(.4,0,0,1)}
.hdr.in{clip-path:inset(0 0 0% 0)}
.hdr-brand{font-size:8px;letter-spacing:.55em;text-transform:uppercase;color:var(--muted)}
.hdr-num{font-family:'Playfair Display',serif;font-style:italic;font-size:14px;color:var(--gold)}
.giant-row{padding:0 20px;display:flex;align-items:flex-end;justify-content:space-between;overflow:hidden;clip-path:inset(0 0 100% 0);transition:clip-path .8s .2s cubic-bezier(.4,0,0,1)}
.giant-row.in{clip-path:inset(0 0 0% 0)}
.giant-villa{font-family:'Playfair Display',serif;display:flex;flex-direction:column;align-items:flex-start;line-height:1}
.giant-kicker{display:block;font-family:'Bebas Neue',sans-serif;font-size:clamp(11px,3vw,17px);letter-spacing:.38em;text-transform:uppercase;color:var(--muted);margin-bottom:.35em}
.giant-glow{display:block;font-size:clamp(52px,19vw,108px);font-weight:900;font-style:italic;line-height:.86;color:#1a1410;
  text-shadow:
    0 0 1px rgba(255,250,240,.25),
    0 0 24px rgba(201,169,110,.55),
    0 0 52px rgba(201,169,110,.32),
    0 0 96px rgba(201,169,110,.14);
  animation:heroTextGlow 4.2s ease-in-out infinite}
@keyframes heroTextGlow{0%,100%{filter:brightness(1)}50%{filter:brightness(1.06)}}
.giant-right{text-align:right;padding-bottom:8px}
.giant-right:has(.giant-year:empty){display:none}
.giant-year{font-family:'Bebas Neue',sans-serif;font-size:clamp(15px,5vw,26px);color:var(--muted);letter-spacing:.08em;line-height:1.1;display:block}
.full-img{width:100%;height:clamp(200px,54vw,340px);position:relative;overflow:hidden;clip-path:inset(100% 0 0 0);transition:clip-path .9s .35s cubic-bezier(.4,0,0,1)}
.full-img.in{clip-path:inset(0% 0 0 0)}
.full-img img{width:100%;height:130%;object-fit:cover;object-position:center 20%;display:block;will-change:transform;filter:saturate(.88) brightness(.93)}
.img-cap{position:absolute;bottom:14px;left:18px;font-size:8px;letter-spacing:.45em;text-transform:uppercase;color:rgba(255,255,255,.65);background:rgba(0,0,0,.22);padding:4px 10px;backdrop-filter:blur(6px)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:3px}
.split-dark{background:#0E0B07;padding:22px 18px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;text-align:center;clip-path:inset(0 100% 0 0);transition:clip-path .8s .45s cubic-bezier(.4,0,0,1)}
.split-dark.in{clip-path:inset(0 0% 0 0)}
.sd-tag{font-size:7px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.sd-text{font-family:'Playfair Display',serif;font-size:clamp(17px,5.5vw,26px);font-style:italic;font-weight:400;color:var(--cream);line-height:1.25;flex:1;text-align:center;max-width:min(100%,28em)}
.sd-foot{font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-top:16px}
.split-img{position:relative;overflow:hidden;clip-path:inset(0 0 0 100%);transition:clip-path .8s .55s cubic-bezier(.4,0,0,1)}
.split-img.in{clip-path:inset(0 0 0 0%)}
.split-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:saturate(.85)}
.marquee-strip{background:var(--cream);height:clamp(44px,13vw,70px);display:flex;align-items:center;overflow:hidden;margin-top:3px;clip-path:inset(0 0 100% 0);transition:clip-path .5s .12s cubic-bezier(.4,0,0,1)}
.marquee-strip.in{clip-path:inset(0 0 0% 0)}
/* Défilement seulement une fois visible : sinon Safari mobile garde l’animation figée / hors phase */
.mq-inner{display:flex;align-items:center;white-space:nowrap;flex-shrink:0;width:max-content;min-width:100%;-webkit-backface-visibility:hidden;backface-visibility:hidden}
.marquee-strip.in .mq-inner{animation:mqMarquee 20s linear infinite;will-change:transform}
.mq-inner span,.mq-inner em{flex-shrink:0}
.mq-inner span{font-family:'Bebas Neue',sans-serif;font-size:clamp(28px,9vw,52px);color:#1A1410;letter-spacing:.06em;padding:0 14px}
.mq-inner em{font-family:'Playfair Display',serif;font-style:italic;font-weight:400;font-size:clamp(18px,6vw,36px);color:var(--muted)}
.mq-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;margin:0 8px}
@keyframes mqMarquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion:reduce){
  .marquee-strip.in .mq-inner{animation:none;justify-content:center;flex-wrap:wrap;white-space:normal;max-width:100%;padding:6px 10px;text-align:center;row-gap:4px}
}
.bot-pair{display:grid;grid-template-columns:3fr 2fr;gap:3px;margin-top:3px}
.bot-img{position:relative;overflow:hidden;height:clamp(130px,38vw,220px);clip-path:inset(100% 0 0 0);transition:clip-path .9s cubic-bezier(.4,0,0,1)}
.bot-img.in{clip-path:inset(0% 0 0 0)}
.bot-img:nth-child(2){transition-delay:.12s}
.bot-img img{width:100%;height:130%;object-fit:cover;display:block;will-change:transform;filter:saturate(.88) brightness(.9)}
.bot-tag{position:absolute;top:10px;left:10px;font-size:7px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.55);background:rgba(0,0,0,.28);padding:3px 8px;backdrop-filter:blur(4px)}
.mystery{background:#0E0B07;padding:30px 22px 55px;text-align:center;margin-top:3px;clip-path:inset(0 0 100% 0);transition:clip-path .8s cubic-bezier(.4,0,0,1)}
.mystery.in{clip-path:inset(0 0 0% 0)}
.mys-pre{font-size:8px;letter-spacing:.6em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.mys-title{font-family:'Playfair Display',serif;font-size:clamp(26px,9vw,44px);font-weight:300;font-style:italic;color:var(--cream);line-height:1.15;margin-bottom:10px}
.mys-sub{font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.mys-pre:empty,.mys-sub:empty{display:none;margin:0}
#bc{position:fixed;inset:0;pointer-events:none;z-index:79}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes breathe{0%,100%{opacity:.45}50%{opacity:.95}}

/* ── IMAGE ENVELOPE ── */
.env-img-wrap {
  width: min(380px, 88vw);
  position: relative;
  cursor: pointer;
  opacity: 0;
  filter: drop-shadow(0 24px 60px rgba(0,0,0,.75));
}
#stage-env.active .env-img-wrap {
  animation: scaleIn .8s .3s cubic-bezier(.2,1,.4,1) forwards;
}
#envelopeImg {
  width: 100%;
  display: block;
  border-radius: 4px;
  transform-origin: center top;
  transition: transform 1s cubic-bezier(.4,0,.2,1), opacity .6s ease;
}
#envelopeImg.opening {
  transform: rotateX(-160deg) scaleY(0.15);
  opacity: 0;
}
/* Hover: subtle lift */
.env-img-wrap:hover #envelopeImg {
  transform: translateY(-6px) scale(1.015);
}
.env-img-wrap:hover.is-opening #envelopeImg {
  transform: rotateX(-160deg) scaleY(0.15);
}

/* ── THEME VIEUX JOURNAL ── */
body.theme-journal #card{
  background:#ddd2ba;
  background-image:
    radial-gradient(circle at 20% 10%,rgba(255,255,255,.22),transparent 26%),
    radial-gradient(circle at 80% 90%,rgba(0,0,0,.08),transparent 24%),
    repeating-linear-gradient(0deg,rgba(0,0,0,.022) 0 1px,transparent 1px 3px);
}
body.theme-journal .page{
  position:relative;
  max-width:980px;
  margin:0 auto;
  background:#eee3c9;
  box-shadow:0 0 0 1px rgba(45,34,22,.24),0 12px 40px rgba(28,18,8,.28);
}
body.theme-journal .page::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:repeating-radial-gradient(circle at 0 0,rgba(0,0,0,.028) 0 1px,transparent 1px 4px);
  mix-blend-mode:multiply;
  opacity:.55;
}
body.theme-journal .hdr{
  border-bottom:2px solid rgba(44,31,18,.75);
  margin:0 14px;
  padding-top:24px;
}
body.theme-journal .hdr-brand,body.theme-journal .hdr-num{
  color:#2b1e10;
  text-transform:uppercase;
  letter-spacing:.26em;
}
body.theme-journal .giant-kicker{
  color:#4a3a2a;
  letter-spacing:.32em;
}
body.theme-journal .giant-glow{
  font-style:normal;
  font-weight:900;
  letter-spacing:.02em;
  color:#18110a;
  text-shadow:
    0 0 1px rgba(255,248,230,.2),
    0 0 20px rgba(120,82,38,.4),
    0 0 48px rgba(90,58,22,.22);
}
body.theme-journal .giant-year{
  color:#2c2116;
  letter-spacing:.14em;
}
body.theme-journal .split-dark,body.theme-journal .mystery{
  background:#efe6d0;
  border:1px solid rgba(43,29,14,.35);
}
body.theme-journal .sd-text,body.theme-journal .mys-title{
  color:#1f150c;
}
body.theme-journal .sd-foot,body.theme-journal .mys-sub,body.theme-journal .mys-pre{
  color:#3d2d1d;
}
body.theme-journal .marquee-strip{
  background:#dbcfb3;
  border-top:1px solid rgba(40,28,16,.4);
  border-bottom:1px solid rgba(40,28,16,.4);
}
body.theme-journal .mq-inner span,body.theme-journal .mq-inner em{
  color:#2a1d11;
}
body.theme-journal .mq-dot{
  background:#2f2215;
}
.news-cut{
  filter:sepia(.62) contrast(1.08) saturate(.62) brightness(.96);
  animation:paperFloat 8s ease-in-out infinite;
}
@keyframes paperFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-6px) rotate(-.45deg)}
}

.indices-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  padding:8px 10px 36px;
  background:#e6dac0;
}
.indice-card{
  overflow:hidden;
  border:1px solid rgba(46,33,19,.38);
  background:#f2ead8;
  box-shadow:0 6px 14px rgba(24,16,10,.16);
  clip-path:inset(100% 0 0 0);
  animation:revealCard .8s cubic-bezier(.4,0,0,1) forwards;
}
.indice-card img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  filter:sepia(.34) contrast(1.05) saturate(.92);
}
@keyframes revealCard{
  to{clip-path:inset(0 0 0 0)}
}

.journal-closer{
  position:relative;
  margin:10px 10px 0;
  min-height:46vh;
  padding:46px 22px 62px;
  overflow:hidden;
  background:radial-gradient(circle at 50% 10%,rgba(255,255,255,.22),rgba(16,11,8,.98) 58%);
  border-top:2px solid rgba(210,186,144,.36);
  transform:translateY(20px);
  opacity:0;
  transition:transform .8s cubic-bezier(.2,.7,.2,1),opacity .8s ease;
}
.journal-closer::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:0;height:38%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));
  pointer-events:none;
}
.journal-closer .jc-noise{
  position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:repeating-radial-gradient(circle at 0 0,rgba(255,255,255,.22) 0 1px,transparent 1px 3px);
}
.journal-closer .jc-inner{
  position:relative;z-index:2;text-align:center;
}
.journal-closer .jc-line{
  width:min(220px,60vw);height:1px;margin:0 auto 16px;background:linear-gradient(90deg,transparent,rgba(232,202,152,.85),transparent);
}
.journal-closer .jc-over{
  font-size:10px;letter-spacing:.42em;text-transform:uppercase;color:#d8bf95;opacity:.9;margin-bottom:14px;
}
.journal-closer .jc-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(46px,15vw,110px);
  letter-spacing:.08em;
  color:#f8edd6;
  line-height:.9;
  text-shadow:0 0 22px rgba(255,214,152,.22),0 0 2px rgba(255,255,255,.8);
  margin-bottom:12px;
}
.journal-closer .jc-sub{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(236,220,191,.78);
}
body.theme-journal .journal-closer{
  transform:translateY(0);
  opacity:1;
  margin:0;
  padding:clamp(32px,6vw,52px) clamp(10px,3vw,22px) clamp(44px,8vw,64px);
  min-height:auto;
  background:#e6dac0;
  border-top:1px solid rgba(46,33,19,.38);
  border-bottom:none;
  box-shadow:none;
}
body.theme-journal .journal-closer::after{
  display:none;
}
body.theme-journal .journal-closer .jc-noise{
  opacity:.28;
  mix-blend-mode:multiply;
  background-image:repeating-radial-gradient(circle at 0 0,rgba(0,0,0,.028) 0 1px,transparent 1px 4px);
}
body.theme-journal .journal-closer .jc-inner{
  max-width:560px;
  margin:0 auto;
  padding:0;
  border:none;
  box-shadow:none;
  background:transparent;
}
body.theme-journal .journal-closer .jc-line{
  width:min(280px,72vw);
  height:1px;
  margin:0 auto 14px;
  background:linear-gradient(90deg,transparent,rgba(44,31,18,.4),rgba(44,31,18,.55),rgba(44,31,18,.4),transparent);
}
body.theme-journal .journal-closer .jc-over{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:clamp(12px,2.8vw,14px);
  letter-spacing:.26em;
  text-transform:uppercase;
  color:#2b1e10;
  margin-bottom:18px;
}
body.theme-journal .journal-closer .jc-title{
  font-family:'Bebas Neue',sans-serif;
  font-style:normal;
  font-weight:400;
  font-size:clamp(36px,12vw,88px);
  letter-spacing:.08em;
  line-height:.9;
  color:#1a1410;
  text-shadow:none;
  margin:0;
  padding:0;
  border:none;
}

.page-footer{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:clamp(28px,5vw,48px) clamp(16px,4vw,28px) clamp(40px,8vw,64px);
  background:var(--bg);
  border-top:1px solid rgba(46,33,19,.2);
}
body.theme-journal .page-footer{
  background:#e6dac0;
  border-top-color:rgba(46,33,19,.28);
}
.page-footer-logo{
  width:min(100%,220px);
  height:auto;
  display:block;
  opacity:.94;
}
