/* =========================================================
   MATHIAS VALENS — Site vitrine
   Design system
   ========================================================= */

:root{
  /* Night / ink */
  --night:        #080b15;
  --night-1:      #0c1120;
  --night-2:      #11182b;
  --night-3:      #1a2238;
  --hairline:     rgba(201,168,90,.18);
  --hairline-soft:rgba(216,210,196,.10);

  /* Gold */
  --gold:         #c9a14a;
  --gold-bright:  #e7c878;
  --gold-deep:    #8a6c30;
  --gold-glow:    rgba(231,200,120,.45);

  /* Emerald (the gem) */
  --emerald:      #1f9e6e;
  --emerald-br:   #34c98c;

  /* Order accents */
  --foyer:        #d05a4a;  /* Éclat — feu */
  --conjonction:  #cfd6e6;  /* Lien — argent */
  --voile:        #6f6a99;  /* Volonté — ombre violacée */
  --astrolabe:    #9b6fd4;  /* Arcane — pourpre */

  /* Parchment */
  --parchment:    #ece0c4;
  --parchment-2:  #e3d4b2;
  --ink:          #2c2415;
  --ink-soft:     #5a4d33;

  /* Text on dark */
  --text:         #ddd6c7;
  --text-dim:     #9a9385;
  --text-faint:   #6e6859;

  --serif:  "Cormorant Garamond", Georgia, serif;
  --display:"Cinzel", "Trajan Pro", Georgia, serif;

  --maxw: 1200px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--night);
  color:var(--text);
  font-family:var(--serif);
  font-size:20px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---- type helpers ---- */
.display{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:.04em;
  line-height:1.1;
}
.eyebrow{
  font-family:var(--display);
  font-size:.74rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
}
.lead{
  font-size:1.35rem;
  color:var(--text);
  line-height:1.75;
}
.muted{ color:var(--text-dim); }

.section{
  position:relative;
  padding:clamp(80px,11vw,150px) 28px;
}
.wrap{ max-width:var(--maxw); margin:0 auto; }
.wrap-narrow{ max-width:820px; margin:0 auto; }

/* divider flourish */
.flourish{
  display:flex; align-items:center; gap:18px;
  color:var(--gold); justify-content:center;
}
.flourish::before,.flourish::after{
  content:""; height:1px; width:min(120px,18vw);
  background:linear-gradient(90deg,transparent,var(--gold));
}
.flourish::after{ background:linear-gradient(90deg,var(--gold),transparent); }
.flourish .diamond{
  width:9px; height:9px; transform:rotate(45deg);
  background:var(--emerald-br);
  box-shadow:0 0 12px var(--emerald-br);
}

/* section heading block */
.sec-head{ text-align:center; margin-bottom:clamp(40px,6vw,72px); }
.sec-head h2{
  font-family:var(--display); font-weight:700;
  font-size:clamp(2rem,4.4vw,3.3rem);
  margin:.5em 0 .35em;
  color:#f3ecda; letter-spacing:.02em;
}
.sec-head p{ margin:0 auto; max-width:620px; color:var(--text-dim); font-size:1.18rem; }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(20px,4vw,46px);
  transition:background .4s ease, border-color .4s ease, padding .4s ease;
  background:rgba(8,11,21,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--hairline);
}
.nav.scrolled{
  background:rgba(8,11,21,.92);
  padding-top:12px; padding-bottom:12px;
}
.nav .brand{
  font-family:var(--display); font-weight:700; letter-spacing:.22em;
  font-size:.95rem; color:var(--gold-bright); text-transform:uppercase;
  opacity:1; transition:opacity .4s ease; white-space:nowrap;
}
.nav nav{ display:flex; gap:30px; align-items:center; }
.nav nav a{
  font-family:var(--display); font-size:.72rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--text-dim); white-space:nowrap;
  transition:color .25s ease; position:relative;
}
.nav nav a::after{
  content:""; position:absolute; left:0; bottom:-6px; height:1px; width:0;
  background:var(--gold); transition:width .3s ease;
}
.nav nav a:hover{ color:var(--gold-bright); }
.nav nav a:hover::after{ width:100%; }
.nav .nav-cta{
  border:1px solid var(--gold); color:var(--gold-bright);
  padding:9px 20px; border-radius:2px; letter-spacing:.16em;
}
.nav .nav-cta:hover{ background:var(--gold); color:var(--night); }
.nav-toggle{ display:none; }

