/* ============================================
   TOKENS — NewTouch Vision V2 / Cinéma
   ============================================ */
:root{
  --ink:        #0A0A0A;
  --ink-2:      #141312;
  --paper:      #F5F0E8;
  --paper-dim:  #E8E1D4;
  --cinabre:    #C0392B;
  --cinabre-br: #E0584A;
  --gold:       #C9A227;
  --gold-dim:   #8B6914;
  --smoke:      rgba(245,240,232,0.64);
  --smoke-dim:  rgba(245,240,232,0.36);
  --glass:      rgba(20,19,18,0.45);
  --line:       rgba(245,240,232,0.13);

  --serif: 'Fraunces', Georgia, serif;
  --sans:  'Inter', -apple-system, sans-serif;
  --mono:  'JetBrains Mono', monospace;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important;}
}
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--cinabre);color:var(--paper);}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
:focus-visible{outline:2px solid var(--cinabre);outline-offset:3px;}

.container{max-width:1280px;margin:0 auto;padding:0 32px;}
@media (max-width:768px){.container{padding:0 20px;}}

/* Grain de pellicule — texture globale subtile */
.grain{
  position:fixed;inset:0;
  z-index:300;
  pointer-events:none;
  opacity:0.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ============================================
   CLAPPERBOARD — signature, rail gauche
   ============================================ */
.rail{
  position:fixed;left:0;top:0;bottom:0;width:60px;
  background:var(--ink);
  border-right:1px solid var(--line);
  z-index:200;
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:24px 0;
}
.rail-logo{
  writing-mode:vertical-rl;
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;
  color:var(--smoke);text-transform:uppercase;
}
.rail-logo strong{color:var(--paper);}
.clap{
  width:32px;
  display:flex;flex-direction:column;align-items:center;gap:0;
}
.clap-top{
  width:32px;height:7px;
  background:repeating-linear-gradient(115deg, var(--paper) 0 4px, var(--ink) 4px 8px);
  transform-origin:left bottom;
  transition:transform 0.5s var(--ease);
}
.clap-top.snap{transform:rotate(-22deg) translateY(-2px);}
.clap-body{
  width:32px;height:38px;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-top:none;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;
}
.clap-scene{font-family:var(--mono);font-size:8px;color:var(--cinabre);letter-spacing:0.05em;}
.clap-take{font-family:var(--mono);font-size:7px;color:var(--smoke-dim);}
.rail-line{width:1px;flex:1;background:linear-gradient(to bottom,transparent,var(--line) 20%,var(--line) 80%,transparent);margin:20px 0;}

@media (max-width:900px){.rail{display:none;}}

/* ============================================
   TOP NAV
   ============================================ */
.topnav{
  position:fixed;top:0;left:60px;right:0;z-index:190;
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 44px;
  transition:background 0.4s var(--ease-soft),padding 0.4s var(--ease-soft),border-color 0.4s;
  border-bottom:1px solid transparent;
}
.topnav.scrolled{
  background:rgba(10,10,10,0.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:15px 44px;
  border-bottom:1px solid var(--line);
}
.topnav-logo{font-family:var(--serif);font-size:18px;font-weight:600;}
.topnav-logo span{color:var(--cinabre);}
.topnav-links{display:flex;gap:38px;align-items:center;}
.topnav-links a{font-size:13px;color:var(--smoke);transition:color 0.2s;}
.topnav-links a:hover{color:var(--paper);}
.topnav-cta{
  font-size:13px;padding:10px 22px;border:1px solid var(--paper);border-radius:1px;
  transition:all 0.25s var(--ease-soft);
}
.topnav-cta:hover{background:var(--paper);color:var(--ink);}
.nav-toggle{display:none;width:30px;height:30px;position:relative;}
.nav-toggle span{position:absolute;left:3px;right:3px;height:1px;background:var(--paper);transition:all 0.3s var(--ease-soft);}
.nav-toggle span:nth-child(1){top:11px;}
.nav-toggle span:nth-child(2){top:18px;}
.nav-toggle.open span:nth-child(1){transform:translateY(4px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){transform:translateY(-3px) rotate(-45deg);}

@media (max-width:900px){
  .topnav{left:0;padding:18px 20px;}
  .topnav.scrolled{padding:14px 20px;}
  .topnav-links{
    position:fixed;top:0;right:0;bottom:0;width:80%;max-width:340px;
    background:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;
    gap:26px;padding:40px;
    transform:translateX(100%);transition:transform 0.4s var(--ease);
    border-left:1px solid var(--line);
  }
  .topnav-links.open{transform:translateX(0);}
  .topnav-links a{font-size:19px;font-family:var(--serif);}
  .topnav-links a.topnav-cta{
    font-size:14px;font-family:var(--sans);
    padding:12px 24px;margin-top:6px;
  }
  .nav-toggle{display:block;z-index:201;}
}

/* ============================================
   SHARED
   ============================================ */
main{margin-left:60px;}
@media (max-width:900px){main{margin-left:0;}}

.scene-tag{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--cinabre);margin-bottom:24px;
}
.scene-tag::before{content:'';width:24px;height:1px;background:var(--cinabre);}
.scene-tag .take{color:var(--smoke-dim);font-size:10px;}

h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:-0.01em;line-height:1.04;}
h2{font-size:clamp(34px,5vw,60px);}

.lede{font-size:clamp(16px,1.5vw,18px);color:var(--smoke);max-width:540px;line-height:1.65;}

.reveal{opacity:0;transform:translateY(32px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-d1{transition-delay:0.1s;}
.reveal-d2{transition-delay:0.2s;}
.reveal-d3{transition-delay:0.3s;}
.reveal-d4{transition-delay:0.4s;}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14px;font-weight:500;padding:16px 30px;border-radius:1px;
  transition:all 0.35s var(--ease-soft);white-space:nowrap;
}
.btn-primary{background:var(--cinabre);color:var(--paper);}
.btn-primary:hover{background:var(--paper);color:var(--ink);transform:translateY(-2px);}
.btn-glass{
  background:var(--glass);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(245,240,232,0.25);color:var(--paper);
}
.btn-glass:hover{border-color:var(--paper);background:rgba(245,240,232,0.08);}

/* Separator avec assistant en filigrane */
.sep-assistant{
  position:relative;
  height:140px;
  overflow:hidden;
  background:var(--ink);
}
.sep-assistant img{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-38%);
  width:240px;opacity:0.06;filter:grayscale(1) contrast(1.2);
}
.sep-assistant::before,.sep-assistant::after{
  content:'';position:absolute;left:0;right:0;height:1px;background:var(--line);
}
.sep-assistant::before{top:0;}
.sep-assistant::after{bottom:0;}
.sep-label{
  position:relative;z-index:2;
  height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;letter-spacing:0.2em;color:var(--smoke-dim);
  text-transform:uppercase;
}

/* ============================================
   HERO — pièce maîtresse, vidéo YouTube réelle
   ============================================ */
.hero{
  position:relative;
  height:100vh;height:100dvh;
  overflow:hidden;
  background:var(--ink);
}
.hero-yt-wrap{
  position:absolute;inset:0;z-index:1;
  pointer-events:none;
  background-size:cover;
  background-position:center 25%;
}
.hero-yt-wrap iframe,
.hero-yt-wrap video{
  position:absolute;top:50%;left:50%;
  width:100vw;height:56.25vw; /* 16:9 */
  min-height:100vh;min-width:177.78vh; /* couvre toujours le viewport */
  transform:translate(-50%,-50%);
  object-fit:cover;
  opacity:0;
  transition:opacity 1.2s var(--ease-soft);
}
.hero-yt-wrap iframe.loaded,
.hero-yt-wrap video{opacity:1;}
.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(10,10,10,0.96) 0%, transparent 60%),
    linear-gradient(180deg, rgba(10,10,10,0.65) 0%, rgba(10,10,10,0.15) 30%, rgba(10,10,10,0.25) 55%, rgba(10,10,10,0.9) 100%),
    linear-gradient(90deg, rgba(10,10,10,0.5) 0%, transparent 25%, transparent 75%, rgba(10,10,10,0.5) 100%);
}
.hero-vignette{
  position:absolute;inset:0;z-index:2;
  box-shadow:inset 0 0 180px 40px rgba(0,0,0,0.65);
  pointer-events:none;
}
.hero-frame{
  position:absolute;inset:20px;z-index:3;
  border:1px solid rgba(245,240,232,0.14);
  pointer-events:none;
}
@media (max-width:768px){.hero-frame{inset:12px;}}

