/* ============================================================
   VLADISPALA · agency edition
   All sans-serif · monumental type · horizontal scroll · parallax
   ============================================================ */

:root{
  --ink:#0a0a0b; --ink-2:#101012; --ink-3:#17171b;
  --bone:#f4f1ea; --bone-dim:#a8a59d; --smoke:#6a6a70;
  --line:rgba(244,241,234,.13); --line-soft:rgba(244,241,234,.06);
  --volt:#4d5dff; --volt-2:#8c97ff; --acid:#d7ff3e;

  --display:"Bricolage Grotesque", system-ui, sans-serif;
  --sans:"Space Grotesk", system-ui, sans-serif;
  --mono:"Space Mono", ui-monospace, monospace;

  --d-mono: clamp(2.7rem, 9.6vw, 8.4rem); /* hero */
  --d-1:    clamp(2.8rem, 10vw, 10rem);
  --d-2:    clamp(2rem, 6vw, 5rem);
  --s--1:   clamp(.78rem,.74rem+.2vw,.9rem);
  --s-0:    clamp(1rem,.95rem+.3vw,1.2rem);
  --s-1:    clamp(1.3rem,1rem+1vw,2rem);

  --pad: clamp(1.1rem, 4.5vw, 5.5rem);
  --maxw: 1760px;
  --ease: cubic-bezier(.19,1,.22,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
html:not(.rm){scroll-behavior:smooth}
body{background:var(--ink);color:var(--bone);font-family:var(--sans);font-size:var(--s-0);
  line-height:1.5;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
::selection{background:var(--volt);color:#fff}
::-webkit-scrollbar{width:9px}::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:#26262c}::-webkit-scrollbar-thumb:hover{background:var(--volt)}

.fill{color:var(--volt)}
.o{-webkit-text-stroke:1.6px var(--bone);color:transparent}

/* ── anti-copie (déterrent) : sélection / drag désactivés ── */
html{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}
img{-webkit-user-drag:none;user-drag:none;-webkit-touch-callout:none}

/* grain + progress + cursor */
.grain{position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-4%,2%)}50%{transform:translate(3%,-3%)}75%{transform:translate(-2%,3%)}}
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--volt);z-index:9600;box-shadow:0 0 14px var(--volt)}

.cursor{position:fixed;top:0;left:0;z-index:9500;pointer-events:none;width:42px;height:42px;
  border:1px solid var(--bone);border-radius:50%;transform:translate(-50%,-50%);mix-blend-mode:difference;
  display:grid;place-items:center;opacity:0;transition:width .35s var(--ease),height .35s var(--ease),background .35s,opacity .3s}
.cursor.is-active{opacity:1}
.cursor.grow{width:104px;height:104px;background:var(--bone);border-color:transparent;mix-blend-mode:normal}
.cursor__label{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);opacity:0;transform:scale(.5)}
.cursor.grow .cursor__label{opacity:1;transform:scale(1);transition:.25s}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* loader */
.loader{position:fixed;inset:0;z-index:9800;background:var(--ink);display:flex;flex-direction:column;
  justify-content:flex-end;padding:var(--pad);transition:transform .9s var(--ease);transform:translateY(0)}
.loader.done{transform:translateY(-100%)}
.loader__row{display:flex;justify-content:space-between;align-items:flex-end}
.loader__word{font-family:var(--display);font-weight:800;font-size:var(--d-1);line-height:.85;letter-spacing:-.03em}
.loader__num{font-family:var(--mono);font-size:var(--s-1);color:var(--volt-2)}
.loader__bar{height:2px;background:var(--line);margin-top:1.4rem;overflow:hidden}
.loader__bar i{display:block;height:100%;width:0;background:var(--bone)}

/* nav */
.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;
  justify-content:space-between;padding:1.1rem var(--pad);mix-blend-mode:difference;transition:transform .5s var(--ease)}