@media(max-width:860px){
  .nav nav{ display:none; }
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center;
  padding:96px 0 56px;
  overflow:hidden;
  background:#05070e;
}
.hero__slides{
  position:absolute; inset:0;
  transform:scale(1.0); transform-origin:center;
  transition:transform .18s ease-out;
  will-change:transform;
}
.hero__bg{
  position:absolute; inset:0;
  background-position:center center;
  background-size:contain;
  background-repeat:no-repeat;
  background-color:#05070e;
  opacity:0;
  transition:opacity 1.2s ease;
}
.hero__bg.is-active{ opacity:1; }
.hero__scrim{
  position:absolute; inset:0; opacity:var(--scrim-strength,1);
  background:
    linear-gradient(90deg, rgba(6,9,18,.86) 0%, rgba(6,9,18,.62) 28%, rgba(6,9,18,.22) 56%, rgba(6,9,18,0) 80%),
    linear-gradient(0deg, rgba(6,9,18,.92) 0%, rgba(6,9,18,0) 40%),
    linear-gradient(180deg, rgba(6,9,18,.55) 0%, rgba(6,9,18,0) 22%);
}
.hero__content{
  position:relative; z-index:2;
  max-width:var(--maxw); margin:0 auto; width:100%;
  padding:0 clamp(20px,4vw,46px);
}
.hero__inner{ max-width:620px; }
.hero__logo{
  width:min(480px,72%); margin-bottom:26px;
  filter:drop-shadow(0 6px 30px rgba(0,0,0,.6));
}
.hero__tome{
  display:inline-block; margin-bottom:20px;
  font-family:var(--display); letter-spacing:.34em; text-transform:uppercase;
  font-size:.8rem; color:var(--gold-bright);
  border:1px solid var(--hairline); border-radius:2px;
  padding:8px 18px; background:rgba(8,11,21,.4);
}
.hero__title{
  font-family:var(--display); font-weight:700;
  font-size:clamp(2.1rem,5.2vw,3.6rem); line-height:1.08;
  color:#f5eeda; margin:0 0 22px;
  text-shadow:0 4px 28px rgba(0,0,0,.6);
}
.hero__title .em{
  color:var(--emerald-br);
  text-shadow:0 0 26px rgba(52,201,140,.35);
}
.hero__sub{
  font-size:1.32rem; color:var(--text); max-width:540px; margin:0 0 38px;
}
.hero__cta{
  display:flex; gap:16px; flex-wrap:wrap;
}
/* hero entrance via reveal class (JS-driven, reliable) */
.hero__inner .reveal{ transition-duration:.9s; }

/* buttons */
.btn{
  font-family:var(--display); font-size:.82rem; letter-spacing:.18em;
  text-transform:uppercase; cursor:pointer;
  padding:16px 32px; border-radius:2px; border:1px solid transparent;
  transition:transform .2s ease, box-shadow .3s ease, background .3s ease, color .3s ease;
  display:inline-flex; align-items:center; gap:10px;
}
.btn-gold{
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  color:#2a1f08; border-color:var(--gold-bright);
  box-shadow:0 6px 26px rgba(201,168,90,.28), inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 12px 36px rgba(201,168,90,.45), inset 0 1px 0 rgba(255,255,255,.55); }
.btn-ghost{
  background:rgba(8,11,21,.35); color:var(--text); border-color:var(--hairline);
}
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-bright); transform:translateY(-2px); }

.scrolldown{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  z-index:3; color:var(--text-dim); font-family:var(--display);
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  animation:fade 2s ease-in-out infinite;
}
.scrolldown span{ width:1px; height:34px; background:linear-gradient(var(--gold),transparent); }
@media(max-height:760px){ .scrolldown{ display:none; } }

/* =========================================================
   LE LIVRE / SYNOPSIS
   ========================================================= */
.livre{ background:
    radial-gradient(120% 90% at 80% 0%, rgba(31,158,110,.06), transparent 60%),
    var(--night-1);
  border-top:1px solid var(--hairline-soft);
}
.livre__grid{
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(40px,6vw,80px);
  align-items:center;
}
.livre__text h2{
  font-family:var(--display); font-weight:700;
  font-size:clamp(1.9rem,3.6vw,2.8rem); color:#f3ecda; margin:.4em 0 .7em;
  line-height:1.15;
}
.livre__text .drop::first-letter{
  font-family:var(--display); float:left; font-size:4.4rem; line-height:.82;
  padding:6px 12px 0 0; color:var(--gold-bright);
}
.livre__text p{ margin:0 0 1.3em; }
.livre__meta{
  display:flex; flex-wrap:wrap; gap:14px 34px; margin-top:34px;
  padding-top:30px; border-top:1px solid var(--hairline-soft);
}
.livre__meta div span{
  display:block; font-family:var(--display); font-size:.66rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold); margin-bottom:5px;
}
.livre__meta div strong{ font-weight:500; font-size:1.05rem; color:var(--text); }