.hero-rec{
  position:absolute;top:100px;left:48px;z-index:4;
  display:flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.14em;
  color:rgba(245,240,232,0.7);
}
.hero-rec .dot{width:6px;height:6px;border-radius:50%;background:var(--cinabre);animation:pulse 1.8s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:0.25;}}
.hero-tc{
  position:absolute;top:100px;right:48px;z-index:4;
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;
  color:rgba(245,240,232,0.55);
  text-align:right;
}
@media (max-width:768px){
  .hero-rec,.hero-tc{display:none;}
}

.hero-sound-btn{
  position:absolute;bottom:34px;right:48px;z-index:5;
  display:flex;align-items:center;gap:9px;
  padding:11px 18px;
  background:var(--glass);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(245,240,232,0.25);
  border-radius:1px;
  color:var(--paper);
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;
  transition:all 0.25s var(--ease-soft);
}
.hero-sound-btn:hover{border-color:var(--paper);background:rgba(245,240,232,0.1);}
.hero-sound-icon{width:17px;height:17px;flex-shrink:0;}
.hero-sound-icon-on{display:none;}
.hero-sound-btn.on .hero-sound-icon-off{display:none;}
.hero-sound-btn.on .hero-sound-icon-on{display:block;}
@media (max-width:768px){
  .hero-sound-btn{right:24px;bottom:90px;padding:9px 14px;}
  .hero-sound-label{display:none;}
}

