/* =====================================================================
   DESIGN RESTORATION — ARCHIVE JULES VERNE
   ---------------------------------------------------------------------
   Couche de FINITION premium, chargée EN DERNIER (après archive.css +
   glacial-noir.css). Restaure l'ADN éditorial premium : relief,
   profondeur douce, rythme éditorial, micro-interactions, traitement
   d'image — dans la direction froide « glacial noir » déjà en place.

   PRINCIPES
   · Additif et piloté par les classes .ej-* existantes — aucune
     réécriture de structure, aucun texte modifié.
   · Entièrement réversible : retirer ce <link> (et design-restoration.js)
     restaure exactement l'état précédent.
   · Direction : luxe froid et silencieux. On AJOUTE du relief et de la
     tension — jamais d'aplat, jamais plus sombre, jamais gadget.
   ===================================================================== */

:root {
  /* Relief de luminance (surfaces légèrement relevées vs le fond) */
  --rz-lift:        #122A3A;   /* panneau relevé — océan */
  --rz-lift-2:      #173447;   /* panneau au survol */
  --rz-hairline:    rgba(173, 199, 212, 0.16);
  --rz-hairline-lit:rgba(206, 158, 96, 0.52);   /* filet accentué — dorure cuivre */
  --rz-glow:        rgba(194, 133, 63, 0.28);    /* halo cuivre localisé */
  --rz-ink-deep:    #04080D;   /* encre d'abysse la plus profonde (ombres) */
  /* courbe standard = --ease (archive.css) ; on ne garde que la variante out */
  --rz-ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --rz-shadow-soft: 0 2px 14px rgba(3, 7, 12, 0.45);
  --rz-shadow-card: 0 18px 48px rgba(3, 7, 12, 0.55), 0 2px 6px rgba(3, 7, 12, 0.4);
}

/* =====================================================================
   1. PROFONDEUR DE FOND — relief atmosphérique (sans assombrir)
   ===================================================================== */
/* Une seconde nappe de lumière froide très haute + grain optique discret,
   superposée au voile de glacial-noir, pour casser l'aplat du navy. */
body::after {
  content: "";
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(60% 32% at 50% 0%, rgba(63, 150, 170, 0.07), transparent 70%),
    radial-gradient(40% 24% at 88% 8%, rgba(194, 133, 63, 0.06), transparent 70%);
  mix-blend-mode: screen;
}

/* =====================================================================
   2. RYTHME ÉDITORIAL DES SECTIONS — strates, filets qui se tracent
   ===================================================================== */
/* Alternance de ton très subtile : une section sur deux reçoit un voile
   plus clair → les blocs se lisent comme composés, pas uniformes. */
main > .ej-section:nth-of-type(even):not(.ej-quote) {
  background:
    linear-gradient(180deg, rgba(194, 133, 63, 0.022) 0%, transparent 22%, transparent 78%, rgba(4, 8, 13, 0.30) 100%);
}

/* Filet de section anobli : dégradé lumineux au centre plutôt qu'un trait plat */
.ej-section[style*="border-top"] {
  border-top: 0 !important;
  position: relative;
}
.ej-section[style*="border-top"]::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--rz-hairline-lit) 50%, transparent);
  opacity: 0.7;
}

/* Sur-titre (kicker) : trait qui se trace à l'entrée (piloté par JS .is-drawn) */
.ej-kicker::before {
  transform: scaleX(0.55); transform-origin: left center;
  transition: transform 0.9s var(--rz-ease-out), opacity 0.6s ease;
}
/* le kicker porte lui-même .ej-reveal → reçoit .is-in ; ou son en-tête est tracé */
.ej-section-head.is-drawn .ej-kicker::before,
.ej-kicker.is-in::before { transform: scaleX(1); }

/* En-tête de section : filet horizontal fin qui se trace sous le titre */
.ej-section-head { position: relative; }
.ej-section-head::after {
  content: ""; display: block; height: 1px; margin-top: clamp(1.4rem, 3vw, 2.2rem);
  max-width: 8.5rem;
  background: linear-gradient(90deg, var(--rz-hairline-lit), transparent);
  transform: scaleX(0); transform-origin: left center;
  transition: transform 1s var(--rz-ease-out) 0.15s;
}
.ej-section-head.is-center::after { margin-left: auto; margin-right: auto;
  background: linear-gradient(90deg, transparent, var(--rz-hairline-lit), transparent); }
.ej-section-head.is-drawn::after { transform: scaleX(1); }

/* =====================================================================
   3. HERO — présence éditoriale, profondeur, indice de défilement
   ===================================================================== */
.ej-hero-inner { max-width: var(--container); margin: 0 auto; }
/* Le kicker du hero respire davantage */
.ej-hero .ej-kicker { letter-spacing: 0.26em; opacity: 0.95; }
/* Titre : contraste et tenue typographique */
.ej-hero-title { letter-spacing: -0.025em; line-height: 1.04; text-wrap: balance; }
/* Signature : agrandie pour la présence + filet de séparation discret au-dessus */
.ej-hero-signature {
  position: relative; padding-top: 1.6rem;
  height: clamp(104px, 13vw, 150px); width: auto; opacity: 0.95;
}
.ej-hero-signature::before {
  content: ""; position: absolute; top: 0; left: 0; width: 3.4rem; height: 1px;
  background: linear-gradient(90deg, var(--rz-hairline-lit), transparent);
}
/* Indice de défilement — trait vertical lumineux qui pulse, bas du hero */
.ej-hero::after {
  content: ""; position: absolute; left: 50%; bottom: 1.6rem; width: 1px; height: 46px;
  background: linear-gradient(180deg, transparent, var(--rz-hairline-lit));
  transform: translateX(-50%); transform-origin: bottom; z-index: 2;
  animation: rzScrollCue 2.6s var(--ease) infinite;
}
@keyframes rzScrollCue {
  0%, 100% { opacity: 0.15; transform: translateX(-50%) scaleY(0.55); }
  50%      { opacity: 0.9;  transform: translateX(-50%) scaleY(1); }
}

