/* ============================================================
   VIEWFINDER — landing
   DA : papier crème + outremer, typo expanded ultra-grasse,
   accents serif italiques, HUD de viseur, flashs, grain.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wdth,wght@0,62..125,100..900;1,62..125,100..900&family=DM+Mono:wght@400;500&family=Instrument+Serif:ital@0;1&display=swap');

:root{
  /* papier crème — chaud, mat */
  --paper:   #efe9da;
  --paper-2: #e8e1cf;
  --paper-3: #ddd5c0;
  --ink:     #13161d;
  --ink-2:   #2b303b;
  --ink-soft: rgba(19,22,29,.55);
  --flash:   #ffffff;

  /* bleu outremer = couleur principale */
  --hot:   #2334d4;   /* bleu outremer — accent principal / duotone */
  --cyan:  #4cc6ff;   /* bleu clair — aberration */
  --navy:  #101a66;   /* bleu profond */
  --rec:   #e03131;   /* point REC */

  --edge: rgba(19,22,29,.12);
  --paper-edge: rgba(239,233,218,.28);
  --shadow: 34px 44px 80px -34px rgba(16,26,102,.42);

  --display: 'Archivo', sans-serif;
  --body: 'Archivo', system-ui, sans-serif;
  --mono: 'DM Mono', ui-monospace, monospace;
  --serif: 'Instrument Serif', Georgia, serif;

  --pad-x: clamp(18px, 5vw, 90px);

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-snap: cubic-bezier(.16,1.2,.3,1);
}

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

html{ scroll-behavior:smooth; }
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

body.vf{
  font-family: var(--body);
  color: var(--ink);
  background: var(--paper);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

::selection{ background: var(--hot); color: var(--flash); }

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
.mono{ font-family: var(--mono); }

/* ---------- typo display partagée : expanded, ultra-grasse ---------- */
.vf-loader__word, .vf-logo,
.vf-hook__title,
.vf-marquee__chunk,
.vf-cs__head h2, .cs-intro__big, .cs-outro__big, .cs-cell__no,
.vf-offers__head h2, .offer h3, .offer__no,
.vf-foot h4, .vf-foot__invite{
  font-family: var(--display);
  font-weight: 900;
  font-stretch: 125%;
  letter-spacing: -0.012em;
  text-transform: uppercase;
}

/* accent serif italique (mot en bas-de-casse au milieu des capitales) */
.sx{
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-stretch: 100%;
  letter-spacing: 0;
  text-transform: none;
  font-size: 1.04em;
}
.hot{ color: var(--hot); }

/* ---------- couches d'ambiance fixes ---------- */
.vf-bg{
  position: fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(125% 90% at 50% -15%, rgba(255,255,255,.7), transparent 62%),
    radial-gradient(100% 90% at 50% 118%, rgba(20,80,239,.07), transparent 60%),
    linear-gradient(180deg, var(--paper), var(--paper-2) 65%, var(--paper-3));
}
/* pli de papier discret */
.vf-bg::before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(102deg, transparent 0 49%, rgba(255,255,255,.5) 49.6% 50.2%, transparent 51%);
  mix-blend-mode: soft-light; opacity:.5;
}
/* grille technique très légère (plan de travail) */
.vf-bg::after{
  content:""; position:absolute; inset:0; opacity:.55;
  background-image:
    linear-gradient(rgba(19,22,29,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19,22,29,.04) 1px, transparent 1px);
  background-size: 84px 84px;
}

/* grain animé (discret) */
.vf-grain{
  position: fixed; inset:-50%; z-index:60; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%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)' opacity='0.55'/%3E%3C/svg%3E");
  mix-blend-mode: multiply; opacity:.05;
  animation: grain .42s steps(2) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 25%{transform:translate(-4%,2%)}
  50%{transform:translate(3%,-3%)} 75%{transform:translate(-2%,4%)} 100%{transform:translate(2%,-2%)}
}

/* vignette (légère) */
.vf-vignette{
  position:fixed; inset:0; z-index:55; pointer-events:none;
  box-shadow: inset 0 0 200px 30px rgba(11,28,74,.14);
}

/* flash plein écran (déclenché au tir / transitions) */
.vf-flash{
  position: fixed; inset:0; z-index:90; pointer-events:none;
  background: radial-gradient(circle at 50% 78%, var(--flash), rgba(255,253,245,.0) 65%);
  opacity:0;
}

/* canvas 3D de la caméra — absolu DANS le hero : le boîtier défile
   naturellement avec la section. z-index AU-DESSUS des faisceaux : la caméra
   occulte les images là où elle est, donc elle n'est jamais recouverte.
   (canvas transparent + pointer-events:none → les faisceaux restent visibles
   et cliquables à travers les zones vides) */
#vf-stage-canvas{
  position: absolute; inset:0; z-index:12; pointer-events:none;
  width:100%; height:100%;
}

/* clignotement générique (REC, diodes) */
@keyframes vfblink{ 0%,49%{opacity:1} 50%,100%{opacity:.15} }

/* ============================================================
   ÉCRAN DE CHARGEMENT — minimal
   ============================================================ */
.vf-loader{
  position: fixed; inset:0; z-index:200;
  display:grid; place-items:center;
  background: linear-gradient(180deg, var(--paper), var(--paper-2));
  will-change: opacity;
}
.vf-loader__inner{
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.vf-loader__kick{
  font-size:10px; letter-spacing:.3em; color:var(--hot); margin-bottom:18px;
  text-transform:uppercase;
}
.vf-loader__word{
  font-size: clamp(38px, 6vw, 76px);
  line-height:.9; color:var(--ink);
}
.vf-loader__track{
  margin-top:28px; width: min(320px, 60vw); height:2px; background:rgba(19,22,29,.14);
  overflow:hidden;
}
.vf-loader__track i{
  display:block; width:100%; height:100%; background:var(--hot);
  transform:scaleX(0); transform-origin:0 50%;
  transition: transform .3s linear; will-change: transform;
}
.vf-loader__meta{
  margin-top:12px; width: min(320px, 60vw);
  display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-soft);
}
.vf-loader__meta .vf-loader__pct{ color:var(--ink); }
.vf-loader.is-done{ pointer-events:none; }

