/* ─────────────────────────────────────────────────────────
   PLONGÉE.TV — Carnet d'expédition
   Direction : éditorial documentaire / Nat-Geo cinematic
   ───────────────────────────────────────────────────────── */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --ink:        #03101e;          /* deep navy */
  --ink-2:      #07182b;
  --ink-3:      #0d2236;
  --paper:      #f1ead4;          /* warm cream */
  --paper-dim:  #d6cdb6;
  --paper-mute: #8b8772;
  --rule:       rgba(241, 234, 212, .14);
  --rule-soft:  rgba(241, 234, 212, .07);
  --gold:       #e9c46a;
  --coral:      #ef6f47;
  --abyss:      #021526;

  --serif:  'Fraunces', 'Times New Roman', serif;
  --sans:   'Hanken Grotesk', system-ui, sans-serif;
  --mono:   'JetBrains Mono', ui-monospace, monospace;
}

html {
  scroll-behavior: smooth;
  background: var(--ink);
}

body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

/* ─── grain de film (overlay global) ─── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: .07;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.85'/></svg>");
  background-size: 240px 240px;
  animation: grain 1s steps(6) infinite;
}
@keyframes grain {
  0%   { transform: translate(0, 0); }
  20%  { transform: translate(-3%, 2%); }
  40%  { transform: translate(2%, -3%); }
  60%  { transform: translate(-2%, 1%); }
  80%  { transform: translate(3%, -1%); }
  100% { transform: translate(0, 0); }
}

::selection { background: var(--gold); color: var(--ink); }

a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
img { display: block; max-width: 100%; }

/* ─── typographie utilitaire ─── */
.serif      { font-family: var(--serif); font-variation-settings: 'opsz' 144, 'SOFT' 0, 'WONK' 0; }
.italic     { font-style: italic; font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1; }
.kicker     { font-family: var(--sans); font-size: 11px; letter-spacing: .28em; text-transform: uppercase; font-weight: 600; }
.rule       { display:inline-block; width:36px; height:1px; background: currentColor; vertical-align: middle; margin-right: 14px; opacity: .5; }
.numeral    { font-family: var(--serif); font-style: italic; font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1; font-weight: 300; }

/* ═════════════════════════════════════════════
   MASTHEAD
   ═════════════════════════════════════════════ */
.masthead {
  position: relative;
  z-index: 50;
  padding: 28px 56px 22px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  border-bottom: 1px solid var(--rule);
  background: var(--ink);
}
.mh-left, .mh-right {
  display: flex;
  align-items: center;
  gap: 28px;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--paper-dim);
}
.mh-right { justify-content: flex-end; }
.mh-left a, .mh-right a { transition: color .2s; }
.mh-left a:hover, .mh-right a:hover { color: var(--gold); }
.mh-logotype {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 32px;
  letter-spacing: .04em;
  text-align: center;
  color: var(--paper);
  font-variation-settings: 'opsz' 144, 'SOFT' 30, 'WONK' 0;
}
.mh-logotype em {
  font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  color: var(--gold);
  font-weight: 300;
}

.mh-issue {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--paper-mute);
}
.mh-account {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 6px 14px;
  transition: border-color .2s, color .2s;
}
.mh-account:hover { border-color: var(--gold); color: var(--gold); }

/* CTA filled (S'abonner) */
.mh-cta {
  display: inline-flex;
  align-items: center;
  background: var(--gold);
  color: var(--ink);
  border: 1px solid var(--gold);
  border-radius: 999px;
  padding: 6px 16px;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 600;
  text-decoration: none;
  transition: opacity .2s, transform .15s;
}
.mh-cta:hover { opacity: .88; transform: translateY(-1px); }

/* sous-bandeau navigation */
.subnav {
  display: flex;
  justify-content: center;
  gap: 32px;
  padding: 14px 56px;
  border-bottom: 1px solid var(--rule);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--paper-dim);
  background: var(--ink);
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(10px);
}
.subnav a {
  position: relative;
  padding: 4px 0;
  transition: color .2s;
}
.subnav a:hover, .subnav a.active { color: var(--gold); }
.subnav a.active::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -15px;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold);
}

