/* =========================================================
   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; position:relative; z-index:2;
  width:42px; height:42px; padding:10px; border:1px solid var(--hairline);
  border-radius:3px; background:rgba(8,11,21,.6); cursor:pointer;
}
.nav-toggle span{
  display:block; height:2px; width:100%; background:var(--gold-bright);
  border-radius:2px; transition:transform .3s ease, opacity .25s ease;
}
.nav-toggle span + span{ margin-top:5px; }
.nav--open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav--open .nav-toggle span:nth-child(2){ opacity:0; }
.nav--open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media(max-width:860px){
  .nav-toggle{ display:block; }
  .nav nav{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:rgba(8,11,21,.98); backdrop-filter:blur(12px);
    border-bottom:1px solid var(--hairline);
    padding:8px clamp(20px,4vw,46px) 18px;
    max-height:0; overflow:hidden; opacity:0; visibility:hidden;
    transition:max-height .35s ease, opacity .25s ease, padding .35s ease, visibility 0s linear .35s;
  }
  .nav--open nav{
    max-height:80vh; opacity:1; visibility:visible;
    transition:max-height .4s ease, opacity .3s ease, padding .4s ease, visibility 0s;
  }
  .nav nav a{
    padding:15px 4px; font-size:.82rem; border-top:1px solid var(--hairline-soft);
  }
  .nav nav a::after{ display:none; }
  .nav .nav-cta{
    margin-top:14px; text-align:center; border-top:1px solid var(--gold);
  }
}

/* =========================================================
   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__eyebrow{
  display:block; margin:0 0 14px;
  font-family:var(--display); font-weight:500; line-height:1.2;
  letter-spacing:.32em; text-transform:uppercase;
  font-size:.78rem; color:var(--gold-bright); text-shadow:none;
}
.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;
  width:calc(100% - 14px); height:100%;
  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-image:image-set(url('/images/gemmes.webp') type('image/webp'), 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;
  background-image:
    linear-gradient(0deg, rgba(8,11,21,.7), rgba(8,11,21,.7)),
    image-set(url("/images/hero_bg.webp") type("image/webp"), url("/images/hero_bg.png"));
  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){
  .hero__bg{ background-size:cover; background-position:center center; }
  .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; }
}

/* =========================================================
   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;
  background-image:image-set(url("/images/actualites_hero.webp") type("image/webp"), url("/images/actualites_hero.png"));
  transform:scale(1.06); transform-origin:center;
  transition:transform .18s ease-out; will-change:transform;
}
.actus-hero--visions .actus-hero__bg{
  background-image:url("/images/visions_hero.png");
  background-image:image-set(url("/images/visions_hero.webp") type("image/webp"), url("/images/visions_hero.png"));
}
.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));
  }
}

/* =========================================================
   VISIONS (galerie vidéos)
   ========================================================= */