/* ============================================================
   HEADER
   ============================================================ */
.vf-header{
  position: fixed; top:0; left:0; right:0; z-index:70;
  display:flex; align-items:center; justify-content:space-between;
  padding: 20px clamp(18px,4vw,54px);
  mix-blend-mode: multiply;
  transition: background .35s var(--ease), padding .35s var(--ease),
              box-shadow .35s var(--ease);
}
/* dès qu'on scrolle : fond papier translucide + flou, on quitte le mode fondu */
.vf-header.is-scrolled{
  mix-blend-mode: normal;
  background: rgba(239,233,218,.85);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--edge);
  padding-top: 13px; padding-bottom: 13px;
  box-shadow: 0 18px 40px -32px rgba(16,26,102,.4);
}
.vf-logo{
  font-size:19px; letter-spacing:.02em;
  display:flex; align-items:center; gap:10px;
}
.vf-logo .dot{ width:11px;height:11px;border-radius:50%;background:var(--hot);
  box-shadow:0 0 0 3px rgba(35,52,212,.25); }
.vf-nav{ display:flex; align-items:center; gap: clamp(14px,2vw,34px); font-family:var(--mono);
  font-size:11px; letter-spacing:.16em; text-transform:uppercase; }
.vf-nav a{ position:relative; padding:4px 0; }
.vf-nav a::after{ content:""; position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--ink); transition:width .3s var(--ease); }
.vf-nav a:hover::after{ width:100%; }
.vf-nav .vf-nav__pill{
  border:1.5px solid var(--ink); border-radius:99px; padding:9px 18px;
  transition: background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease);
}
.vf-nav .vf-nav__pill::after{ display:none; }
.vf-nav .vf-nav__pill:hover{ background:var(--ink); color:var(--paper); }

/* ============================================================
   HERO — la pellicule
   La caméra 3D vit en bas à gauche (canvas), l'objectif pointe
   vers la droite ; les faisceaux jaillissent vers la droite.
   ============================================================ */
.vf-hero{
  position: relative; z-index:10;
  min-height: 100svh;
  overflow:hidden;
}

/* ---- hook fort, au-dessus de la caméra (gauche) ---- */
.vf-hook{
  position:absolute; z-index:13;
  left: clamp(18px, 4vw, 72px);
  top: clamp(86px, 12.5vh, 150px);
  max-width: min(920px, 53vw);
}
.vf-hook__kicker{
  font-size:11px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--hot); margin-bottom: clamp(12px,2vh,20px);
}
.vf-hook__title{
  font-size: clamp(40px, 5vw, 96px); line-height:.94;
  color:var(--ink);
}
.vf-hook__title .line{ display:block; overflow:hidden; }
.vf-hook__title .line i{ display:block; font-style:normal; will-change:transform; }
.vf-hook__title .hl{ color:var(--hot); }
.vf-hook__sub{
  margin-top: clamp(12px,2vh,20px); max-width:34ch;
  font-weight:600; font-size: clamp(14px,1.15vw,17px); line-height:1.6;
  color:var(--ink-2);
}
/* CTA : bouton posé bien en dessous de la caméra (desktop) */
.vf-hook__cta{
  position:absolute; z-index:14;
  left: clamp(18px, 4vw, 72px);
  bottom: clamp(40px, 8vh, 92px);
  display:flex; align-items:center; gap:26px; margin:0;
}
/* bouton plein outremer : on comprend tout de suite que c'est cliquable */
.vf-cta{
  display:inline-flex; align-items:center; gap:14px;
  background:var(--hot); color:var(--flash);
  padding:13px 16px 13px 28px; border-radius:46px;
  box-shadow:0 14px 30px -12px rgba(35,52,212,.55);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
}
.vf-cta:hover{ transform:translateY(-2px); background:var(--navy);
  box-shadow:0 20px 44px -14px rgba(35,52,212,.7); }
.vf-cta:active{ transform:translateY(0); }
.vf-cta__ring{
  width:36px; height:36px; border-radius:50%;
  background:var(--flash); color:var(--hot); border:0;
  display:grid; place-items:center; font-size:16px;
  transition: color .3s var(--ease), transform .35s var(--ease);
}
.vf-cta:hover .vf-cta__ring{ color:var(--navy); }
.vf-cta__arrow{ transition: transform .35s var(--ease); }
.vf-cta:hover .vf-cta__arrow{ transform: translateY(3px); }
.vf-cta__txt{
  font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:600;
  color:var(--flash);
}