/* ═════════════════════════════════════════════
   COVER (hero éditorial)
   ═════════════════════════════════════════════ */
.cover {
  position: relative;
  min-height: 88vh;
  display: grid;
  grid-template-columns: 1fr;
  overflow: hidden;
  background: var(--ink);
  isolation: isolate;
}
.cover-image {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.cover-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 40%;
  filter: saturate(.85) contrast(1.05);
  transform: scale(1.02);
  animation: cover-pan 20s ease-out forwards;
}
@keyframes cover-pan {
  from { transform: scale(1.08) translateX(-1%); }
  to   { transform: scale(1.00) translateX(0); }
}
.cover-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 28% 60%, rgba(3,16,30,.45) 0%, rgba(3,16,30,.85) 65%, var(--ink) 100%),
    linear-gradient(to top, var(--ink) 0%, transparent 35%);
}

.cover-meta-top {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 28px 56px 0;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper-dim);
}
.cover-meta-top .vol {
  display: flex;
  align-items: center;
  gap: 14px;
}
.cover-meta-top .vol::before {
  content: '';
  display: inline-block;
  width: 22px; height: 1px;
  background: var(--gold);
}

.cover-headline {
  position: relative;
  z-index: 2;
  padding: 14vh 56px 80px;
  max-width: 1180px;
}
.cover-kicker {
  font-size: 11px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 28px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 14px;
}
.cover-kicker::before {
  content: '';
  width: 36px; height: 1px;
  background: var(--gold);
}

.cover-title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(72px, 13vw, 200px);
  line-height: .85;
  letter-spacing: -.045em;
  color: var(--paper);
  margin-bottom: 32px;
  font-variation-settings: 'opsz' 144, 'SOFT' 0, 'WONK' 0;
}
.cover-title .it {
  display: block;
  font-style: italic;
  color: var(--gold);
  margin-left: .4em;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}

.cover-deck {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 22px;
  line-height: 1.4;
  max-width: 580px;
  color: var(--paper-dim);
  margin-bottom: 40px;
  font-variation-settings: 'opsz' 36, 'SOFT' 30;
}
.cover-deck::first-letter {
  font-style: italic;
  color: var(--gold);
  font-size: 1.4em;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  margin-right: 2px;
}

.cover-actions {
  display: flex;
  gap: 24px;
  align-items: center;
}
.btn-watch {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 14px 28px 14px 22px;
  background: var(--gold);
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  border-radius: 999px;
  transition: transform .2s, background .2s;
}
.btn-watch:hover { transform: translateY(-2px); background: var(--paper); }
.btn-watch .ico {
  width: 28px; height: 28px;
  background: var(--ink);
  color: var(--gold);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.btn-watch .ico svg { margin-left: 1px; }

.btn-link {
  font-size: 12px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 4px;
  transition: gap .2s, color .2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn-link:hover { color: var(--gold); gap: 12px; }

/* Cover side-bar (info colonne droite) */
.cover-sidecard {
  position: absolute;
  right: 56px;
  bottom: 80px;
  z-index: 3;
  width: 240px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-items: flex-start;
  padding: 22px;
  border: 1px solid var(--rule);
  background: rgba(3,16,30,.55);
  backdrop-filter: blur(14px);
  text-align: left;
}
.cover-sidecard .sk { font-size: 10px; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); }
.cover-sidecard .sn {
  font-family: var(--serif);
  font-style: italic;
  font-size: 36px;
  line-height: 1;
  color: var(--paper);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  font-weight: 300;
}
.cover-sidecard ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 12px;
  width: 100%;
}
.cover-sidecard ul li {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 5px;
  color: var(--paper-dim);
}
.cover-sidecard ul li span:last-child { color: var(--paper); }

/* ═════════════════════════════════════════════
   CHAPITRES
   ═════════════════════════════════════════════ */
