/* =========================================================
   LES OUBLIEES DE LONDRES, JEUX & DIVERTISSEMENTS (1888)
   Page dediee : test interactif, mots croises, horoscope
   Coherente avec css/style.css (qu'elle ne modifie pas)
   ========================================================= */

: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)}
:focus-visible{outline:2px solid var(--accent-soft);outline-offset:3px}

/* =================== 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:0;cursor:pointer;font-family:var(--sans);
  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(28px,7vw,42px);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 =================== */
.ghero{
  position:relative;min-height:88svh;display:flex;align-items:center;
  padding:clamp(120px,18vh,180px) clamp(18px,4vw,48px) clamp(60px,10vh,110px);
  background:
    radial-gradient(120% 90% at 82% 4%,rgba(226,49,32,0.16) 0%,rgba(226,49,32,0) 55%),
    radial-gradient(100% 80% at 8% 100%,rgba(255,90,68,0.08) 0%,rgba(255,90,68,0) 50%),
    var(--ink-deep);
  overflow:hidden;
}
.ghero__inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%}
.ghero__title{
  font-family:var(--serif);font-weight:300;line-height:.92;letter-spacing:-.03em;
  font-size:clamp(2.8rem,11vw,8.5rem);margin-bottom:clamp(26px,4vh,40px);
}
.ghero__title span{font-style:italic;color:var(--accent-soft)}
.ghero__chapeau{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.05rem,2vw,1.5rem);line-height:1.45;
  color:rgba(244,239,230,0.9);max-width:46ch;
  padding-left:18px;border-left:2px solid var(--accent);
  margin-bottom:clamp(30px,5vh,46px);
}
.ghero__jump{display:flex;flex-wrap:wrap;gap:12px}
.ghero__jump a{
  text-decoration:none;color:var(--paper);font-size:13px;letter-spacing:.04em;
  border:1px solid var(--line);border-radius:40px;padding:10px 20px;
  transition:border-color .3s,background .3s,color .3s,transform .3s var(--ease);
}
.ghero__jump a:hover{border-color:var(--accent);background:var(--accent);transform:translateY(-2px)}
.ghero__filigrane{
  position:absolute;z-index:1;right:clamp(-3vw,1vw,30px);bottom:-3vh;
  font-family:var(--serif);font-weight:300;font-style:italic;line-height:.8;
  font-size:clamp(8rem,32vw,30rem);letter-spacing:-.04em;
  color:rgba(244,239,230,0.045);pointer-events:none;user-select:none;
}

/* =================== STRUCTURE JEU =================== */
.game{padding:clamp(64px,11vh,130px) clamp(18px,4vw,48px);position:relative}
.game--test{border-top:1px solid var(--line)}
.game--cross{background:var(--ink);border-top:1px solid var(--line)}
.game--horo{border-top:1px solid var(--line)}
.game__inner{max-width:var(--maxw);margin:0 auto}
.game__head{max-width:760px;margin-bottom:clamp(36px,6vh,60px)}
.game__kicker{
  display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:600;margin-bottom:18px;
}
.game__title{
  font-family:var(--serif);font-weight:300;line-height:1;letter-spacing:-.025em;
  font-size:clamp(2rem,5.6vw,4rem);margin-bottom:20px;
}
.game__title span{font-style:italic;color:var(--paper);opacity:.9}
.game__lead{font-size:clamp(1rem,1.5vw,1.18rem);color:rgba(244,239,230,0.78);max-width:60ch}

/* =================== QUIZ =================== */
.quiz{
  background:linear-gradient(180deg,rgba(244,239,230,0.05),rgba(244,239,230,0.02));
  border:1px solid var(--line);border-radius:22px;
  padding:clamp(26px,4vw,52px);max-width:920px;position:relative;overflow:hidden;
}
.quiz::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 90% at 100% 0%,rgba(226,49,32,0.1),transparent 55%);
}
.quiz__panel{position:relative;z-index:1}
.quiz__intro{text-align:center;padding:clamp(20px,4vh,48px) 0}
.quiz__intro-line{
  font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2.4vw,1.7rem);
  color:rgba(244,239,230,0.9);margin-bottom:30px;
}