/* ---- éventail de projection : l'objectif "tire" les films ---- */
.vf-fan{
  --ox: 22.5vw;                    /* origine = bout de l'objectif */
  --oy: 67vh;
  --len: 92vw;                     /* longueur d'un faisceau */
  --spread: 19vw;                  /* épaisseur du faisceau à son extrémité */
  --gap: 7.5vw;                    /* arrondi : les faisceaux démarrent sur un arc autour de l'objectif */
  --a0: -22deg;                    /* angle du premier faisceau (au-dessus : le hook reste lisible) */
  --astep: 12deg;                  /* écart angulaire entre faisceaux */
  --imgw: 100vw;                   /* boîte image contre-rotée (photo droite) */
  --imgh: 76vw;
  position:absolute; inset:0; z-index:11;
  pointer-events:none;             /* seuls les faisceaux (clip-path) sont cliquables */
}
/* points de progression du deck mobile (cachés sur desktop) */
.vf-deck-dots{ display:none; }
.fan-beam{
  --angle: calc(var(--a0) + var(--astep) * var(--i));
  position:absolute; left:var(--ox); top:var(--oy);
  width:var(--len); height:var(--spread);
  margin-top: calc(var(--spread) / -2);
  transform: rotate(var(--angle));
  transform-origin: 0 50%;
  -webkit-mask-image: radial-gradient(circle at 0 50%, transparent calc(var(--gap) - 1px), #000 var(--gap));
          mask-image: radial-gradient(circle at 0 50%, transparent calc(var(--gap) - 1px), #000 var(--gap));
}

/* ---- faisceau : trapèze clipé, image duotone, légende le long de l'axe ---- */
.frame-card{
  position:absolute; inset:0; display:block;
  clip-path: polygon(0 47%, 100% 0, 100% 100%, 0 53%);
  background: var(--navy);
  cursor:pointer;
  pointer-events:auto;
  transform-origin: 0 50%;
}
.frame-card__media{
  position:absolute; inset:0;
}
.frame-card__media img,
.frame-card__media video{
  position:absolute; left:50%; top:50%;
  width:var(--imgw); height:var(--imgh); max-width:none;
  object-fit:cover; object-position:center;
  transform: translate(-50%,-50%) rotate(calc(-1 * var(--angle)));
  filter: grayscale(1) contrast(1.12) brightness(1.04);
  transition: filter .55s var(--ease);
}
/* la vidéo EST la cover (sa 1re image) — visible en permanence, en duotone */
.frame-card__media video{ opacity:1; transition: filter .55s var(--ease); }
/* duotone : ombres outremer, lumières crème */
.frame-card__media::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background: var(--hot); mix-blend-mode: lighten;
  transition: opacity .55s var(--ease);
}
.frame-card__media::after{
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none;
  background: var(--paper); mix-blend-mode: multiply;
  transition: opacity .55s var(--ease);
}
.frame-card:hover .frame-card__media::before,
.frame-card:hover .frame-card__media::after{ opacity:0; }
.frame-card:hover .frame-card__media img,
.frame-card:hover .frame-card__media video{ filter:none; }

/* logo du client, posé le long du faisceau (remplace le texte par <img> pour un vrai logo) */
.frame-card__logo{
  position:absolute; z-index:4; left:55%; top:50%;
  transform: translate(-50%,-50%);
  color: var(--paper); pointer-events:none; white-space:nowrap;
  text-shadow: 0 2px 30px rgba(16,26,102,.65);
  transition: opacity .4s var(--ease), transform .5s var(--ease);
}
.frame-card:hover .frame-card__logo{ transform: translate(-50%,-50%) scale(1.05); }
.vf-fan.is-watching .frame-card__logo{ opacity:0; }
.frame-card__logo img{
  max-height: clamp(30px, 3.2vw, 56px); width:auto;
  filter: brightness(0) invert(1);                /* logo passé en blanc */
}
/* quatre styles de wordmark provisoires (un par client) */
.logo--serif{ font-family:var(--serif); font-style:italic; font-size:clamp(24px,2.3vw,44px); letter-spacing:.01em; }
.logo--wide{ font-family:var(--display); font-weight:900; font-stretch:125%; text-transform:uppercase;
  font-size:clamp(17px,1.7vw,32px); letter-spacing:.22em; }
.logo--mono{ font-family:var(--mono); font-size:clamp(14px,1.4vw,26px); letter-spacing:.3em; text-transform:uppercase; }
.logo--ext{ font-family:var(--body); font-weight:500; font-stretch:125%; text-transform:uppercase;
  font-size:clamp(15px,1.5vw,28px); letter-spacing:.42em; }

/* ---- lecteur en place : la vidéo cliquée se redresse en rectangle ----
   (habillage outremer uniquement : cadre, bouton, fond bleu nuit) */
.vf-player{
  position:absolute; inset:0; z-index:30;
  background: var(--navy);
  will-change: clip-path;
}
.vf-player img,
.vf-player video{
  position:absolute; object-fit:cover; max-width:none; display:block;
  background: var(--navy);
}
.vf-player video{ opacity:0; transition: opacity .35s var(--ease); }
.vf-player video.is-live{ opacity:1; }
.vf-player__frame{
  position:absolute; pointer-events:none;
  border:2px solid var(--hot);
  box-shadow: 0 40px 90px -40px rgba(16,26,102,.7);
  opacity:0; transition: opacity .4s var(--ease) .1s;
}
.vf-player.is-open .vf-player__frame{ opacity:1; }
.vf-player__close{
  position:absolute;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  background:var(--hot); color:var(--flash); border:0; cursor:pointer;
  padding:10px 18px; border-radius:40px;
  opacity:0; transform: translateY(-8px);
  transition: opacity .35s var(--ease) .15s, transform .35s var(--ease) .15s, background .3s;
}
.vf-player.is-open .vf-player__close{ opacity:1; transform:none; }
.vf-player__close:hover{ background:var(--ink); }

/* repère "objectif" au point de convergence (mobile uniquement) */
.vf-fan__lens{
  display:none;
  position:absolute; left:var(--ox); top:var(--oy);
  width:20px; height:20px; margin:-10px 0 0 -10px; border-radius:50%;
  background: var(--paper); border:2.5px solid var(--hot);
  box-shadow: 0 0 0 6px rgba(35,52,212,.16);
}
.vf-fan__lens::after{
  content:""; position:absolute; inset:4px; border-radius:50%;
  background: var(--hot); animation: vfblink 1.4s steps(2) infinite;
}

/* ============================================================
   MARQUEE — bande-annonce typographique
   ============================================================ */
.vf-marquee{
  position:relative; z-index:13;
  background:var(--ink); color:var(--paper);
  transform: rotate(-1.2deg) scale(1.03);
  margin: clamp(-40px,-3vh,-20px) 0 clamp(30px,5vh,60px);
  padding: clamp(14px,1.6vh,22px) 0;
  overflow:hidden;
  box-shadow: 0 34px 70px -42px rgba(16,26,102,.55);
}
.vf-marquee__track{
  display:flex; width:max-content;
  animation: marquee 26s linear infinite;
}
.vf-marquee:hover .vf-marquee__track{ animation-play-state:paused; }
.vf-marquee__chunk{
  display:flex; align-items:baseline; gap:.55em; padding-right:.55em;
  font-size: clamp(28px,3.4vw,54px); line-height:1; white-space:nowrap;
}
.vf-marquee__chunk b{
  font-weight:900; color:transparent;
  -webkit-text-stroke:1.5px rgba(239,233,218,.85);
}
.vf-marquee__chunk i{ font-style:normal; color:var(--cyan); font-size:.55em; }
.vf-marquee__chunk em{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-stretch:100%; text-transform:none; letter-spacing:0;
  color:var(--cyan);
}
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ============================================================
   SECTIONS scroll
   ============================================================ */
.vf-section{ position:relative; z-index:10; padding: clamp(90px,14vh,180px) var(--pad-x); }

.reveal{ opacity:0; transform: translateY(40px); }
.reveal.in{ opacity:1; transform:none; transition: opacity .8s var(--ease), transform .9s var(--ease); }

.kick{ font-family:var(--mono); font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--hot); }

