/* ============================================================
   ROXANE ROUAULT — PORTFOLIO
   Feuille de style partagée (index.html + about.html)
   ------------------------------------------------------------
   1. RESET
   2. TOKENS         — couleurs & polices
   3. HEADER         — partagé (masthead centré)
   4. CURSOR         — partagé (curseur custom)
   5. HOME           — stage / slides / overlay / lecteur / rail
   6. ABOUT          — layout portrait
   7. PROJECT        — page projet (page/Project-*.html)
   8. RESPONSIVE
============================================================ */


/* ============================================================
   1. RESET
============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{height:100%;scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font-label);
  -webkit-font-smoothing:antialiased;
}
/* La HOME tourne en plein écran : le scroll se fait dans .stage.
   Seule la home porte un attribut data-dir, donc ce verrou ne touche pas le ABOUT. */
body[data-dir]{height:100%;overflow:hidden}
img,video{display:block}
img{max-width:100%}
a{color:inherit;text-decoration:none}


/* ============================================================
   2. TOKENS  (la home peut changer de direction via data-dir)
============================================================ */
:root{
  --bg:#121212; --fg:#f1efe9; --muted:#8c8a83;
  --line:rgba(241,239,233,.15); --line-strong:rgba(241,239,233,.4);
  --font-display:'Cabinet Grotesk',sans-serif;
  --font-label:'Space Mono',monospace;
  --frame:0px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
body[data-dir="editorial"]{
  --bg:#121212; --fg:#f1efe9; --muted:#8c8a83;
  --line:rgba(241,239,233,.15); --line-strong:rgba(241,239,233,.4);
  --font-display:'Cabinet Grotesk',sans-serif;
  --font-label:'Space Mono',monospace;
}
body[data-dir="galerie"]{
  --bg:#0a0908; --fg:#efe9df; --muted:#9b8f7e;
  --line:rgba(239,233,223,.14); --line-strong:rgba(239,233,223,.32);
  --font-display:'Zodiak',serif;
  --font-label:'Space Mono',monospace;
}
body[data-dir="mono"]{
  --bg:#070809; --fg:#e9ece9; --muted:#76807a;
  --line:rgba(233,236,233,.14); --line-strong:rgba(233,236,233,.36);
  --font-display:'Space Mono',monospace;
  --font-label:'Space Mono',monospace;
}


/* ============================================================
   3. HEADER  (masthead centré — identique sur les deux pages)
============================================================ */
.head{
  position:fixed;top:0;left:0;width:100%;z-index:80;
  background:linear-gradient(180deg,rgba(0,0,0,.62),rgba(0,0,0,0));
  backdrop-filter:blur(3px);
}
.h-main{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:34px;
  padding:22px 34px;border-bottom:1px solid var(--line);
}
.h-meta{
  justify-self:start;display:flex;align-items:baseline;gap:13px;
  font-family:var(--font-label);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);white-space:nowrap;
}
.h-meta .clock{color:var(--fg);font-variant-numeric:tabular-nums;letter-spacing:.08em}
.h-id{text-align:center}
.logo{
  display:block;font-family:var(--font-display);font-weight:700;
  font-size:25px;letter-spacing:-.012em;line-height:.95;text-transform:uppercase;
}
.role{
  margin-top:9px;font-family:var(--font-label);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);white-space:nowrap;
}
.h-nav{justify-self:end;display:flex;gap:28px;font-family:var(--font-label);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.h-nav a{position:relative;display:flex;align-items:flex-start;gap:5px;color:var(--fg);padding-bottom:3px;transition:color .3s}
.h-nav a i{font-size:8px;color:var(--muted);font-style:normal;letter-spacing:.02em;transform:translateY(1px)}
.h-nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.h-nav a:hover::after{transform:scaleX(1)}
.h-nav a.active i{color:var(--fg)}
.h-burger{display:none} /* visible seulement en mobile (voir Responsive) */
.h-close{display:none}  /* croix du menu plein écran — visible seulement en mobile */
.h-nav a.h-nav-mail{display:none} /* contact, visible seulement dans l'overlay mobile (voir Responsive) */


/* ============================================================
   4. CUSTOM CURSOR  (partagé)
============================================================ */
.cursor{
  position:fixed;top:0;left:0;z-index:200;pointer-events:none;display:none;
  font-family:var(--font-label);font-size:12px;letter-spacing:.14em;color:var(--fg);
  text-transform:uppercase;transform:translate(-50%,-50%);mix-blend-mode:difference;
  opacity:0;transition:opacity .2s;
}
/* PROJECT + ABOUT : curseur = point plein (pas de texte "scroll") */
body[data-page="project"] .cursor,
body[data-about] .cursor{width:14px;height:14px;border-radius:50%;background:var(--fg)}

/* HOME : curseur en bloc glass rectangulaire (les deux états, lisible sur tout fond) */
body[data-dir] .cursor{
  mix-blend-mode:normal;color:var(--fg);
  padding:9px 15px;border-radius:0;
  border:1px solid rgba(255,255,255,.42);
  background:rgba(18,18,20,.55);
  -webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);
  box-shadow:0 18px 50px -26px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.12);
}
/* HOME hors scène (header, lecteur, onglets…) : curseur = simple point, jamais la main */
body[data-dir] .cursor.is-dot{
  width:14px;height:14px;padding:0;border:0;border-radius:50%;
  background:var(--fg);box-shadow:none;
  -webkit-backdrop-filter:none;backdrop-filter:none;
}