.chapter {
  padding: 96px 56px 24px;
  border-top: 1px solid var(--rule);
  position: relative;
}
.chapter-mark {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: end;
  gap: 32px;
  margin-bottom: 56px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--rule);
}
.chapter-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 92px;
  line-height: .8;
  color: var(--gold);
  font-weight: 300;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  letter-spacing: -.03em;
}
.chapter-num small {
  font-style: normal;
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--paper-mute);
  display: block;
  margin-bottom: 10px;
  font-variation-settings: normal;
}
.chapter-title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 42px;
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--paper);
  font-variation-settings: 'opsz' 144;
}
.chapter-title em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.chapter-link {
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper-dim);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 4px;
  transition: color .2s, border-color .2s, gap .2s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.chapter-link:hover { color: var(--gold); border-color: var(--gold); gap: 12px; }

/* ── grille asymétrique « parutions » ── */
.grid-features {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px 20px;
}
.feat-card {
  position: relative;
  display: block;
  overflow: hidden;
}
.feat-card .photo {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--ink-3);
  position: relative;
}
.feat-card .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.9);
  transition: transform .8s cubic-bezier(.2,.7,.2,1), filter .4s;
}
.feat-card:hover .photo img { transform: scale(1.05); filter: saturate(1.1); }
.feat-card .photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 65%, rgba(3,16,30,.65));
}

.feat-card .num {
  position: absolute;
  top: 14px;
  left: 14px;
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: var(--gold);
  z-index: 2;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  font-weight: 300;
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
}
.feat-card .runtime {
  position: absolute;
  bottom: 14px;
  right: 14px;
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--paper);
  z-index: 2;
  font-feature-settings: 'tnum';
}
.feat-card .body {
  padding: 16px 0 0;
}
.feat-card .cat {
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}
.feat-card h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -.01em;
  color: var(--paper);
  margin-bottom: 10px;
  font-variation-settings: 'opsz' 36, 'SOFT' 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.feat-card .meta {
  font-size: 12px;
  color: var(--paper-mute);
  display: flex;
  gap: 10px;
  align-items: center;
  font-feature-settings: 'tnum';
}
.feat-card .meta b { color: var(--gold); font-weight: 500; }

/* tailles asymétriques */
.span-7 { grid-column: span 7; }
.span-5 { grid-column: span 5; }
.span-4 { grid-column: span 4; }
.span-3 { grid-column: span 3; }
.span-6 { grid-column: span 6; }
.span-8 { grid-column: span 8; }

.tall .photo { aspect-ratio: 4/5; }
.wide .photo { aspect-ratio: 16/9; }
.cinema .photo { aspect-ratio: 21/9; }

.feat-card.cover-style h3 {
  font-size: 36px;
  font-style: italic;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  font-weight: 300;
}

/* ═════════════════════════════════════════════
   FEATURE STORY (pull-quote / cinemascope)
   ═════════════════════════════════════════════ */
.story {
  position: relative;
  margin: 96px 0 0;
  padding: 0;
  border-top: 1px solid var(--rule);
}
.story-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  min-height: 78vh;
  align-items: stretch;
}
.story-img {
  position: relative;
  overflow: hidden;
  background: var(--ink-3);
}
.story-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(.95) contrast(1.05);
}
.story-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(45deg, rgba(3,16,30,.4) 0%, transparent 100%);
}
.story-body {
  padding: 80px 64px;
  background: var(--ink-2);
  border-left: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.story-mark {
  font-family: var(--serif);
  font-size: 110px;
  line-height: .8;
  color: var(--gold);
  font-style: italic;
  font-weight: 300;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  margin-bottom: 24px;
  display: block;
}
.story-kicker {
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
}
.story-body h2 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 46px;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--paper);
  margin-bottom: 28px;
  font-variation-settings: 'opsz' 144;
}
.story-body h2 em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.story-body p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--paper-dim);
  margin-bottom: 22px;
  max-width: 460px;
}
.story-body p::first-letter {
  font-family: var(--serif);
  font-style: italic;
  font-size: 3em;
  line-height: .9;
  float: left;
  color: var(--gold);
  margin: 6px 8px 0 0;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.story-credits {
  display: flex;
  gap: 32px;
  margin-top: 12px;
  border-top: 1px solid var(--rule);
  padding-top: 22px;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--paper-mute);
}
.story-credits b { color: var(--paper); display: block; margin-top: 4px; letter-spacing: 0; text-transform: none; font-size: 14px; }