/* book cover mock */
.cover-stage{ display:flex; justify-content:center; perspective:1400px; }
.book{
  position:relative; width:min(360px,82%); aspect-ratio:2/3;
  border-radius:4px 8px 8px 4px;
  background:
    linear-gradient(115deg, rgba(255,255,255,.06), transparent 40%),
    radial-gradient(130% 100% at 50% -10%, rgba(31,158,110,.18), transparent 55%),
    var(--night-2);
  box-shadow:
    -18px 26px 60px rgba(0,0,0,.6),
    inset 0 0 0 1px var(--hairline),
    inset 9px 0 18px rgba(0,0,0,.5);
  transform:rotateY(-16deg) rotateX(3deg);
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
  padding:42px 34px; display:flex; flex-direction:column; align-items:center;
  text-align:center; overflow:hidden;
}
.book::before{ /* spine */
  content:""; position:absolute; left:0; top:0; bottom:0; width:14px;
  background:linear-gradient(90deg, rgba(0,0,0,.55), rgba(255,255,255,.05) 60%, rgba(0,0,0,.4));
}
.cover-stage:hover .book{ transform:rotateY(-7deg) rotateX(1deg); }
.book__frame{
  position:absolute; inset:16px; border:1px solid var(--hairline);
  border-radius:3px; pointer-events:none;
}
.book__logo{ width:88%; margin:6% auto 0; filter:drop-shadow(0 4px 14px rgba(0,0,0,.5)); }
.book__meta{ margin-top:auto; }
.book__title{
  font-family:var(--display); font-size:1rem; letter-spacing:.14em;
  color:var(--gold-bright); text-transform:uppercase; margin:0 0 6px;
}
.book__tome{ font-size:.85rem; letter-spacing:.3em; color:var(--text-dim); text-transform:uppercase; font-family:var(--display); }
.book__gem{
  width:20px; height:34px; margin:14px auto 0;
  background:linear-gradient(180deg,var(--emerald-br),var(--emerald));
  clip-path:polygon(50% 0,100% 28%,100% 72%,50% 100%,0 72%,0 28%);
  box-shadow:0 0 22px rgba(52,201,140,.6);
}

/* book cover : full-bleed image (spine excluded) with text overlaid */
.book--cover{ padding:0; }
.book__cover{
  position:absolute; top:0; right:0; bottom:0; left:14px;
  object-fit:cover; object-position:center;
  border-radius:0 8px 8px 0;
  z-index:0;
}
.book--cover::after{
  content:""; position:absolute; left:14px; right:0; bottom:0; height:58%;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82));
  border-radius:0 0 8px 0;
  z-index:1; pointer-events:none;
}
.book--cover .book__frame{ z-index:2; }
.book--cover .book__meta{
  position:absolute; left:14px; right:0; bottom:0; z-index:3;
  margin:0; padding:0 20px 24px; text-align:center;
}

/* =========================================================
   VINCULUM / ORDRES
   ========================================================= */
.magie{ background:var(--night); position:relative; }
.magie__intro{ max-width:760px; margin:0 auto clamp(48px,6vw,72px); text-align:center; }
.ordres{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
}
.ordre{
  position:relative; padding:34px 26px 30px;
  background:linear-gradient(180deg, var(--night-2), var(--night-1));
  border:1px solid var(--hairline-soft); border-radius:4px;
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
  overflow:hidden;
}
.ordre::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px;
  background:var(--accent,var(--gold));
  opacity:.85;
}
.ordre:hover{ transform:translateY(-6px); border-color:var(--hairline);
  box-shadow:0 20px 50px rgba(0,0,0,.5); }
.ordre__gem{
  width:64px; aspect-ratio:537.75 / 540; margin:0 auto 20px; display:block;
  background-image:url('/images/gemmes.png');
  background-repeat:no-repeat;
  background-size:400% 100%;
  filter:drop-shadow(0 7px 16px color-mix(in srgb,var(--accent) 55%, transparent));
}
.ordre__gem--foyer{ background-position-x:0%; }
.ordre__gem--conjonction{ background-position-x:33.3333%; }
.ordre__gem--voile{ background-position-x:66.6667%; }
.ordre__gem--astrolabe{ background-position-x:100%; }
.ordre h3{
  font-family:var(--display); font-weight:600; font-size:1.18rem;
  letter-spacing:.06em; color:#f0e8d4; margin:0 0 4px;
}
.ordre .ordre__gemname{
  font-family:var(--display); font-size:.66rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--accent); margin-bottom:14px;
}
.ordre p{ font-size:1rem; color:var(--text-dim); margin:0; line-height:1.6; }

