/* =========================================================
   LES OUBLIEES DE LONDRES, NOTE D'INTENTION
   Page dediee : le mot et l'intention d'Alexandra Bialy.
   Autonome : reprend les memes tokens que css/style.css et
   css/journal.css, sans les modifier.
   ========================================================= */

:root{
  --ink:#15110f;
  --ink-deep:#0f0c0a;
  --paper:#f4efe6;
  --accent:#e23120;
  --accent-soft:#ff5a44;
  --muted:rgba(244,239,230,0.62);
  --line:rgba(244,239,230,0.16);
  --maxw:1320px;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--ink-deep);
  color:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
em{font-style:italic}
::selection{background:var(--accent);color:var(--paper)}

/* =================== SCROLL PROGRESS =================== */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;
  background:var(--accent);z-index:1000;
}

/* =================== TYPO HELPERS =================== */
.eyebrow{
  display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:600;margin-bottom:22px;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  text-decoration:none;border-radius:48px;font-weight:600;letter-spacing:.02em;
  padding:15px 30px;font-size:15px;
  transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s;
}
.btn--solid{background:var(--accent);color:var(--paper)}
.btn--solid:hover{background:var(--accent-soft);transform:translateY(-3px)}
.btn--big{padding:19px 40px;font-size:17px}

/* =================== NAV =================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,4vw,48px);
  transition:background .4s var(--ease),padding .4s var(--ease),backdrop-filter .4s var(--ease);
}
.nav.is-scrolled{
  background:rgba(15,12,10,0.74);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding-top:12px;padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
.nav__brand{
  text-decoration:none;color:var(--paper);line-height:.95;
  font-family:var(--serif);font-weight:600;
}
.nav__brand-l1{display:block;font-size:15px}
.nav__brand-l2{display:block;font-size:15px;font-style:italic;color:var(--muted)}
.nav__links{display:flex;gap:clamp(14px,1.8vw,28px)}
.nav__links a{
  color:var(--paper);text-decoration:none;font-size:13px;letter-spacing:.02em;
  opacity:.78;position:relative;padding:4px 0;transition:opacity .3s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);
  transition:width .35s var(--ease);
}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__links a.is-active{opacity:1}
.nav__links a.is-active::after{width:100%}
.nav__actions{display:flex;align-items:center;gap:16px}
.nav__home{
  color:var(--muted);text-decoration:none;font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;transition:color .3s;
}
.nav__home:hover{color:var(--paper)}
.btn-reserver{
  text-decoration:none;color:var(--ink);background:var(--paper);
  padding:9px 18px;border-radius:40px;font-size:13px;font-weight:600;letter-spacing:.02em;
  transition:background .3s,color .3s,transform .3s var(--ease);
}
.btn-reserver:hover{background:var(--accent);color:var(--paper);transform:translateY(-2px)}

.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:26px;height:2px;background:var(--paper);transition:transform .3s,opacity .3s}
.nav__burger.is-open span:first-child{transform:translateY(7px) rotate(45deg)}
.nav__burger.is-open span:last-child{transform:translateY(-7px) rotate(-45deg)}

.menu-mobile{
  position:fixed;inset:0;z-index:850;background:rgba(15,12,10,0.97);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;
}
.menu-mobile.is-open{opacity:1;visibility:visible}
.menu-mobile nav{display:flex;flex-direction:column;gap:6px;text-align:center}
.menu-mobile a{
  color:var(--paper);text-decoration:none;font-family:var(--serif);
  font-size:clamp(26px,6.5vw,40px);font-weight:400;line-height:1.15;opacity:.85;
}
.menu-mobile a:hover,.menu-mobile a.is-active{color:var(--accent-soft)}
.menu-mobile__home{
  font-family:var(--sans)!important;font-size:14px!important;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)!important;margin-top:26px;
}

/* =================== HERO =================== */
.nhero{
  position:relative;min-height:88svh;display:flex;align-items:flex-end;
  padding:clamp(120px,18vh,180px) clamp(18px,4vw,48px) clamp(60px,10vh,110px);
  overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% 0%,rgba(226,49,32,0.16) 0%,rgba(226,49,32,0) 55%),
    radial-gradient(100% 80% at 12% 100%,rgba(255,90,68,0.08) 0%,rgba(255,90,68,0) 50%),
    var(--ink-deep);
}
.nhero__media{
  position:absolute;inset:0;z-index:0;
}
.nhero__media img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.92) contrast(1.05) brightness(0.7);
}
.nhero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(15,17,15,0.55) 0%,rgba(15,17,15,0.2) 35%,rgba(15,13,11,0.92) 100%),
    radial-gradient(90% 70% at 50% 30%,rgba(226,49,32,0.12) 0%,rgba(226,49,32,0) 60%);
}
.nhero::before{
  content:"Intention";position:absolute;z-index:1;right:clamp(-2vw,1vw,30px);bottom:-3vh;
  font-family:var(--serif);font-weight:300;font-style:italic;line-height:.8;
  font-size:clamp(5rem,18vw,16rem);letter-spacing:-.04em;
  color:rgba(244,239,230,0.05);pointer-events:none;user-select:none;
}
.nhero__inner{position:relative;z-index:2;max-width:1000px}
.nhero__title{
  font-family:var(--serif);font-weight:300;line-height:.94;
  font-size:clamp(2.8rem,10vw,8.4rem);letter-spacing:-.035em;margin-bottom:clamp(24px,4vh,38px);
}
.nhero__title span{font-style:italic;color:var(--accent-soft)}
.nhero__lead{
  max-width:58ch;border-left:2px solid var(--accent);padding-left:26px;
  font-size:clamp(1.05rem,1.7vw,1.34rem);color:rgba(244,239,230,0.9);line-height:1.55;
}
.nhero__meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-top:clamp(26px,4vh,38px);
  font-size:.84rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);
}
.nhero__meta .dot{width:4px;height:4px;border-radius:50%;background:var(--accent)}