.quiz__progress{display:flex;align-items:center;gap:18px;margin-bottom:28px}
.quiz__count{font-size:13px;letter-spacing:.08em;color:var(--muted);white-space:nowrap}
.quiz__count b{color:var(--accent-soft);font-weight:600;font-size:16px}
.quiz__bar{flex:1;height:3px;background:var(--line);border-radius:3px;overflow:hidden}
.quiz__bar i{display:block;height:100%;width:0;background:var(--accent);transition:width .5s var(--ease)}

.quiz__question{
  font-family:var(--serif);font-weight:300;line-height:1.15;letter-spacing:-.01em;
  font-size:clamp(1.5rem,3.4vw,2.4rem);margin-bottom:clamp(22px,3.5vh,34px);
}
.quiz__answers{display:grid;gap:12px}
.quiz__answer{
  display:flex;align-items:flex-start;gap:14px;text-align:left;width:100%;
  background:rgba(244,239,230,0.03);border:1px solid var(--line);border-radius:14px;
  color:var(--paper);font-family:var(--sans);font-size:clamp(1rem,1.5vw,1.12rem);
  padding:16px 20px;cursor:pointer;line-height:1.4;
  transition:border-color .25s,background .25s,transform .25s var(--ease);
}
.quiz__answer:hover{border-color:var(--accent);background:rgba(226,49,32,0.1);transform:translateX(4px)}
.quiz__answer.is-picked{border-color:var(--accent);background:rgba(226,49,32,0.16)}
.quiz__answer .letter{
  flex:none;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--serif);font-weight:600;font-size:14px;
  background:var(--paper);color:var(--ink);margin-top:1px;
}
.quiz__back{
  margin-top:24px;background:none;border:0;cursor:pointer;color:var(--muted);
  font-family:var(--sans);font-size:13px;letter-spacing:.04em;
  text-decoration:underline;text-underline-offset:4px;transition:color .3s;
}
.quiz__back:hover{color:var(--paper)}

.quiz__result{text-align:center;padding:clamp(10px,2vh,24px) 0}
.quiz__verdict-label{
  display:inline-block;font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:600;margin-bottom:18px;
}
.quiz__verdict-title{
  font-family:var(--serif);font-weight:300;font-style:italic;line-height:1.05;
  font-size:clamp(1.9rem,5vw,3.2rem);color:var(--accent-soft);margin-bottom:22px;
}
.quiz__verdict-text{
  font-size:clamp(1.05rem,1.7vw,1.28rem);color:rgba(244,239,230,0.88);
  max-width:54ch;margin:0 auto 18px;line-height:1.55;
}
.quiz__verdict-tag{
  font-family:var(--serif);font-style:italic;color:var(--muted);
  font-size:1.02rem;margin-bottom:30px;
}

/* =================== MOTS CROISES =================== */
.cross{display:grid;grid-template-columns:minmax(0,1.25fr) 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.cross__board{position:sticky;top:96px;min-width:0}
.cross__scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding-bottom:4px}
.cross__grid{
  --cell:clamp(15px,2.1vw,26px);
  display:grid;gap:1px;background:var(--line);padding:1px;border-radius:6px;width:max-content;
}
.cross__row{display:grid;grid-auto-flow:column;gap:2px}
.cross__cell{
  position:relative;width:var(--cell);height:var(--cell);background:var(--ink-deep);
}
.cross__cell--block{background:transparent}
.cross__cell--play{background:rgba(244,239,230,0.04)}
.cross__num{
  position:absolute;top:1px;left:3px;font-size:9px;line-height:1;
  color:var(--muted);font-weight:600;pointer-events:none;z-index:2;
}
.cross__input{
  width:100%;height:100%;background:transparent;border:1px solid transparent;border-radius:3px;
  text-align:center;color:var(--paper);font-family:var(--serif);font-weight:500;
  font-size:calc(var(--cell) * .5);text-transform:uppercase;caret-color:var(--accent-soft);
  transition:background .2s,border-color .2s,color .2s;padding:0;
}
.cross__input:focus{outline:0;border-color:var(--accent);background:rgba(226,49,32,0.14)}
.cross__cell.is-correct .cross__input{color:var(--accent-soft);background:rgba(226,49,32,0.12)}
.cross__cell.is-wrong .cross__input{background:rgba(255,90,68,0.05)}