.hero-content{
  position:relative;z-index:5;
  height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 56px 90px;
}
@media (max-width:900px){.hero-content{padding:0 24px 70px;}}

.hero-eyebrow{
  font-family:var(--mono);font-size:11.5px;letter-spacing:0.16em;text-transform:uppercase;
  color:#E8897D;
  background:rgba(192,57,43,0.1);
  border:1px solid rgba(192,57,43,0.32);
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;margin-bottom:26px;width:fit-content;
}
.hero-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(46px,8vw,118px);
  line-height:0.96;letter-spacing:-0.015em;
  max-width:17ch;margin-bottom:24px;
}
.hero-title em{font-style:italic;color:var(--cinabre);font-weight:400;}
.hero-subtitle{
  font-size:clamp(16px,1.6vw,19px);
  color:rgba(245,240,232,0.82);
  max-width:520px;line-height:1.6;margin-bottom:40px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
@media (max-width:768px){
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{justify-content:center;}
}

.hero-scroll{
  position:absolute;bottom:34px;left:56px;z-index:5;
  display:flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.12em;color:var(--smoke);
}
.hero-scroll-line{width:46px;height:1px;background:rgba(245,240,232,0.3);position:relative;overflow:hidden;}
.hero-scroll-line::after{
  content:'';position:absolute;top:0;left:-100%;bottom:0;width:100%;
  background:var(--cinabre);animation:scrollLine 2.2s ease-in-out infinite;
}
@keyframes scrollLine{0%{left:-100%;}100%{left:100%;}}
@media (max-width:768px){.hero-scroll{left:24px;}}

/* ============================================
   MÉTHODE — présentation personnage de film
   ============================================ */
.methode{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  background:var(--ink);
  overflow:hidden;
  padding:120px 0;
}
.methode-bg{
  position:absolute;inset:0;z-index:0;
}
.methode-bg img{
  width:100%;height:100%;object-fit:cover;object-position:center 12%;
  filter:grayscale(0.55) contrast(1.12) brightness(0.62);
}
.methode-bg::after{
  content:'';position:absolute;inset:0;
  background:
    linear-gradient(90deg, var(--ink) 0%, rgba(10,10,10,0.88) 30%, rgba(10,10,10,0.35) 60%, rgba(10,10,10,0.1) 100%),
    linear-gradient(180deg, var(--ink) 0%, transparent 18%, transparent 80%, var(--ink) 100%);
}
.methode-content{
  position:relative;z-index:2;
  width:100%;
}
.methode-quote{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(30px,4.6vw,58px);
  line-height:1.16;letter-spacing:-0.01em;
  max-width:15ch;margin-bottom:36px;
}
.methode-quote .fade{color:var(--smoke-dim);}
.methode-quote em{font-style:italic;color:var(--cinabre);}
.methode-body{
  max-width:480px;color:var(--smoke);font-size:16.5px;line-height:1.75;margin-bottom:20px;
}
.methode-attr{
  font-family:var(--mono);font-size:12px;color:var(--smoke-dim);letter-spacing:0.04em;
}
@media (max-width:900px){
  .methode{padding:80px 0;min-height:auto;}
  .methode-bg img{object-position:65% 15%;filter:grayscale(0.55) contrast(1.12) brightness(0.4);}
  .methode-bg::after{
    background:linear-gradient(180deg, var(--ink) 0%, rgba(10,10,10,0.55) 35%, rgba(10,10,10,0.88) 75%, var(--ink) 100%);
  }
}

/* ============================================
   POURQUOI — comparaison
   ============================================ */
.pourquoi{
  background:var(--paper);color:var(--ink);
  padding:130px 0;
  position:relative;
}
.pourquoi .scene-tag{color:var(--cinabre);}
.pourquoi .scene-tag::before{background:var(--cinabre);}
.pourquoi .scene-tag .take{color:rgba(13,13,13,0.4);}
.pourquoi-head{max-width:680px;margin-bottom:64px;}
.pourquoi-head h2{color:var(--ink);}
.pourquoi-head .lede{color:rgba(13,13,13,0.6);margin-top:18px;}
.pq-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid rgba(13,13,13,0.1);}
.pq-col{padding:46px 42px;}
.pq-col+.pq-col{border-left:1px solid rgba(13,13,13,0.1);}
.pq-col.bad{background:var(--paper-dim);}
.pq-col.good{background:var(--ink);color:var(--paper);}
.pq-label{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:22px;display:block;}
.pq-col.bad .pq-label{color:rgba(13,13,13,0.42);}
.pq-col.good .pq-label{color:var(--cinabre);}
.pq-col h3{font-size:23px;margin-bottom:30px;font-family:var(--serif);}
.pq-col.bad h3{color:rgba(13,13,13,0.68);}
.pq-list{list-style:none;display:flex;flex-direction:column;gap:17px;}
.pq-list li{display:flex;gap:11px;font-size:14.5px;line-height:1.5;}
.pq-col.bad .pq-list li{color:rgba(13,13,13,0.58);}
.pq-col.good .pq-list li{color:rgba(245,240,232,0.85);}
.pq-mark{flex-shrink:0;width:17px;height:17px;margin-top:1px;}
@media (max-width:768px){
  .pourquoi{padding:80px 0;}
  .pq-grid{grid-template-columns:1fr;}
  .pq-col+.pq-col{border-left:none;border-top:1px solid rgba(13,13,13,0.1);}
}