.nav.hide{transform:translateY(-120%)}
.nav__brand{display:flex;align-items:center;gap:.5rem}
.nav__mark{display:inline-block;font-size:clamp(1.3rem,2vw,1.7rem);color:var(--volt-2);animation:spin 9s linear infinite}
.nav__word{font-family:var(--display);font-weight:800;font-size:clamp(1.25rem,1.9vw,1.7rem);letter-spacing:-.05em;line-height:1}
.nav__tm{font-family:var(--mono);font-size:.62em;font-weight:400;transform:translateY(-.6em);opacity:.6}
@keyframes spin{to{transform:rotate(360deg)}}
.nav__links{display:flex;gap:1.7rem;font-family:var(--mono);font-size:var(--s--1)}
.nav__links a{display:flex;gap:.3rem;align-items:baseline;position:relative;padding:.2rem 0}
.nav__links i{font-style:normal;color:var(--volt-2);font-size:9px}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--bone);transition:width .4s var(--ease)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{width:26px;height:2px;background:var(--bone);transition:.4s var(--ease)}
.nav.open .nav__burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){transform:translateY(-0px) rotate(-45deg)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-size:var(--s--1);
  font-weight:500;letter-spacing:.01em;cursor:pointer;border:1px solid var(--line);border-radius:100px;
  padding:.9rem 1.6rem;transition:background .4s var(--ease),color .4s,border-color .4s,transform .2s var(--ease);will-change:transform}
.btn b{font-style:normal}
.btn--solid{background:var(--bone);color:var(--ink);border-color:var(--bone)}
.btn--solid:hover{background:var(--volt);border-color:var(--volt);color:#fff}
.btn--ghost:hover{border-color:var(--bone);background:rgba(244,241,234,.05)}
.btn--pill{padding:.5rem .5rem .5rem 1.1rem}
.btn__dot{width:28px;height:28px;border-radius:50%;background:var(--volt);transition:transform .5s var(--ease)}
.btn--pill:hover .btn__dot{transform:scale(1.2)}
.nav__cta{mix-blend-mode:normal}

/* menu */
.menu{position:fixed;inset:0;z-index:999;background:var(--ink-2);display:flex;flex-direction:column;
  justify-content:center;padding:var(--pad);transform:translateY(-100%);transition:transform .7s var(--ease);visibility:hidden}
.menu.open{transform:translateY(0);visibility:visible}
.menu a{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,11vw,4rem);line-height:1.15;
  display:flex;align-items:baseline;gap:1rem;border-bottom:1px solid var(--line-soft);padding:.45rem 0;letter-spacing:-.02em}
.menu a i{font-family:var(--mono);font-size:.7rem;color:var(--volt-2)}
.menu__cta{color:var(--volt-2)}

/* shared */
.section{padding:clamp(5rem,11vw,10rem) var(--pad);max-width:var(--maxw);margin:0 auto;position:relative}
.sec-head{display:flex;align-items:center;gap:1.4rem;margin-bottom:clamp(2.5rem,6vw,4.5rem)}
.sec-idx{font-family:var(--mono);font-size:var(--s--1);letter-spacing:.1em;text-transform:uppercase;color:var(--bone-dim);white-space:nowrap}
.sec-line{height:1px;flex:1;background:var(--line)}
.sec-head--inv .sec-idx{color:var(--volt-2)}
.kicker{font-family:var(--mono);font-size:var(--s--1);letter-spacing:.12em;text-transform:uppercase;color:var(--bone-dim)}
.kicker--status{display:inline-flex;align-items:center;gap:.5rem;color:var(--bone)}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--acid);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(215,255,62,.6)}70%{box-shadow:0 0 0 9px rgba(215,255,62,0)}100%{box-shadow:0 0 0 0 rgba(215,255,62,0)}}

/* reveal */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-reveal]{display:block;overflow:hidden;padding:.06em 0}
[data-reveal]>span,[data-reveal]>em{display:inline-block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
[data-reveal].in>span,[data-reveal].in>em{transform:translateY(0)}

/* ───────── HERO ───────── */
.hero{min-height:100svh;padding:8rem var(--pad) 2.5rem;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.hero__fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;object-fit:cover;
  opacity:.7;image-rendering:pixelated;image-rendering:crisp-edges;pointer-events:none}
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(77,93,255,.12), transparent 55%),
    radial-gradient(140% 120% at 50% 45%, transparent 38%, rgba(10,10,11,.72) 100%),
    linear-gradient(180deg, rgba(10,10,11,.5) 0%, rgba(10,10,11,.55) 50%, rgba(10,10,11,.85) 100%)}