/* caret machine à écrire — collé au texte, avant le crochet fermant */
body[data-dir] .cursor .caret{
  font-style:normal;color:var(--fg);
  animation:caret .9s steps(1) infinite;
}
@keyframes caret{50%{opacity:0}}
@media (pointer:fine){
  body[data-cursor="on"] .cursor{display:block}
  body[data-dir][data-cursor="on"]{cursor:none}           /* HOME    : curseur natif masqué partout (pas de main) */
  body[data-about][data-cursor="on"]{cursor:none}         /* ABOUT   : curseur natif masqué sur toute la page */
  body[data-page="project"][data-cursor="on"]{cursor:none} /* PROJECT : idem */
}


/* ============================================================
   5. HOME — STAGE / SLIDES
============================================================ */
.stage{
  height:100%;overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth;
  scrollbar-width:none;
}
.stage::-webkit-scrollbar{display:none}
.slide{
  position:relative;height:100vh;width:100%;scroll-snap-align:start;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.media{
  position:absolute;inset:0;
  transform:none;opacity:1;
}
.media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.media.empty{
  display:flex;align-items:center;justify-content:center;
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,.022) 0 1px,transparent 1px 12px),
    radial-gradient(120% 120% at 50% 40%,#161618 0%,#0d0d0e 70%);
}
.media.empty .empty-tag{
  font-family:var(--font-label);font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--line-strong);padding:11px 20px;
}
.media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.42) 0%,rgba(0,0,0,0) 26%,rgba(0,0,0,0) 52%,rgba(0,0,0,.62) 100%);
}

/* GALERIE: framed video, no heavy scrim */
body[data-dir="galerie"] .media{inset:96px 96px 132px;border:1px solid var(--line-strong)}
body[data-dir="galerie"] .media::after{background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.18))}

/* ---- OVERLAY ---- */
.overlay{position:absolute;inset:0;z-index:5;pointer-events:none}
.overlay > *{pointer-events:auto}

/* TOP — index */
.s-top{
  position:absolute;top:118px;left:34px;display:flex;align-items:baseline;gap:10px;
  font-family:var(--font-label);font-size:12px;letter-spacing:.18em;color:var(--muted);
}
.s-index{font-size:13px;color:var(--fg)}