/* ============================================
   PIPELINE — scénario annoté
   ============================================ */
.pipeline{
  background:var(--ink);
  padding:130px 0 100px;
  position:relative;
  overflow:hidden;
}
.pipeline-bg-img{
  position:absolute;right:-8%;top:8%;
  width:42%;opacity:0.08;
  filter:grayscale(1) contrast(1.3);
  pointer-events:none;
}
.pipeline-head{margin-bottom:64px;position:relative;z-index:2;}
.pipeline-head .lede{margin-top:16px;}
.script-track{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
}
.script-row{
  display:grid;
  grid-template-columns:90px 1fr 140px;
  gap:24px;
  align-items:start;
  padding:28px 0;
  border-top:1px solid var(--line);
  transition:background 0.3s;
}
.script-row:last-child{border-bottom:1px solid var(--line);}
.script-row:hover{background:rgba(245,240,232,0.02);}
.script-num{
  font-family:var(--serif);font-size:15px;color:var(--cinabre);
  display:flex;align-items:center;gap:8px;
}
.script-num::before{content:'SC.';color:var(--smoke-dim);font-family:var(--mono);font-size:10px;}
.script-main h3{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:8px;}
.script-main p{font-size:14px;color:var(--smoke);max-width:520px;line-height:1.55;}
.script-annotation{
  font-family:var(--mono);font-size:10px;letter-spacing:0.06em;color:var(--smoke-dim);
  text-align:right;text-transform:uppercase;line-height:1.6;
  padding-top:4px;
}
.script-row.core .script-annotation{color:var(--cinabre);}
.script-row.core .script-num{color:var(--gold);}
@media (max-width:768px){
  .pipeline{padding:80px 0 70px;}
  .pipeline-bg-img{display:none;}
  .script-row{grid-template-columns:1fr;gap:8px;}
  .script-annotation{text-align:left;}
}