/* ═════════════════════════════════════════════
   SÉRIES (galerie horizontale d'affiches)
   ═════════════════════════════════════════════ */
.posters {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 8px 56px 32px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  margin: 0 -56px;
}
.posters::-webkit-scrollbar { display: none; }
.poster {
  flex: 0 0 280px;
  scroll-snap-align: start;
  position: relative;
  display: block;
}
.poster .photo {
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--ink-3);
  position: relative;
}
.poster .photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.85);
  transition: transform .8s, filter .4s;
}
.poster:hover .photo img { transform: scale(1.05); filter: saturate(1.05); }
.poster .photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(3,16,30,.95) 0%, transparent 60%);
}
.poster .poster-cap {
  position: absolute;
  bottom: 18px;
  left: 18px;
  right: 18px;
  z-index: 2;
}
.poster .poster-cap h3 {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 26px;
  line-height: 1;
  color: var(--paper);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  margin-bottom: 6px;
}
.poster .poster-cap .sub {
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
}

/* ═════════════════════════════════════════════
   MAGAZINE (news éditoriales)
   ═════════════════════════════════════════════ */
.mag-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 48px;
}
.mag-feat {
  display: block;
  position: relative;
  background: var(--ink-2);
  border: 1px solid var(--rule);
}
.mag-feat .photo {
  aspect-ratio: 16/10;
  overflow: hidden;
  position: relative;
}
.mag-feat .photo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s, filter .4s;
}
.mag-feat:hover .photo img { transform: scale(1.04); }
.mag-feat .photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(3,16,30,.7));
}
.mag-feat .photo .tag {
  position: absolute;
  top: 18px; left: 18px;
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--gold);
  padding: 5px 10px;
  z-index: 2;
}
.mag-feat .body {
  padding: 30px 36px 36px;
}
.mag-feat .body .when {
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper-mute);
  margin-bottom: 16px;
}
.mag-feat .body h3 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 34px;
  line-height: 1.1;
  letter-spacing: -.01em;
  margin-bottom: 16px;
  color: var(--paper);
  font-variation-settings: 'opsz' 144;
}
.mag-feat .body h3 em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.mag-feat .body p {
  color: var(--paper-dim);
  font-size: 15px;
  line-height: 1.65;
  margin-bottom: 22px;
}
.mag-feat .read-on {
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 3px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap .2s;
}
.mag-feat:hover .read-on { gap: 12px; }

.mag-list { display: flex; flex-direction: column; }
.mag-item {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 22px;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  align-items: start;
}
.mag-item:last-child { border-bottom: 1px solid var(--rule); }
.mag-item .num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 32px;
  color: var(--gold);
  line-height: 1;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  font-weight: 300;
}
.mag-item .num small {
  display: block;
  font-style: normal;
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: .3em;
  color: var(--paper-mute);
  margin-top: 4px;
  font-variation-settings: normal;
}
.mag-item .info .cat {
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}
.mag-item .info h4 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 19px;
  line-height: 1.25;
  margin-bottom: 8px;
  color: var(--paper);
  transition: color .2s;
  font-variation-settings: 'opsz' 36, 'SOFT' 0;
}
.mag-item:hover .info h4 { color: var(--gold); }
.mag-item .info .when {
  font-size: 11px;
  color: var(--paper-mute);
  letter-spacing: .15em;
}

/* ═════════════════════════════════════════════
   NEWSLETTER ribbon
   ═════════════════════════════════════════════ */