/* =================== SECTIONS =================== */
.section{
  padding:clamp(70px,12vh,150px) clamp(18px,4vw,48px);
}
.section--ink{background:var(--ink)}
.section--deep{background:var(--ink-deep)}
.section--grad{
  background:linear-gradient(180deg,var(--ink-deep) 0%,var(--ink) 45%,var(--ink-deep) 100%);
}
.wrap{max-width:var(--maxw);margin:0 auto}
.wrap--narrow{max-width:860px;margin:0 auto}

.section__head{margin-bottom:clamp(40px,7vh,80px)}
.section__title{
  font-family:var(--serif);font-weight:300;line-height:1.05;letter-spacing:-.02em;
  font-size:clamp(2rem,5vw,3.8rem);max-width:20ch;margin-bottom:22px;
}
.section__title em{color:var(--accent-soft)}
.section__sub{max-width:60ch;font-size:clamp(1rem,1.5vw,1.18rem);color:rgba(244,239,230,0.78)}

.lede{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.4rem,3.2vw,2.4rem);line-height:1.3;letter-spacing:-.01em;
  color:rgba(244,239,230,0.95);max-width:26ch;
}

.prose p{
  font-size:clamp(1.02rem,1.5vw,1.18rem);color:rgba(244,239,230,0.84);
  line-height:1.7;max-width:62ch;
}
.prose p + p{margin-top:1.2em}
.prose strong{color:var(--paper);font-weight:600}
.prose em{color:var(--accent-soft)}