/* ============================================================
   SÉQ. 02 — PLANCHE-CONTACT (pellicule horizontale épinglée)
   ============================================================ */
.vf-section--cs{ padding:0; }
.vf-cs{
  position:relative; height:100svh; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center;
  gap: clamp(18px,3.4vh,40px);
  padding: clamp(86px,12vh,140px) 0 clamp(54px,8vh,80px);
}
.vf-cs__head{
  display:flex; flex-wrap:wrap; align-items:baseline; gap:10px 18px;
  padding: 0 var(--pad-x);
}
.vf-cs__head h2{
  order:3; flex-basis:100%;
  font-size: clamp(28px,4.2vw,66px); line-height:.92; margin-top:8px;
}
.vf-cs__dev{ margin-left:auto; font-size:10px; letter-spacing:.18em; color:var(--ink-soft); text-transform:uppercase; }

.vf-cs__rail{ flex:1; display:flex; align-items:center; min-height:0; }

/* la bande pellicule : fond encre + perforations haut/bas */
.vf-cs__grid{
  position:relative; display:flex; align-items:center;
  gap: clamp(26px,3.4vw,60px);
  width:max-content; will-change:transform;
  background: var(--ink);
  padding: clamp(40px,5.4vh,58px) var(--pad-x);
  box-shadow: 0 40px 90px -50px rgba(16,26,102,.65);
}
.vf-cs__grid::before,
.vf-cs__grid::after{
  content:""; position:absolute; left:0; right:0; height:9px; opacity:.9;
  background-image: repeating-linear-gradient(90deg,
    transparent 0 8px, var(--paper) 8px 20px, transparent 20px 28px);
}
.vf-cs__grid::before{ top:13px; }
.vf-cs__grid::after{ bottom:13px; }

.cs-intro, .cs-outro{
  flex:none; display:flex; flex-direction:column; justify-content:center;
  gap:16px; color:var(--paper);
}
.cs-intro{ width:clamp(300px,26vw,420px); }
.cs-intro > p.mono{ font-size:10px; letter-spacing:.24em; color:rgba(239,233,218,.55); text-transform:uppercase; }
.cs-intro__big{
  font-size: clamp(34px,3.6vw,58px); line-height:.92; color:var(--paper);
}
.cs-intro__hint{ color:var(--cyan); font-size:10px; letter-spacing:.24em; }
.cs-outro{ width:clamp(340px,34vw,560px); align-items:center; text-align:center; gap:20px; }
.cs-outro__big{ font-size: clamp(36px,4vw,66px); line-height:.92; color:var(--paper); }
.cs-outro > p.mono{ color:rgba(239,233,218,.55); font-size:10px; letter-spacing:.24em; }

.cs-cell{ position:relative; flex:none; width:clamp(340px,30vw,520px); }
.cs-frame{
  position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--navy);
}
.cs-frame img{
  width:114%; height:100%; max-width:none; object-fit:cover;
  filter: grayscale(1) contrast(1.1) brightness(1.02);
  transition: filter .6s var(--ease);
  will-change: transform;
}
/* duotone, comme les faisceaux du hero */
.cs-frame::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:var(--hot); mix-blend-mode:lighten; transition: opacity .55s var(--ease);
}
.cs-frame::after{
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:var(--paper); mix-blend-mode:multiply; transition: opacity .55s var(--ease);
}
.cs-cell:hover .cs-frame::before,
.cs-cell:hover .cs-frame::after{ opacity:0; }
.cs-cell:hover .cs-frame img{ filter:none; }

/* gros numéro débordant */
.cs-cell__no{
  position:absolute; z-index:4; top:-34px; right:-12px;
  font-size: clamp(70px,7vw,120px); line-height:1;
  color:transparent; -webkit-text-stroke:1.5px rgba(239,233,218,.5);
  pointer-events:none;
}
.cs-cell figcaption{
  display:flex; gap:14px; align-items:center; margin-top:12px;
  font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(239,233,218,.75);
}
.cs-no{ color:var(--cyan); font-weight:500; }
.cs-k{ margin-left:auto; border:1px solid var(--paper-edge); border-radius:99px; padding:3px 10px; }

/* repères de cadrage aux coins */
.cs-reg{ position:absolute; width:12px; height:12px; z-index:5; opacity:0; transition:opacity .5s .2s; }
.cs-cell.in .cs-reg{ opacity:.9; }
.cs-reg::before,.cs-reg::after{ content:""; position:absolute; background:var(--cyan); }
.cs-reg::before{ left:50%; top:0; width:1.5px; height:100%; transform:translateX(-50%); }
.cs-reg::after{ top:50%; left:0; height:1.5px; width:100%; transform:translateY(-50%); }
.cs-reg.tl{ top:-7px; left:-7px; } .cs-reg.tr{ top:-7px; right:-7px; }
.cs-reg.bl{ bottom:-7px; left:-7px; } .cs-reg.br{ bottom:-7px; right:-7px; }