/* =====================================================================
   4. CARTES — papier muséal froid : relief, rim lumineux, hover noble
   ===================================================================== */
.ej-card {
  background:
    linear-gradient(180deg, var(--rz-lift) 0%, #0B1F2C 100%);
  border-color: var(--rz-hairline);
  box-shadow: var(--rz-shadow-soft);
  transition:
    transform 0.5s var(--ease), box-shadow 0.5s var(--ease),
    border-color 0.5s var(--ease), background 0.5s var(--ease);
}
.ej-card:hover {
  background: linear-gradient(180deg, var(--rz-lift-2) 0%, #102A3C 100%);
  border-color: var(--rz-hairline-lit);
  box-shadow: var(--rz-shadow-card), inset 0 1px 0 rgba(206, 158, 96, 0.16);
  transform: translateY(-6px);
}
/* Liseré HUD supérieur : plus présent, lumière glacier */
.ej-card::before { background: var(--rz-hairline-lit); opacity: 0.6; height: 2px; box-shadow: 0 0 10px var(--rz-glow); }
.ej-card:hover::before { width: 72px; opacity: 1; }
/* Numéro d'index : capitale froide, présence d'archive */
.ej-card-index { color: var(--cu, #C2853F); opacity: 0.9; }
.ej-access-card .ej-card-arrow { transition: gap 0.4s var(--ease), color 0.4s var(--ease); }
.ej-access-card:hover .ej-card-arrow { color: var(--cu-soft, #DDA866); }

/* Cartes œuvres : cadre intérieur + lévitation */
.ej-work {
  background: linear-gradient(180deg, var(--rz-lift) 0%, #0B1E2B 100%);
  box-shadow: var(--rz-shadow-soft); border-color: var(--rz-hairline);
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), border-color 0.5s var(--ease);
}
.ej-work:hover { transform: translateY(-6px); box-shadow: var(--rz-shadow-card); border-color: var(--rz-hairline-lit); }
.ej-work-cover { box-shadow: inset 0 0 0 1px rgba(176, 205, 221, 0.08), inset 0 -40px 60px -40px rgba(3, 7, 12, 0.8); }

/* =====================================================================
   5. BOUTONS — remplissage balayé, focus premium
   ===================================================================== */
.ej-btn { position: relative; overflow: hidden; isolation: isolate; }
/* Balayage lumineux au survol (primary) */
.ej-btn--primary::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(120deg, transparent 20%, rgba(255, 255, 255, 0.55) 50%, transparent 80%);
  transform: translateX(-120%); transition: transform 0.7s var(--rz-ease-out);
}
.ej-btn--primary:hover::after { transform: translateX(120%); }
/* Focus clavier visible et raffiné */
.ej-btn:focus-visible,
.ej-nav-link:focus-visible,
.ej-source-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gl-navy, #0A131C), 0 0 0 4px var(--rz-hairline-lit);
  border-radius: 4px;
}

/* =====================================================================
   6. SECTIONS IMAGE + TEXTE — direction artistique éditoriale
   ===================================================================== */
/* ombre portée sur le CONTENEUR (sinon overflow:hidden la rognerait sur l'img) */
.ej-split-media { position: relative; overflow: hidden; border-radius: var(--radius, 14px); box-shadow: 0 24px 60px rgba(3, 7, 12, 0.5); }
.ej-split-media img { border: 0; border-radius: inherit; }
/* Voile d'étalonnage froid + liseré intérieur (cadre muséal) */
.ej-split-media::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: linear-gradient(180deg, rgba(10, 19, 28, 0) 55%, rgba(5, 9, 14, 0.45) 100%);
  box-shadow: inset 0 0 0 1px var(--rz-hairline);
}
.ej-figure-cap { color: var(--gl-steel, #92A6B4); }

/* =====================================================================
   7. FOOTER — finition : titres laiton froid, liens soulignés animés
   ===================================================================== */
.ej-footer { position: relative; }
.ej-footer::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--rz-hairline-lit), transparent);
  opacity: 0.6;
}
.ej-footer-col a { position: relative; display: inline-block; }
.ej-footer-col a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1px;
  background: var(--cu, #C2853F);
  transform: scaleX(0); transform-origin: left center;
  transition: transform 0.4s var(--ease);
}
.ej-footer-col a:hover::after { transform: scaleX(1); }

/* =====================================================================
   8. RÉVÉLATIONS — courbe raffinée + cascade échelonnée (piloté par JS)
   ===================================================================== */
.ej-reveal {
  transform: translateY(30px) scale(0.992);
  transition:
    opacity 0.9s var(--rz-ease-out), transform 0.9s var(--rz-ease-out);
}
/* will-change seulement tant que non révélé → la couche compositeur est libérée après .is-in */
.ej-reveal:not(.is-in) { will-change: opacity, transform; }
.ej-reveal.is-in { transform: none; }
/* La cascade (transition-delay par index) est appliquée en inline par le JS. */

/* Images à parallaxe / zoom au scroll : préparées par le JS (.ej-parallax) */
.ej-parallax { will-change: transform; }

/* =====================================================================
   9. ACCESSIBILITÉ MOUVEMENT — tout repli proprement
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
  .ej-hero::after { animation: none; opacity: 0.4; }
  .ej-section-head::after,
  .ej-kicker::before { transform: none !important; transition: none; }
  .ej-btn--primary::after { display: none; }
  .ej-parallax { transform: none !important; }
}