.vinc-band{
  margin-top:clamp(48px,6vw,76px);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,64px);
  align-items:center;
  background:linear-gradient(180deg, var(--night-1), var(--night-2));
  border:1px solid var(--hairline-soft); border-radius:6px;
  padding:clamp(34px,4vw,56px);
}
.vinc-band img{
  border-radius:4px; box-shadow:0 18px 50px rgba(0,0,0,.6);
  border:1px solid var(--hairline);
}
/* Vinculum zoom trigger + lightbox */
.vinc-zoom{
  position:relative; display:block; padding:0; margin:0; border:none;
  background:none; cursor:zoom-in; width:100%; border-radius:4px;
}
.vinc-zoom img{ width:100%; transition:transform .4s ease, box-shadow .4s ease; }
.vinc-zoom:hover img{ box-shadow:0 22px 60px rgba(0,0,0,.7); }
.vinc-zoom__hint{
  position:absolute; bottom:14px; left:50%; transform:translateX(-50%) translateY(6px);
  font-family:var(--display); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold-bright); background:rgba(8,11,21,.82); border:1px solid var(--hairline);
  padding:9px 16px; border-radius:30px; white-space:nowrap;
  opacity:0; transition:opacity .3s ease, transform .3s ease; pointer-events:none;
}
.vinc-zoom:hover .vinc-zoom__hint{ opacity:1; transform:translateX(-50%) translateY(0); }
.lightbox{
  position:fixed; inset:0; z-index:200; display:grid; place-items:center;
  padding:32px; background:rgba(5,7,14,.92); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .28s ease; cursor:zoom-out;
}
.lightbox[hidden]{ display:none; }
.lightbox.open{ opacity:1; }
.lightbox img{
  max-width:min(94vw,760px); max-height:92vh; object-fit:contain;
  border:1px solid var(--hairline); border-radius:6px;
  box-shadow:0 30px 90px rgba(0,0,0,.7);
  transform:scale(.96); transition:transform .28s cubic-bezier(.2,.7,.2,1);
}
.lightbox.open img{ transform:scale(1); }
.lightbox__close{
  position:fixed; top:22px; right:26px; z-index:201;
  width:48px; height:48px; border-radius:50%; cursor:pointer;
  background:rgba(8,11,21,.6); border:1px solid var(--hairline);
  color:var(--gold-bright); font-size:1.8rem; line-height:1; display:grid; place-items:center;
  transition:background .25s ease, transform .25s ease;
}
.lightbox__close:hover{ background:var(--gold); color:var(--night); transform:rotate(90deg); }
.vinc-band h3{
  font-family:var(--display); font-weight:700; font-size:clamp(1.6rem,3vw,2.3rem);
  color:#f3ecda; margin:0 0 .5em; line-height:1.15;
}
.vinc-steps{ list-style:none; padding:0; margin:24px 0 0; }
.vinc-steps li{
  display:flex; gap:16px; padding:14px 0; border-top:1px solid var(--hairline-soft);
}
.vinc-steps li:first-child{ border-top:none; }
.vinc-steps .n{
  flex:none; width:34px; height:34px; border-radius:50%;
  border:1px solid var(--gold); color:var(--gold-bright);
  display:grid; place-items:center; font-family:var(--display); font-size:.9rem;
}
.vinc-steps .t strong{ display:block; font-family:var(--display); color:#efe7d3; font-weight:600; letter-spacing:.04em; font-size:1.02rem; }
.vinc-steps .t span{ font-size:.98rem; color:var(--text-dim); }

/* =========================================================
   UNIVERS / CARTE
   ========================================================= */
.univers{
  position:relative;
  background:
    linear-gradient(180deg, var(--night) 0%, var(--night-1) 100%);
  border-top:1px solid var(--hairline-soft);
}
.carte-frame{
  position:relative; margin-top:clamp(36px,5vw,56px);
  border-radius:6px; overflow:hidden;
  border:1px solid var(--hairline);
  box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.carte-frame img{ width:100%; transition:transform 6s ease; }
.carte-frame:hover img{ transform:scale(1.05); }
.carte-frame figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding:26px 28px; color:var(--ink);
  background:linear-gradient(0deg, rgba(236,224,196,.92), rgba(236,224,196,0));
  font-family:var(--serif);
}
.carte-frame figcaption strong{
  font-family:var(--display); display:block; font-size:1.1rem; letter-spacing:.08em;
  color:#3a2f17;
}
.lieux-hint{
  text-align:center; margin:26px 0 0; color:var(--text-faint);
  font-family:var(--display); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
}
.lieux-tags{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:16px; }
.lieux-tags button{
  font-family:var(--display); font-size:.72rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--text-dim); cursor:pointer;
  background:rgba(20,28,46,.5); border:1px solid var(--hairline-soft); border-radius:30px;
  padding:9px 19px; transition:color .25s ease, border-color .25s ease, background .25s ease, transform .2s ease;
}
.lieux-tags button:hover{ color:var(--gold-bright); border-color:var(--gold); background:rgba(20,28,46,.85); transform:translateY(-2px); }