.cross__tools{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:20px;width:min(100%,320px)}
.cross__btn{
  background:var(--accent);color:var(--paper);border:0;cursor:pointer;font-family:var(--sans);
  font-size:13px;font-weight:600;letter-spacing:.02em;padding:11px 20px;border-radius:40px;
  transition:background .3s,transform .3s var(--ease);
}
.cross__btn:hover{background:var(--accent-soft);transform:translateY(-2px)}
.cross__btn--ghost{background:transparent;border:1px solid var(--line);color:var(--paper)}
.cross__btn--ghost:hover{background:rgba(244,239,230,0.06);border-color:var(--paper)}
.cross__status{flex-basis:100%;font-size:13px;color:var(--accent-soft);font-style:italic;min-height:1.2em}

.cross__clues{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,3vw,40px)}
.cross__cluetitle{
  font-family:var(--serif);font-weight:400;font-size:1.15rem;letter-spacing:.04em;
  text-transform:uppercase;padding-bottom:10px;margin-bottom:14px;
  border-bottom:1px solid var(--line);color:var(--paper);
}
.cross__cluelist{list-style:none}
.cross__cluelist li{
  display:flex;gap:10px;font-size:.95rem;line-height:1.4;
  color:rgba(244,239,230,0.82);padding:5px 0;
}
.cross__cluelist b{color:var(--accent-soft);font-weight:600;min-width:1.8em;flex:none}

/* =================== HOROSCOPE =================== */
.horo{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:clamp(26px,4vw,52px);align-items:start}
.horo__wheel{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.horo__sign{
  background:rgba(244,239,230,0.03);border:1px solid var(--line);border-radius:14px;
  color:var(--paper);font-family:var(--sans);cursor:pointer;
  padding:16px 12px;text-align:center;
  transition:border-color .25s,background .25s,transform .25s var(--ease);
}
.horo__sign:hover{border-color:var(--accent);transform:translateY(-3px)}
.horo__sign.is-active{border-color:var(--accent);background:rgba(226,49,32,0.16)}
.horo__glyph{display:block;font-family:var(--serif);font-size:1.7rem;line-height:1;margin-bottom:8px;color:var(--accent-soft)}
.horo__name{display:block;font-size:.82rem;letter-spacing:.04em}
.horo__dates{display:block;font-size:.68rem;color:var(--muted);margin-top:3px}

.horo__card{
  background:linear-gradient(180deg,rgba(244,239,230,0.05),rgba(244,239,230,0.02));
  border:1px solid var(--line);border-radius:22px;
  padding:clamp(28px,4vw,48px);min-height:240px;
  display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;
}
.horo__card::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(110% 80% at 0% 0%,rgba(226,49,32,0.1),transparent 55%);
}
.horo__placeholder{font-family:var(--serif);font-style:italic;color:var(--muted);font-size:clamp(1.05rem,2vw,1.4rem);position:relative;z-index:1}
.horo__card .horo__glyph-big{font-family:var(--serif);font-size:2.6rem;color:var(--accent-soft);line-height:1;margin-bottom:14px;position:relative;z-index:1}
.horo__card h3{font-family:var(--serif);font-weight:300;font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:6px;position:relative;z-index:1}
.horo__card .horo__card-dates{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;position:relative;z-index:1}
.horo__card p.horo__text{font-size:clamp(1.05rem,1.8vw,1.32rem);line-height:1.55;color:rgba(244,239,230,0.9);position:relative;z-index:1}