/* =================== MOT DE L'AUTRICE (citation phare) =================== */
.author{
  background:
    radial-gradient(110% 80% at 80% 0%,rgba(226,49,32,0.16) 0%,rgba(226,49,32,0) 55%),
    var(--ink-deep);
  position:relative;overflow:hidden;
}
.author__grid{
  display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(30px,5vw,72px);align-items:center;
}
.author__media{
  position:relative;border-radius:4px;overflow:hidden;
  box-shadow:0 2px 4px rgba(0,0,0,0.4),0 26px 60px rgba(0,0,0,0.55),0 50px 100px rgba(0,0,0,0.45);
}
.author__media img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:4 / 5;
  filter:saturate(0.95) contrast(1.04);
}
.author__media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 120% at 50% 0%,rgba(0,0,0,0) 58%,rgba(0,0,0,0.3) 100%);
  mix-blend-mode:multiply;
}
.author__mark{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(5rem,12vw,9rem);line-height:.6;color:var(--accent);
  display:block;margin-bottom:6px;
}
.author__quote p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.16rem,2vw,1.6rem);line-height:1.42;letter-spacing:-.01em;
  color:rgba(244,239,230,0.94);max-width:40ch;
}
.author__quote p + p{margin-top:1em}
.author__quote .q-strong{color:var(--accent-soft);font-style:italic}
.author__sign{
  margin-top:clamp(28px,4vh,40px);display:flex;align-items:center;gap:16px;
}
.author__sign-line{width:46px;height:1px;background:var(--accent)}
.author__sign-name{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2vw,1.4rem);color:var(--paper);
}
.author__sign-role{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* =================== THEMES =================== */
.themes{
  list-style:none;display:grid;grid-template-columns:repeat(2,1fr);
  gap:clamp(18px,2.4vw,34px);
}
.theme{
  position:relative;border:1px solid var(--line);border-radius:6px;
  padding:clamp(26px,3vw,40px);background:rgba(244,239,230,0.025);
  transition:border-color .4s var(--ease),transform .5s var(--ease),background .4s var(--ease);
  overflow:hidden;
}
.theme::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);
  transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease);
}
@media (hover:hover) and (pointer:fine){
  .theme:hover{transform:translateY(-4px);border-color:rgba(226,49,32,0.4);background:rgba(244,239,230,0.045)}
  .theme:hover::before{transform:scaleY(1)}
}
.theme__num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.5rem,3vw,2.2rem);color:var(--accent-soft);line-height:1;display:block;margin-bottom:18px;
}
.theme__title{
  font-family:var(--serif);font-weight:400;font-size:clamp(1.3rem,2.2vw,1.7rem);
  line-height:1.15;letter-spacing:-.01em;margin-bottom:14px;
}
.theme__body{font-size:clamp(.98rem,1.4vw,1.08rem);color:rgba(244,239,230,0.78);line-height:1.6}
.theme__body strong{color:var(--paper);font-weight:600}
.theme--wide{grid-column:1 / -1}

/* =================== BANDEAU IMAGE PLEINE =================== */
.band{
  position:relative;min-height:62svh;display:flex;align-items:center;
  padding:clamp(60px,10vh,120px) clamp(18px,4vw,48px);overflow:hidden;
}
.band__media{position:absolute;inset:0;z-index:0}
.band__media img{width:100%;height:100%;object-fit:cover;filter:saturate(0.9) contrast(1.06) brightness(0.66)}
.band__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(15,13,11,0.92) 0%,rgba(15,13,11,0.55) 45%,rgba(15,13,11,0.25) 100%);
}
.band__inner{position:relative;z-index:1;max-width:720px}
.band__quote{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.5rem,3.6vw,2.8rem);line-height:1.28;letter-spacing:-.01em;
  color:var(--paper);
}
.band__caption{
  margin-top:22px;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);
}

/* =================== MISE EN SCENE : split media + texte =================== */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,70px);align-items:center;
}
.split + .split{margin-top:clamp(56px,8vh,110px)}
.split--rev .split__media{order:2}
.split__media{
  position:relative;border-radius:5px;overflow:hidden;
  box-shadow:0 2px 4px rgba(0,0,0,0.4),0 24px 56px rgba(0,0,0,0.5),0 46px 96px rgba(0,0,0,0.4);
}
.split__media img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:4 / 3;
  filter:saturate(0.95) contrast(1.04);
}
.split__media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 120% at 50% 100%,rgba(0,0,0,0) 55%,rgba(0,0,0,0.32) 100%);
  mix-blend-mode:multiply;
}
.split__label{
  display:inline-block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:600;margin-bottom:18px;
}
.split__title{
  font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:-.02em;
  font-size:clamp(1.7rem,3.6vw,2.9rem);margin-bottom:22px;
}
.split__title em{color:var(--accent-soft)}

/* liste objets de scenographie */
.props{
  list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;
}
.props li{
  font-size:.82rem;letter-spacing:.04em;color:rgba(244,239,230,0.82);
  border:1px solid var(--line);border-radius:40px;padding:8px 16px;
  background:rgba(244,239,230,0.02);
}
.props li strong{color:var(--accent-soft);font-weight:600}

/* =================== GALERIE LUMIERE =================== */
.gallery{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.8vw,26px);
}
.gallery__item{
  position:relative;border-radius:5px;overflow:hidden;
  box-shadow:0 2px 4px rgba(0,0,0,0.4),0 20px 44px rgba(0,0,0,0.5);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);
}
.gallery__item img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:3 / 4;
  filter:saturate(0.96) contrast(1.04);
  transition:transform .8s var(--ease);
}
.gallery__item--wide{grid-column:span 2;aspect-ratio:auto}
.gallery__item--wide img{aspect-ratio:3 / 2}
.gallery__item figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 18px 16px;
  font-size:.8rem;letter-spacing:.06em;color:rgba(244,239,230,0.92);
  background:linear-gradient(0deg,rgba(8,6,5,0.85) 0%,rgba(8,6,5,0) 100%);
}
@media (hover:hover) and (pointer:fine){
  .gallery__item:hover{transform:translateY(-4px);box-shadow:0 4px 8px rgba(0,0,0,0.4),0 32px 64px rgba(0,0,0,0.6)}
  .gallery__item:hover img{transform:scale(1.05)}
}