/* Modale lieu — par-dessus la carte */
.map-modal{
  position:fixed; inset:0; z-index:210; display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,48px);
  background:rgba(5,7,14,.9); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .3s ease;
}
.map-modal.open{ opacity:1; }
.map-modal[hidden]{ display:none; }
.map-modal__panel{
  position:relative; width:min(560px,100%); max-height:100%; overflow:auto;
  background:linear-gradient(180deg, rgba(17,24,43,.97), rgba(12,17,32,.98));
  border:1px solid var(--hairline); border-radius:6px;
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  padding:clamp(26px,3.5vw,40px);
  transform:translateY(14px) scale(.98); transition:transform .3s cubic-bezier(.2,.7,.2,1);
}
.map-modal.open .map-modal__panel{ transform:none; }
.map-modal__panel::before{
  content:""; position:absolute; left:0; right:0; top:0; height:3px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.map-modal__close{
  position:absolute; top:14px; right:16px; width:38px; height:38px; border-radius:50%;
  background:rgba(8,11,21,.6); border:1px solid var(--hairline-soft); color:var(--gold-bright);
  font-size:1.5rem; line-height:1; cursor:pointer; display:grid; place-items:center;
  transition:background .25s ease, transform .25s ease;
}
.map-modal__close:hover{ background:var(--gold); color:var(--night); transform:rotate(90deg); }
.map-modal__kicker{
  font-family:var(--display); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.map-modal__title{
  font-family:var(--display); font-weight:700; font-size:clamp(1.5rem,3vw,2rem);
  color:#f3ecda; margin:0 0 6px; letter-spacing:.02em; padding-right:34px;
}
.map-modal__region{
  font-style:italic; color:var(--emerald-br); font-size:1rem; margin-bottom:18px;
  padding-bottom:18px; border-bottom:1px solid var(--hairline-soft);
}
.map-modal__body{ font-size:1.05rem; line-height:1.7; color:var(--text-dim); }
.map-modal__body p{ margin:0 0 1em; }
.map-modal__body p:last-child{ margin-bottom:0; }
.map-modal__body em{ color:var(--text); }

/* =========================================================
   PERSONNAGES
   ========================================================= */
.perso{ background:var(--night-1); border-top:1px solid var(--hairline-soft); }
.perso-subhead{ display:flex; align-items:center; gap:20px; margin:clamp(40px,5vw,66px) 0 26px; }
.perso-subhead span{
  font-family:var(--display); font-size:.74rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--gold); white-space:nowrap;
}
.perso-subhead::after{ content:""; flex:1; height:1px; background:linear-gradient(90deg,var(--hairline),transparent); }
.perso-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px;
}
.card{
  position:relative; border:1px solid var(--hairline-soft); border-radius:5px;
  overflow:hidden; background:var(--night-2);
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.card:hover{ transform:translateY(-6px); border-color:var(--hairline); box-shadow:0 20px 50px rgba(0,0,0,.5); }
.card.feature{ grid-column:span 3; display:grid; grid-template-columns:.9fr 1.1fr; }
.card__portrait{
  position:relative; aspect-ratio:7/10; background:var(--night-3);
}
.card.feature .card__portrait{ aspect-ratio:3/4; min-height:0; align-self:stretch; }
.card__body{ padding:26px 28px; display:flex; flex-direction:column; }
.card.feature .card__body{ justify-content:center; padding:clamp(28px,4vw,52px); }
.card__role{ font-family:var(--display); font-size:.64rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.card__name{ font-family:var(--display); font-weight:600; font-size:1.3rem; color:#f0e8d4; margin:0 0 4px; letter-spacing:.03em; }
.card.feature .card__name{ font-size:clamp(1.8rem,3vw,2.5rem); }
.card__order{ font-size:.95rem; color:var(--emerald-br); margin-bottom:14px; font-style:italic; }
.card__desc{ font-size:1rem; color:var(--text-dim); margin:0; }
.card.feature .card__desc{ font-size:1.18rem; line-height:1.7; color:var(--text); }
.card__tag{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--display); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  background:rgba(8,11,21,.7); border:1px solid var(--hairline);
  color:var(--gold-bright); padding:6px 12px; border-radius:2px;
}
.card__tag.foe{ color:#e69a8e; border-color:rgba(208,90,74,.5); }

.card__portrait img.card__img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}

/* portrait placeholder (en attendant les illustrations) */
.portrait-ph{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  text-align:center; padding:18px;
  font-family:var(--display); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--text-faint); line-height:1.5;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(201,168,90,.06), transparent 60%),
    repeating-linear-gradient(45deg, rgba(216,210,196,.025) 0 12px, transparent 12px 24px),
    var(--night-3);
}
.portrait-ph::before{
  content:""; position:absolute; inset:14px; border:1px solid var(--hairline-soft); border-radius:3px;
}