/* progression de la bande */
.cs-progress{
  position:absolute; left:var(--pad-x); right:var(--pad-x); bottom:clamp(20px,3.4vh,32px);
  height:2px; background:rgba(19,22,29,.14); overflow:hidden;
}
.cs-progress i{
  display:block; height:100%; width:100%; background:var(--hot);
  transform:scaleX(0); transform-origin:0 50%;
}

/* fallback sans épinglage (mobile / reduced motion) */
.vf-section--cs.cs-static .vf-cs{ height:auto; }
.vf-section--cs.cs-static .vf-cs__rail{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
.vf-section--cs.cs-static .cs-progress{ display:none; }

/* ============================================================
   SÉQ. 03 — OFFRES (cartes empilées)
   ============================================================ */
.vf-offers__head{ max-width:1320px; margin:0 auto clamp(40px,6vh,80px); }
.vf-offers__head h2{ font-size: clamp(34px,4.8vw,80px); line-height:.94; margin-top:14px; }

.offer-stack{
  max-width:1320px; margin:0 auto;
  display:flex; flex-direction:column; gap: clamp(22px,4vh,44px);
}
/* grandes fiches papier qui s'empilent en scrollant — même langage que le
   reste de la page : encre, papier, duotone outremer, angles nets */
.offer{
  position:sticky; top: clamp(86px,12vh,130px);
  display:grid; grid-template-columns: 1.08fr .92fr; gap: clamp(24px,4vw,64px);
  background: var(--paper-2);
  border:1.5px solid var(--ink);
  box-shadow: 0 34px 70px -44px rgba(16,26,102,.5);
  padding: clamp(26px,3.6vw,56px);
  min-height: min(68vh, 600px);
}
.offer:nth-child(2){ top: calc(clamp(86px,12vh,130px) + 16px); }
.offer:nth-child(3){ top: calc(clamp(86px,12vh,130px) + 32px); }

.offer__txt{ display:flex; flex-direction:column; align-items:flex-start; min-width:0; }
.offer__top{
  display:flex; align-items:baseline; gap:18px; width:100%;
  border-bottom:2px solid var(--ink); padding-bottom:14px;
}
.offer__no{
  font-size: clamp(28px,2.4vw,40px); line-height:1;
  color:transparent; -webkit-text-stroke:1.5px var(--hot);
}
.offer__tag{
  margin-left:auto;
  font-size:10px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--hot);
}
.offer h3{
  font-size: clamp(30px,3.8vw,62px); line-height:.92; margin-top:clamp(16px,2.6vh,26px);
  letter-spacing:-.012em; color:var(--ink);
}
.offer h3 .sx{ color:var(--hot); }
.offer__lead{
  margin-top:16px; max-width:48ch; font-weight:500;
  font-size:clamp(14px,1.2vw,17px); line-height:1.65; color:var(--ink-2);
}
.offer__list{ list-style:none; margin-top:clamp(16px,2.6vh,26px); width:100%; }
.offer__list li{
  position:relative; padding:11px 0 11px 22px;
  border-top:1px solid var(--edge);
  font-weight:600; font-size:clamp(13px,1.1vw,15px); color:var(--ink);
}
.offer__list li::before{
  content:""; position:absolute; left:0; top:50%; width:7px; height:7px;
  transform:translateY(-50%);
  background:var(--hot);                       /* carré, comme un repère de cadrage */
}
.offer__list li:last-child{ border-bottom:1px solid var(--edge); }
.offer__bottom{
  margin-top:auto; padding-top:clamp(20px,3vh,30px); width:100%;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
}
.offer__cta{
  display:inline-flex; align-items:center; gap:12px;
  background:var(--hot); color:var(--flash);
  font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  padding:15px 26px; border-radius:46px;
  transition: transform .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease);
}
.offer__cta i{ font-style:normal; transition: transform .3s var(--ease); }
.offer__cta:hover{ transform:translateY(-2px); background:var(--navy); box-shadow:0 16px 34px -12px var(--hot); }
.offer__cta:hover i{ transform:translateX(5px); }
.offer__chips{ display:flex; flex-wrap:wrap; gap:8px; }
.offer__chips span{
  border:1.2px solid var(--edge); border-radius:99px; padding:6px 12px;
  font-size:9.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-2);
}
.offer__media{
  position:relative; overflow:hidden;
  border:1.5px solid var(--ink); background:var(--navy); min-height:340px;
}
.offer__media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter: grayscale(1) contrast(1.1);
  transition: filter .6s var(--ease), transform .9s var(--ease);
}
/* duotone outremer, comme la pellicule — le survol révèle les vraies couleurs */
.offer__media::before{
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:var(--hot); mix-blend-mode:lighten; transition: opacity .55s var(--ease);
}
.offer__media::after{
  content:""; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:var(--paper); mix-blend-mode:multiply; transition: opacity .55s var(--ease);
}
.offer:hover .offer__media::before,
.offer:hover .offer__media::after{ opacity:0; }
.offer:hover .offer__media img{ filter:none; transform:scale(1.04); }
.offer__badge{
  position:absolute; z-index:4; left:14px; bottom:14px;
  font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink);
  background:var(--paper); border:1px solid var(--ink);
  padding:8px 14px;
}

/* ============================================================
   SÉQ. 04 — GÉNÉRIQUE / CTA
   ============================================================ */