/* BOTTOM block */
.s-bottom{
  position:absolute;left:34px;right:34px;bottom:46px;
}
.s-title{
  font-family:var(--font-display);font-weight:800;line-height:.92;
  font-size:clamp(38px,7.4vw,116px);letter-spacing:-.02em;text-transform:uppercase;
  max-width:14ch;
}
/* module CTA mobile (remplace le curseur hover) — caché en desktop, voir Responsive */
.s-cta{display:none}
.s-meta{
  margin-top:26px;display:flex;gap:0;border-top:1px solid var(--line);
}
.meta-cell{
  flex:0 0 auto;min-width:200px;padding:14px 28px 0 0;
}
.meta-cell .ml{
  display:block;font-family:var(--font-label);font-size:10px;letter-spacing:.22em;
  color:var(--muted);text-transform:uppercase;margin-bottom:7px;
}
.meta-cell .mv{
  display:block;font-family:var(--font-label);font-size:13px;letter-spacing:.04em;color:var(--fg);
}

/* titre projet cliquable (toute la slide l'est aussi, via JS) */
.s-link{display:inline-block;color:var(--fg);transition:opacity .3s}
.s-link:hover{opacity:.7}

/* corner ticks (mono direction) */
.corners{position:absolute;inset:26px;display:none;pointer-events:none}
.corners i{position:absolute;width:14px;height:14px;border:1px solid var(--line-strong)}
.corners i:nth-child(1){top:0;left:0;border-right:0;border-bottom:0}
.corners i:nth-child(2){top:0;right:0;border-left:0;border-bottom:0}
.corners i:nth-child(3){bottom:0;left:0;border-right:0;border-top:0}
.corners i:nth-child(4){bottom:0;right:0;border-left:0;border-top:0}

/* ---- DIRECTION: GALERIE overlay ---- */
body[data-dir="galerie"] .s-top{top:120px;left:120px;color:var(--muted)}
body[data-dir="galerie"] .s-bottom{
  left:0;right:0;bottom:46px;text-align:center;display:flex;flex-direction:column;align-items:center;
}
body[data-dir="galerie"] .s-title{
  font-weight:500;text-transform:none;letter-spacing:-.01em;
  font-size:clamp(30px,4.6vw,68px);line-height:1;max-width:none;
}
body[data-dir="galerie"] .s-meta{
  border-top:0;justify-content:center;gap:0;margin-top:16px;
}
body[data-dir="galerie"] .meta-cell{
  min-width:0;padding:0 18px;text-align:center;position:relative;
}
body[data-dir="galerie"] .meta-cell + .meta-cell::before{
  content:"";position:absolute;left:0;top:3px;bottom:3px;width:1px;background:var(--line);
}
body[data-dir="galerie"] .meta-cell .ml{display:none}
body[data-dir="galerie"] .meta-cell .mv{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ---- DIRECTION: MONO overlay ---- */
body[data-dir="mono"] .corners{display:block}
body[data-dir="mono"] .s-title{
  font-weight:700;font-size:clamp(28px,4.4vw,60px);letter-spacing:-.01em;line-height:1;
}
body[data-dir="mono"] .s-meta{border-top:1px solid var(--line);gap:0}
body[data-dir="mono"] .meta-cell{min-width:0;padding:12px 36px 0 0}
body[data-dir="mono"] .meta-cell .ml{color:var(--muted)}
body[data-dir="mono"] .s-top{
  top:auto;bottom:46px;left:auto;right:34px;flex-direction:column;align-items:flex-end;gap:2px;
}
body[data-dir="mono"] .s-index{font-size:clamp(40px,6vw,84px);font-family:var(--font-label);font-weight:700;line-height:.9}

/* ---- HOME — MUSIC PLAYER (docked right, glass, click to open) ---- */
.player{
  position:fixed;right:0;top:calc(50% + 90px);z-index:110;
  display:flex;align-items:stretch;font-family:var(--font-label);
}
/* collapsed handle */
.pl-tab{
  appearance:none;cursor:pointer;color:var(--fg);
  display:flex;flex-direction:column;align-items:center;gap:11px;
  padding:13px 10px;
  border:1px solid rgba(255,255,255,.16);border-right:0;
  background:rgba(255,255,255,.05);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);
  box-shadow:0 18px 50px -26px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.1);
  transition:background .25s;
}
.pl-tab:hover{background:rgba(255,255,255,.1)}
.pl-tab .pl-tab-label{
  writing-mode:vertical-rl;text-orientation:mixed;
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}
.player[data-open="1"] .pl-tab{display:none}
/* expanded body */
.pl-body{
  display:none;width:230px;padding:15px;
  border:1px solid rgba(255,255,255,.16);border-right:0;
  background:rgba(255,255,255,.05);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);backdrop-filter:blur(24px) saturate(1.4);
  box-shadow:0 30px 70px -30px rgba(0,0,0,.92),inset 0 1px 0 rgba(255,255,255,.12);
}
.player[data-open="1"] .pl-body{display:block}
.pl-head{
  display:flex;justify-content:space-between;align-items:center;
  font-size:9px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.14);padding-bottom:10px;margin-bottom:12px;
}
.pl-close{appearance:none;border:0;background:transparent;color:var(--muted);cursor:pointer;
  font-family:var(--font-label);font-size:16px;line-height:1;padding:0 2px;transition:color .2s}