.visions{ background:var(--night-1); border-top:1px solid var(--hairline-soft); }
.visions-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.vid{
  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;
}
.vid:hover{ transform:translateY(-6px); border-color:var(--hairline); box-shadow:0 22px 54px rgba(0,0,0,.5); }
.vid__media{ position:relative; background:var(--night-3); aspect-ratio:16/9; overflow:hidden; }
.vid__img, .vid__ph{ position:absolute; inset:0; width:100%; height:100%; }
.vid__img{ object-fit:cover; }
.vid__media::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(0deg, rgba(8,11,21,.5), transparent 45%);
  transition:background .3s ease;
}
.vid:hover .vid__media::after{ background:linear-gradient(0deg, rgba(8,11,21,.35), transparent 55%); }
.vid__cat{
  position:absolute; top:14px; left:14px; z-index:3;
  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;
}
.vid__dur{
  position:absolute; bottom:14px; right:14px; z-index:3;
  font-family:var(--display); font-size:.64rem; letter-spacing:.12em;
  background:rgba(8,11,21,.8); border:1px solid var(--hairline-soft);
  color:var(--text); padding:5px 11px; border-radius:30px;
}
.vid__play{
  position:absolute; z-index:3; top:50%; left:50%; transform:translate(-50%,-50%) scale(1);
  width:62px; height:62px; border-radius:50%;
  background:rgba(8,11,21,.55); border:1.5px solid var(--gold-bright);
  display:grid; place-items:center; backdrop-filter:blur(2px);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), background .3s ease, box-shadow .3s ease;
  box-shadow:0 8px 26px rgba(0,0,0,.45);
}
.vid__tri{
  width:0; height:0; margin-left:4px;
  border-left:18px solid var(--gold-bright);
  border-top:11px solid transparent; border-bottom:11px solid transparent;
  transition:border-left-color .3s ease;
}
.vid:hover .vid__play{ transform:translate(-50%,-50%) scale(1.12); background:var(--gold); box-shadow:0 0 0 8px rgba(201,161,74,.14), 0 10px 30px rgba(0,0,0,.5); }
.vid:hover .vid__tri{ border-left-color:var(--night); }
.vid__soon{
  position:absolute; bottom:14px; left:14px; z-index:3;
  font-family:var(--display); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  background:rgba(31,158,110,.16); border:1px solid rgba(52,201,140,.5);
  color:var(--emerald-br); padding:6px 12px; border-radius:30px;
}
.vid__body{ padding:22px 24px 26px; display:flex; flex-direction:column; flex:1; }
.vid__date{
  font-family:var(--display); font-size:.64rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px;
}
.vid__title{
  font-family:var(--display); font-weight:600; color:#f0e8d4; letter-spacing:.02em;
  font-size:1.18rem; line-height:1.24; margin:0 0 10px;
}
.vid__excerpt{ font-size:.98rem; color:var(--text-dim); line-height:1.6; margin:0; }

/* Modale lecteur vidéo */
.video-modal{
  position:fixed; inset:0; z-index:220; display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,56px);
  background:rgba(4,6,12,.93); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .3s ease;
}
.video-modal.open{ opacity:1; }
.video-modal[hidden]{ display:none; }
.video-modal__panel{
  position:relative; width:min(1000px,100%); max-height:92vh; overflow:auto;
  transform:scale(.97); transition:transform .3s cubic-bezier(.2,.7,.2,1);
}
.video-modal.open .video-modal__panel{ transform:none; }
.video-modal__stage{
  position:relative; aspect-ratio:16/9; width:100%;
  background:#000; border:1px solid var(--hairline); border-radius:6px; overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.7);
}
.video-modal__video{ width:100%; height:100%; display:block; background:#000; }
.video-modal__placeholder{ position:absolute; inset:0; }
.video-modal__placeholder[hidden]{ display:none; }
.video-modal__placeholder img{ width:100%; height:100%; object-fit:cover; filter:brightness(.5) saturate(.9); }
.video-modal__soon{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:24px;
}
.video-modal__soon span{
  font-family:var(--display); font-size:.8rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold-bright); border:1px solid var(--gold); border-radius:30px; padding:10px 22px;
  background:rgba(8,11,21,.5);
}
.video-modal__soon p{ font-family:var(--serif); color:var(--text); font-size:1.15rem; margin:16px 0 0; font-style:italic; }
.video-modal__meta{ padding:24px 6px 0; }
.video-modal__cat{
  font-family:var(--display); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold); margin-bottom:8px;
}
.video-modal__date{ display:block; font-style:italic; color:var(--emerald-br); font-size:.98rem; margin-bottom:10px; }
.video-modal__title{
  font-family:var(--display); font-weight:700; color:#f3ecda; letter-spacing:.02em;
  font-size:clamp(1.5rem,3vw,2.1rem); line-height:1.2; margin:0 0 12px;
}
.video-modal__desc{ font-size:1.08rem; line-height:1.65; color:var(--text-dim); margin:0; max-width:760px; }
.video-modal__close{
  position:fixed; top:22px; right:26px; z-index:222;
  width:46px; height:46px; border-radius:50%; cursor:pointer;
  background:rgba(8,11,21,.6); 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;
}
.video-modal__close:hover{ background:var(--gold); color:var(--night); transform:rotate(90deg); }