.vf-foot{
  position:relative; z-index:10; padding: clamp(80px,13vh,160px) var(--pad-x) 50px;
  text-align:center;
}
.vf-slate{ display:inline-block; font-size:10px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--flash); background:var(--ink); padding:6px 14px; margin-bottom: clamp(18px,3vw,30px); }
.vf-slate.cut{ background:var(--hot); }
.vf-foot__invite{ font-size: clamp(17px,2.2vw,30px); margin:10px 0 6px; }
.vf-foot h4{ font-size:clamp(46px,12.5vw,205px); line-height:.84; letter-spacing:-.015em;
  margin-top: clamp(10px,2vh,22px); }
.vf-foot h4 span{ color:transparent; -webkit-text-stroke:2px var(--ink); }
.vf-foot .sub{ margin-top:18px; font-family:var(--mono); font-size:11px; letter-spacing:.26em;
  text-transform:uppercase; color:var(--ink-soft); }
.vf-shutter{ display:inline-flex; align-items:center; gap:12px; margin: clamp(26px,4.5vw,40px) 0 12px;
  background:var(--hot); color:var(--flash); font-family:var(--mono); font-size:13px; letter-spacing:.16em;
  text-transform:uppercase; padding:18px 32px; border-radius:46px; cursor:pointer;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s; }
.vf-shutter:hover{ transform: translateY(-2px); box-shadow: 0 18px 38px -12px var(--hot); background:var(--navy); }
.vf-shutter__dot{ width:14px; height:14px; border-radius:50%; background:var(--flash);
  box-shadow: inset 0 0 0 3px rgba(20,80,239,.55); animation: vfblink 1.4s steps(2) infinite; }
.vf-foot .legal{ margin-top:70px; font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  border-top:1px solid var(--edge); padding-top:20px; }
.vf-foot .legal a{ border-bottom:1px solid transparent; transition: color .3s, border-color .3s; }
.vf-foot .legal a:hover{ color:var(--hot); border-color:var(--hot); }

/* ============================================================
   TREMBLEMENTS / GLITCH
   ============================================================ */
.shake{ animation: shake .5s var(--ease); }
@keyframes shake{
  0%,100%{transform:translate(0,0) rotate(0)}
  12%{transform:translate(-7px,4px) rotate(-.6deg)}
  28%{transform:translate(8px,-5px) rotate(.5deg)}
  44%{transform:translate(-6px,6px) rotate(-.4deg)}
  60%{transform:translate(7px,-3px) rotate(.5deg)}
  78%{transform:translate(-4px,3px) rotate(-.2deg)}
}
.rgb-split{ animation: rgbsplit .42s steps(2) 2; }
@keyframes rgbsplit{
  0%{ text-shadow:none; filter:none; }
  50%{ text-shadow: 4px 0 var(--hot), -4px 0 var(--cyan); }
  100%{ text-shadow:none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1180px){
  .vf-hook{ max-width: min(620px, 52vw); }
}
@media (max-width: 900px){
  /* ===== HERO MOBILE = DECK de films à swiper (pas de caméra 3D) ===== */
  #vf-stage-canvas{ display:none; }
  .vf-fan__lens{ display:none; }

  /* le hero passe en colonne : titre en haut, deck en bas */
  .vf-hero{
    display:flex; flex-direction:column; gap: clamp(16px,3vh,28px);
    padding: clamp(92px,15vh,134px) 0 clamp(18px,4vh,38px);
  }
  .vf-hook{
    position:relative; left:auto; top:auto; z-index:13;
    max-width:100%; padding: 0 6vw;
  }
  .vf-hook__title{ font-size: clamp(38px, 8.6vw, 82px); }
  .vf-hook__sub{ max-width: 44ch; }
  .vf-hook__cta{ position:static; left:auto; bottom:auto; padding:0 6vw; gap:18px; }

  /* la rangée de films : scroll-snap horizontal au doigt */
  .vf-fan{
    position:relative; inset:auto; z-index:11;
    flex:none; height:clamp(300px, 50vh, 460px);   /* hauteur DÉFINIE → les cartes height:100% se calculent */
    display:flex; align-items:stretch; gap:16px;
    padding: 6px 8vw 6px 6vw;
    overflow-x:auto; overflow-y:visible;
    scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none;
    pointer-events:auto;
  }
  .vf-fan::-webkit-scrollbar{ display:none; }
  .fan-beam{
    position:relative; left:auto; top:auto; margin:0;
    flex:0 0 auto; width:min(78vw,320px); height:100%;
    transform:none; transform-origin:center;
    -webkit-mask-image:none; mask-image:none;
    scroll-snap-align:center;
  }
  .frame-card{
    position:absolute; inset:0; clip-path:none;
    border:1.5px solid var(--ink); border-radius:20px; overflow:hidden;
    box-shadow: 0 26px 48px -26px rgba(16,26,102,.5);
  }
  .frame-card__media video{
    position:absolute; inset:0; left:0; top:0; width:100%; height:100%; transform:none;
  }
  .frame-card__logo{ left:50%; top:auto; bottom:16px; transform:translateX(-50%); }
  .frame-card:hover .frame-card__logo{ transform:translateX(-50%); }
  /* tactile : pas de survol → la carte EN LECTURE révèle les vraies couleurs */
  .frame-card.is-playing .frame-card__media::before,
  .frame-card.is-playing .frame-card__media::after{ opacity:0; }
  .frame-card.is-playing .frame-card__media video{ filter:none; }
  .frame-card__cap{ display:none; }

  /* points de progression du deck */
  .vf-deck-dots{ display:flex; justify-content:center; gap:9px; padding-top:2px; z-index:12; }
  .vf-deck-dots i{ width:7px; height:7px; border-radius:50%;
    background:var(--ink); opacity:.26; transition:opacity .3s, transform .3s, background .3s; }
  .vf-deck-dots i.on{ opacity:1; transform:scale(1.35); background:var(--hot); }

  .vf-marquee__chunk{ font-size: clamp(22px,6vw,38px); }

  /* planche-contact : bande défilable au doigt */
  .vf-cs{ height:auto; gap:22px; }
  .vf-cs__rail{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .vf-cs__grid{ padding: 36px clamp(18px,5vw,40px); gap:22px; }
  .cs-cell{ width: min(74vw, 420px); }
  .cs-intro{ width: min(64vw, 340px); }
  .cs-outro{ width: min(70vw, 420px); }
  .cs-progress{ display:none; }

  /* offres : cartes simples, plus d'empilement collant */
  .offer{ position:static; grid-template-columns:1fr; min-height:0; }
  .offer__media{ min-height:240px; order:-1; }
}
@media (max-width: 560px){
  .vf-nav a:not(.vf-nav__pill){ display:none; }
  .vf-hook{ max-width: 100%; }
  .fan-beam{ width: 86vw; }
  .cs-cell{ width: 84vw; }
}

/* accessibilité : réduit les animations */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition-duration:.001s !important; }
  body.vf{ cursor:auto; }
  .reveal{ opacity:1; transform:none; }
}