.pl-close:hover{color:var(--fg)}
.pl-eq{display:flex;align-items:flex-end;gap:2px;height:13px}
.pl-eq span{width:2px;height:4px;background:var(--fg)}
body[data-playing="1"] .pl-eq span{animation:eq .9s steps(4,end) infinite}
body[data-playing="1"] .pl-eq span:nth-child(2){animation-delay:.15s}
body[data-playing="1"] .pl-eq span:nth-child(3){animation-delay:.3s}
body[data-playing="1"] .pl-eq span:nth-child(4){animation-delay:.45s}
@keyframes eq{0%,100%{height:3px}50%{height:13px}}
.pl-title{font-size:12px;letter-spacing:.02em;color:var(--fg);line-height:1.3;min-height:30px}
.pl-artist{font-size:10px;letter-spacing:.06em;color:var(--muted);margin-top:2px}
.pl-ctrl{display:flex;gap:7px;margin-top:13px}
.pl-ctrl button{
  flex:1;appearance:none;border:1px solid rgba(255,255,255,.2);background:transparent;color:var(--fg);
  font-family:var(--font-label);font-size:11px;padding:7px 0;cursor:pointer;
  transition:background .2s,color .2s,border-color .2s;
}
.pl-ctrl button:hover{background:var(--fg);color:#121212;border-color:var(--fg)}
.pl-ctrl .play{flex:1.4}

/* ---- HOME — PROGRESS RAIL ---- */
.rail{
  position:fixed;top:50%;right:18px;transform:translateY(-50%);z-index:90;
  display:flex;flex-direction:column;gap:9px;
}
body[data-dir="mono"] .rail{right:18px}
.rail i{
  display:block;width:6px;height:6px;border:1px solid var(--line-strong);border-radius:50%;
}
.rail i.on{background:var(--fg);transform:scale(1.25)}


/* ============================================================
   6. ABOUT — LAYOUT (portrait)
============================================================ */
.ab{max-width:1180px;margin:0 auto;padding:160px 48px 140px}
.ab-eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.ab-h{font-family:var(--font-label);font-size:12px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:34px}

/* INTRO */
.ab-intro{position:relative}
.ab-title{font-family:var(--font-display);font-weight:800;text-transform:uppercase;
  letter-spacing:-.02em;line-height:.9;font-size:clamp(52px,11vw,164px);margin:18px 0 0}
.ab-role{margin-top:22px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.ab-portrait{margin-top:0}

/* BIO */
.ab-bio{margin-top:120px}
.ab-meta{display:flex;flex-wrap:wrap;gap:8px 26px;padding-bottom:18px;border-bottom:1px solid var(--line);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.ab-prose{margin-top:38px;max-width:780px}
.ab-prose p{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.3vw,29px);
  line-height:1.45;letter-spacing:-.01em;margin-bottom:24px;color:var(--fg)}
.ab-prose p.dim{color:var(--muted)}
/* lien inline mis en avant (ex : CARTEL) — flèche ↗ qui invite au clic */
.ab-link{
  color:var(--fg);white-space:nowrap;
  border-bottom:1px solid var(--line-strong);
  transition:border-color .3s,color .3s;
}
.ab-link:hover{border-color:var(--fg)}
.ab-link .arr{
  display:inline-block;margin-left:.18em;font-family:var(--font-label);
  transition:transform .3s;
}
.ab-link:hover .arr{transform:translate(2px,-2px)}

/* JOURNEY */
.ab-journey{margin-top:130px}
/* corps du Journey en gris (comme l'intro dim) — le lien CARTEL garde sa couleur blanche */
.ab-journey .ab-prose p{color:var(--muted)}

/* SKILLS */
.ab-skills{margin-top:130px}
.ab-skill-list{list-style:none}
.ab-skill-list li{display:grid;grid-template-columns:64px 1fr 1.4fr;gap:34px;align-items:baseline;
  padding:20px 0;border-top:1px solid var(--line)}
.ab-skill-list li:last-child{border-bottom:1px solid var(--line)}
.sk-n{font-size:11px;letter-spacing:.1em;color:var(--muted)}
.sk-d{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:clamp(20px,2.4vw,30px);letter-spacing:-.01em}
.sk-t{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-self:center}

/* ---- ABOUT — split portrait (texte à gauche, portrait sticky à droite) ---- */
body[data-about="c"] .ab{max-width:1280px}
body[data-about="c"] .ab-intro{display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center;min-height:74vh}
body[data-about="c"] .ab-portrait{position:sticky;top:120px}
body[data-about="c"] .ab-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover}
body[data-about="c"] .ab-title{font-size:clamp(44px,7vw,104px)}
body[data-about="c"] .ab-skill-list li{grid-template-columns:1fr 1fr}
body[data-about="c"] .sk-n{display:none}


/* ============================================================
   7. PROJECT — page projet (layout cinématique, full-bleed)
   page/Project-*.html · header, curseur & tokens = sections partagées.
   Scopé sur body[data-page="project"] (même logique d'isolation que home/about).
============================================================ */
/* SHELL — vidéos pleine largeur, sections texte recentrées à 1180px */
body[data-page="project"] .case{margin:0 auto}
body[data-page="project"] .eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

/* EN-TÊTE PROJET */
body[data-page="project"] .p-head{--p-pad:48px;max-width:1180px;margin:0 auto;padding:150px var(--p-pad) 70px;border-bottom:1px solid var(--line)}
body[data-page="project"] .p-index{display:flex;align-items:baseline;gap:10px;font-size:12px;letter-spacing:.18em;color:var(--muted)}
body[data-page="project"] .p-index b{color:var(--fg);font-weight:400}
body[data-page="project"] .p-title{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:-.02em;
  line-height:.9;font-size:clamp(40px,8.2vw,118px);margin:22px 0 0;max-width:16ch}
/* la barre du haut court sur toute la largeur de l'en-tête (comme la barre du bas) */
body[data-page="project"] .p-facts{margin:40px calc(var(--p-pad) * -1) 0;padding-left:var(--p-pad);
  display:flex;flex-wrap:wrap;gap:0;border-top:1px solid var(--line)}
body[data-page="project"] .p-facts .fc{padding:16px 30px 0 0;min-width:190px}
body[data-page="project"] .p-facts .fl{display:block;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
body[data-page="project"] .p-facts .fv{display:block;font-size:13px;letter-spacing:.03em;color:var(--fg)}

/* VIDÉO — contenue & centrée (pas pleine largeur) */
body[data-page="project"] .v-sec{margin:0;padding:0 48px}
body[data-page="project"] .v-wrap{max-width:1040px;margin:0 auto;position:relative;background:#000;overflow:hidden;border:1px solid var(--line)}
body[data-page="project"] .v-wrap video,
body[data-page="project"] .v-wrap img{width:100%;height:auto;display:block}
body[data-page="project"] .v-wrap iframe{width:100%;aspect-ratio:16/9;display:block;border:0}
body[data-page="project"] .v-cap{max-width:1040px;margin:13px auto 0;display:flex;justify-content:space-between;gap:16px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
/* placeholder vidéo manquante */
body[data-page="project"] .v-missing{position:relative;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:#0f0f10}
body[data-page="project"] .v-missing::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(135deg,transparent,transparent 14px,rgba(241,239,233,.025) 14px,rgba(241,239,233,.025) 15px)}
body[data-page="project"] .v-missing .tag{position:relative;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.7}

/* TEXTE — traitement édito : colonne mesurée alignée à gauche,
   index [ 01 ] en marge gauche (compteur), chapô plus grand */
body[data-page="project"] .flow{counter-reset:para}
body[data-page="project"] .t-sec{max-width:1180px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:120px minmax(0,1fr);align-items:start}
body[data-page="project"] .t-sec::before{
  counter-increment:para;content:"[ " counter(para,decimal-leading-zero) " ]";
  font-family:var(--font-label);font-size:11px;letter-spacing:.14em;color:var(--muted);padding-top:.55em}
body[data-page="project"] .t-sec .projet-text{font-family:var(--font-display);font-weight:400;letter-spacing:-.01em;
  font-size:clamp(22px,2.6vw,38px);line-height:1.4;max-width:34ch;text-align:left;color:var(--fg)}
/* chapô (premier bloc) — plus grand, mesure un peu plus large */
body[data-page="project"] .t-sec.lead .projet-text{font-size:clamp(26px,3.2vw,48px);max-width:28ch;letter-spacing:-.015em}
body[data-page="project"] .t-sec .projet-text a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--line-strong);
  padding-bottom:1px;transition:border-color .3s,color .3s}
body[data-page="project"] .t-sec .projet-text a:hover{color:var(--muted);border-color:var(--muted)}
/* bloc crédits — pas de numéro, corps mono gris en pleine mesure */
body[data-page="project"] .t-credit::before{content:""}
body[data-page="project"] .t-credit .projet-text{font-family:var(--font-label);font-size:clamp(12px,1.3vw,15px);line-height:1.8;
  letter-spacing:.02em;max-width:60ch;color:var(--muted)}
body[data-page="project"] .t-credit .projet-text a{color:var(--fg);border-bottom-color:var(--muted)}

/* FOOTER — partagé (page projet + about) */
.main-footer{border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.main-footer a{color:var(--fg)}
body[data-page="project"] .main-footer{max-width:1180px;margin:120px auto 0;padding:26px 48px 64px}
body[data-about] .main-footer{margin-top:120px;padding-top:26px}

/* RYTHME VERTICAL */
body[data-page="project"] .flow > section{margin-top:120px}
body[data-page="project"] .flow > .p-head{margin-top:0}


/* ============================================================
   8. RESPONSIVE
============================================================ */
/* ---- ABOUT ---- */
@media (max-width:860px){
  .h-main{display:flex;justify-content:space-between;gap:14px;padding:22px 18px;align-items:center}
  .head .role,.head .h-meta{display:none!important}
  .logo{font-size:16px}
  .ab{padding:120px 20px 56px}
  body[data-about="c"] .ab-intro{grid-template-columns:1fr}
  .ab-skill-list li{grid-template-columns:1fr!important;gap:6px}
}

/* ---- HOME ---- */
@media (max-width:760px){
  .h-main{display:flex;justify-content:space-between;padding:22px 18px;gap:16px;align-items:center}
  .head .role,.head .h-meta{display:none!important}
  .logo{font-size:16px}
  .h-nav{gap:18px}
  /* vidéos 16/9 → bande 4/5 centrée (crop doux) plutôt qu'un cover plein écran qui rogne trop en portrait.
     Le noir au-dessus/dessous devient le cadre ; le texte reste en overlay (index haut, titre bas). */
  .slide{height:100dvh}
  .media{top:50%;bottom:auto;left:0;right:0;height:auto;aspect-ratio:4/5;transform:translateY(-50%)}
  .s-top{top:96px;left:18px}
  .s-bottom{left:18px;right:18px;bottom:34px}
  /* module CTA : même boîte "glass" que le curseur desktop, au-dessus du titre */
  .s-cta{
    display:flex;align-items:center;width:max-content;max-width:100%;
    margin-bottom:13px;min-height:28px;
    font-family:var(--font-label);font-size:9.5px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--fg);
    padding:7px 12px;border:1px solid rgba(255,255,255,.42);
    background:rgba(18,18,20,.55);
    -webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);
    box-shadow:0 18px 50px -26px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.12);
  }
  .s-cta .caret{font-style:normal;color:var(--fg);animation:caret .9s steps(1) infinite}
  .s-meta{flex-wrap:wrap}
  .meta-cell{min-width:140px}
  .player{right:0;top:50%;bottom:auto;transform:translateY(-50%)}
  .pl-body{width:220px;padding:14px}
  body[data-dir="galerie"] .media{inset:80px 18px 150px}
  body[data-dir="galerie"] .s-top{left:18px;top:96px}
  .rail{display:none}
}