@media(max-width:980px){
  .visions-grid{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:600px){
  .visions-grid{ grid-template-columns:1fr; }
}

/* ===================== CONTACT ===================== */
.contact{ background:var(--night); border-top:1px solid var(--hairline-soft);
  background-image:radial-gradient(120% 90% at 15% 0%, rgba(31,158,110,.06), transparent 55%);
}
.contact__grid{
  display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(40px,6vw,84px);
  align-items:start;
}
.flourish--left{ justify-content:flex-start; }
.flourish--left::before{ display:none; }
.contact__intro h2{
  font-family:var(--display); font-weight:700; color:#f3ecda;
  font-size:clamp(1.9rem,3.6vw,2.8rem); line-height:1.15; margin:.45em 0 .5em;
}
.contact__intro .muted{ font-size:1.12rem; }
.contact__direct{
  margin-top:30px; padding-top:24px; border-top:1px solid var(--hairline-soft);
  font-family:var(--display); font-size:.92rem; color:var(--text-dim);
  display:flex; flex-wrap:wrap; align-items:baseline; gap:6px 12px;
}
.contact__direct span{ letter-spacing:.08em; }
.contact__direct a{ color:var(--gold-bright); letter-spacing:.04em; border-bottom:1px solid var(--hairline); padding-bottom:2px; }
.contact__direct a:hover{ border-color:var(--gold); }

.contact__form{
  background:linear-gradient(180deg, var(--night-2), var(--night-1));
  border:1px solid var(--hairline-soft); border-radius:6px;
  padding:clamp(26px,3.4vw,42px);
}
.contact__form .field{ margin-bottom:22px; }
.contact__form label,
.contact__form .field__label{
  display:block; font-family:var(--display); font-size:.7rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--gold); margin-bottom:10px;
}
.contact__form input[type="email"],
.contact__form input[type="text"],
.contact__form textarea{
  width:100%; background:rgba(8,11,21,.6); border:1px solid var(--hairline);
  color:var(--text); padding:14px 16px; border-radius:3px;
  font-family:var(--serif); font-size:1.06rem; line-height:1.5; resize:vertical;
  transition:border-color .25s ease, background .25s ease;
}
.contact__form input::placeholder,
.contact__form textarea::placeholder{ color:var(--text-faint); }
.contact__form input:focus,
.contact__form textarea:focus{ outline:none; border-color:var(--gold); background:rgba(8,11,21,.85); }

.segmented{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.seg{ position:relative; cursor:pointer; }
.seg input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.seg span{
  display:block; text-align:center; padding:13px 10px; border-radius:3px;
  font-family:var(--display); font-size:.78rem; letter-spacing:.04em; white-space:nowrap;
  color:var(--text-dim); background:rgba(8,11,21,.5); border:1px solid var(--hairline);
  transition:color .25s ease, border-color .25s ease, background .25s ease;
}
.seg:hover span{ color:var(--gold-bright); border-color:var(--gold); }
.seg input:checked + span{
  color:var(--night); background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  border-color:var(--gold-bright); font-weight:600;
}
.seg input:focus-visible + span{ box-shadow:0 0 0 3px rgba(201,161,74,.35); }

.contact__form .btn-gold{ width:100%; justify-content:center; margin-top:4px; }
.contact__note{ margin-top:16px; font-size:1rem; line-height:1.55; font-style:italic; min-height:1.4em; }
.contact__note.is-ok{ color:var(--emerald-br); }
.contact__note.is-error{ color:#e69a8e; }

@media(max-width:860px){
  .contact__grid{ grid-template-columns:1fr; gap:34px; }
}