/* =================== CODA =================== */
.gcoda{
  padding:clamp(70px,12vh,140px) clamp(18px,4vw,48px);text-align:center;
  background:
    radial-gradient(110% 100% at 50% 0%,rgba(226,49,32,0.14),transparent 60%),
    var(--ink);
  border-top:1px solid var(--line);
}
.gcoda__inner{max-width:760px;margin:0 auto}
.gcoda__small{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent-soft);font-weight:600;margin-bottom:20px}
.gcoda__title{font-family:var(--serif);font-weight:300;line-height:1.02;font-size:clamp(2rem,5.6vw,3.8rem);letter-spacing:-.025em;margin-bottom:24px}
.gcoda__title span{font-style:italic;color:var(--accent-soft)}
.gcoda__text{font-size:clamp(1.05rem,1.7vw,1.28rem);color:rgba(244,239,230,0.84);margin-bottom:34px}

/* =================== FOOTER =================== */
.gfooter{background:var(--ink-deep);border-top:1px solid var(--line);padding:clamp(40px,7vh,70px) clamp(18px,4vw,48px)}
.gfooter__inner{max-width:var(--maxw);margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:22px 40px}
.gfooter__brand{font-family:var(--serif);font-weight:600;font-size:1.2rem;color:var(--paper);text-decoration:none}
.gfooter__brand span{font-style:italic;color:var(--accent-soft)}
.gfooter__nav{display:flex;flex-wrap:wrap;gap:18px 26px;margin-left:auto}
.gfooter__nav a{color:var(--muted);text-decoration:none;font-size:13px;letter-spacing:.02em;transition:color .3s}
.gfooter__nav a:hover{color:var(--paper)}
.gfooter__legal{width:100%;color:var(--muted);font-size:.86rem;border-top:1px solid var(--line);padding-top:22px;margin-top:6px}

/* =================== REVEAL =================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* =================== RESPONSIVE =================== */
@media (max-width:960px){
  .cross{grid-template-columns:1fr}
  .cross__board{position:static}
  .horo{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav__links,.nav__home{display:none}
  .nav__burger{display:flex}
  .cross__clues{grid-template-columns:1fr}
  .gfooter__nav{margin-left:0}
}
@media (max-width:440px){
  .horo__wheel{grid-template-columns:repeat(2,1fr)}
}

/* =================== REDUCED MOTION =================== */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .quiz__answer:hover,.horo__sign:hover,.ghero__jump a:hover,.btn:hover,.cross__btn:hover{transform:none}
}

/* ===== Le jeu en mode telephone ===== */
.jeu__hint{margin-top:1.4rem;font-size:.95rem;color:#b9aeb0}
.jeu__hint a{color:#e23120;text-decoration:underline;text-underline-offset:3px}
.jeu-stage{display:flex;justify-content:center;padding:1rem 1rem 6rem}
.phone{position:relative;width:392px;max-width:92vw;aspect-ratio:392 / 850;background:#0b0708;border-radius:48px;padding:14px;
  box-shadow:0 50px 120px rgba(0,0,0,.6), 0 0 0 2px rgba(255,255,255,.06), inset 0 0 0 2px rgba(255,255,255,.04);}
.phone__notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:148px;height:26px;background:#0b0708;border-radius:0 0 16px 16px;z-index:2}
.phone__screen{width:100%;height:100%;border:0;border-radius:36px;background:#fff8f0;display:block}
@media (max-width:480px){
  /* Plein ecran : on retire le cadre du telephone, le jeu remplit l'ecran */
  .jeu-stage{padding:0 0 3.5rem}
  .phone{width:100%;max-width:none;aspect-ratio:auto;height:calc(100svh - 92px);min-height:560px;
    border-radius:0;padding:0;box-shadow:none;background:#fff8f0}
  .phone__screen{border-radius:0;height:100%}
  .phone__notch{display:none}
}

/* =================== 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}