/* ---- PROJECT ---- */
@media (max-width:860px){
  body[data-page="project"] .t-sec,
  body[data-page="project"] .main-footer,
  body[data-page="project"] .v-sec{padding-left:18px;padding-right:18px}
  body[data-page="project"] .p-head{--p-pad:18px}
  /* moins d'air : en-tête plus haut + sections plus rapprochées */
  body[data-page="project"] .p-head{padding-top:104px;padding-bottom:40px}
  body[data-page="project"] .flow > section{margin-top:60px}
  /* index repassé au-dessus du texte, colonne unique */
  body[data-page="project"] .t-sec{grid-template-columns:1fr;gap:12px}
  body[data-page="project"] .t-sec::before{padding-top:0}
  body[data-page="project"] .t-sec .projet-text,
  body[data-page="project"] .t-sec.lead .projet-text{max-width:none}
}

/* ---- FOOTER mobile (projet + about) : tout centré, peu de marge en bas ---- */
@media (max-width:860px){
  .main-footer{flex-direction:column;align-items:center;text-align:center;gap:10px}
  body[data-page="project"] .main-footer{margin-top:72px;padding-bottom:40px}
  body[data-about] .main-footer{margin-top:72px}
}

/* ---- HEADER mobile : logo + rôle à gauche, nav en menu plein écran ----
   (placé en dernier pour primer sur les blocs responsive ci-dessus) */