.ribbon {
  margin-top: 96px;
  padding: 80px 56px;
  background: var(--abyss);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.ribbon::before {
  content: '✦';
  position: absolute;
  font-family: var(--serif);
  font-size: 380px;
  color: var(--gold);
  opacity: .04;
  right: -40px;
  top: -120px;
}
.ribbon h2 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 56px;
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--paper);
  font-variation-settings: 'opsz' 144;
}
.ribbon h2 em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.ribbon-form { display: flex; flex-direction: column; gap: 16px; }
.ribbon-form p { color: var(--paper-dim); font-size: 14px; line-height: 1.6; max-width: 420px; margin-bottom: 8px; }
.ribbon-form .row {
  display: flex;
  gap: 0;
  border: 1px solid var(--rule);
  padding: 4px 4px 4px 20px;
  border-radius: 999px;
  align-items: center;
  max-width: 480px;
}
.ribbon-form input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--paper);
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: .02em;
  padding: 10px 0;
}
.ribbon-form input::placeholder { color: var(--paper-mute); }
.ribbon-form button {
  background: var(--gold);
  color: var(--ink);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: 12px 22px;
  border-radius: 999px;
  transition: background .2s;
}
.ribbon-form button:hover { background: var(--paper); }

/* ═════════════════════════════════════════════
   COLOPHON / FOOTER
   ═════════════════════════════════════════════ */
.colophon {
  padding: 72px 56px 32px;
  background: var(--ink);
  display: grid;
  grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: 48px;
}
.colophon h4 {
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
}
.colophon ul { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.colophon li a {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 17px;
  color: var(--paper-dim);
  transition: color .2s;
  font-variation-settings: 'opsz' 36;
}
.colophon li a:hover { color: var(--gold); font-style: italic; }
.col-brand .mh-logotype { text-align: left; margin-bottom: 18px; font-size: 36px; }
.col-brand p { color: var(--paper-dim); font-size: 13px; line-height: 1.7; max-width: 320px; margin-bottom: 24px; }
.col-brand .socials { display: flex; gap: 10px; }
.col-brand .socials a {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
  color: var(--paper-dim);
  transition: border-color .2s, color .2s, transform .2s;
}
.col-brand .socials a:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-2px); }

.colo-bottom {
  grid-column: 1/-1;
  border-top: 1px solid var(--rule);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--paper-mute);
}

/* ═════════════════════════════════════════════
   APPARITIONS (page load reveal)
   ═════════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  animation: reveal .9s cubic-bezier(.2,.7,.2,1) forwards;
}
.reveal.d1 { animation-delay: .1s; }
.reveal.d2 { animation-delay: .25s; }
.reveal.d3 { animation-delay: .4s; }
.reveal.d4 { animation-delay: .55s; }
.reveal.d5 { animation-delay: .7s; }
@keyframes reveal {
  to { opacity: 1; transform: translateY(0); }
}

/* curseur custom – disque doré sur les cartes interactives */
.feat-card, .poster, .mag-feat, .mag-item, .btn-watch, .btn-link {
  cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28'><circle cx='14' cy='14' r='5' fill='%23e9c46a'/></svg>") 14 14, pointer;
}

/* ═════════════════════════════════════════════
   PAGES SECONDAIRES (login, video) – hérité du précédent
   conservé pour compat
   ═════════════════════════════════════════════ */
.auth-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 24px 40px;
  position: relative;
  overflow: hidden;
}
.auth-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
}
.auth-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(.3) saturate(.8);
}
.auth-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at center, rgba(3,16,30,.4) 0%, rgba(3,16,30,.95) 80%);
}

.auth-card {
  width: 100%;
  max-width: 460px;
  background: rgba(3,16,30,.85);
  backdrop-filter: blur(20px);
  border: 1px solid var(--rule);
  padding: 48px 44px;
}
.auth-card .auth-mark {
  font-family: var(--serif);
  font-style: italic;
  font-size: 64px;
  color: var(--gold);
  line-height: 1;
  font-weight: 300;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
  margin-bottom: 12px;
}
.auth-card h1 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 36px;
  line-height: 1;
  margin-bottom: 8px;
  letter-spacing: -.01em;
  color: var(--paper);
}
.auth-card .auth-sub {
  font-size: 13px;
  color: var(--paper-dim);
  margin-bottom: 30px;
  letter-spacing: .02em;
}
.auth-field { margin-bottom: 18px; }
.auth-field label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--paper-mute);
  margin-bottom: 8px;
}
.auth-field input {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--rule);
  color: var(--paper);
  padding: 10px 0;
  font-size: 15px;
  font-family: var(--sans);
  outline: none;
  transition: border-color .2s;
}
.auth-field input:focus { border-bottom-color: var(--gold); }