/* ============================================
   SÉPARATEUR ASSISTANT
   ============================================ */
.sep-assistant{
  position:relative;height:130px;overflow:hidden;background:var(--ink);
}
.sep-assistant img{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-38%);
  width:220px;opacity:0.07;filter:grayscale(1) contrast(1.2);
}
.sep-assistant::before,.sep-assistant::after{content:'';position:absolute;left:0;right:0;height:1px;background:var(--line);}
.sep-assistant::before{top:0;}
.sep-assistant::after{bottom:0;}
.sep-label{
  position:relative;z-index:2;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;letter-spacing:0.2em;color:var(--smoke-dim);text-transform:uppercase;
}

/* ============================================
   ASSISTANT IA — galerie immersive
   ============================================ */
.assistant-gal{
  background:var(--ink);
  padding:130px 0;
  position:relative;
}
.ag-head{margin-bottom:56px;max-width:680px;}
.ag-head .lede{margin-top:16px;}
.ag-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.ag-card{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  background:var(--ink-2);
  border:1px solid var(--line);
  cursor:default;
}
.ag-card:nth-child(1),.ag-card:nth-child(4){grid-row:span 2;aspect-ratio:3/5.4;}
.ag-card img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.35) contrast(1.08);
  transition:transform 1.4s var(--ease-soft),filter 0.6s;
}
.ag-card:hover img{transform:scale(1.06);filter:grayscale(0) contrast(1.1);}
.ag-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,0.85) 100%);
}
.ag-tag{
  position:absolute;bottom:16px;left:16px;z-index:2;
  font-family:var(--mono);font-size:9.5px;letter-spacing:0.08em;color:rgba(245,240,232,0.7);
  text-transform:uppercase;
}
@media (max-width:900px){
  .assistant-gal{padding:80px 0;}
  .ag-grid{grid-template-columns:repeat(2,1fr);}
  .ag-card:nth-child(1),.ag-card:nth-child(4){grid-row:span 1;aspect-ratio:3/4;}
}