/* =========================================================
   CTA / NEWSLETTER
   ========================================================= */
.finale{
  position:relative; text-align:center;
  background:
    linear-gradient(0deg, rgba(8,11,21,.7), rgba(8,11,21,.7)),
    url("/images/hero_bg.png") center/cover fixed no-repeat;
  border-top:1px solid var(--hairline);
}
.finale h2{
  font-family:var(--display); font-weight:700; color:#f5eeda;
  font-size:clamp(2rem,4.6vw,3.4rem); margin:.4em 0; line-height:1.1;
}
.finale p{ max-width:560px; margin:0 auto 36px; color:var(--text); font-size:1.25rem; }
.finale__extrait{ margin:0 auto 40px; }
.finale__extrait .btn{ font-size:.82rem; padding:16px 34px; }
.news{
  display:flex; gap:12px; max-width:520px; margin:0 auto; flex-wrap:wrap;
  justify-content:center;
}
.news input{
  flex:1 1 260px; background:rgba(8,11,21,.6); border:1px solid var(--hairline);
  color:var(--text); padding:15px 20px; border-radius:2px; font-family:var(--serif);
  font-size:1.05rem;
}
.news input::placeholder{ color:var(--text-faint); }
.news input:focus{ outline:none; border-color:var(--gold); }
.news .ok{ color:var(--emerald-br); margin-top:18px; font-style:italic; min-height:1.4em; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  background:var(--night); border-top:1px solid var(--hairline-soft);
  padding:56px 28px 40px; text-align:center;
}
.footer .brand{
  font-family:var(--display); font-weight:700; letter-spacing:.24em;
  color:var(--gold-bright); text-transform:uppercase; font-size:1rem;
}
.footer .motto{ font-style:italic; color:var(--text-dim); margin:10px 0 24px; letter-spacing:.06em; }
.footer nav{ display:flex; gap:24px; justify-content:center; flex-wrap:wrap; margin-bottom:24px; }
.footer nav a{ font-family:var(--display); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); }
.footer nav a:hover{ color:var(--gold-bright); }
.footer small{ color:var(--text-faint); font-size:.8rem; letter-spacing:.04em; }

/* =========================================================
   reveal anim
   ========================================================= */