.auth-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 24px 0;
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.auth-row label { color: var(--paper-mute); display: flex; align-items: center; gap: 6px; }
.auth-row a { color: var(--gold); }

.btn-primary {
  width: 100%;
  background: var(--gold);
  color: var(--ink);
  border: none;
  padding: 16px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .3em;
  text-transform: uppercase;
  cursor: pointer;
  font-family: var(--sans);
  transition: background .2s;
}
.btn-primary:hover { background: var(--paper); }

.auth-sep {
  text-align: center;
  margin: 24px 0;
  font-size: 10px;
  letter-spacing: .35em;
  color: var(--paper-mute);
  position: relative;
}
.auth-sep::before, .auth-sep::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 38%;
  height: 1px;
  background: var(--rule);
}
.auth-sep::before { left: 0; }
.auth-sep::after { right: 0; }

.auth-social { display: flex; gap: 10px; margin-bottom: 28px; }
.btn-soc {
  flex: 1;
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--paper);
  padding: 11px;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color .2s;
}
.btn-soc:hover { border-color: var(--gold); }

.auth-foot {
  text-align: center;
  font-size: 12px;
  color: var(--paper-mute);
  letter-spacing: .1em;
}
.auth-foot a { color: var(--gold); }

/* ═════════════════════════════════════════════
   PAGE VIDEO
   ═════════════════════════════════════════════ */
.player-section {
  padding-top: 0;
  background: #000;
  position: relative;
}
.player {
  width: 100%;
  aspect-ratio: 21/9;
  max-height: 80vh;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.player-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(.5) saturate(.95);
}
.player-overlay {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}
.big-play {
  width: 96px; height: 96px;
  border-radius: 50%;
  background: var(--gold);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .15s;
}
.big-play:hover { transform: scale(1.05); }
.big-play svg { color: var(--ink); margin-left: 4px; }
.player-overlay .player-info {
  color: var(--paper);
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
}

.video-container {
  max-width: 1300px;
  margin: 0 auto;
  padding: 56px 56px 80px;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
}

.vid-title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 56px;
  letter-spacing: -.02em;
  line-height: 1;
  margin-bottom: 22px;
  color: var(--paper);
  font-variation-settings: 'opsz' 144;
}
.vid-title em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}
.vid-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper-mute);
  flex-wrap: wrap;
}
.vid-meta .tag {
  border: 1px solid var(--rule);
  padding: 4px 10px;
  color: var(--paper-dim);
}
.vid-meta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--paper-mute); }
.hero-rating { color: var(--gold); }

.vid-actions { display: flex; gap: 10px; margin-bottom: 36px; flex-wrap: wrap; }
.action-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--paper-dim);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  font-family: var(--sans);
  font-weight: 500;
  cursor: pointer;
  transition: border-color .2s, color .2s;
}
.action-btn:hover { border-color: var(--gold); color: var(--gold); }
.action-btn.primary {
  background: var(--gold);
  color: var(--ink);
  border-color: var(--gold);
}
.action-btn.primary:hover { background: var(--paper); border-color: var(--paper); color: var(--ink); }

.vid-desc {
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 28px 0;
  margin-bottom: 32px;
}
.vid-desc h3 {
  font-size: 10px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 18px;
}
.vid-desc p {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 19px;
  line-height: 1.6;
  color: var(--paper-dim);
  font-variation-settings: 'opsz' 36;
}
.vid-desc p::first-letter {
  font-style: italic;
  color: var(--gold);
  font-size: 1.3em;
  font-variation-settings: 'opsz' 144, 'SOFT' 100, 'WONK' 1;
}