/* Variante premium — 2 photos seulement */
.ag-grid-duo{
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.ag-grid-duo .ag-card{
  aspect-ratio:3/4.2;
  border:1px solid rgba(245,240,232,0.16);
}
.ag-grid-duo .ag-card img{filter:grayscale(0.15) contrast(1.1);}
.ag-grid-duo .ag-card:hover img{transform:scale(1.04);filter:grayscale(0) contrast(1.12);}
@media (max-width:768px){
  .ag-grid-duo{grid-template-columns:1fr;gap:18px;}
  .ag-grid-duo .ag-card{aspect-ratio:4/5;}
}

/* ============================================
   FORMATEUR — discret, portrait de profil
   ============================================ */
.formateur{
  background:var(--paper);color:var(--ink);
  padding:130px 0;
}
.formateur .scene-tag{color:var(--cinabre);}
.formateur .scene-tag::before{background:var(--cinabre);}
.formateur .scene-tag .take{color:rgba(13,13,13,0.4);}
.formateur-grid{
  display:grid;
  grid-template-columns:1fr 280px;
  gap:64px;
  align-items:start;
}
.formateur-text h2{color:var(--ink);margin-bottom:22px;}
.formateur-text .lede{color:rgba(13,13,13,0.62);margin-bottom:32px;}
.formateur-block{margin-bottom:26px;}
.formateur-block-label{
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--cinabre);margin-bottom:8px;display:block;
}
.formateur-block p{color:rgba(13,13,13,0.62);font-size:14.5px;line-height:1.6;}
.formateur-stats{
  display:flex;gap:36px;margin-top:36px;padding-top:28px;border-top:1px solid rgba(13,13,13,0.1);
}
.formateur-stat-num{font-family:var(--serif);font-size:26px;display:block;color:var(--ink);}
.formateur-stat-label{font-size:10.5px;color:rgba(13,13,13,0.45);text-transform:uppercase;letter-spacing:0.04em;}

.formateur-portrait{
  position:relative;
}
.formateur-portrait-img{
  width:100%;aspect-ratio:3/4;
  overflow:hidden;
  filter:grayscale(0.7) contrast(1.05) brightness(0.92);
  border:1px solid rgba(13,13,13,0.12);
}
.formateur-portrait-img img{width:100%;height:100%;object-fit:cover;object-position:70% 30%;}
.formateur-portrait-cap{
  font-family:var(--mono);font-size:9.5px;letter-spacing:0.08em;color:rgba(13,13,13,0.4);
  margin-top:10px;text-align:right;text-transform:uppercase;
}
@media (max-width:900px){
  .formateur{padding:80px 0;}
  .formateur-grid{grid-template-columns:1fr;gap:32px;}
  .formateur-portrait{max-width:220px;}
}

/* ============================================
   PARIS / DAKAR
   ============================================ */
.vision{
  background:var(--ink);padding:130px 0;position:relative;overflow:hidden;
}
.vision-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;min-height:520px;}
.vision-text{display:flex;flex-direction:column;justify-content:center;padding-right:60px;}
.vision-text h2{margin-bottom:22px;}
.vision-text .lede{margin-bottom:36px;}
.vision-cities{display:flex;gap:44px;margin-bottom:36px;}
.vision-city{font-family:var(--serif);font-size:30px;position:relative;padding-bottom:12px;}
.vision-city::after{content:'';position:absolute;bottom:0;left:0;width:28px;height:2px;background:var(--cinabre);}
.vision-tags{display:flex;flex-wrap:wrap;gap:9px;}
.vision-tag{
  font-family:var(--mono);font-size:10.5px;letter-spacing:0.05em;text-transform:uppercase;
  border:1px solid var(--line);padding:7px 13px;color:var(--smoke);
}
.vision-media{position:relative;overflow:hidden;}
.vision-media img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.35) contrast(1.05);}
.vision-media::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--ink) 0%,transparent 22%,transparent 100%);}
.vision-media-label{
  position:absolute;bottom:22px;left:22px;z-index:2;
  font-family:var(--mono);font-size:10px;letter-spacing:0.08em;color:var(--paper);
}
@media (max-width:900px){
  .vision{padding:80px 0;}
  .vision-grid{grid-template-columns:1fr;min-height:auto;}
  .vision-text{padding-right:0;}
  .vision-media{order:-1;aspect-ratio:16/10;}
}

/* ============================================
   OFFRES — effet verre
   ============================================ */