@keyframes rise{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@keyframes fade{ 0%,100%{ opacity:.3; } 50%{ opacity:1; } }
.reveal{ opacity:1; transform:none; transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal-ready .reveal:not(.in){ opacity:0; transform:translateY(34px); }

@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}
/* Tweak: disable motion */
body.anims-off .reveal{ transition:none !important; opacity:1 !important; transform:none !important; }
body.anims-off .ordre,
body.anims-off .card,
body.anims-off .book,
body.anims-off .carte-frame img,
body.anims-off .btn{ transition:none !important; }
body.anims-off .ordre:hover,
body.anims-off .card:hover,
body.anims-off .btn:hover{ transform:none !important; }
body.anims-off .scrolldown{ animation:none !important; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .ordres{ grid-template-columns:repeat(2,1fr); }
  .vinc-band{ grid-template-columns:1fr; }
  .livre__grid{ grid-template-columns:1fr; }
  .cover-stage{ order:-1; margin-bottom:20px; }
  .perso-grid{ grid-template-columns:repeat(2,1fr); }
  .card.feature{ grid-column:span 2; grid-template-columns:1fr; }
  .card.feature .card__portrait{ max-width:380px; width:100%; margin:0 auto; }
}
@media(max-width:600px){
  body{ font-size:18px; }
  .ordres{ grid-template-columns:1fr; }
  .perso-grid{ grid-template-columns:1fr; }
  .card.feature{ grid-column:span 1; }
  .hero__cta{ flex-direction:column; align-items:stretch; }
  .btn{ justify-content:center; }
  .hero__bg{ background-size:cover; background-position:center center; }
}

/* =========================================================
   ACTUALITÉS
   ========================================================= */
.actus{ background:var(--night); border-top:1px solid var(--hairline-soft); }
.actus-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
.actu{
  display:flex; flex-direction:column; cursor:pointer;
  border:1px solid var(--hairline-soft); border-radius:6px; overflow:hidden;
  background:linear-gradient(180deg, var(--night-2), var(--night-1));
  transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.actu:hover{ transform:translateY(-6px); border-color:var(--hairline); box-shadow:0 22px 54px rgba(0,0,0,.5); }
.actu--feature{ grid-column:1 / -1; flex-direction:row; }
.actu__media{ position:relative; background:var(--night-3); aspect-ratio:16/10; }
.actu--feature .actu__media{ flex:0 0 46%; aspect-ratio:auto; min-height:300px; }
.actu__img, .actu__ph{ position:absolute; inset:0; width:100%; height:100%; }
.actu__img{ object-fit:cover; object-position:50% 40%; }
.actu__cat{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--display); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  background:rgba(8,11,21,.78); border:1px solid var(--hairline);
  color:var(--gold-bright); padding:6px 13px; border-radius:2px;
}
.actu__body{ padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.actu--feature .actu__body{ justify-content:center; padding:clamp(28px,4vw,48px); }
.actu__date{
  font-family:var(--display); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:12px;
}
.actu__title{
  font-family:var(--display); font-weight:600; color:#f0e8d4; letter-spacing:.02em;
  font-size:1.3rem; line-height:1.22; margin:0 0 12px;
}
.actu--feature .actu__title{ font-size:clamp(1.6rem,2.6vw,2.2rem); }
.actu__excerpt{ font-size:1.02rem; color:var(--text-dim); line-height:1.65; margin:0 0 18px; }
.actu--feature .actu__excerpt{ font-size:1.12rem; }
.actu__more{
  margin-top:auto; font-family:var(--display); font-size:.72rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--gold-bright); cursor:pointer;
  align-self:flex-start; transition:gap .2s ease, color .2s ease;
}
.actu__more:hover{ color:var(--gold); }
.actus-all{ text-align:center; margin-top:clamp(34px,4vw,52px); }
.actus-empty{ text-align:center; color:var(--text-dim); font-size:1.2rem; padding:40px 0; }

.actus-pagination{
  display:flex; justify-content:center; align-items:center; gap:8px; flex-wrap:wrap;
  margin-top:clamp(34px,4vw,52px);
}
.actus-pagination a, .actus-pagination span{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:42px; height:42px; padding:0 14px;
  font-family:var(--display); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  border:1px solid var(--hairline); color:var(--gold); border-radius:2px;
  transition:background .25s ease, color .25s ease, border-color .25s ease;
}
.actus-pagination a:hover{ border-color:var(--gold); color:var(--gold-bright); }
.actus-pagination .current{ background:var(--gold); color:var(--night); border-color:var(--gold); }

/* News modal (plein écran) */
.news-modal{
  position:fixed; inset:0; z-index:210; display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,48px);
  background:rgba(5,7,14,.9); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .3s ease;
}
.news-modal.open{ opacity:1; }
.news-modal[hidden]{ display:none; }
.news-modal__panel{
  position:relative; width:min(720px,100%); max-height:90vh; overflow:auto;
  background:linear-gradient(180deg, var(--night-2), var(--night-1));
  border:1px solid var(--hairline); border-radius:8px;
  box-shadow:0 30px 90px rgba(0,0,0,.7);
}
.news-modal__panel::before{
  content:""; position:absolute; left:0; right:0; top:0; height:3px; z-index:3;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.news-modal__close{
  position:fixed; top:22px; right:26px; z-index:212;
  width:46px; height:46px; border-radius:50%; cursor:pointer;
  background:rgba(8,11,21,.7); border:1px solid var(--hairline); color:var(--gold-bright);
  font-size:1.7rem; line-height:1; display:grid; place-items:center;
  transition:background .25s ease, transform .25s ease;
}
.news-modal__close:hover{ background:var(--gold); color:var(--night); transform:rotate(90deg); }
.news-modal__imgwrap{ position:relative; aspect-ratio:16/8; background:var(--night-3); overflow:hidden; }
.news-modal__imgwrap img{ width:100%; height:100%; object-fit:cover; object-position:50% 40%; }
.news-modal__imgwrap::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(12,17,32,.85), transparent 55%);
}
.news-modal__content{ padding:clamp(28px,4vw,52px); }
.news-modal__cat{
  font-family:var(--display); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.news-modal__date{
  display:block; font-style:italic; color:var(--emerald-br); font-size:1rem; margin-bottom:14px;
}
.news-modal__title{
  font-family:var(--display); font-weight:700; color:#f3ecda; letter-spacing:.02em;
  font-size:clamp(1.7rem,3.4vw,2.6rem); line-height:1.18; margin:0 0 22px;
}
.news-modal__body{ font-size:1.12rem; line-height:1.75; color:var(--text-dim); }
.news-modal__body p{ margin:0 0 1.1em; }
.news-modal__body p:last-child{ margin-bottom:0; }
.news-modal__body strong{ color:var(--text); font-weight:600; }
.news-modal__body em{ color:var(--gold-bright); font-style:italic; }

/* Hero page Actualités */
.nav nav a.active{ color:var(--gold-bright); }
.nav nav a.active::after{ width:100%; }
.actus-hero{
  position:relative; min-height:clamp(440px,64vh,660px);
  display:flex; align-items:center; overflow:hidden;
  padding:120px 0 56px; background:#05070e;
  border-bottom:1px solid var(--hairline);
}
.actus-hero__bg{
  position:absolute; left:0; right:0; top:-8%; height:116%;
  background:url("/images/actualites_hero.png") center right/cover no-repeat;
  transform:scale(1.06); transform-origin:center;
  transition:transform .18s ease-out; will-change:transform;
}
.actus-hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(6,9,18,.94) 0%, rgba(6,9,18,.78) 30%, rgba(6,9,18,.34) 58%, rgba(6,9,18,.08) 82%),
    linear-gradient(0deg, rgba(6,9,18,.85) 0%, rgba(6,9,18,0) 38%),
    linear-gradient(180deg, rgba(6,9,18,.6) 0%, rgba(6,9,18,0) 24%);
}
.actus-hero__content{
  position:relative; z-index:2; width:100%;
  max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,4vw,46px);
}
.actus-hero__inner{ max-width:600px; }
.actus-hero .flourish{ justify-content:flex-start; margin-bottom:22px; }
.actus-hero .flourish::before{ display:none; }
.actus-hero__eyebrow{
  font-family:var(--display); font-size:.74rem; letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold); font-weight:600;
}
.actus-hero h1{
  font-family:var(--display); font-weight:700; color:#f5eeda;
  font-size:clamp(2.6rem,6.5vw,4.4rem); letter-spacing:.03em; line-height:1.05;
  margin:.18em 0 .35em; text-shadow:0 4px 28px rgba(0,0,0,.6);
}
.actus-hero p{ max-width:480px; color:var(--text); font-size:1.28rem; margin:0 0 32px; }
.actus-hero .back{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--display); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold-bright); border:1px solid var(--hairline); border-radius:2px; padding:13px 24px;
  background:rgba(8,11,21,.4); transition:background .25s ease, color .25s ease, transform .2s ease;
}
.actus-hero .back:hover{ background:var(--gold); color:var(--night); transform:translateY(-2px); }