.vid-credits {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
}
.vid-credit {
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  padding-right: 24px;
}
.vid-credit:nth-child(2n) { border-right: none; padding-left: 24px; padding-right: 0; }
.vid-credit .lbl {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .35em;
  color: var(--paper-mute);
  margin-bottom: 6px;
}
.vid-credit .val {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 400;
  color: var(--paper);
  font-variation-settings: 'opsz' 36;
}

.related-side h3 {
  font-size: 10px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 22px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule);
}
.related-list { display: flex; flex-direction: column; }
.related-item {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule);
  text-decoration: none;
  color: inherit;
  align-items: start;
  transition: opacity .2s;
}
.related-item:hover { opacity: .85; }
.related-thumb {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--ink-3);
  position: relative;
}
.related-thumb img { width: 100%; height: 100%; object-fit: cover; }
.related-thumb .card-dur {
  position: absolute;
  bottom: 6px; right: 6px;
  font-size: 10px;
  background: rgba(0,0,0,.7);
  padding: 1px 6px;
  color: var(--paper);
  letter-spacing: .1em;
}
.related-info { flex: 1; }
.related-title {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.25;
  margin-bottom: 6px;
  color: var(--paper);
  font-variation-settings: 'opsz' 36;
}
.related-sub {
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--paper-mute);
}

/* ═════════════════════════════════════════════
   RESPONSIVE
   ═════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .grid-features {
    grid-template-columns: repeat(6, 1fr);
  }
  .span-7, .span-8 { grid-column: span 6; }
  .span-5, .span-4, .span-3, .span-6 { grid-column: span 3; }
  .story-inner { grid-template-columns: 1fr; }
  .story-body { padding: 56px 32px; border-left: none; border-top: 1px solid var(--rule); }
  .mag-grid { grid-template-columns: 1fr; gap: 32px; }
  .ribbon { grid-template-columns: 1fr; padding: 56px 32px; }
  .colophon { grid-template-columns: 1fr 1fr; padding: 56px 32px; }
  .video-container { grid-template-columns: 1fr; padding: 32px; }
}

@media (max-width: 720px) {
  /* Masthead */
  .masthead { padding: 14px 18px 12px; grid-template-columns: auto 1fr auto; gap: 10px; }
  .mh-left { display: flex; gap: 12px; font-size: 9px; letter-spacing: .15em; }
  .mh-left .mh-issue { display: none; }
  .mh-logotype { font-size: 22px; }
  .mh-right { gap: 8px; }
  .mh-right > a:first-child { display: none; } /* hide Recherche */
  .mh-account, .mh-cta {
    padding: 6px 11px;
    font-size: 9.5px;
    letter-spacing: .12em;
  }

  /* Subnav scrollable */
  .subnav {
    padding: 11px 18px;
    gap: 18px;
    overflow-x: auto;
    white-space: nowrap;
    font-size: 11px;
    letter-spacing: .12em;
    scrollbar-width: none;
  }
  .subnav::-webkit-scrollbar { display: none; }
  .subnav a { flex-shrink: 0; }

  /* Cover (hero) */
  .cover { min-height: 92vh; }
  .cover-meta-top { padding: 16px 18px 0; flex-direction: column; align-items: flex-start; gap: 8px; font-size: 10px; }
  .cover-headline { padding: 8vh 18px 60px; }
  .cover-kicker { font-size: 10px; letter-spacing: .25em; margin-bottom: 16px; }
  .cover-title {
    font-size: clamp(56px, 18vw, 92px);
    letter-spacing: -.04em;
    margin-bottom: 22px;
  }
  .cover-deck { font-size: 17px; line-height: 1.4; margin-bottom: 28px; }
  .cover-actions { gap: 10px; flex-wrap: wrap; }
  .btn-watch { padding: 12px 22px; font-size: 12px; }
  .btn-watch .ico { width: 24px; height: 24px; }
  .btn-link { font-size: 11px; }
  .cover-sidecard { display: none; }

  /* Chapitres */
  .chapter { padding: 56px 18px 16px; }
  .chapter-mark {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 0 0 20px;
    margin-bottom: 24px;
  }
  .chapter-num { font-size: 64px; }
  .chapter-num small { font-size: 9px; }
  .chapter-title { font-size: 28px; }
  .chapter-link { font-size: 10px; align-self: start; }

  /* Grid features (chapter 01) */
  .grid-features { grid-template-columns: 1fr; gap: 22px 16px; }
  .span-7, .span-8, .span-5, .span-4, .span-3, .span-6 { grid-column: span 1; }
  .feat-card.cover-style h3 { font-size: 24px; }
  .feat-card h3 { font-size: 19px; }

  /* Story (chapter 02) */
  .story-inner { grid-template-columns: 1fr; min-height: 0; }
  .story-img { min-height: 240px; }
  .story-body { padding: 40px 22px; }
  .story-mark { font-size: 80px; }
  .story-body h2 { font-size: 28px; }
  .story-body p { font-size: 15px; }
  .story-credits { gap: 18px; flex-wrap: wrap; font-size: 9.5px; }

  /* Posters (chapter 03) */
  .posters { padding: 4px 18px 24px; margin: 0; gap: 12px; }
  .poster { flex: 0 0 180px; }
  .poster .poster-cap h3 { font-size: 22px; }

  /* Magazine (chapter 04) */
  .mag-grid { grid-template-columns: 1fr; gap: 14px; }
  .mag-feat .body { padding: 22px 22px 24px; }
  .mag-feat h3 { font-size: 22px; }
  .mag-item { grid-template-columns: 60px 1fr; gap: 14px; padding: 16px 0; }
  .mag-item .num { font-size: 24px; }
  .mag-item .info h4 { font-size: 16px; }

  /* Ribbon */
  .ribbon { grid-template-columns: 1fr; gap: 24px; padding: 56px 22px; margin-top: 56px; }
  .ribbon h2 { font-size: 30px; }
  .ribbon-form .row { padding: 4px 4px 4px 14px; max-width: 100%; }
  .ribbon-form button { padding: 10px 16px; font-size: 10px; }

  /* Colophon (footer) */
  .colophon { grid-template-columns: 1fr; padding: 48px 22px 22px; gap: 28px; }
  .col-brand p { font-size: 13px; }
  .colo-bottom { flex-direction: column; gap: 8px; align-items: flex-start; font-size: 10px; }

  /* Login */
  .auth-card { padding: 32px 26px; }
  .auth-card h1 { font-size: 30px; }

  /* Video */
  .player { aspect-ratio: 16/9; max-height: 50vh; }
  .video-container { grid-template-columns: 1fr; padding: 32px 18px; gap: 32px; }
  .vid-title { font-size: 32px; }
  .vid-credits { grid-template-columns: 1fr; }
  .vid-credit { border-right: none !important; padding-left: 0 !important; padding-right: 0 !important; padding-bottom: 16px; padding-top: 16px; }
}