.offers{background:var(--paper);color:var(--ink);padding:130px 0;}
.offers .scene-tag{color:var(--cinabre);}
.offers .scene-tag::before{background:var(--cinabre);}
.offers .scene-tag .take{color:rgba(13,13,13,0.4);}
.offers-head{max-width:640px;margin-bottom:56px;}
.offers-head h2{color:var(--ink);}
.offers-head .lede{color:rgba(13,13,13,0.6);margin-top:16px;}
.offers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:start;}
.offer-card{
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(13,13,13,0.1);
  padding:34px 26px;display:flex;flex-direction:column;height:100%;
  transition:transform 0.35s var(--ease-soft),box-shadow 0.35s var(--ease-soft);
}
.offer-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px -16px rgba(13,13,13,0.16);}
.offer-card.feat{
  background:rgba(10,10,10,0.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  color:var(--paper);border-color:var(--ink);transform:translateY(-14px);
}
.offer-card.feat:hover{transform:translateY(-20px);}
.offer-badge{
  display:inline-block;font-family:var(--mono);font-size:9.5px;letter-spacing:0.08em;text-transform:uppercase;
  background:var(--cinabre);color:#fff;padding:5px 10px;margin-bottom:16px;align-self:flex-start;
}
.offer-num{font-family:var(--serif);font-size:14px;color:var(--cinabre);margin-bottom:7px;}
.offer-card.feat .offer-num{color:#E8897D;}
.offer-title{font-family:var(--serif);font-size:20px;margin-bottom:16px;line-height:1.2;min-height:48px;}
.offer-price{font-family:var(--serif);font-size:32px;margin-bottom:3px;}
.offer-price-sub{font-size:11.5px;color:rgba(13,13,13,0.5);margin-bottom:22px;}
.offer-card.feat .offer-price-sub{color:var(--smoke-dim);}
.offer-desc{font-size:13px;line-height:1.5;color:rgba(13,13,13,0.6);margin-bottom:20px;}
.offer-card.feat .offer-desc{color:var(--smoke);}
.offer-list{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:26px;flex:1;}
.offer-list li{font-size:12.5px;line-height:1.4;color:rgba(13,13,13,0.66);padding-left:15px;position:relative;}
.offer-list li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:1px;background:var(--cinabre);}
.offer-card.feat .offer-list li{color:var(--smoke);}
.offer-btn{text-align:center;font-size:12.5px;padding:12px 0;border:1px solid var(--ink);transition:all 0.25s var(--ease-soft);}
.offer-btn:hover{background:var(--ink);color:var(--paper);}
.offer-card.feat .offer-btn{border-color:var(--paper);}
.offer-card.feat .offer-btn:hover{background:var(--cinabre);border-color:var(--cinabre);}
.offers-note{text-align:center;margin-top:44px;font-size:12.5px;color:rgba(13,13,13,0.5);}
.offers-note strong{color:var(--cinabre);font-weight:500;}
@media (max-width:1000px){
  .offers-grid{grid-template-columns:1fr 1fr;}
  .offer-card.feat{transform:none;}
  .offer-card.feat:hover{transform:translateY(-6px);}
}
@media (max-width:600px){
  .offers{padding:80px 0;}
  .offers-grid{grid-template-columns:1fr;}
}

/* ============================================
   TÉLÉCHARGEMENT PDF
   ============================================ */
.download{background:var(--ink);padding:100px 0;}
.download-box{
  background:var(--ink-2);border:1px solid var(--line);padding:56px;
  display:flex;justify-content:space-between;align-items:center;gap:36px;
}
.download-box h2{font-size:clamp(24px,2.8vw,34px);margin-bottom:12px;}
.download-box p{color:var(--smoke);max-width:420px;font-size:14.5px;line-height:1.6;}
.download-icon{
  flex-shrink:0;width:58px;height:58px;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--cinabre);
}
@media (max-width:768px){
  .download{padding:70px 0;}
  .download-box{flex-direction:column;text-align:center;padding:40px 26px;}
}

/* ============================================
   FAQ
   ============================================ */