/* En-tête page article (détail) */
.page-head{
  position:relative; padding:clamp(120px,16vh,180px) 28px clamp(40px,6vw,64px);
  text-align:center; overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(31,158,110,.10), transparent 60%),
    linear-gradient(180deg, var(--night-1), var(--night));
  border-bottom:1px solid var(--hairline-soft);
}
.page-head__cat{
  font-family:var(--display); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.page-head h1{
  font-family:var(--display); font-weight:700; color:#f3ecda;
  font-size:clamp(2.2rem,5vw,3.4rem); letter-spacing:.03em; line-height:1.12; margin:0 auto .5em; max-width:760px;
}
.page-head__date{ display:block; font-style:italic; color:var(--emerald-br); font-size:1.05rem; }
.page-head .back{
  display:inline-flex; align-items:center; gap:8px; margin-top:26px;
  font-family:var(--display); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--hairline); border-radius:2px; padding:11px 22px;
  transition:background .25s ease, color .25s ease;
}
.page-head .back:hover{ background:var(--gold); color:var(--night); }
.article-page__cover{ margin-bottom:36px; border:1px solid var(--hairline-soft); border-radius:6px; overflow:hidden; }
.article-page__cover img{ display:block; width:100%; height:auto; }
.article-page__body{ font-size:1.12rem; line-height:1.8; color:var(--text-dim); }
.article-page__body p{ margin:0 0 1.1em; }
.article-page__body strong{ color:var(--text); font-weight:600; }
.article-page__body em{ color:var(--gold-bright); font-style:italic; }

@media(max-width:760px){
  .actus-grid{ grid-template-columns:1fr; }
  .actu--feature{ flex-direction:column; }
  .actu--feature .actu__media{ flex:none; aspect-ratio:16/10; min-height:0; }
  .actus-hero__scrim{
    background:linear-gradient(0deg, rgba(6,9,18,.92), rgba(6,9,18,.45));
  }
}