/* =================== SIGNATURE FINALE =================== */
.endmark{
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:26px;
}
.endmark__line{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.4rem,3.4vw,2.4rem);color:rgba(244,239,230,0.94);max-width:26ch;line-height:1.3;
}
.endmark__sign{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.6rem);color:var(--accent-soft)}
.endmark__role{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.endmark__cta{margin-top:14px;display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* =================== FOOTER =================== */
.jfooter{
  background:var(--ink-deep);border-top:1px solid var(--line);
  padding:clamp(50px,8vh,80px) clamp(18px,4vw,48px);
}
.jfooter__inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;
}
.jfooter__brand{
  font-family:var(--serif);font-weight:300;font-size:clamp(1.4rem,3vw,2rem);
  color:var(--paper);text-decoration:none;line-height:1;
}
.jfooter__brand span{font-style:italic;color:var(--accent-soft)}
.jfooter__nav{display:flex;flex-wrap:wrap;gap:18px 26px}
.jfooter__nav a{color:var(--muted);text-decoration:none;font-size:13px;letter-spacing:.02em;transition:color .3s}
.jfooter__nav a:hover{color:var(--paper)}
.jfooter__legal{width:100%;color:var(--muted);font-size:.86rem;border-top:1px solid var(--line);padding-top:22px;margin-top:6px}

/* =================== REVEALS =================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-in{opacity:1;transform:translateY(0)}
.reveal--d1{transition-delay:.08s}
.reveal--d2{transition-delay:.16s}
.reveal--d3{transition-delay:.24s}

/* =================== RESPONSIVE =================== */
@media (max-width:1100px){
  .nav__links{display:none}
  .nav__home{display:none}
  .nav__burger{display:flex}
}
@media (max-width:920px){
  .author__grid{grid-template-columns:1fr;gap:clamp(28px,6vw,44px)}
  .author__media{max-width:460px;margin:0 auto}
  .split{grid-template-columns:1fr;gap:clamp(24px,6vw,40px)}
  .split--rev .split__media{order:0}
}
@media (max-width:720px){
  .themes{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery__item--wide{grid-column:span 2}
  .nhero{align-items:flex-end}
}
@media (max-width:460px){
  .gallery{grid-template-columns:1fr}
  .gallery__item--wide{grid-column:auto}
}

/* =================== REDUCED MOTION =================== */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .theme::before{transform:scaleY(1)!important}
}

/* =================== CURSEUR, HALO DE LANTERNE =================== */
.cursor{position:fixed;top:0;left:0;width:340px;height:340px;border-radius:50%;pointer-events:none;z-index:9999;display:none;transform:translate(-50%,-50%);background:radial-gradient(circle at center,rgba(255,206,138,0.32) 0%,rgba(255,170,86,0.17) 24%,rgba(214,110,40,0.07) 45%,rgba(0,0,0,0) 70%);mix-blend-mode:screen;transition:opacity .45s ease}
.cursor::after{content:"";position:absolute;top:50%;left:50%;width:7px;height:7px;border-radius:50%;margin:-3.5px 0 0 -3.5px;background:radial-gradient(circle,#ffe7ba 0%,#ff9d3c 65%,rgba(255,120,40,0) 100%);box-shadow:0 0 12px 4px rgba(255,170,80,0.75);transition:width .3s ease,height .3s ease,margin .3s ease,box-shadow .3s ease}
.cursor__label{position:absolute;top:50%;left:50%;transform:translate(-50%,34px);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff1dc;opacity:0;white-space:nowrap;font-weight:600;text-shadow:0 1px 8px rgba(0,0,0,.7);transition:opacity .25s}
.cursor.is-active::after{width:12px;height:12px;margin:-6px 0 0 -6px;box-shadow:0 0 20px 8px rgba(255,176,86,0.92)}
.cursor.is-active .cursor__label{opacity:1}
body.cursor-on{cursor:none}
body.cursor-on .cursor{display:block}