.faq{background:var(--ink);padding:90px 0 130px;}
.faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:56px;}
.faq-head h2{margin-bottom:14px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:24px 0;font-family:var(--serif);font-size:17px;color:var(--paper);
}
.faq-q-plus{flex-shrink:0;width:20px;height:20px;position:relative;}
.faq-q-plus::before,.faq-q-plus::after{content:'';position:absolute;background:var(--cinabre);transition:transform 0.3s var(--ease-soft);}
.faq-q-plus::before{top:50%;left:0;right:0;height:1px;}
.faq-q-plus::after{left:50%;top:0;bottom:0;width:1px;}
.faq-item.open .faq-q-plus::after{transform:rotate(90deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease-soft);}
.faq-a-inner{padding-bottom:24px;font-size:13.5px;color:var(--smoke);line-height:1.6;max-width:540px;}
@media (max-width:900px){
  .faq{padding:70px 0;}
  .faq-grid{grid-template-columns:1fr;gap:28px;}
}

/* ============================================
   CONTACT
   ============================================ */
.contact{background:var(--paper);color:var(--ink);padding:130px 0;}
.contact .scene-tag{color:var(--cinabre);}
.contact .scene-tag::before{background:var(--cinabre);}
.contact-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:64px;}
.contact-head h2{color:var(--ink);margin-bottom:18px;}
.contact-head .lede{color:rgba(13,13,13,0.6);margin-bottom:36px;}
.contact-direct{display:flex;flex-direction:column;gap:16px;padding-top:28px;border-top:1px solid rgba(13,13,13,0.1);}
.contact-direct-label{font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:rgba(13,13,13,0.45);}
.contact-direct-value{font-family:var(--serif);font-size:17px;}
.contact-direct-value a{border-bottom:1px solid transparent;transition:border-color 0.2s;}
.contact-direct-value a:hover{border-color:var(--cinabre);}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.form-field.full{grid-column:1/-1;}
.form-field label{font-size:11.5px;color:rgba(13,13,13,0.55);}
.form-field input,.form-field select,.form-field textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(13,13,13,0.25);
  padding:9px 2px;font-family:var(--sans);font-size:14.5px;color:var(--ink);transition:border-color 0.25s;
}
.form-field textarea{resize:vertical;min-height:84px;}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-bottom-color:var(--cinabre);outline:none;}
.form-submit{
  margin-top:12px;background:var(--ink);color:var(--paper);padding:15px 34px;
  font-size:13.5px;font-weight:500;transition:background 0.25s;border-radius:1px;
}
.form-submit:hover{background:var(--cinabre);}
.form-success{display:none;background:var(--ink);color:var(--paper);padding:30px;text-align:center;font-family:var(--serif);font-size:17px;}
.form-success.show{display:block;}
.form-success span{display:block;font-family:var(--sans);font-size:12.5px;color:var(--smoke);margin-top:8px;}
@media (max-width:900px){
  .contact{padding:80px 0;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  .form-grid{grid-template-columns:1fr;}
}

/* ============================================
   FOOTER
   ============================================ */
footer{background:var(--ink);border-top:1px solid var(--line);padding:60px 0 32px;}
.footer-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:36px;
  padding-bottom:44px;border-bottom:1px solid var(--line);margin-bottom:26px;flex-wrap:wrap;
}
.footer-brand{font-family:var(--serif);font-size:22px;}
.footer-brand span{color:var(--cinabre);}
.footer-brand-sub{font-size:12.5px;color:var(--smoke-dim);margin-top:7px;}
.footer-links{display:flex;gap:32px;flex-wrap:wrap;}
.footer-links a{font-size:12.5px;color:var(--smoke);transition:color 0.2s;}
.footer-links a:hover{color:var(--paper);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  font-family:var(--mono);font-size:10.5px;color:var(--smoke-dim);
}
@media (max-width:768px){
  footer{padding:44px 0 26px;}
  .footer-top{flex-direction:column;gap:22px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
}