.hero__cam{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.hero__kick{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;position:relative;z-index:2}
.hero__title{font-family:var(--display);font-weight:800;font-size:var(--d-mono);line-height:.82;
  letter-spacing:-.045em;text-transform:uppercase;margin:auto 0;padding:1rem 0;position:relative;z-index:2}
.hl{display:block;overflow:hidden}
.hl--fill span{color:var(--volt)}
.hero__title .ai{font-style:italic;font-weight:500;color:var(--volt-2)}
.hero__bottom{position:relative;z-index:2}
.badge{z-index:2}
.hero__bottom{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;
  border-top:1px solid var(--line);padding-top:1.6rem}
.hero__lede{max-width:46ch;color:var(--bone-dim);font-size:var(--s-0)}
.hero__cta{display:flex;gap:.7rem;flex-wrap:wrap}
.badge{position:absolute;right:var(--pad);top:30vh;width:128px;height:128px;display:grid;place-items:center}
.badge__ring{position:absolute;inset:0;width:100%;height:100%;animation:spin 14s linear infinite;fill:var(--bone-dim)}
.badge__ring text{font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase}
.badge__arrow{font-size:1.3rem;color:var(--volt-2)}

/* ───────── PARALLAX STONES (depth of field, toutes sections) ───────── */
.stones{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.stones--back{z-index:1}
.stones--front{z-index:3}
.stone{position:absolute;animation:stonefloat var(--dur,12s) ease-in-out infinite;animation-delay:var(--dly,0s)}
.stone img{display:block;width:100%;height:auto;will-change:transform}
/* darken : overlay sombre intégré via le filtre (pierres plus foncées) */
.stone.far img{opacity:.6;filter:blur(5px) brightness(.78) contrast(1.04)}
.stone.mid img{opacity:.85;filter:blur(2px) brightness(.92) contrast(1.03)}
.stone.near img{opacity:1;filter:brightness(1.02) contrast(1.02) drop-shadow(0 24px 34px rgba(0,0,0,.55))}
@keyframes stonefloat{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-16px) rotate(calc(var(--r,0deg) + 3deg))}}
/* tailles */
.sz-s{width:clamp(54px,6vw,110px)}
.sz-m{width:clamp(85px,9.5vw,165px)}
.sz-l{width:clamp(120px,14vw,225px)}
/* positions (coins, hors du contenu) */
.sp-tl{top:-3%;left:-3%}.sp-tr{top:2%;right:-2%}
.sp-bl{bottom:-3%;left:-3%}.sp-br{bottom:-2%;right:-3%}
.sp-ml{top:36%;left:-4%}.sp-mr{top:42%;right:-4%}
.sp-tc{top:-5%;left:58%}.sp-bc{bottom:-5%;left:26%}
/* UX : le contenu reste TOUJOURS au-dessus des pierres */
.has-stones>.sec-head,.about__grid,.exp-list,.prompt__grid,.proc,
.signal__stage,.contact>:not(.stones){position:relative;z-index:2}

/* marquee */
.mq{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:1.4rem 0;background:var(--ink-2)}
.mq__t{display:flex;align-items:center;gap:1.6rem;width:max-content;animation:scrollx 28s linear infinite;
  font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,5vw,4rem);text-transform:uppercase;letter-spacing:-.02em}
.mq__t b{color:var(--volt)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ───────── ABOUT ───────── */
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,6vw,6rem)}
.about__sticky{position:sticky;top:14vh;align-self:start;display:flex;flex-direction:column;gap:2rem}
.about__plate{position:relative;aspect-ratio:4/5;border-radius:10px;overflow:hidden;border:1px solid var(--line);
  background:#0c0c10;cursor:none}
.about__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;z-index:1;
  filter:grayscale(1) contrast(1.06) brightness(.9);transition:filter .6s var(--ease),transform 1s var(--ease);will-change:transform,filter}
/* duotone indigo par défaut (écho pipeline SIGNAL) */
.about__plate::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(150deg,rgba(77,93,255,.5),rgba(10,10,11,.4));mix-blend-mode:color;transition:opacity .6s var(--ease)}
/* scanlines */
.about__plate::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.18) 0 1px,transparent 1px 3px);mix-blend-mode:multiply;transition:opacity .6s}
.about__tag{position:absolute;left:.8rem;bottom:.7rem;z-index:5;font-family:var(--mono);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--bone);mix-blend-mode:difference}
/* conteneur image + chiffres : porte la parallaxe, réserve l'espace pour les chiffres à cheval */
.about__media{position:relative;margin-bottom:clamp(3.4rem,5vw,4.6rem)}
/* chiffres À CHEVAL sur le coin bas-gauche (moitié sur l'image, moitié dessous) */
.about__figures{position:absolute;left:1.1rem;bottom:0;transform:translateY(40%);z-index:6;display:flex;flex-direction:column;
  gap:.3rem;pointer-events:none;mix-blend-mode:difference}