@media (max-width:760px){
  /* sans ça, le backdrop-filter du header piège le position:fixed du menu dans le header */
  .head{-webkit-backdrop-filter:none;backdrop-filter:none}
  .h-main{display:block;position:relative;text-align:left;padding:28px 60px 28px 18px;border-bottom:0}
  .h-id{text-align:left}
  .head .role{display:block!important;margin-top:7px;font-size:9px;letter-spacing:.12em}
  .h-meta{display:none!important}

  /* hamburger (compact) → croix quand ouvert */
  .h-burger{
    display:flex;flex-direction:column;justify-content:center;gap:5px;
    position:absolute;top:50%;right:18px;transform:translateY(-50%);
    width:22px;height:13px;padding:0;background:transparent;border:0;cursor:pointer;z-index:90;
  }
  .h-burger span{display:block;width:100%;height:1.5px;background:var(--fg);
    transition:transform .3s var(--ease),opacity .3s}
  .head.nav-open .h-burger span:nth-child(1){transform:translateY(3.25px) rotate(45deg)}
  .head.nav-open .h-burger span:nth-child(2){transform:translateY(-3.25px) rotate(-45deg)}

  /* nav → overlay plein écran opaque AU-DESSUS DE TOUT (z-index max) */
  .h-nav{
    position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;max-width:100vw;z-index:300;
    display:flex;flex-direction:column;justify-content:center;gap:0;
    padding:0 24px;background:var(--bg);counter-reset:navi;
    opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;
  }
  .h-nav.open{opacity:1;visibility:visible}
  /* croix de fermeture (injectée en JS, dans l'overlay) */
  .h-close{
    position:absolute;top:14px;right:16px;width:42px;height:42px;
    display:flex;align-items:center;justify-content:center;
    background:transparent;border:0;color:var(--fg);
    font-family:var(--font-label);font-size:30px;line-height:1;cursor:pointer;z-index:1;
  }
  /* hiérarchie : index mono + grand titre display + filets */
  .h-nav a{
    display:flex;align-items:baseline;gap:16px;width:100%;padding:24px 0;
    border-top:1px solid var(--line);color:var(--fg);
    font-family:var(--font-display);font-weight:700;text-transform:uppercase;
    font-size:clamp(46px,15vw,82px);letter-spacing:-.01em;line-height:1;
  }
  .h-nav a:last-child{border-bottom:1px solid var(--line)}
  .h-nav a::before{
    counter-increment:navi;content:"0" counter(navi);
    font-family:var(--font-label);font-weight:400;font-size:11px;letter-spacing:.12em;
    color:var(--muted);align-self:flex-start;margin-top:.55em;
  }
  /* contact ancré en bas de l'overlay (hors flux, donc Work/About restent centrés) */
  .h-nav a.h-nav-mail{
    display:block;position:absolute;left:24px;right:24px;bottom:34px;
    padding:0;border:0;
    font-family:var(--font-label);font-weight:400;text-transform:none;
    font-size:13px;letter-spacing:.04em;line-height:1.3;color:var(--muted);
  }
  .h-nav a.h-nav-mail::before{content:none;counter-increment:none}

  /* menu ouvert : on masque le lecteur (z-index élevé) qui traverserait l'overlay */
  .head.nav-open ~ .player{display:none}
}