@media (max-width: 480px) {
  .cover-title { font-size: 64px; }
  .chapter-num { font-size: 52px; }
  .chapter-title { font-size: 24px; }
}

/* ═════════════════════════════════════════════
   THEMES
   ═════════════════════════════════════════════ */

/* B · Crème (papier — version inversée) */
html.theme-b {
  --ink:        #f4eee0;          /* fond clair */
  --ink-2:      #ebe5d4;
  --ink-3:      #d8d1ba;
  --paper:      #1a1f2c;          /* texte foncé */
  --paper-dim:  #353c4d;
  --paper-mute: #6b6557;
  --rule:       rgba(26, 31, 44, .14);
  --rule-soft:  rgba(26, 31, 44, .07);
  --gold:       #b88a2e;
  --abyss:      #d8d1ba;
}
html.theme-b body::before { opacity: .04 !important; mix-blend-mode: multiply !important; }
html.theme-b ::selection { background: var(--gold); color: var(--paper); }

/* C · Pétrole (deep teal) */
html.theme-c {
  --ink:        #0e3447;
  --ink-2:      #134055;
  --ink-3:      #1a516b;
  --paper:      #f1ead4;
  --paper-dim:  #d6cdb6;
  --paper-mute: #95a4b1;
  --gold:       #f4b860;
  --abyss:      #082230;
}