.about__figures .fig{display:flex;align-items:baseline;gap:.55rem}
.about__figures b{font-family:var(--display);font-weight:800;font-size:clamp(3rem,7.5vw,5rem);
  line-height:.8;letter-spacing:-.04em;color:#fff}
.about__figures span{font-family:var(--mono);font-size:clamp(10px,1.1vw,13px);letter-spacing:.12em;
  text-transform:uppercase;color:#fff}
.about__hint{position:absolute;right:.8rem;top:.7rem;z-index:5;font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--bone-dim);border:1px solid var(--line);border-radius:100px;
  padding:.25rem .6rem;transition:opacity .4s,transform .4s var(--ease)}
.about__sweep{position:absolute;top:0;left:-60%;width:55%;height:100%;z-index:4;pointer-events:none;opacity:0;
  background:linear-gradient(100deg,transparent,rgba(140,151,255,.4),transparent);transform:skewX(-12deg)}
.about__glow{position:absolute;inset:0;z-index:2;mix-blend-mode:screen;opacity:.55;transition:opacity .6s;
  background:radial-gradient(60% 50% at 60% 40%,rgba(77,93,255,.4),transparent 60%),radial-gradient(40% 40% at 30% 80%,rgba(215,255,62,.14),transparent 60%)}
/* hover : couleur + zoom + glitch + balayage + glow */
.about__plate:hover .about__photo{filter:grayscale(0) contrast(1.02) brightness(1.02) saturate(1.05);
  transform:scale(1.05);animation:photoglitch .45s steps(3,end) 1}
.about__plate:hover::before{opacity:0}
.about__plate:hover::after{opacity:.85}
.about__plate:hover .about__glow{opacity:1}
.about__plate:hover .about__hint{opacity:0;transform:translateY(-6px)}
.about__plate:hover .about__sweep{animation:sweep .8s var(--ease) 1}
@keyframes sweep{0%{left:-60%;opacity:0}12%{opacity:1}100%{left:165%;opacity:0}}
@keyframes photoglitch{
  0%{clip-path:inset(0 0 0 0);transform:scale(1.05) translateX(0)}
  20%{clip-path:inset(18% 0 42% 0);transform:scale(1.05) translateX(-5px)}
  40%{clip-path:inset(52% 0 12% 0);transform:scale(1.05) translateX(5px)}
  60%{clip-path:inset(8% 0 64% 0);transform:scale(1.05) translateX(-3px)}
  80%{clip-path:inset(40% 0 28% 0);transform:scale(1.05) translateX(2px)}
  100%{clip-path:inset(0 0 0 0);transform:scale(1.05) translateX(0)}}
/* tactile : pas de hover → photo en couleur par défaut */
@media (hover:none){
  .about__photo{filter:grayscale(0) contrast(1.02) brightness(1)}
  .about__plate::before{opacity:.22}
  .about__hint{display:none}
}
.about__stats{display:flex;gap:clamp(1rem,3vw,2.4rem);flex-wrap:wrap}
.about__stats b{display:block;font-family:var(--display);font-weight:800;font-size:var(--d-2);line-height:.9}
.about__stats span{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--smoke)}
.about__sectors{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.4rem}
.about__sectors li{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--bone-dim);border:1px solid var(--line);border-radius:100px;padding:.45rem .8rem;transition:.3s}
.about__sectors li:hover{border-color:var(--volt);color:var(--bone)}
.about__sectors li:last-child{border-color:var(--volt-2);color:var(--volt-2)}
.about__body{display:flex;flex-direction:column;gap:1.5rem;max-width:60ch}
.about__body h2{font-family:var(--display);font-weight:700;font-size:var(--d-2);line-height:1;letter-spacing:-.03em}
.about__body p{color:var(--bone-dim)}
.about__body b{color:var(--bone);font-weight:600}
.about__sign{font-family:var(--mono);font-size:var(--s--1);text-transform:uppercase;letter-spacing:.08em;color:var(--bone)}

/* ───────── EXPERTISE ───────── */
.exp-list{border-top:1px solid var(--line)}
.exp-row{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:1.5rem;
  padding:clamp(1.3rem,3.4vw,2.6rem) .4rem;border-bottom:1px solid var(--line);position:relative;cursor:default;
  transition:padding .5s var(--ease),color .5s}