/* ============================================================
   INTRO MARQUE (home) · RÉSERVATION Calendly · PAGE À PROPOS
   ============================================================ */

/* --- intro marque (entre le hero et la planche-contact) --- */
.vf-intro{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,72px);
  align-items:center; max-width:1320px; margin:0 auto;
}
.vf-intro__txt h2{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  letter-spacing:-.012em; text-transform:uppercase; color:var(--ink);
  font-size:clamp(30px,4.2vw,68px); line-height:.94; margin:14px 0 20px;
}
.vf-intro__txt h2 .sx{ color:var(--hot); }
.vf-intro__lead{
  max-width:54ch; font-weight:500; font-size:clamp(14px,1.2vw,17px);
  line-height:1.7; color:var(--ink-2); margin-bottom:30px;
}
.vf-intro__media{
  position:relative; overflow:hidden; border:1.5px solid var(--ink);
  background:var(--navy); aspect-ratio:4/5; box-shadow:var(--shadow); margin:0;
}
.vf-intro__media img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.1); transition:filter .6s var(--ease), transform .9s var(--ease);
}
.vf-intro__media:hover img{ filter:none; transform:scale(1.04); }
.vf-intro__badge{
  position:absolute; left:14px; bottom:14px; background:var(--paper);
  border:1px solid var(--ink); padding:8px 14px; font-size:9.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink);
}

/* --- réservation : Calendly --- */
.vf-rdv{
  position:relative; z-index:10; max-width:1100px; margin:0 auto;
  padding:clamp(70px,11vh,150px) var(--pad-x);
}
.vf-rdv__head{ text-align:center; margin-bottom:clamp(26px,4.5vh,52px); }
.vf-rdv__head h2{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:-.012em; color:var(--ink);
  font-size:clamp(34px,5vw,84px); line-height:.92; margin-top:12px;
}
.vf-rdv__head h2 .sx{ color:var(--hot); }
.vf-rdv__sub{
  margin:16px auto 0; max-width:52ch; font-weight:500;
  font-size:clamp(14px,1.2vw,17px); line-height:1.6; color:var(--ink-2);
}
.vf-rdv__cal{
  position:relative; background:var(--paper); border:1.5px solid var(--ink);
  box-shadow:var(--shadow); overflow:hidden;
}
.vf-rdv__cal .calendly-inline-widget{ position:relative; z-index:1; min-height:560px; }

/* --- maquette d'affichage du calendrier (vrai Calendly branché plus tard) --- */
.vf-cal{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.1fr) minmax(0,.72fr); }
.vf-cal > *{ padding:clamp(20px,2.3vw,34px); }
.vf-cal__side{ border-right:1px solid var(--edge); display:flex; flex-direction:column; gap:14px; }
.vf-cal__logo{ font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:.02em; color:var(--ink); font-size:15px; }
.vf-cal__logo::first-letter{ color:var(--hot); }
.vf-cal__title{ font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:-.01em; color:var(--ink);
  font-size:clamp(22px,2.1vw,32px); line-height:.96; }
.vf-cal__meta{ list-style:none; display:flex; flex-direction:column; gap:7px;
  font-size:11px; letter-spacing:.05em; color:var(--ink-2); }
.vf-cal__desc{ font-size:13.5px; line-height:1.6; color:var(--ink-2); }
.vf-cal__demo{ margin-top:auto; font-size:9px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--hot); border:1px solid var(--hot); padding:6px 10px; align-self:flex-start; }
.vf-cal__month{ border-right:1px solid var(--edge); }
.vf-cal__monthbar{ display:flex; align-items:center; justify-content:space-between;
  margin-bottom:16px; font-size:12px; letter-spacing:.14em; color:var(--ink); }
.vf-cal__nav{ width:30px; height:30px; border:1px solid var(--edge); background:transparent;
  cursor:pointer; color:var(--ink); border-radius:50%; transition:background .25s, color .25s; }
.vf-cal__nav:hover{ background:var(--ink); color:var(--paper); }
.vf-cal__dows{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-bottom:8px;
  font-size:10px; color:var(--ink-soft); text-align:center; }
.vf-cal__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.vf-cal__day{ aspect-ratio:1; border:1px solid var(--edge); background:var(--paper-2);
  cursor:pointer; font-family:var(--mono); font-size:12.5px; color:var(--ink); border-radius:4px;
  transition:background .2s, color .2s, border-color .2s; }
.vf-cal__day:hover:not(.is-off){ background:var(--hot); color:var(--paper); border-color:var(--hot); }
.vf-cal__day.is-off{ color:var(--ink-soft); opacity:.4; cursor:not-allowed; background:transparent; }
.vf-cal__day.is-sel{ background:var(--hot); color:var(--paper); border-color:var(--hot); font-weight:700; }
.vf-cal__slots{ display:flex; flex-direction:column; gap:8px; }
.vf-cal__slotsh{ font-size:11px; letter-spacing:.12em; color:var(--ink-soft); margin-bottom:4px; }
.vf-cal__slot{ border:1.5px solid var(--ink); background:transparent; color:var(--ink);
  cursor:pointer; font-family:var(--mono); font-size:13px; letter-spacing:.08em; padding:11px;
  text-align:center; transition:background .2s, color .2s; }