/* ============================================================
   9. LOADER  (intro de la home — overlay plein écran au chargement)
   Tout est scopé sous .loader ; les couleurs/polices passent par les tokens.
============================================================ */
.loader{position:fixed;inset:0;z-index:9000;background:var(--bg);overflow:hidden;display:none;will-change:transform}
.loader.on{display:block}
/* intro déjà vue dans la session → loader masqué dès le départ (aucun flash) */
html.intro-done .loader{display:none}
.loader .ld-corner{position:absolute;font-family:var(--font-label);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.loader .ld-tl{top:30px;left:34px}
.loader .ld-tr{top:30px;right:34px}
/* manifeste machine — haut gauche */
.loader .term{position:absolute;top:104px;left:34px;width:min(540px,70vw)}
.loader .tline{display:flex;gap:14px;align-items:baseline;font-family:var(--font-label);
  font-size:13px;letter-spacing:.05em;line-height:2.45;opacity:0;transform:translateY(4px);
  transition:opacity .25s,transform .25s;color:var(--fg)}
.loader .tline.show{opacity:1;transform:none}
.loader .tline .k{color:var(--muted);min-width:26px}
.loader .tline .v{flex:1}
.loader .tline .ok{color:var(--fg);letter-spacing:.18em;font-size:11px;opacity:0;transition:opacity .2s}
.loader .tline.show .ok{opacity:1;transition-delay:.18s}
.loader .tline.lead{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  font-size:clamp(20px,2.4vw,28px);letter-spacing:-.01em;line-height:1.15;margin-bottom:20px}
/* compteur géant — bas droite */
.loader .count{position:absolute;right:30px;bottom:18px;text-align:right;line-height:.8}
.loader .count .cap{font-family:var(--font-label);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.loader .count .num{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(110px,24vw,360px);font-variant-numeric:tabular-nums}
.loader .count .num .pct{font-size:.26em;vertical-align:top;color:var(--muted);margin-left:.1em;letter-spacing:0}
/* barre de progression */
.loader .bar{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--fg)}
@media (max-width:760px){
  .loader .ld-corner{font-size:9px;top:22px}
  .loader .ld-tl{left:18px}
  .loader .ld-tr{right:18px}
  .loader .term{top:86px;left:18px;width:78vw}
  .loader .tline{font-size:12px;line-height:2.1}
  .loader .count{right:18px;bottom:14px}
}