.exp-row::before{content:"";position:absolute;inset:0;background:var(--bone);transform:scaleY(0);transform-origin:bottom;transition:transform .5s var(--ease);z-index:-1}
.exp-row:hover{padding-left:1.6rem;padding-right:1.6rem;color:var(--ink)}
.exp-row:hover::before{transform:scaleY(1)}
.exp-num{font-family:var(--mono);font-size:var(--s--1);color:var(--smoke)}
.exp-row:hover .exp-num{color:var(--ink)}
.exp-name{font-family:var(--display);font-weight:700;font-size:var(--d-2);letter-spacing:-.03em;line-height:1;text-transform:uppercase}
.exp-desc{font-family:var(--mono);font-size:var(--s--1);color:var(--bone-dim);text-align:right;justify-self:end}
.exp-row:hover .exp-desc{color:#33333a}
.exp-arrow{font-size:1.5rem;opacity:0;transform:translateX(-10px);transition:.4s var(--ease)}
.exp-row:hover .exp-arrow{opacity:1;transform:translateX(0)}
.exp-hover{position:fixed;width:230px;height:290px;pointer-events:none;z-index:50;border-radius:8px;
  opacity:0;transform:scale(.8) translate(-50%,-50%);transition:opacity .4s,transform .5s var(--ease)}
.exp-hover.show{opacity:1}

/* ───────── HORIZONTAL SCROLL CASE STUDIES ───────── */
.hwrap{position:relative}
.hpin{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden;display:flex;align-items:center}
.htrack{display:flex;align-items:center;gap:clamp(1.5rem,4vw,4rem);padding:0 var(--pad);will-change:transform}
.hintro{flex:0 0 auto;width:min(80vw,520px);padding-right:2rem}
.hintro .sec-idx{display:block;margin-bottom:1.4rem}
.hintro__title{font-family:var(--display);font-weight:800;font-size:var(--d-1);line-height:.85;letter-spacing:-.04em;text-transform:uppercase}
.hintro p{font-family:var(--mono);font-size:var(--s--1);color:var(--bone-dim);margin-top:1.4rem;letter-spacing:.04em}
/* GRANDES cartes vitrine (quasi plein écran) */
.hcard{flex:0 0 auto;height:min(62vh,640px);display:flex;align-items:center;gap:clamp(1.4rem,3vw,3.5rem)}
.hcard__media{position:relative;display:block;height:100%;aspect-ratio:16/12;border-radius:16px;overflow:hidden;
  border:1px solid var(--line);background:#0b0b0e;perspective:1300px;
  box-shadow:0 50px 130px -50px rgba(0,0,0,.85);transition:box-shadow .5s var(--ease)}
.hcard:hover .hcard__media{box-shadow:0 60px 150px -40px rgba(77,93,255,.45)}
.hcard__tilt{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .5s var(--ease);will-change:transform}
.hcard__img{position:absolute;inset:-3%;width:106%;height:106%;object-fit:cover;display:block;
  transition:transform .9s var(--ease);will-change:transform}
.hcard:hover .hcard__img{transform:scale(1.05)}
.hcard__big{position:absolute;left:1.1rem;bottom:.6rem;z-index:3;font-family:var(--display);font-weight:800;
  font-size:clamp(3.2rem,6vw,6rem);line-height:.66;color:#fff;mix-blend-mode:difference;letter-spacing:-.04em;pointer-events:none}
.hcard__view{position:absolute;right:1.3rem;bottom:1.4rem;z-index:4;display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--mono);font-size:var(--s--1);letter-spacing:.05em;text-transform:uppercase;color:var(--ink);
  background:var(--bone);border-radius:100px;padding:.75rem 1.2rem;opacity:0;transform:translateY(16px) scale(.92);
  transition:opacity .45s var(--ease),transform .45s var(--ease),background .3s,color .3s}
.hcard__view i{font-style:normal}
.hcard:hover .hcard__view{opacity:1;transform:translateY(0) scale(1)}
.hcard__media:hover .hcard__view{background:var(--volt);color:#fff}
.hcard__soon{position:absolute;right:1rem;top:1rem;z-index:4;font-family:var(--mono);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--bone);border:1px solid var(--line);
  border-radius:100px;padding:.35rem .8rem;background:rgba(10,10,11,.5);backdrop-filter:blur(6px)}
.hcard__noise{position:absolute;inset:0}
.plate-1 .hcard__noise{background:radial-gradient(70% 80% at 30% 20%,rgba(77,93,255,.5),transparent 60%),linear-gradient(135deg,#15151d,#0b0b0e)}
.plate-2 .hcard__noise{background:radial-gradient(70% 80% at 70% 30%,rgba(215,255,62,.22),transparent 60%),linear-gradient(135deg,#16161a,#0b0b0e)}
.plate-3 .hcard__noise{background:radial-gradient(80% 80% at 50% 70%,rgba(140,151,255,.45),transparent 60%),linear-gradient(135deg,#141419,#0b0b0e)}
.hcard:hover .hcard__noise{transform:scale(1.06);transition:transform 1s var(--ease)}
.hcard__meta{width:clamp(280px,24vw,420px);display:flex;flex-direction:column;justify-content:center;gap:.5rem}
.hcard__idx{font-family:var(--mono);font-size:var(--s--1);color:var(--volt-2);letter-spacing:.06em}
.hcard__meta h3{font-family:var(--display);font-weight:800;font-size:clamp(2.8rem,5vw,5rem);line-height:.88;letter-spacing:-.03em;margin:.3rem 0}
.hcard__role{font-family:var(--mono);font-size:var(--s--1);color:var(--volt-2);margin-bottom:.9rem}
.hcard__desc{color:var(--bone-dim);font-size:var(--s-0);margin-bottom:1.2rem;max-width:40ch}
.hcard__kpis{display:flex;gap:1.6rem;flex-wrap:wrap;margin-bottom:.4rem}
.hcard__kpi{display:flex;align-items:baseline;gap:.7rem;border-top:1px solid var(--line);padding:.7rem 0}
.hcard__kpi b{font-family:var(--display);font-weight:800;font-size:var(--s-1);color:var(--bone)}
.hcard__kpi span{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--smoke)}
.hcard__go{margin-top:1.2rem;align-self:flex-start;font-family:var(--mono);font-size:var(--s--1);color:var(--bone);
  border-bottom:1px solid var(--line);padding-bottom:.3rem;transition:color .3s,border-color .3s}
.hcard__go:hover,.hcard:hover .hcard__go{color:var(--volt-2);border-color:var(--volt)}
/* HUD progression vitrine */
.hwork-hud{position:absolute;bottom:clamp(1rem,3vh,2.2rem);left:50%;transform:translateX(-50%);z-index:6;
  display:flex;align-items:center;gap:1rem;font-family:var(--mono);font-size:var(--s--1);color:var(--bone-dim);pointer-events:none}
.hwork-hud b{color:var(--bone);font-style:normal}
.hwork-bar{width:130px;height:2px;background:var(--line);overflow:hidden}
.hwork-bar i{display:block;height:100%;width:0;background:var(--volt);box-shadow:0 0 10px var(--volt)}
.houtro{flex:0 0 auto;width:min(80vw,460px);display:flex;flex-direction:column;justify-content:center;gap:1rem;padding-left:2rem}
.houtro span{font-family:var(--mono);font-size:var(--s--1);color:var(--bone-dim);text-transform:uppercase;letter-spacing:.08em}
.houtro b{font-family:var(--display);font-weight:800;font-size:var(--d-1);line-height:.85;letter-spacing:-.04em;text-transform:uppercase;transition:color .3s}
.houtro:hover b{color:var(--volt)}

/* ───────── PROMPT ───────── */
.prompt{background:linear-gradient(180deg,var(--ink),#070708);border-radius:24px;border:1px solid var(--line);margin:2rem auto}
.prompt__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.prompt__intro h2{font-family:var(--display);font-weight:700;font-size:var(--d-2);line-height:1;letter-spacing:-.03em;margin-bottom:1.2rem}
.prompt__intro p{color:var(--bone-dim);max-width:46ch;margin-bottom:1.6rem}
.prompt__tags{display:flex;flex-wrap:wrap;gap:.5rem}
.prompt__tags li{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;
  border:1px solid var(--line);border-radius:100px;padding:.45rem .85rem;color:var(--bone-dim);transition:.3s}
.prompt__tags li:hover{border-color:var(--volt);color:var(--bone)}
.prompt__card{background:#050506;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 50px 130px -50px rgba(77,93,255,.4)}
.prompt__bar{display:flex;align-items:center;gap:.5rem;padding:.8rem 1rem;border-bottom:1px solid var(--line);background:#0c0c0f}
.prompt__bar span{width:11px;height:11px;border-radius:50%;background:#2a2a30}
.prompt__bar span:nth-child(1){background:#ff5f57}.prompt__bar span:nth-child(2){background:#febc2e}.prompt__bar span:nth-child(3){background:#28c840}
.prompt__bar b{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--smoke);letter-spacing:.1em}
.prompt__code{padding:1.4rem 1.6rem;font-family:var(--mono);font-size:clamp(.72rem,1.4vw,.85rem);line-height:1.85;color:var(--bone-dim);overflow-x:auto}
.c-key{color:var(--volt-2)}.c-str{color:var(--acid)}.c-cur{color:var(--volt);animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* ───────── PROCESS ───────── */
.proc{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.proc li{background:var(--ink);padding:clamp(1.6rem,3vw,2.6rem);min-height:240px;display:flex;flex-direction:column;transition:background .5s var(--ease);position:relative;overflow:hidden}
.proc li:hover{background:var(--ink-3)}
.proc li::after{content:"";position:absolute;left:0;top:0;width:0;height:2px;background:var(--volt);transition:width .5s var(--ease)}
.proc li:hover::after{width:100%}
.proc__ico{width:clamp(40px,4.2vw,56px);height:auto;color:var(--volt-2);margin-bottom:.4rem;
  transition:color .4s var(--ease);will-change:transform,filter}
.proc li:hover .proc__ico{color:var(--bone);animation:icoGlitch .55s steps(3,end) 1}
.proc__n{font-family:var(--mono);font-size:var(--s--1);color:var(--volt-2);margin:.6rem 0 auto;transition:color .4s}
.proc li:hover .proc__n{color:var(--bone)}
.proc h3{font-family:var(--display);font-weight:800;font-size:clamp(2rem,3.6vw,3rem);line-height:.95;
  text-transform:uppercase;margin:1.4rem 0 .7rem;letter-spacing:-.03em}
.proc p{color:var(--bone-dim);font-size:var(--s--1)}
@keyframes icoGlitch{
  0%{clip-path:inset(0 0 0 0);transform:translateX(0);filter:none}
  20%{clip-path:inset(28% 0 34% 0);transform:translateX(-4px);filter:drop-shadow(3px 0 0 var(--acid)) drop-shadow(-3px 0 0 var(--volt))}
  40%{clip-path:inset(8% 0 60% 0);transform:translateX(4px);filter:none}
  60%{clip-path:inset(58% 0 8% 0);transform:translateX(-3px);filter:drop-shadow(-3px 0 0 var(--acid)) drop-shadow(3px 0 0 var(--volt))}
  80%{clip-path:inset(22% 0 42% 0);transform:translateX(2px);filter:none}
  100%{clip-path:inset(0 0 0 0);transform:translateX(0);filter:none}}

/* ───────── MEDIA PIPELINE / SIGNAL ───────── */
.signal{background:radial-gradient(120% 70% at 50% 0%,#101016,var(--ink) 70%)}
.signal__stage{position:relative;aspect-ratio:21/9;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);background:#050506;box-shadow:0 60px 160px -60px rgba(77,93,255,.45);cursor:crosshair}
.signal__canvas{position:absolute;inset:0;width:100%;height:100%;display:block;
  image-rendering:pixelated;image-rendering:crisp-edges}
.signal__src{display:none}
.signal__scan{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.22) 0 1px,transparent 1px 3px);mix-blend-mode:multiply}
.signal__hud{position:absolute;top:1rem;left:1.1rem;right:1.1rem;z-index:3;display:flex;
  justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--mono);font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--bone);mix-blend-mode:difference;pointer-events:none}
.signal__hud b{font-style:normal}
.signal__hud .rec{color:var(--acid);animation:blink 1.4s steps(1) infinite}
.signal__title{position:absolute;left:1.4rem;bottom:.6rem;z-index:3;font-family:var(--display);
  font-weight:800;font-size:clamp(2.6rem,11vw,8rem);line-height:.78;letter-spacing:-.04em;
  text-transform:uppercase;mix-blend-mode:difference;pointer-events:none}
.signal__cap{position:absolute;right:1.4rem;bottom:1.3rem;z-index:3;font-family:var(--mono);
  font-size:var(--s--1);color:var(--bone-dim);text-align:right;pointer-events:none}

/* ───────── CONTACT ───────── */
.contact{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.6rem;padding-block:clamp(6rem,15vw,12rem);overflow:hidden}
.contact>:not(.stones){position:relative;z-index:2}
.contact__title{font-family:var(--display);font-weight:800;font-size:var(--d-1);line-height:.85;text-transform:uppercase;letter-spacing:-.04em}
.contact__title .hl--fill span{color:var(--volt)}
.contact__mail{font-family:var(--display);font-weight:500;font-size:var(--d-2);border-bottom:1px solid var(--line);padding-bottom:.2rem;letter-spacing:-.02em;transition:.4s var(--ease)}
.contact__mail:hover{color:var(--volt-2);border-color:var(--volt)}
.contact__row{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}
.contact__social{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center;font-family:var(--mono);font-size:var(--s--1);margin-top:1rem}
.contact__social a{color:var(--bone-dim);transition:color .3s}.contact__social a:hover{color:var(--bone)}

/* footer */
.footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:1.8rem var(--pad);
  border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--smoke)}
.footer__mid{color:var(--bone-dim)}

/* ───────── RESPONSIVE ───────── */
@media (max-width:1024px){
  .nav__links,.nav__cta{display:none}.nav__burger{display:flex}
  .about__grid,.prompt__grid{grid-template-columns:1fr}
  .about__sticky{position:static}
  .proc{grid-template-columns:1fr 1fr}
  .badge{display:none}
}
@media (max-width:760px){
  /* CASE STUDIES mobile : pile VERTICALE de cartes (plus d'horizontal) */
  .hcard{flex-direction:column;align-items:stretch;height:auto;width:100%;gap:1rem;opacity:1;transform:none}
  .hcard__media{height:auto;width:100%}
  .hcard__meta{width:auto;gap:.45rem}
  .hcard__big{font-size:clamp(3.2rem,14vw,5.5rem)}
  .hcard__desc{font-size:var(--s--1);max-width:100%;margin-bottom:.4rem}
  .hcard__kpis{gap:1.2rem}
  /* CTA tactile : bouton circulaire « ↗ » sur l'image (toujours visible) */
  .hcard__view{opacity:1;transform:none;width:44px;height:44px;padding:0;border-radius:50%;justify-content:center;font-size:16px;right:.9rem;bottom:.9rem}
  .hcard__view-t{display:none}
  .hcard__media{box-shadow:0 30px 70px -40px rgba(0,0,0,.8)}
  .hwork-hud,.hwork-dots,.hwork-swipe{display:none}
  .exp-row{grid-template-columns:auto 1fr;gap:.8rem}.exp-desc,.exp-arrow{display:none}
  .proc{grid-template-columns:1fr}
  .signal__stage{aspect-ratio:4/5}
  .signal__cap{display:none}
  .hero__bottom{flex-direction:column;align-items:flex-start}

  /* portrait About cadré et centré (le conteneur porte la taille pour aligner les chiffres) */
  .about__media{max-width:360px;width:100%;margin-inline:auto}
  .about__sticky{align-items:center}
  /* email Contact : ne jamais déborder */
  .contact__mail{font-size:clamp(1.05rem,5.2vw,1.8rem);max-width:100%;overflow-wrap:anywhere;text-align:center}
  .contact__title,.lab__title,.hintro__title,.houtro b{word-break:break-word}
  /* kicker hero : laisser passer à la ligne (plus de coupe) */
  .hero__kick .kicker{flex-basis:100%;white-space:normal;min-width:0}

  /* stones : on retire la couche « far » (perf), on garde mid/near, flou allégé */
  .stones .far{display:none}
  .sz-l{width:32vw}.sz-m{width:24vw}.sz-s{width:18vw}
  .stone.mid img{opacity:.85;filter:blur(1.5px) brightness(.92) contrast(1.03)}
  .stone.near img{opacity:1;filter:brightness(1.02) drop-shadow(0 12px 18px rgba(0,0,0,.5))}
  /* pierres de 1er plan retirées sur mobile (passaient sur le titre du hero) */
  .hero .stones--front{display:none}
}
@media (max-width:420px){
  .about__stats{gap:1.2rem}
  .nav{padding:.9rem var(--pad)}
  .hero{padding-top:6.5rem}
}

/* mobile : case studies en pile VERTICALE (plus de scroll horizontal) */
@media (max-width:760px),(prefers-reduced-motion:reduce){
  .hwrap{height:auto!important}
  .hpin{position:static;height:auto;overflow:visible;display:block}
  .htrack{transform:none!important;flex-direction:column;align-items:stretch;width:100%;
    gap:clamp(2rem,6vw,3rem);padding:1rem var(--pad) 1rem}
  .hintro{width:100%;padding-right:0}
  .houtro{width:100%;padding-left:0;padding-top:1rem;border-top:1px solid var(--line)}
}
.hwork-dots{display:none}