.vf-cal__slot:hover, .vf-cal__slot.is-sel{ background:var(--ink); color:var(--paper); }
.vf-cal__confirm{ margin-top:6px; background:var(--hot); color:var(--flash); border:0;
  cursor:pointer; font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; padding:13px; transition:background .25s, transform .25s; }
.vf-cal__confirm:hover{ background:var(--navy); transform:translateY(-2px); }
@media (max-width:820px){
  .vf-cal{ grid-template-columns:1fr; }
  .vf-cal__side, .vf-cal__month{ border-right:0; border-bottom:1px solid var(--edge); }
  .vf-cal__slots{ flex-direction:row; flex-wrap:wrap; }
  .vf-cal__slotsh{ flex-basis:100%; }
  .vf-cal__slot{ flex:1 1 30%; }
  .vf-cal__confirm{ flex-basis:100%; }
}

/* --- page à propos (minimaliste) --- */
.vf-ap-hero{
  position:relative; z-index:10; max-width:1100px; margin:0 auto;
  padding:clamp(140px,22vh,240px) var(--pad-x) clamp(36px,6vh,80px);
}
.vf-ap-title{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  letter-spacing:-.012em; text-transform:uppercase; color:var(--ink);
  font-size:clamp(44px,8vw,128px); line-height:.9; margin:18px 0 0;
}
.vf-ap-title .sx{ color:var(--hot); }
.vf-ap-intro{
  margin-top:clamp(18px,3vh,30px); max-width:60ch; font-weight:500;
  font-size:clamp(15px,1.4vw,20px); line-height:1.6; color:var(--ink-2);
}
.vf-ap-story{
  display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(28px,5vw,72px);
  align-items:center; max-width:1320px; margin:0 auto;
}
.vf-ap-story__media{
  position:relative; overflow:hidden; border:1.5px solid var(--ink);
  background:var(--navy); aspect-ratio:4/3; box-shadow:var(--shadow); margin:0;
}
.vf-ap-story__media img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.1); transition:filter .6s var(--ease);
}
.vf-ap-story__media:hover img{ filter:none; }
.vf-ap-story__txt h2{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:-.012em; color:var(--ink);
  font-size:clamp(30px,4vw,64px); line-height:.94; margin:14px 0 18px;
}
.vf-ap-story__txt h2 .sx{ color:var(--hot); }
.vf-ap-story__txt p{
  max-width:52ch; font-weight:500; font-size:clamp(14px,1.2vw,17px);
  line-height:1.7; color:var(--ink-2); margin-bottom:16px;
}
.vf-ap-pillars{ max-width:1320px; margin:0 auto; }
.vf-ap-pillars__head{ max-width:32ch; margin-bottom:clamp(26px,4.5vh,52px); }
.vf-ap-pillars__head h2{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:-.012em; color:var(--ink);
  font-size:clamp(28px,4vw,60px); line-height:.94; margin-top:12px;
}
.vf-ap-pillars__head h2 .sx{ color:var(--hot); }
.vf-ap-pillars__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,32px);
}
.vf-ap-pillar{ border-top:2px solid var(--ink); padding-top:18px; }
.vf-ap-pillar__no{ font-size:11px; letter-spacing:.2em; color:var(--hot); }
.vf-ap-pillar h3{
  font-family:var(--display); font-weight:900; font-stretch:125%;
  text-transform:uppercase; letter-spacing:-.012em; color:var(--ink);
  font-size:clamp(22px,2.4vw,36px); line-height:.96; margin:10px 0 12px;
}
.vf-ap-pillar h3 .sx{ color:var(--hot); }
.vf-ap-pillar p{ font-weight:500; font-size:clamp(13px,1.1vw,15.5px); line-height:1.65; color:var(--ink-2); }
.vf-ap-foot{ position:relative; z-index:10; padding:clamp(36px,6vh,72px) var(--pad-x) 44px; }
.vf-ap-foot .legal{
  font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  border-top:1px solid var(--edge); padding-top:20px;
}
.vf-ap-foot .legal a{ border-bottom:1px solid transparent; transition:color .3s, border-color .3s; }
.vf-ap-foot .legal a:hover{ color:var(--hot); border-color:var(--hot); }

@media (max-width:900px){
  .vf-intro{ grid-template-columns:1fr; }
  .vf-intro__media{ order:-1; aspect-ratio:16/10; }
  .vf-ap-story{ grid-template-columns:1fr; }
  .vf-ap-story__media{ order:-1; aspect-ratio:16/10; }
  .vf-ap-pillars__grid{ grid-template-columns:1fr; }
  .vf-rdv__cal{ min-height:600px; }
  /* titre à propos : ne déborde plus sur petit écran */
  .vf-ap-hero{ padding-top:clamp(112px,18vh,150px); }
  .vf-ap-title{ font-size:clamp(34px,7.4vw,84px); }
}

@media (max-width:560px){
  /* gros titres : version condensée pour tenir en largeur */
  .vf-ap-title{ font-size:clamp(25px,7vw,46px); font-stretch:80%; letter-spacing:-.01em; }
  .vf-ap-hero{ padding-top:clamp(100px,16vh,130px); }
  /* header : resserré pour que la pastille tienne toujours */
  .vf-header{ padding-left:14px; padding-right:14px; }
  .vf-nav{ gap:0; }
  .vf-nav__pill{ padding:7px 12px; font-size:10px; white-space:nowrap; }
  .vf-logo{ font-size:16px; }
}
