
:root{--bg:#0a0a0a;--paper:#f1ece4;--ink:#121212;--text:#f7f2ec;--muted:rgba(255,255,255,.64);--muted-dark:rgba(18,18,18,.62);--line:rgba(255,255,255,.12);--line-dark:rgba(18,18,18,.14);--font-display:'Bodoni Moda',Georgia,serif;--font-heading:'Big Shoulders Display',Impact,sans-serif;--font-body:'Inter',Arial,sans-serif;--shadow:0 24px 80px rgba(0,0,0,.24)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;padding:18px clamp(18px,3vw,40px);background:linear-gradient(180deg,rgba(10,10,10,.92),rgba(10,10,10,.64),rgba(10,10,10,0));backdrop-filter:blur(16px)}
.brand{display:flex;align-items:center;gap:16px}.brand img{width:76px;height:76px;object-fit:contain;border:1px solid var(--line);border-radius:20px;padding:8px;background:rgba(255,255,255,.035)}.brand span{font-family:var(--font-heading);font-size:clamp(34px,4vw,56px);line-height:.9;letter-spacing:.04em}.site-header nav{display:flex;gap:clamp(18px,3vw,42px);align-items:center}.site-header nav a{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.site-header nav a:hover{color:#fff}
main{padding-top:118px}.home-hero{min-height:calc(100vh - 118px);display:grid;grid-template-columns:minmax(0,.88fr) minmax(360px,1.12fr);align-items:end;gap:clamp(24px,4vw,58px);padding:clamp(28px,4vw,54px) clamp(18px,3vw,40px)}.kicker{margin:0 0 16px;color:var(--muted);font-size:11px;letter-spacing:.22em;text-transform:uppercase}h1,h2{font-family:var(--font-display);font-weight:700;letter-spacing:-.04em;margin:0}.home-hero h1,.page-intro h1{font-size:clamp(58px,8vw,118px);line-height:.9;max-width:10ch}.lead{font-size:clamp(18px,1.8vw,28px);line-height:1.45;color:var(--muted);max-width:36ch;margin:22px 0 0}.home-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}.home-actions a{min-height:48px;display:inline-flex;align-items:center;padding:0 18px;border-radius:999px;text-transform:uppercase;letter-spacing:.16em;font-size:12px;border:1px solid var(--line);color:#fff}.home-actions a:first-child{background:#fff;color:#111}.home-visual{margin:0;border-radius:34px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}.home-visual img{width:100%;height:min(72vh,760px);object-fit:cover;filter:saturate(.84) brightness(.9)}
.quiet-manifesto{padding:clamp(44px,6vw,90px) clamp(18px,3vw,40px);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.quiet-manifesto p{font-family:var(--font-display);font-size:clamp(44px,7vw,108px);line-height:.92;letter-spacing:-.04em;margin:0}.entry-grid{display:grid;grid-template-columns:repeat(3,1fr);background:var(--paper);color:var(--ink)}.entry-grid a{min-height:260px;padding:26px;display:grid;align-content:end;gap:10px;border-right:1px solid var(--line-dark)}.entry-grid a:last-child{border-right:0}.entry-grid span{color:var(--muted-dark);font-size:12px;letter-spacing:.18em}.entry-grid strong{font-family:var(--font-heading);font-size:clamp(52px,6vw,98px);line-height:.82;letter-spacing:.03em;text-transform:uppercase}.entry-grid em{font-style:normal;color:var(--muted-dark)}
.page{background:var(--paper);color:var(--ink);min-height:100vh}.page-intro{padding:clamp(54px,7vw,110px) clamp(18px,3vw,40px) clamp(34px,5vw,70px)}.page-intro .kicker,.page-intro .lead{color:var(--muted-dark)}.work-section{padding:clamp(44px,6vw,84px) clamp(18px,3vw,40px);border-top:1px solid var(--line-dark)}.section-title{display:grid;grid-template-columns:70px minmax(0,.8fr) minmax(260px,1fr);gap:24px;align-items:end;margin-bottom:28px}.section-title span{color:var(--muted-dark);letter-spacing:.18em;font-size:12px}.section-title h2{font-family:var(--font-heading);font-size:clamp(58px,8vw,128px);line-height:.82;letter-spacing:.03em;text-transform:uppercase}.section-title p{margin:0;color:var(--muted-dark);font-size:clamp(17px,1.8vw,24px);line-height:1.4}.works-grid{display:grid;grid-template-columns:1.25fr repeat(2,1fr);gap:14px}.work-card{margin:0;background:#d8d0c4;border-radius:24px;overflow:hidden;border:1px solid var(--line-dark)}.work-card:first-child{grid-row:span 2}.work-card img{width:100%;height:100%;min-height:280px;object-fit:cover;transition:transform .35s ease}.work-card:hover img{transform:scale(1.02)}.work-card figcaption{padding:14px 16px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-dark)}
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:16px;padding:0 clamp(18px,3vw,40px) clamp(64px,8vw,110px)}.video-link-card{display:block;background:#ded6ca;border:1px solid var(--line-dark);border-radius:26px;overflow:hidden;color:var(--ink)}.video-thumb{aspect-ratio:16/9;background:#111 center/cover no-repeat;position:relative}.video-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.42))}.video-thumb span{position:absolute;z-index:2;right:20px;bottom:18px;width:58px;height:58px;border-radius:999px;background:#fff;color:#111;display:grid;place-items:center;font-size:24px}.video-text{padding:18px}.video-text h3{font-family:var(--font-heading);font-size:clamp(32px,4vw,54px);line-height:.9;letter-spacing:.04em;text-transform:uppercase;margin:0 0 8px}.video-text p{margin:0;color:var(--muted-dark);line-height:1.5}
.contact-page{display:grid;align-content:center}.contact-links{display:grid;gap:12px;padding:0 clamp(18px,3vw,40px) clamp(70px,8vw,120px)}.contact-links a{font-family:var(--font-heading);font-size:clamp(36px,6vw,96px);line-height:.9;letter-spacing:.03em;text-transform:uppercase;border-top:1px solid var(--line-dark);padding:18px 0}.site-footer{display:flex;justify-content:space-between;gap:16px;padding:20px clamp(18px,3vw,40px);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--line);background:#0a0a0a}.back-top{position:fixed;right:24px;bottom:24px;z-index:60;width:58px;height:58px;border-radius:999px;display:grid;place-items:center;background:#fff;color:#111;font-family:var(--font-heading);font-size:34px;box-shadow:0 18px 48px rgba(0,0,0,.28)}
@media(max-width:900px){main{padding-top:118px}.site-header{align-items:flex-start}.site-header nav{position:absolute;left:18px;right:18px;bottom:-36px;justify-content:space-between}.brand img{width:60px;height:60px}.home-hero{grid-template-columns:1fr;min-height:auto;padding-top:74px}.home-visual img{height:auto}.entry-grid{grid-template-columns:1fr}.entry-grid a{border-right:0;border-bottom:1px solid var(--line-dark)}.section-title{grid-template-columns:1fr;gap:10px}.works-grid{grid-template-columns:1fr}.work-card:first-child{grid-row:auto}}

/* V18 index upgrade + bilingual toggle + forbidden button */
.header-right{display:flex;align-items:center;gap:clamp(18px,3vw,42px)}
.lang-toggle{width:56px;height:56px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:transparent;color:#fff;font-size:13px;letter-spacing:.16em;cursor:pointer}
.lang-toggle:hover{background:#fff;color:#111}
.home-hero-v18{position:relative;align-items:center;overflow:hidden}
.home-hero-v18::before{content:"";position:absolute;inset:118px clamp(18px,3vw,40px) 36px;border:1px solid rgba(255,255,255,.08);border-radius:34px;pointer-events:none}
.home-copy{position:relative;z-index:2}
.signature-line{width:min(360px,70%);height:1px;margin-top:28px;background:linear-gradient(90deg,#fff,transparent);opacity:.35}
.home-visual-v18{position:relative;border-radius:42px;transform:rotate(-1.2deg);background:#111}
.home-visual-v18::before{content:"";position:absolute;inset:-18px 18px 18px -18px;border:1px solid rgba(255,255,255,.12);border-radius:42px;z-index:-1}
.home-visual-v18 img{height:min(78vh,820px)}
.home-visual-v18 figcaption{position:absolute;left:18px;right:18px;bottom:18px;display:flex;justify-content:space-between;align-items:center;gap:12px;color:#fff;padding:12px 16px;border-radius:999px;background:rgba(0,0,0,.48);backdrop-filter:blur(12px);letter-spacing:.16em;text-transform:uppercase;font-size:12px}
.manifesto-grid{display:grid;grid-template-columns:repeat(3,1fr);background:#0a0a0a;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}
.manifesto-grid div{min-height:260px;padding:clamp(22px,3vw,40px);display:grid;align-content:end;border-right:1px solid rgba(255,255,255,.12)}
.manifesto-grid div:last-child{border-right:0}.manifesto-grid span{color:rgba(255,255,255,.42);letter-spacing:.18em;font-size:12px}
.manifesto-grid p{margin:18px 0 0;font-family:var(--font-display);font-size:clamp(36px,5vw,88px);line-height:.92;letter-spacing:-.045em}
.entry-grid-v18 a{transition:background .25s ease,transform .25s ease}.entry-grid-v18 a:hover{background:#111;color:#fff;transform:translateY(-2px)}.entry-grid-v18 a:hover span,.entry-grid-v18 a:hover em{color:rgba(255,255,255,.6)}
.chaos-button{position:fixed;left:18px;bottom:18px;z-index:90;padding:7px 10px;border-radius:999px;border:1px solid #fff;background:#000;color:#fff;font-size:9px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;opacity:.88}
.chaos-mode{filter:invert(1) hue-rotate(180deg)}.chaos-mode *{transform:rotate(180deg)}.chaos-mode .chaos-button,.chaos-mode .back-top{transform:rotate(180deg)!important}
@media(max-width:900px){.header-right{width:100%;justify-content:space-between}.lang-toggle{width:48px;height:48px}.home-hero-v18::before{display:none}.home-visual-v18{transform:none}.manifesto-grid{grid-template-columns:1fr}.manifesto-grid div{border-right:0;border-bottom:1px solid rgba(255,255,255,.12);min-height:180px}}


/* V19 - liste des arts et outils */
.tool-list-section{
  background:#0a0a0a;
  color:#fff;
  padding:clamp(54px,7vw,110px) clamp(18px,3vw,40px);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.tool-list-head{
  display:grid;
  grid-template-columns:minmax(0,.7fr) minmax(0,1fr);
  gap:clamp(24px,5vw,80px);
  align-items:end;
  margin-bottom:clamp(28px,5vw,68px);
}
.tool-list-head h2{
  margin:0;
  font-family:var(--font-display);
  font-size:clamp(48px,7vw,116px);
  line-height:.9;
  letter-spacing:-.05em;
}
.tool-list{
  display:grid;
  border-top:1px solid rgba(255,255,255,.14);
}
.tool-list p{
  margin:0;
  min-height:72px;
  display:grid;
  grid-template-columns:1fr 80px 1fr;
  align-items:center;
  gap:18px;
  border-bottom:1px solid rgba(255,255,255,.14);
  font-family:var(--font-heading);
  text-transform:uppercase;
  letter-spacing:.04em;
}
.tool-list span,
.tool-list em{
  font-size:clamp(32px,5vw,88px);
  line-height:.82;
  font-style:normal;
}
.tool-list span{
  color:#fff;
}
.tool-list strong{
  text-align:center;
  color:rgba(255,255,255,.42);
  font-size:clamp(22px,3vw,52px);
  font-weight:500;
}
.tool-list em{
  color:rgba(255,255,255,.68);
  text-align:right;
}
.tool-list-final{
  background:#fff;
  color:#111;
  padding:0 18px;
}
.tool-list-final span,
.tool-list-final em,
.tool-list-final strong{
  color:#111;
}
.tool-list-signature{
  margin:clamp(28px,5vw,70px) 0 0;
  max-width:920px;
  font-family:var(--font-display);
  font-size:clamp(42px,7vw,118px);
  line-height:.9;
  letter-spacing:-.05em;
}
@media(max-width:800px){
  .tool-list-head{
    grid-template-columns:1fr;
  }
  .tool-list p{
    grid-template-columns:1fr 34px 1fr;
    gap:10px;
    min-height:58px;
  }
  .tool-list span,
  .tool-list em{
    font-size:clamp(28px,8vw,54px);
  }
}


/* V23 TV alpha hero */
.home-video-shell{
  margin:0;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
  border-radius:0;
}
.home-video-shell::before{display:none}
.tv-stage{
  position:relative;
  width:100%;
  max-width:1200px;
  margin-inline:auto;
}
.tv-overlay{
  position:relative;
  z-index:2;
  display:block;
  width:100%;
  height:auto;
}
.tv-screen-video{
  position:absolute;
  z-index:1;
  left:9.86%;
  top:12.62%;
  width:64.91%;
  height:63.23%;
  object-fit:cover;
  object-position:center;
  border-radius:9% / 12%;
  background:transparent;
}
.hero-sound-toggle{
  position:absolute;
  right:2.8%;
  top:6.5%;
  z-index:3;
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(10px);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:24px;
  cursor:pointer;
}
.hero-sound-toggle:hover{background:#fff;color:#111}
.home-video-shell figcaption{
  position:absolute;
  left:2%;
  right:2%;
  bottom:2.2%;
  z-index:3;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  color:#fff;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:12px;
}
@media(max-width:900px){
  .hero-sound-toggle{width:48px;height:48px;font-size:20px;right:3%;top:6%}
  .home-video-shell figcaption{font-size:10px;bottom:1.6%}
}


/* V24 size/cadrage patch */
.home-hero-v18{
  grid-template-columns:minmax(300px,.42fr) minmax(0,.58fr);
  align-items:center;
  gap:clamp(18px,2.6vw,42px);
}
.home-copy{
  max-width:560px;
}
.home-video-shell{
  width:100%;
}
.tv-stage{
  width:min(100%, 1500px);
  margin-inline:auto;
}
.tv-overlay{
  width:100%;
}
.tv-screen-video{
  left:10.65%;
  top:13.72%;
  width:64.91%;
  height:63.23%;
  object-fit:contain;
  object-position:center center;
  background:#000;
}
@media(min-width:1400px){
  .home-hero-v18{
    grid-template-columns:minmax(320px,.36fr) minmax(900px,.64fr);
  }
  .tv-stage{
    width:min(100%, 1650px);
    transform:scale(1.06);
    transform-origin:center;
  }
}
@media(max-width:1100px){
  .home-hero-v18{
    grid-template-columns:1fr;
    gap:22px;
  }
  .home-copy{max-width:none}
  .tv-stage{width:min(100%, 1200px)}
}
@media(max-width:700px){
  .tv-screen-video{
    object-fit:contain;
  }
}


/* V25 video only, no base TV image */
.home-hero-v18{
  grid-template-columns:minmax(300px,.42fr) minmax(0,.58fr);
  align-items:center;
  gap:clamp(18px,2.6vw,42px);
}
.home-copy{max-width:560px}
.home-video-shell{
  position:relative;
  width:min(100%, 1500px);
  margin-inline:auto;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
  border-radius:0;
}
.home-video-shell::before{display:none}
.tv-video-alone{
  display:block;
  width:100%;
  height:auto;
  max-height:none;
  background:transparent;
}
.hero-sound-toggle{
  position:absolute;
  right:2.6%;
  top:6.5%;
  z-index:3;
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(10px);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:24px;
  cursor:pointer;
}
.hero-sound-toggle:hover{background:#fff;color:#111}
.home-video-shell figcaption{
  position:absolute;
  left:2%;
  right:2%;
  bottom:2.2%;
  z-index:3;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  color:#fff;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:12px;
}
@media(min-width:1400px){
  .home-hero-v18{
    grid-template-columns:minmax(320px,.36fr) minmax(900px,.64fr);
  }
  .home-video-shell{
    width:min(100%, 1650px);
    transform:scale(1.04);
    transform-origin:center;
  }
}
@media(max-width:1100px){
  .home-hero-v18{
    grid-template-columns:1fr;
    gap:22px;
  }
  .home-copy{max-width:none}
  .home-video-shell{width:min(100%, 1200px); transform:none}
}
@media(max-width:900px){
  .hero-sound-toggle{width:48px;height:48px;font-size:20px;right:3%;top:6%}
  .home-video-shell figcaption{font-size:10px;bottom:1.6%}
}


/* V26 - pure black background to match hero video */
:root{
  --bg:#000000 !important;
}
html, body{
  background:#000000 !important;
}
body,
main,
.home-hero,
.home-hero-v18,
.home-video-shell,
.tool-list-section,
.manifesto-grid,
.quiet-manifesto,
.site-footer{
  background:#000000 !important;
}
.site-header{
  background:linear-gradient(180deg, rgba(0,0,0,.96), rgba(0,0,0,.72), rgba(0,0,0,0)) !important;
}
.home-hero-v18::before,
.tool-list,
.tool-list p,
.manifesto-grid,
.manifesto-grid div,
.quiet-manifesto,
.site-footer{
  border-color:rgba(255,255,255,.10) !important;
}
.kicker,
.lead,
.manifesto-grid span,
.tool-list em,
.site-header nav a,
.site-footer{
  color:rgba(255,255,255,.68) !important;
}
.home-actions a{
  border-color:rgba(255,255,255,.16) !important;
}


/* V27 - poster slogan + logo in hero, no top-left logo */
.site-header{
  justify-content:flex-end !important;
}
.header-right-only{
  width:100%;
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:clamp(18px,3vw,42px);
}
.header-right-only nav{
  display:flex;
  gap:clamp(18px,3vw,42px);
  align-items:center;
}

.home-hero-v18{
  grid-template-columns:minmax(320px,.42fr) minmax(0,.58fr) !important;
  align-items:center !important;
}

.home-copy-poster{
  max-width:560px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:22px;
}

.poster-logo-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:132px;
  height:132px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:transparent;
}

.poster-logo{
  width:84px;
  height:84px;
  object-fit:contain;
  display:block;
  filter:brightness(1.08);
}

.hero-poster-text{
  display:flex;
  flex-direction:column;
  gap:2px;
  width:100%;
}

.poster-line{
  display:block;
  color:#ffffff;
  font-family:var(--font-heading);
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:.82;
  text-wrap:balance;
}

.poster-line-1{
  font-size:clamp(68px,8vw,128px);
}
.poster-line-2{
  font-size:clamp(46px,5vw,78px);
  color:rgba(255,255,255,.88);
}
.poster-line-3{
  font-size:clamp(86px,10vw,156px);
}

.poster-lead{
  margin-top:4px !important;
  max-width:24ch !important;
}

.home-actions{
  margin-top:4px !important;
}

@media(max-width:1100px){
  .site-header{
    justify-content:stretch !important;
  }
  .header-right-only{
    justify-content:space-between;
  }
  .home-hero-v18{
    grid-template-columns:1fr !important;
    gap:28px !important;
  }
  .home-copy-poster{
    max-width:none;
  }
  .poster-logo-link{
    width:104px;
    height:104px;
  }
  .poster-logo{
    width:70px;
    height:70px;
  }
}


/* V28 - closer poster proportions, English fixed, top logo replaced by user logo */
:root{
  --font-poster:'League Spartan', 'Arial Black', sans-serif;
}
.home-hero-v18{
  grid-template-columns:minmax(360px, .44fr) minmax(0, .56fr) !important;
  gap:clamp(22px, 3vw, 52px) !important;
  align-items:center !important;
}
.home-copy-poster-v28{
  max-width:480px;
  min-height:min(76vh, 860px);
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  align-items:center;
  text-align:center;
  gap:18px;
  padding-top:12px;
}
.poster-logo-link-v28{
  width:160px;
  height:160px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:transparent;
}
.poster-logo-v28{
  width:104px;
  height:104px;
  object-fit:contain;
}
.hero-poster-text-v28{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0;
}
.poster-line-v28{
  font-family:var(--font-poster);
  font-weight:900;
  text-transform:uppercase;
  color:#fff;
  letter-spacing:-0.045em;
  line-height:.86;
  text-wrap:nowrap;
}
.poster-line-a,
.poster-line-b,
.poster-line-d{
  font-size:clamp(98px, 11vw, 166px);
}
.poster-line-c{
  font-size:clamp(58px, 5vw, 82px);
  letter-spacing:-0.03em;
  line-height:.94;
  margin:4px 0;
}
.poster-line-d{
  margin-top:-4px;
}
.poster-lead-v28{
  margin:12px 0 0 !important;
  max-width:26ch !important;
  text-align:center;
  color:rgba(255,255,255,.72) !important;
  font-size:clamp(16px,1.4vw,22px) !important;
}
.home-actions-v28{
  margin-top:10px !important;
  justify-content:center;
}
@media(min-width:1500px){
  .home-copy-poster-v28{
    max-width:520px;
  }
  .poster-logo-link-v28{
    width:174px;
    height:174px;
  }
  .poster-logo-v28{
    width:116px;
    height:116px;
  }
}
@media(max-width:1100px){
  .home-hero-v18{
    grid-template-columns:1fr !important;
  }
  .home-copy-poster-v28{
    max-width:none;
    min-height:auto;
  }
  .poster-logo-link-v28{
    width:138px;
    height:138px;
  }
  .poster-logo-v28{
    width:92px;
    height:92px;
  }
  .poster-line-a,
  .poster-line-b,
  .poster-line-d{
    font-size:clamp(84px, 17vw, 146px);
  }
  .poster-line-c{
    font-size:clamp(46px, 9vw, 74px);
  }
}


/* V30 - revenir proche de V28, mais moins à gauche + logo x2 */
.home-hero-v18{
  grid-template-columns:minmax(420px,.46fr) minmax(0,.54fr) !important;
  gap:clamp(28px,3vw,58px) !important;
  align-items:center !important;
}

.home-copy-poster-v28{
  max-width:560px !important;
  min-height:min(76vh,860px) !important;
  justify-content:flex-start !important;
  align-items:center !important;
  text-align:center !important;
  gap:18px !important;
  padding-top:12px !important;
  padding-left:clamp(34px,4vw,88px) !important;
}

.poster-logo-link-v28{
  width:320px !important;
  height:320px !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.12) !important;
  background:transparent !important;
}

.poster-logo-v28{
  width:208px !important;
  height:208px !important;
  object-fit:contain !important;
}

.hero-poster-text-v28{
  width:100% !important;
  align-items:center !important;
  text-align:center !important;
}

.poster-line-a,
.poster-line-b,
.poster-line-d{
  font-size:clamp(98px, 10vw, 166px) !important;
}

.poster-line-c{
  font-size:clamp(58px, 5vw, 82px) !important;
  margin:4px 0 !important;
}

.poster-lead-v28{
  text-align:center !important;
  max-width:24ch !important;
}

.home-actions-v28{
  justify-content:center !important;
}

@media (min-width: 1500px){
  .home-copy-poster-v28{
    padding-left:clamp(54px,5vw,110px) !important;
  }
  .poster-logo-link-v28{
    width:350px !important;
    height:350px !important;
  }
  .poster-logo-v28{
    width:228px !important;
    height:228px !important;
  }
}

@media (max-width: 1180px){
  .home-hero-v18{
    grid-template-columns:minmax(340px,.47fr) minmax(360px,.53fr) !important;
  }
  .home-copy-poster-v28{
    padding-left:clamp(16px,2.8vw,34px) !important;
  }
  .poster-logo-link-v28{
    width:240px !important;
    height:240px !important;
  }
  .poster-logo-v28{
    width:156px !important;
    height:156px !important;
  }
}

@media (max-width: 980px){
  .home-hero-v18{
    grid-template-columns:1fr !important;
  }
  .home-copy-poster-v28{
    max-width:none !important;
    min-height:auto !important;
    padding-left:0 !important;
  }
  .poster-logo-link-v28{
    width:200px !important;
    height:200px !important;
  }
  .poster-logo-v28{
    width:130px !important;
    height:130px !important;
  }
}

@media (max-width: 700px){
  .poster-logo-link-v28{
    width:156px !important;
    height:156px !important;
  }
  .poster-logo-v28{
    width:102px !important;
    height:102px !important;
  }
}

@media (max-width: 420px){
  .poster-logo-link-v28{
    width:132px !important;
    height:132px !important;
  }
  .poster-logo-v28{
    width:86px !important;
    height:86px !important;
  }
}


/* V32 - vidéos : meilleure lisibilité + thumbnail Shorts remplacée */
.page-videos{
  background:#000 !important;
  color:#fff !important;
}
.page-videos .page-intro{
  background:#000 !important;
  padding-bottom:clamp(26px,4vw,48px) !important;
}
.page-videos .kicker{
  color:rgba(255,255,255,.82) !important;
}
.page-videos .page-intro h1{
  color:rgba(255,255,255,.18) !important;
  max-width:8ch !important;
}
.page-videos .lead{
  color:rgba(255,255,255,.88) !important;
  max-width:28ch !important;
}
.page-videos .video-grid{
  background:#000 !important;
  padding-top:10px !important;
}
.page-videos .video-link-card{
  background:#e7dfd4 !important;
  color:#111 !important;
}
.page-videos .video-thumb{
  background-color:#111 !important;
}
.page-videos .video-thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.10));
}
.page-videos .video-text h3{
  color:#111 !important;
}
.page-videos .video-text p{
  color:rgba(17,17,17,.7) !important;
}
@media (max-width:700px){
  .page-videos .page-intro h1{
    color:rgba(255,255,255,.22) !important;
  }
}


/* V33 - contraste et lisibilité renforcés sur toutes les pages */
.page{
  background:#000 !important;
  color:#fff !important;
}

.page .page-intro{
  background:#000 !important;
}

.page .kicker{
  color:rgba(255,255,255,.82) !important;
}

.page .page-intro h1{
  color:rgba(255,255,255,.20) !important;
}

.page .page-intro .lead{
  color:rgba(255,255,255,.88) !important;
}

.work-section{
  background:#000 !important;
  border-top:1px solid rgba(255,255,255,.10) !important;
}

.section-title span{
  color:rgba(255,255,255,.55) !important;
}

.section-title h2{
  color:#ffffff !important;
}

.section-title p{
  color:rgba(255,255,255,.76) !important;
}

.works-grid{
  background:#000 !important;
}

.work-card{
  background:#0b0b0b !important;
  border:1px solid rgba(255,255,255,.10) !important;
}

.work-card figcaption{
  color:rgba(255,255,255,.84) !important;
}

.video-grid{
  background:#000 !important;
}

.contact-page{
  background:#000 !important;
}

.contact-links a{
  color:#ffffff !important;
  border-top:1px solid rgba(255,255,255,.12) !important;
}

.contact-links a:hover{
  color:rgba(255,255,255,.82) !important;
}

.site-footer{
  background:#000 !important;
  color:rgba(255,255,255,.62) !important;
  border-top:1px solid rgba(255,255,255,.10) !important;
}

.page .back-top{
  border:1px solid rgba(255,255,255,.16) !important;
}

@media (max-width:700px){
  .page .page-intro h1{
    color:rgba(255,255,255,.24) !important;
  }
  .section-title p,
  .page .page-intro .lead,
  .work-card figcaption{
    color:rgba(255,255,255,.86) !important;
  }
}


/* V34 - Contact copiable + œuvres clean */
:root{
  --offwhite:#f1eadf;
  --offwhite-soft:#e5dccf;
}

/* Corrige le chevauchement des lettres sur les titres fantômes */
.page .page-intro h1{
  line-height:1.02 !important;
  letter-spacing:-.035em !important;
  max-width:9.4ch !important;
  color:rgba(241,234,223,.24) !important;
}

/* Couleur blanc cassé / beige pour les catégories Œuvres */
.section-title h2,
.work-card figcaption,
.contact-links a,
.contact-main{
  color:var(--offwhite) !important;
}

.section-title h2{
  letter-spacing:.035em !important;
}

.work-card{
  background:#070707 !important;
}

.work-card figcaption{
  color:rgba(241,234,223,.84) !important;
}

.section-title p,
.page .page-intro .lead{
  color:rgba(241,234,223,.86) !important;
}

/* Contact page */
.contact-links-v34{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:18px !important;
  padding:0 clamp(18px,3vw,40px) clamp(70px,8vw,120px) !important;
}

.contact-card{
  border-top:1px solid rgba(241,234,223,.18);
  padding:22px 0 24px;
}

.contact-label{
  display:block;
  margin-bottom:12px;
  color:rgba(241,234,223,.58);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.contact-main{
  display:inline-block;
  font-family:var(--font-heading);
  font-size:clamp(42px,7vw,108px);
  line-height:.88;
  letter-spacing:.02em;
  text-transform:uppercase;
  word-break:break-word;
}

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.contact-actions a,
.contact-actions button{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(241,234,223,.18);
  border-radius:999px;
  padding:0 15px;
  background:transparent;
  color:rgba(241,234,223,.86) !important;
  font-family:var(--font-body);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  cursor:pointer;
}

.contact-actions a:hover,
.contact-actions button:hover{
  background:var(--offwhite);
  color:#000 !important;
}

.contact-simple{
  font-family:var(--font-heading);
  font-size:clamp(34px,5vw,82px);
  line-height:.9;
  letter-spacing:.03em;
  text-transform:uppercase;
  border-top:1px solid rgba(241,234,223,.14) !important;
  padding:18px 0 !important;
}

@media(max-width:700px){
  .page .page-intro h1{
    line-height:1.06 !important;
    max-width:10ch !important;
    color:rgba(241,234,223,.28) !important;
  }
  .contact-main{
    font-size:clamp(34px,11vw,62px);
  }
  .contact-actions{
    gap:8px;
  }
  .contact-actions a,
  .contact-actions button{
    min-height:40px;
    font-size:11px;
    padding:0 12px;
  }
}


/* V35 - domaine réintégré */
.footer-domain{
  color:rgba(241,234,223,.72) !important;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.footer-domain:hover{
  color:#f1eadf !important;
}


/* V36 - volume fader on the left of the TV */
.home-video-shell{
  position:relative;
  overflow:visible !important;
}

.volume-rig{
  position:absolute;
  left:-118px;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  z-index:5;
}

.volume-rig-label{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(241,234,223,.78);
}

.volume-rig-ui{
  position:relative;
  width:120px;
  height:282px;
  display:grid;
  place-items:center;
}

.volume-rig-skin{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.35));
}

.volume-range{
  position:absolute;
  top:50%;
  left:50%;
  width:238px;
  height:42px;
  transform:translate(-50%,-50%) rotate(-90deg);
  opacity:0;
  cursor:pointer;
}

.tv-video-alone{
  box-shadow:0 20px 44px rgba(0,0,0,.22);
}

.section-title h2,
.work-card figcaption{
  color:#f1eadf !important;
}

@media (max-width: 1280px){
  .volume-rig{
    left:-96px;
  }
  .volume-rig-ui{
    width:104px;
    height:244px;
  }
  .volume-range{
    width:206px;
  }
}

@media (max-width: 980px){
  .volume-rig{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    margin:0 0 18px;
    flex-direction:row;
    justify-content:flex-start;
    align-items:flex-start;
    gap:14px;
  }
  .volume-rig-label{
    writing-mode:vertical-rl;
    transform:rotate(180deg);
    margin-top:6px;
  }
  .volume-rig-ui{
    width:84px;
    height:196px;
  }
  .volume-range{
    width:164px;
  }
}

@media (max-width: 700px){
  .volume-rig{
    margin-bottom:14px;
  }
  .volume-rig-ui{
    width:70px;
    height:164px;
  }
  .volume-range{
    width:136px;
  }
}


/* V37 - elegant volume button, no fader */
.volume-rig,
.volume-rig-ui,
.volume-rig-skin,
.volume-range{
  display:none !important;
}

.volume-toggle-elegant{
  position:absolute;
  left:-82px;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:62px;
  height:164px;
  border-radius:999px;
  border:1px solid rgba(241,234,223,.30);
  background:rgba(0,0,0,.42);
  backdrop-filter:blur(14px);
  color:#f1eadf;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  cursor:pointer;
  box-shadow:0 20px 55px rgba(0,0,0,.38), inset 0 0 0 1px rgba(255,255,255,.05);
}

.volume-toggle-label{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(241,234,223,.70);
}

.volume-toggle-icon{
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(241,234,223,.50);
  display:grid;
  place-items:center;
  font-size:18px;
  line-height:1;
}

.volume-toggle-elegant.is-on{
  background:#f1eadf;
  color:#000;
}

.volume-toggle-elegant.is-on .volume-toggle-label,
.volume-toggle-elegant.is-on .volume-toggle-icon{
  color:#000;
  border-color:rgba(0,0,0,.40);
}

.volume-toggle-elegant:hover{
  transform:translateY(-50%) scale(1.03);
}

/* Legal page */
.legal-content{
  padding:0 clamp(18px,3vw,40px) clamp(70px,8vw,120px);
  display:grid;
  gap:26px;
  max-width:1040px;
}

.legal-content article{
  border-top:1px solid rgba(241,234,223,.14);
  padding-top:22px;
}

.legal-content h2{
  font-family:var(--font-heading);
  font-size:clamp(34px,5vw,82px);
  line-height:.9;
  letter-spacing:.04em;
  color:#f1eadf;
  text-transform:uppercase;
  margin:0 0 18px;
}

.legal-content p{
  color:rgba(241,234,223,.78);
  font-size:clamp(16px,1.4vw,20px);
  line-height:1.65;
  max-width:75ch;
}

.legal-content a{
  color:#f1eadf;
  text-decoration:underline;
  text-underline-offset:4px;
}

/* Cookie banner */
.cookie-banner{
  position:fixed;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:120;
  max-width:760px;
  margin:auto;
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  padding:16px;
  border:1px solid rgba(241,234,223,.18);
  border-radius:24px;
  background:rgba(0,0,0,.82);
  color:#f1eadf;
  backdrop-filter:blur(18px);
  box-shadow:0 20px 70px rgba(0,0,0,.42);
  transition:opacity .24s ease, transform .24s ease;
}

.cookie-banner.is-hidden{
  opacity:0;
  transform:translateY(10px);
}

.cookie-copy strong{
  display:block;
  font-family:var(--font-heading);
  font-size:26px;
  line-height:.9;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-bottom:6px;
}

.cookie-copy p{
  margin:0;
  color:rgba(241,234,223,.72);
  font-size:13px;
  line-height:1.45;
}

.cookie-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}

.cookie-actions button,
.cookie-actions a{
  min-height:38px;
  border:1px solid rgba(241,234,223,.18);
  border-radius:999px;
  padding:0 13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  color:#f1eadf;
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  text-decoration:none;
}

.cookie-actions button:last-child{
  background:#f1eadf;
  color:#000;
}

@media(max-width:1180px){
  .volume-toggle-elegant{
    left:18px;
    top:auto;
    bottom:18px;
    transform:none;
    width:136px;
    height:52px;
    flex-direction:row;
    padding:0 12px;
  }
  .volume-toggle-label{
    writing-mode:horizontal-tb;
    transform:none;
  }
  .volume-toggle-elegant:hover{
    transform:scale(1.03);
  }
}

@media(max-width:700px){
  .volume-toggle-elegant{
    width:112px;
    height:46px;
    left:12px;
    bottom:12px;
  }
  .volume-toggle-icon{
    width:30px;
    height:30px;
    font-size:15px;
  }
  .cookie-banner{
    flex-direction:column;
    align-items:flex-start;
    left:12px;
    right:12px;
    bottom:12px;
  }
  .cookie-actions{
    width:100%;
    justify-content:flex-start;
  }
}


/* V38 pictos for video cards */
.page-videos .video-thumb{
  background:#ffffff center/contain no-repeat !important;
}
.page-videos .video-thumb::after{
  display:none !important;
}
.page-videos .video-thumb span{
  background:#111111 !important;
  color:#f1eadf !important;
  border:1px solid rgba(241,234,223,.18);
}
.page-videos .video-link-card{
  background:#ded6ca !important;
}

/* V39 clearer image-backed sound button */
.volume-toggle-elegant,
.hero-sound-toggle,
.volume-rig{display:none!important}
.sound-image-toggle{
  position:absolute;
  left:-92px;
  top:50%;
  transform:translateY(-50%);
  z-index:6;
  width:74px;
  height:154px;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  display:block;
  filter:drop-shadow(0 18px 45px rgba(0,0,0,.42));
}
.sound-image-toggle:hover{transform:translateY(-50%) scale(1.03)}
.sound-image-toggle img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.sound-image-toggle .sound-state-on{display:none}
.sound-image-toggle.is-on .sound-state-off{display:none}
.sound-image-toggle.is-on .sound-state-on{display:block}
.cinema-grid .work-card img{
  aspect-ratio:16/9;
  min-height:unset!important;
}
@media(max-width:1180px){
  .sound-image-toggle{
    left:18px;
    top:auto;
    bottom:18px;
    transform:none;
    width:58px;
    height:120px;
  }
  .sound-image-toggle:hover{transform:scale(1.03)}
}
@media(max-width:700px){
  .sound-image-toggle{
    left:12px;
    bottom:12px;
    width:50px;
    height:104px;
  }
}


/* V40 - page Vision SEO premium */
.vision-page{
  background:#000 !important;
  color:#f1eadf !important;
}

.vision-hero{
  min-height:78vh;
  display:grid;
  align-content:end;
  padding:clamp(70px,9vw,150px) clamp(18px,3vw,48px) clamp(54px,7vw,110px);
  border-bottom:1px solid rgba(241,234,223,.12);
}

.vision-hero h1{
  font-family:var(--font-display);
  max-width:9.6ch;
  font-size:clamp(66px,10vw,164px);
  line-height:.86;
  letter-spacing:-.055em;
  margin:0;
  color:#f1eadf;
}

.vision-lead{
  max-width:780px;
  margin:clamp(24px,3vw,42px) 0 0;
  color:rgba(241,234,223,.82);
  font-size:clamp(20px,2vw,34px);
  line-height:1.35;
}

.vision-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  border-bottom:1px solid rgba(241,234,223,.12);
}

.vision-block{
  min-height:360px;
  padding:clamp(24px,3vw,46px);
  border-right:1px solid rgba(241,234,223,.12);
  border-bottom:1px solid rgba(241,234,223,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:18px;
}

.vision-block-large{
  grid-row:span 2;
  min-height:720px;
}

.vision-block span{
  color:rgba(241,234,223,.48);
  font-size:12px;
  letter-spacing:.22em;
}

.vision-block h2{
  font-family:var(--font-heading);
  color:#f1eadf;
  font-size:clamp(42px,5vw,96px);
  line-height:.82;
  letter-spacing:.035em;
  text-transform:uppercase;
}

.vision-block p{
  margin:0;
  max-width:58ch;
  color:rgba(241,234,223,.74);
  font-size:clamp(16px,1.4vw,20px);
  line-height:1.58;
}

.skills-section{
  display:grid;
  grid-template-columns:minmax(260px,.42fr) 1fr;
  gap:clamp(28px,5vw,90px);
  padding:clamp(60px,8vw,130px) clamp(18px,3vw,48px);
  border-bottom:1px solid rgba(241,234,223,.12);
}

.skills-intro h2{
  font-family:var(--font-display);
  color:#f1eadf;
  font-size:clamp(54px,7vw,122px);
  line-height:.9;
  letter-spacing:-.05em;
  margin:0;
}

.skills-list{
  display:grid;
  border-top:1px solid rgba(241,234,223,.16);
}

.skills-list p{
  margin:0;
  min-height:84px;
  display:grid;
  grid-template-columns:70px 1fr;
  gap:20px;
  align-items:center;
  border-bottom:1px solid rgba(241,234,223,.16);
}

.skills-list strong{
  color:rgba(241,234,223,.48);
  font-size:12px;
  letter-spacing:.22em;
}

.skills-list span{
  color:#f1eadf;
  font-family:var(--font-heading);
  text-transform:uppercase;
  font-size:clamp(32px,4vw,74px);
  line-height:.88;
  letter-spacing:.035em;
}

.vision-manifesto{
  padding:clamp(64px,8vw,140px) clamp(18px,3vw,48px);
}

.vision-manifesto p{
  margin:0;
  max-width:11ch;
  font-family:var(--font-display);
  font-size:clamp(64px,10vw,170px);
  line-height:.86;
  letter-spacing:-.055em;
  color:#f1eadf;
}

@media(max-width:980px){
  .vision-grid{
    grid-template-columns:1fr;
  }
  .vision-block,
  .vision-block-large{
    min-height:320px;
    grid-row:auto;
  }
  .skills-section{
    grid-template-columns:1fr;
  }
}

@media(max-width:700px){
  .vision-hero{
    min-height:auto;
    padding-top:90px;
  }
  .vision-hero h1{
    font-size:clamp(58px,17vw,96px);
  }
  .vision-lead{
    font-size:18px;
  }
  .skills-list p{
    grid-template-columns:42px 1fr;
    min-height:72px;
  }
  .skills-list span{
    font-size:clamp(30px,9vw,52px);
  }
}


/* V41 fixes: video pictos + header logo + sound control */
.page-videos .brand img{
  object-fit:contain !important;
}

.video-grid-pictos .video-thumb-picto{
  background:#fff !important;
  display:grid !important;
  place-items:center !important;
  overflow:hidden;
}

.video-grid-pictos .video-thumb-picto::after{
  display:none !important;
}

.video-thumb-picto > img{
  width:58% !important;
  height:58% !important;
  object-fit:contain !important;
  filter:none !important;
}

.video-grid-pictos .video-thumb-picto span{
  background:#0b0b0b !important;
  color:#f1eadf !important;
  border:1px solid rgba(241,234,223,.20);
  z-index:2;
}

.video-picto-card{
  background:#ded6ca !important;
}

.sound-image-toggle,
.volume-toggle-elegant,
.hero-sound-toggle,
.volume-rig{
  display:none !important;
}

.sound-control{
  position:absolute;
  left:-86px;
  top:50%;
  transform:translateY(-50%);
  z-index:8;
  width:66px;
  height:166px;
  border-radius:999px;
  border:1px solid rgba(241,234,223,.34);
  background:rgba(0,0,0,.72);
  color:#f1eadf;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  cursor:pointer;
  box-shadow:0 20px 56px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.05);
  backdrop-filter:blur(14px);
}

.sound-control:hover{
  transform:translateY(-50%) scale(1.03);
}

.sound-word{
  writing-mode:vertical-rl;
  transform:rotate(180deg);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.sound-word-on{
  display:none;
}

.sound-control.is-on .sound-word-off{
  display:none;
}

.sound-control.is-on .sound-word-on{
  display:block;
}

.sound-speaker{
  position:relative;
  width:34px;
  height:28px;
  display:block;
}

.sound-speaker::before{
  content:"";
  position:absolute;
  left:1px;
  top:8px;
  width:10px;
  height:12px;
  background:#f1eadf;
  border-radius:2px;
}

.sound-speaker::after{
  content:"";
  position:absolute;
  left:9px;
  top:3px;
  width:18px;
  height:22px;
  background:#f1eadf;
  clip-path:polygon(0 35%,100% 0,100% 100%,0 65%);
}

.sound-control:not(.is-on) .sound-speaker{
  transform:rotate(0deg);
}

.sound-control:not(.is-on) .sound-speaker::after{
  box-shadow:none;
}

.sound-control:not(.is-on)::after{
  content:"";
  position:absolute;
  bottom:62px;
  left:16px;
  width:34px;
  height:2px;
  background:#f1eadf;
  transform:rotate(-42deg);
  border-radius:999px;
}

.sound-control.is-on{
  background:#f1eadf;
  color:#000;
}

.sound-control.is-on .sound-speaker::before,
.sound-control.is-on .sound-speaker::after{
  background:#000;
}

@media(max-width:1180px){
  .sound-control{
    left:18px;
    top:auto;
    bottom:18px;
    transform:none;
    width:134px;
    height:52px;
    flex-direction:row;
    padding:0 14px;
  }
  .sound-control:hover{
    transform:scale(1.03);
  }
  .sound-word{
    writing-mode:horizontal-tb;
    transform:none;
  }
  .sound-control:not(.is-on)::after{
    bottom:25px;
    left:auto;
    right:18px;
  }
}

@media(max-width:700px){
  .sound-control{
    left:12px;
    bottom:12px;
    width:118px;
    height:46px;
  }
  .sound-word{
    font-size:9px;
  }
}


/* V42 - bouton son compatible mobile/tablette/desktop/TV */
.sound-control-v42{
  position:absolute !important;
  top:18px !important;
  right:18px !important;
  left:auto !important;
  bottom:auto !important;
  transform:none !important;
  z-index:20 !important;

  width:auto !important;
  min-width:132px !important;
  height:48px !important;
  padding:0 14px !important;
  border-radius:999px !important;
  border:1px solid rgba(241,234,223,.34) !important;
  background:rgba(0,0,0,.72) !important;
  color:#f1eadf !important;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);

  display:inline-flex !important;
  flex-direction:row !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;

  cursor:pointer !important;
  touch-action:manipulation !important;
  user-select:none !important;
  -webkit-user-select:none !important;
  -webkit-tap-highlight-color:transparent !important;

  box-shadow:0 14px 40px rgba(0,0,0,.40), inset 0 0 0 1px rgba(255,255,255,.05) !important;
}

.sound-control-v42:hover,
.sound-control-v42:focus-visible{
  transform:none !important;
  outline:0 !important;
  border-color:rgba(241,234,223,.72) !important;
}

.sound-control-v42.is-on{
  background:#f1eadf !important;
  color:#000 !important;
}

.sound-control-v42 .sound-word,
.sound-control-v42 .sound-word-on,
.sound-control-v42 .sound-word-off{
  display:none !important;
}

.sound-control-v42 .sound-label-on,
.sound-control-v42 .sound-label-off{
  font-family:var(--font-body);
  font-size:11px;
  line-height:1;
  letter-spacing:.16em;
  text-transform:uppercase;
  white-space:nowrap;
}

.sound-control-v42 .sound-label-on{
  display:none;
}

.sound-control-v42.is-on .sound-label-off{
  display:none;
}

.sound-control-v42.is-on .sound-label-on{
  display:inline;
}

.sound-control-v42 .sound-icon{
  position:relative;
  width:28px;
  height:24px;
  flex:0 0 28px;
  display:block;
}

.sound-control-v42 .sound-icon::before{
  content:"";
  position:absolute;
  left:0;
  top:7px;
  width:9px;
  height:10px;
  border-radius:2px;
  background:currentColor;
}

.sound-control-v42 .sound-icon::after{
  content:"";
  position:absolute;
  left:7px;
  top:3px;
  width:16px;
  height:18px;
  background:currentColor;
  clip-path:polygon(0 34%,100% 0,100% 100%,0 66%);
}

.sound-control-v42:not(.is-on)::after{
  content:"";
  position:absolute;
  left:19px;
  top:24px;
  width:28px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:rotate(-42deg);
  transform-origin:center;
}

.sound-control-v42.is-on .sound-icon{
  box-shadow:8px 0 0 -6px currentColor, 13px 0 0 -6px currentColor;
}

.home-video-shell{
  position:relative !important;
}

@media(max-width:1180px){
  .sound-control-v42{
    top:14px !important;
    right:14px !important;
    min-width:118px !important;
    height:44px !important;
    padding:0 12px !important;
    gap:8px !important;
  }
  .sound-control-v42 .sound-label-on,
  .sound-control-v42 .sound-label-off{
    font-size:10px !important;
    letter-spacing:.14em !important;
  }
}

@media(max-width:700px){
  .sound-control-v42{
    top:10px !important;
    right:10px !important;
    min-width:106px !important;
    height:40px !important;
    padding:0 10px !important;
    gap:7px !important;
  }
  .sound-control-v42 .sound-icon{
    width:24px !important;
    height:20px !important;
    flex-basis:24px !important;
  }
  .sound-control-v42 .sound-label-on,
  .sound-control-v42 .sound-label-off{
    font-size:9px !important;
  }
  .sound-control-v42:not(.is-on)::after{
    left:15px;
    top:20px;
    width:25px;
  }
}


/* V43 RESPONSIVE GLOBAL SITE */
/* Objectif : tout le site doit fonctionner sur mobile, tablette, desktop, grand écran et TV */

html{
  overflow-x:hidden !important;
}

body{
  overflow-x:hidden !important;
  min-width:0 !important;
}

img,
video,
svg{
  max-width:100% !important;
}

main{
  width:100% !important;
  overflow-x:hidden !important;
}

/* Header global */
.site-header{
  min-height:84px !important;
  padding:14px clamp(14px,2.4vw,40px) !important;
}

.site-header .brand{
  min-width:0 !important;
  max-width:45vw !important;
}

.site-header .brand img{
  flex:0 0 auto !important;
}

.site-header .brand span{
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
  max-width:100% !important;
}

.header-right,
.header-right-only{
  min-width:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:clamp(10px,2vw,34px) !important;
}

.site-header nav{
  min-width:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  flex-wrap:wrap !important;
  gap:clamp(10px,1.8vw,30px) !important;
}

.site-header nav a{
  white-space:nowrap !important;
}

/* Home globale */
.home-hero,
.home-hero-v18{
  width:100% !important;
  min-height:calc(100svh - 92px) !important;
  padding:clamp(34px,5vw,76px) clamp(16px,3vw,44px) clamp(40px,6vw,82px) !important;
  display:grid !important;
  grid-template-columns:minmax(360px,.45fr) minmax(420px,.55fr) !important;
  gap:clamp(24px,4vw,72px) !important;
  align-items:center !important;
}

.home-hero-v18::before{
  inset:clamp(90px,9vw,126px) clamp(16px,3vw,40px) 28px !important;
}

.home-copy-poster-v28{
  width:100% !important;
  max-width:560px !important;
  min-height:auto !important;
  padding-left:clamp(14px,3vw,72px) !important;
}

.hero-poster-text-v28{
  width:100% !important;
}

.poster-line-a,
.poster-line-b,
.poster-line-d{
  font-size:clamp(78px,8.4vw,166px) !important;
}

.poster-line-c{
  font-size:clamp(42px,4.8vw,82px) !important;
}

.poster-logo-link-v28{
  width:clamp(150px,16vw,320px) !important;
  height:clamp(150px,16vw,320px) !important;
}

.poster-logo-v28{
  width:64% !important;
  height:64% !important;
}

.home-video-shell{
  width:100% !important;
  max-width:1000px !important;
  justify-self:center !important;
}

.tv-video-alone{
  width:100% !important;
  height:auto !important;
  display:block !important;
}

/* Grilles globales */
.entry-grid,
.manifesto-grid,
.vision-grid,
.skills-section,
.works-grid,
.video-grid{
  width:100% !important;
  max-width:100% !important;
}

.entry-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr)) !important;
}

.manifesto-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr)) !important;
}

.video-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr)) !important;
}

.works-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr)) !important;
}

.work-card:first-child{
  grid-row:auto !important;
}

.work-card img{
  height:auto !important;
  aspect-ratio:16/10 !important;
  object-fit:cover !important;
  min-height:240px !important;
}

/* Pages internes */
.page{
  width:100% !important;
  overflow-x:hidden !important;
}

.page-intro{
  padding:clamp(52px,8vw,120px) clamp(16px,3vw,44px) clamp(34px,5vw,72px) !important;
}

.page .page-intro h1{
  font-size:clamp(54px,9vw,126px) !important;
  line-height:1 !important;
  max-width:11ch !important;
}

.page .page-intro .lead{
  max-width:min(100%,720px) !important;
}

.section-title{
  grid-template-columns:70px minmax(0,.8fr) minmax(260px,1fr) !important;
  gap:clamp(12px,2vw,26px) !important;
}

.section-title h2{
  font-size:clamp(54px,8vw,128px) !important;
  overflow-wrap:anywhere !important;
}

.section-title p{
  max-width:46ch !important;
}

/* Vision page */
.vision-hero{
  min-height:calc(100svh - 92px) !important;
}

.vision-hero h1{
  max-width:10ch !important;
}

.vision-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr)) !important;
}

.vision-block,
.vision-block-large{
  min-height:clamp(300px,34vw,520px) !important;
  grid-row:auto !important;
}

.skills-section{
  grid-template-columns:minmax(260px,.42fr) minmax(0,1fr) !important;
}

.skills-list p{
  min-width:0 !important;
}

.skills-list span{
  overflow-wrap:anywhere !important;
}

/* Contact */
.contact-main{
  overflow-wrap:anywhere !important;
  word-break:break-word !important;
}

.contact-actions{
  max-width:100% !important;
}

/* Boutons fixes */
.back-top{
  z-index:90 !important;
}

.chaos-button{
  z-index:91 !important;
}

/* Desktop compact et laptop */
@media(max-width:1280px){
  .home-hero,
  .home-hero-v18{
    grid-template-columns:minmax(330px,.46fr) minmax(380px,.54fr) !important;
    gap:clamp(22px,3vw,46px) !important;
  }

  .poster-line-a,
  .poster-line-b,
  .poster-line-d{
    font-size:clamp(70px,8vw,132px) !important;
  }

  .poster-line-c{
    font-size:clamp(38px,4.4vw,66px) !important;
  }

  .home-video-shell{
    max-width:780px !important;
  }
}

/* Tablette et petits laptops */
@media(max-width:980px){
  .site-header{
    min-height:auto !important;
    align-items:flex-start !important;
    padding:14px 16px 12px !important;
  }

  .site-header .brand{
    max-width:52vw !important;
  }

  .site-header .brand img{
    width:58px !important;
    height:58px !important;
  }

  .site-header .brand span{
    font-size:clamp(28px,5vw,44px) !important;
  }

  .header-right,
  .header-right-only{
    align-items:flex-end !important;
    flex-direction:column !important;
    gap:10px !important;
  }

  .site-header nav{
    position:static !important;
    width:auto !important;
    justify-content:flex-end !important;
    gap:12px !important;
  }

  .site-header nav a{
    font-size:10px !important;
    letter-spacing:.13em !important;
  }

  .lang-toggle{
    width:44px !important;
    height:44px !important;
  }

  main{
    padding-top:112px !important;
  }

  .home-hero,
  .home-hero-v18{
    grid-template-columns:1fr !important;
    min-height:auto !important;
    padding-top:52px !important;
    gap:34px !important;
  }

  .home-hero-v18::before{
    inset:108px 14px 22px !important;
  }

  .home-copy-poster-v28{
    max-width:100% !important;
    padding-left:0 !important;
    align-items:center !important;
    text-align:center !important;
  }

  .hero-poster-text-v28{
    align-items:center !important;
    text-align:center !important;
  }

  .poster-line-a,
  .poster-line-b,
  .poster-line-d{
    font-size:clamp(68px,15vw,128px) !important;
  }

  .poster-line-c{
    font-size:clamp(38px,8vw,64px) !important;
  }

  .poster-lead-v28{
    text-align:center !important;
    max-width:28ch !important;
  }

  .home-actions-v28{
    justify-content:center !important;
  }

  .home-video-shell{
    max-width:100% !important;
    justify-self:stretch !important;
  }

  .section-title{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }

  .skills-section{
    grid-template-columns:1fr !important;
  }
}

/* Téléphone */
@media(max-width:700px){
  .site-header{
    position:sticky !important;
    top:0 !important;
    background:rgba(0,0,0,.90) !important;
    backdrop-filter:blur(16px) !important;
    -webkit-backdrop-filter:blur(16px) !important;
  }

  .site-header .brand{
    max-width:100% !important;
  }

  .site-header .brand img{
    width:48px !important;
    height:48px !important;
    border-radius:14px !important;
  }

  .site-header .brand span{
    font-size:28px !important;
    max-width:210px !important;
  }

  .header-right,
  .header-right-only{
    width:100% !important;
  }

  .site-header nav{
    width:100% !important;
    display:grid !important;
    grid-template-columns:repeat(3,auto) !important;
    justify-content:space-between !important;
    row-gap:8px !important;
  }

  .site-header nav a{
    font-size:9px !important;
    letter-spacing:.1em !important;
  }

  main{
    padding-top:24px !important;
  }

  .home-hero,
  .home-hero-v18{
    padding:26px 14px 42px !important;
    gap:24px !important;
  }

  .home-hero-v18::before{
    inset:18px 10px 16px !important;
    border-radius:24px !important;
  }

  .poster-logo-link-v28{
    width:132px !important;
    height:132px !important;
  }

  .poster-line-a,
  .poster-line-b,
  .poster-line-d{
    font-size:clamp(52px,17vw,88px) !important;
    line-height:.9 !important;
  }

  .poster-line-c{
    font-size:clamp(30px,9vw,46px) !important;
  }

  .poster-lead-v28{
    font-size:15px !important;
    max-width:24ch !important;
  }

  .home-actions-v28{
    width:100% !important;
    align-items:stretch !important;
  }

  .home-actions-v28 a{
    flex:1 1 100% !important;
    justify-content:center !important;
  }

  .page-intro{
    padding:42px 16px 30px !important;
  }

  .page .page-intro h1{
    font-size:clamp(46px,15vw,82px) !important;
    max-width:10ch !important;
  }

  .page .page-intro .lead{
    font-size:17px !important;
  }

  .entry-grid a{
    min-height:190px !important;
  }

  .work-section{
    padding:42px 16px !important;
  }

  .work-card{
    border-radius:18px !important;
  }

  .work-card img{
    min-height:220px !important;
  }

  .video-grid{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .video-link-card{
    border-radius:18px !important;
  }

  .video-text h3{
    font-size:clamp(34px,11vw,54px) !important;
  }

  .vision-hero{
    min-height:auto !important;
    padding:52px 16px 42px !important;
  }

  .vision-hero h1{
    font-size:clamp(52px,16vw,92px) !important;
  }

  .vision-lead{
    font-size:17px !important;
  }

  .vision-block{
    min-height:260px !important;
    padding:28px 16px !important;
  }

  .skills-section{
    padding:48px 16px !important;
  }

  .skills-list p{
    grid-template-columns:38px 1fr !important;
    min-height:68px !important;
  }

  .skills-list span{
    font-size:clamp(28px,9vw,46px) !important;
  }

  .contact-links-v34,
  .contact-links{
    padding-left:16px !important;
    padding-right:16px !important;
  }

  .contact-main{
    font-size:clamp(32px,10vw,58px) !important;
  }

  .site-footer{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:8px !important;
  }

  .back-top{
    width:46px !important;
    height:46px !important;
    right:12px !important;
    bottom:12px !important;
    font-size:27px !important;
  }

  .chaos-button{
    max-width:150px !important;
    left:10px !important;
    bottom:10px !important;
  }
}

/* Très petits téléphones */
@media(max-width:420px){
  .site-header nav{
    grid-template-columns:repeat(2,auto) !important;
    justify-content:space-between !important;
  }

  .site-header .brand span{
    max-width:170px !important;
  }

  .poster-line-a,
  .poster-line-b,
  .poster-line-d{
    font-size:clamp(46px,16vw,70px) !important;
  }

  .poster-line-c{
    font-size:clamp(26px,8vw,36px) !important;
  }

  .page .page-intro h1{
    font-size:clamp(42px,14vw,68px) !important;
  }
}


/* V44 - bouton son stable, sans conflit JS/CSS */
.sound-control,
.sound-control-v42,
.sound-image-toggle,
.volume-toggle-elegant,
.hero-sound-toggle,
.volume-rig{
  display:none !important;
}

.sound-stable{
  position:absolute !important;
  top:18px !important;
  right:18px !important;
  z-index:30 !important;
  min-width:132px !important;
  height:48px !important;
  padding:0 14px !important;
  border-radius:999px !important;
  border:1px solid rgba(241,234,223,.36) !important;
  background:rgba(0,0,0,.76) !important;
  color:#f1eadf !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  cursor:pointer !important;
  touch-action:manipulation !important;
  -webkit-tap-highlight-color:transparent !important;
  user-select:none !important;
  -webkit-user-select:none !important;
  backdrop-filter:blur(16px) !important;
  -webkit-backdrop-filter:blur(16px) !important;
  box-shadow:0 14px 44px rgba(0,0,0,.46), inset 0 0 0 1px rgba(255,255,255,.05) !important;
}

.sound-stable:hover,
.sound-stable:focus-visible{
  border-color:rgba(241,234,223,.8) !important;
  outline:none !important;
}

.sound-stable.is-on{
  background:#f1eadf !important;
  color:#000 !important;
}

.sound-stable-text{
  font-family:var(--font-body);
  font-size:11px;
  line-height:1;
  letter-spacing:.14em;
  text-transform:uppercase;
  white-space:nowrap;
}

.sound-stable-on{
  display:none;
}

.sound-stable.is-on .sound-stable-off{
  display:none;
}

.sound-stable.is-on .sound-stable-on{
  display:inline;
}

.sound-stable-icon{
  position:relative;
  width:28px;
  height:24px;
  flex:0 0 28px;
  display:block;
}

.sound-stable-icon::before{
  content:"";
  position:absolute;
  left:0;
  top:7px;
  width:9px;
  height:10px;
  border-radius:2px;
  background:currentColor;
}

.sound-stable-icon::after{
  content:"";
  position:absolute;
  left:7px;
  top:3px;
  width:16px;
  height:18px;
  background:currentColor;
  clip-path:polygon(0 34%,100% 0,100% 100%,0 66%);
}

.sound-stable:not(.is-on)::after{
  content:"";
  position:absolute;
  left:19px;
  top:24px;
  width:28px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:rotate(-42deg);
  transform-origin:center;
}

.sound-stable.is-on .sound-stable-icon{
  filter:drop-shadow(10px 0 0 currentColor);
}

@media(max-width:700px){
  .sound-stable{
    top:10px !important;
    right:10px !important;
    min-width:108px !important;
    height:40px !important;
    padding:0 10px !important;
    gap:7px !important;
  }
  .sound-stable-text{
    font-size:9px !important;
    letter-spacing:.12em !important;
  }
  .sound-stable-icon{
    width:24px !important;
    height:20px !important;
    flex-basis:24px !important;
  }
  .sound-stable:not(.is-on)::after{
    left:15px;
    top:20px;
    width:25px;
  }
}


/* V45 - correction de la ligne finale de la liste des 7 arts + IA */
.tool-list{
  width:100% !important;
  overflow:hidden !important;
}

.tool-list p{
  grid-template-columns:minmax(0,1fr) 64px minmax(0,1fr) !important;
  gap:14px !important;
  padding:0 16px !important;
}

.tool-list p > span,
.tool-list p > em,
.tool-list p > strong{
  min-width:0 !important;
}

.tool-list span,
.tool-list em{
  overflow-wrap:anywhere !important;
  word-break:break-word !important;
}

.tool-list em{
  justify-self:end !important;
}

.tool-list-final{
  padding:0 16px !important;
}

.tool-list-final span,
.tool-list-final em{
  font-size:clamp(28px,4.2vw,72px) !important;
}

@media(max-width:980px){
  .tool-list p{
    grid-template-columns:minmax(0,1fr) 42px minmax(0,1fr) !important;
    gap:10px !important;
    padding:0 12px !important;
  }
}

@media(max-width:700px){
  .tool-list p{
    min-height:54px !important;
  }

  .tool-list span,
  .tool-list em{
    font-size:clamp(24px,7.4vw,42px) !important;
    line-height:.88 !important;
  }

  .tool-list strong{
    font-size:clamp(18px,4vw,28px) !important;
  }

  .tool-list-final span,
  .tool-list-final em{
    font-size:clamp(22px,7.2vw,40px) !important;
  }
}


/* V46 - premium system pages */
.premium-page{
  background:#000 !important;
  color:#f1eadf !important;
}

.premium-intro h1{
  color:#f1eadf !important;
  max-width:10ch !important;
}

.premium-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));
  border-top:1px solid rgba(241,234,223,.14);
}

.premium-cards article{
  min-height:360px;
  padding:clamp(24px,3vw,46px);
  border-right:1px solid rgba(241,234,223,.12);
  border-bottom:1px solid rgba(241,234,223,.12);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:16px;
}

.premium-cards span,
.process-list strong{
  color:rgba(241,234,223,.48);
  font-size:12px;
  letter-spacing:.22em;
}

.premium-cards h2{
  font-family:var(--font-heading);
  color:#f1eadf;
  font-size:clamp(42px,5vw,86px);
  line-height:.84;
  letter-spacing:.035em;
  text-transform:uppercase;
}

.premium-cards p,
.process-list em,
.about-text p{
  color:rgba(241,234,223,.76);
  line-height:1.58;
}

.premium-cards a{
  color:#f1eadf;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:12px;
  margin-top:12px;
}

.process-list{
  padding:0 clamp(18px,3vw,48px) clamp(70px,8vw,120px);
  display:grid;
}

.process-list p{
  margin:0;
  min-height:105px;
  display:grid;
  grid-template-columns:70px minmax(160px,.35fr) 1fr;
  gap:24px;
  align-items:center;
  border-top:1px solid rgba(241,234,223,.14);
}

.process-list span{
  color:#f1eadf;
  font-family:var(--font-heading);
  text-transform:uppercase;
  font-size:clamp(34px,5vw,74px);
  line-height:.88;
}

.process-list em{
  font-style:normal;
  max-width:62ch;
}

.about-text{
  padding:0 clamp(18px,3vw,48px) clamp(70px,8vw,120px);
  max-width:1100px;
}

.about-text p{
  font-size:clamp(22px,2.4vw,42px);
  line-height:1.25;
  color:#f1eadf;
}

.home-seo-links{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  background:#000;
  color:#f1eadf;
  border-top:1px solid rgba(241,234,223,.14);
}

.home-seo-links a{
  min-height:240px;
  padding:26px;
  display:grid;
  align-content:end;
  gap:10px;
  border-right:1px solid rgba(241,234,223,.12);
}

.home-seo-links span{
  color:rgba(241,234,223,.5);
  font-size:12px;
  letter-spacing:.18em;
}

.home-seo-links strong{
  font-family:var(--font-heading);
  font-size:clamp(42px,5vw,84px);
  line-height:.84;
  color:#f1eadf;
  text-transform:uppercase;
}

.home-seo-links em{
  font-style:normal;
  color:rgba(241,234,223,.70);
}

/* V46 - perfect chaos button */
.chaos-button{
  border-color:rgba(241,234,223,.35) !important;
  color:#f1eadf !important;
  background:rgba(0,0,0,.68) !important;
  backdrop-filter:blur(12px) !important;
  -webkit-backdrop-filter:blur(12px) !important;
  letter-spacing:.13em !important;
  box-shadow:0 10px 30px rgba(0,0,0,.35) !important;
}

.chaos-button:hover{
  background:#f1eadf !important;
  color:#000 !important;
  transform:translateY(-1px);
}

/* V46 - privacy-safe intro */
.welcome-lock{
  overflow:hidden !important;
}

.welcome-intro{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#000;
  color:#f1eadf;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:1;
  transition:opacity .6s ease, transform .6s ease;
}

.welcome-intro.is-leaving{
  opacity:0;
  transform:scale(1.02);
  pointer-events:none;
}

.welcome-card{
  width:min(760px,100%);
  min-height:420px;
  border:1px solid rgba(241,234,223,.18);
  border-radius:34px;
  padding:clamp(28px,5vw,64px);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:18px;
  background:radial-gradient(circle at 50% 0%, rgba(241,234,223,.10), transparent 45%), #000;
  animation:welcomeIn .9s ease both;
}

@keyframes welcomeIn{
  from{opacity:0; transform:translateY(18px)}
  to{opacity:1; transform:translateY(0)}
}

.welcome-kicker{
  margin:0;
  color:rgba(241,234,223,.55);
  letter-spacing:.24em;
  font-size:12px;
}

.welcome-card h2{
  margin:0;
  color:#f1eadf;
  font-family:var(--font-heading);
  text-transform:uppercase;
  font-size:clamp(52px,9vw,118px);
  line-height:.82;
  letter-spacing:.035em;
}

.welcome-card p:not(.welcome-kicker){
  margin:0;
  color:rgba(241,234,223,.78);
  font-size:clamp(18px,2vw,28px);
}

.welcome-card button{
  align-self:flex-start;
  min-height:46px;
  border:1px solid rgba(241,234,223,.28);
  border-radius:999px;
  background:#f1eadf;
  color:#000;
  padding:0 18px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  cursor:pointer;
}

@media(max-width:980px){
  .process-list p{
    grid-template-columns:1fr;
    gap:8px;
    padding:22px 0;
  }
  .home-seo-links{
    grid-template-columns:1fr;
  }
}

@media(max-width:700px){
  .premium-cards article{
    min-height:270px;
  }
  .welcome-card{
    min-height:360px;
    border-radius:24px;
  }
}


/* V47 - équilibrage des pages Services / Projets */
.premium-cards{
  grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  align-items:stretch;
}

.premium-cards article{
  min-height:420px !important;
  padding:clamp(26px, 3vw, 44px) !important;
  gap:18px !important;
  justify-content:flex-start !important;
}

.premium-cards article span{
  display:block;
  margin-bottom:6px;
}

.premium-cards article h2{
  font-size:clamp(34px, 3.6vw, 62px) !important;
  line-height:.88 !important;
  letter-spacing:.02em !important;
  max-width:9ch !important;
  overflow-wrap:anywhere !important;
  word-break:break-word !important;
  margin:0 0 10px 0 !important;
}

.premium-cards article p{
  margin-top:auto !important;
  max-width:30ch !important;
  font-size:clamp(16px, 1.15vw, 20px) !important;
}

.premium-cards article a{
  margin-top:6px !important;
}

@media(max-width:1280px){
  .premium-cards{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }
  .premium-cards article{
    min-height:360px !important;
  }
}

@media(max-width:700px){
  .premium-cards{
    grid-template-columns:1fr !important;
  }
  .premium-cards article{
    min-height:280px !important;
    padding:24px 16px !important;
  }
  .premium-cards article h2{
    font-size:clamp(30px, 10vw, 48px) !important;
    max-width:10ch !important;
  }
  .premium-cards article p{
    max-width:100% !important;
  }
}


/* V48 - intro graphique légère */
.welcome-intro{
  display:none !important;
}

.intro-lock{
  overflow:hidden !important;
}

.graphic-intro{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#000;
  color:#f1eadf;
  display:grid;
  place-items:center;
  pointer-events:none;
  overflow:hidden;
  animation:giFadeIn .18s ease both;
}

.graphic-intro.is-out{
  animation:giFadeOut .5s cubic-bezier(.7,0,.2,1) forwards;
}

.graphic-intro-inner{
  position:relative;
  width:min(72vw,920px);
  height:min(46vh,420px);
  display:grid;
  place-items:center;
  isolation:isolate;
}

.gi-line{
  position:absolute;
  background:#f1eadf;
  opacity:.86;
  transform-origin:left center;
}

.gi-line-a{
  left:0;
  top:50%;
  width:100%;
  height:1px;
  animation:giLineX .78s cubic-bezier(.76,0,.24,1) both;
}

.gi-line-b{
  left:50%;
  top:0;
  width:1px;
  height:100%;
  transform-origin:center top;
  animation:giLineY .78s cubic-bezier(.76,0,.24,1) .08s both;
}

.gi-line-c{
  left:50%;
  top:50%;
  width:min(34vw,420px);
  height:1px;
  transform:translate(-50%,-50%) rotate(-28deg) scaleX(0);
  transform-origin:left center;
  opacity:.38;
  animation:giSlash .72s cubic-bezier(.76,0,.24,1) .22s both;
}

.gi-logo{
  position:relative;
  z-index:2;
  width:clamp(82px,10vw,138px);
  height:clamp(82px,10vw,138px);
  border:1px solid rgba(241,234,223,.30);
  border-radius:999px;
  display:grid;
  place-items:center;
  font-family:var(--font-heading);
  font-size:clamp(34px,5vw,64px);
  line-height:1;
  letter-spacing:.04em;
  background:#000;
  color:#f1eadf;
  animation:giLogo .74s cubic-bezier(.76,0,.24,1) .34s both;
}

.graphic-intro p{
  position:absolute;
  left:50%;
  bottom:0;
  transform:translateX(-50%);
  margin:0;
  color:rgba(241,234,223,.64);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  white-space:nowrap;
  animation:giText .5s ease .66s both;
}

@keyframes giFadeIn{
  from{opacity:0}
  to{opacity:1}
}

@keyframes giFadeOut{
  to{
    opacity:0;
    transform:scale(1.018);
    visibility:hidden;
  }
}

@keyframes giLineX{
  from{transform:scaleX(0)}
  to{transform:scaleX(1)}
}

@keyframes giLineY{
  from{transform:scaleY(0)}
  to{transform:scaleY(1)}
}

@keyframes giSlash{
  from{transform:translate(-50%,-50%) rotate(-28deg) scaleX(0)}
  to{transform:translate(-50%,-50%) rotate(-28deg) scaleX(1)}
}

@keyframes giLogo{
  from{
    opacity:0;
    transform:scale(.72) rotate(-8deg);
    filter:blur(8px);
  }
  to{
    opacity:1;
    transform:scale(1) rotate(0);
    filter:blur(0);
  }
}

@keyframes giText{
  from{
    opacity:0;
    transform:translateX(-50%) translateY(8px);
  }
  to{
    opacity:1;
    transform:translateX(-50%) translateY(0);
  }
}

@media(max-width:700px){
  .graphic-intro-inner{
    width:82vw;
    height:36vh;
  }
  .graphic-intro p{
    font-size:9px;
    letter-spacing:.18em;
  }
}

@media(prefers-reduced-motion: reduce){
  .graphic-intro{
    display:none !important;
  }
}


/* V49 - intro monogramme CB plus premium et plus ample */
.graphic-intro{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#000;
  color:#f1eadf;
  display:grid;
  place-items:center;
  pointer-events:none;
  overflow:hidden;
}

.graphic-intro::before,
.graphic-intro::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
}

.graphic-intro::before{
  background:
    radial-gradient(circle at 50% 50%, rgba(241,234,223,.10), transparent 38%),
    linear-gradient(to right, transparent 8%, rgba(241,234,223,.08) 8.1%, transparent 8.2%, transparent 50%, rgba(241,234,223,.08) 50.1%, transparent 50.2%, transparent 91.8%, rgba(241,234,223,.08) 91.9%, transparent 92%);
  opacity:.42;
}

.graphic-intro::after{
  background:
    linear-gradient(to bottom, transparent 12%, rgba(241,234,223,.06) 12.1%, transparent 12.2%, transparent 87.8%, rgba(241,234,223,.06) 87.9%, transparent 88%);
  opacity:.5;
}

.graphic-intro-inner{
  position:relative;
  width:min(92vw, 1540px);
  height:min(82vh, 920px);
  display:grid;
  place-items:center;
  isolation:isolate;
}

.gi-frame{
  position:absolute;
  border:1px solid rgba(241,234,223,.12);
  border-radius:38px;
  opacity:.9;
}

.gi-frame-a{
  inset:6% 3%;
  animation:giFrameA 1.05s cubic-bezier(.76,0,.24,1) both;
}

.gi-frame-b{
  inset:16% 11%;
  border-radius:999px;
  opacity:.32;
  animation:giFrameB 1.05s cubic-bezier(.76,0,.24,1) .14s both;
}

.gi-line{
  position:absolute;
  background:#f1eadf;
  transform-origin:left center;
}

.gi-line-a{
  left:3%;
  right:3%;
  top:50%;
  height:1px;
  opacity:.74;
  animation:giLineXWide .9s cubic-bezier(.76,0,.24,1) both;
}

.gi-line-b{
  top:8%;
  bottom:8%;
  left:50%;
  width:1px;
  opacity:.54;
  transform-origin:center top;
  animation:giLineYTall .9s cubic-bezier(.76,0,.24,1) .08s both;
}

.gi-line-c{
  left:50%;
  top:50%;
  width:min(44vw, 760px);
  height:1px;
  opacity:.24;
  transform:translate(-50%,-50%) rotate(-27deg) scaleX(0);
  animation:giSlashLarge .88s cubic-bezier(.76,0,.24,1) .22s both;
}

.gi-monogram{
  position:relative;
  z-index:2;
  width:min(78vw, 1160px);
  height:auto;
  color:#f1eadf;
  filter:drop-shadow(0 8px 26px rgba(241,234,223,.08));
  animation:giMonoWrap 1s cubic-bezier(.76,0,.24,1) .18s both;
}

.gi-monogram .gi-c-shape,
.gi-monogram .gi-b-stem,
.gi-monogram .gi-b-top,
.gi-monogram .gi-b-bottom{
  stroke-dasharray:1200;
  stroke-dashoffset:1200;
}

.gi-monogram .gi-c-shape{
  animation:giDraw 1.0s cubic-bezier(.76,0,.24,1) .28s forwards;
}

.gi-monogram .gi-b-stem{
  animation:giDraw .64s cubic-bezier(.76,0,.24,1) .42s forwards;
}

.gi-monogram .gi-b-top{
  animation:giDraw .82s cubic-bezier(.76,0,.24,1) .52s forwards;
}

.gi-monogram .gi-b-bottom{
  animation:giDraw .82s cubic-bezier(.76,0,.24,1) .64s forwards;
}

.gi-meta{
  position:absolute;
  bottom:9%;
  left:50%;
  transform:translateX(-50%);
  display:grid;
  gap:10px;
  justify-items:center;
  text-align:center;
  z-index:3;
  animation:giTextRise .5s ease .72s both;
}

.gi-kicker,
.gi-sub{
  margin:0;
  text-transform:uppercase;
  white-space:nowrap;
}

.gi-kicker{
  font-family:var(--font-heading);
  letter-spacing:.2em;
  font-size:clamp(13px,1vw,18px);
  color:rgba(241,234,223,.88);
}

.gi-sub{
  letter-spacing:.24em;
  font-size:clamp(10px,.8vw,13px);
  color:rgba(241,234,223,.48);
}

.graphic-intro.is-out{
  animation:giFadeOutV49 .52s cubic-bezier(.7,0,.2,1) forwards;
}

@keyframes giFrameA{
  from{opacity:0; transform:scale(.96)}
  to{opacity:.9; transform:scale(1)}
}

@keyframes giFrameB{
  from{opacity:0; transform:scale(1.04)}
  to{opacity:.32; transform:scale(1)}
}

@keyframes giLineXWide{
  from{transform:scaleX(0)}
  to{transform:scaleX(1)}
}

@keyframes giLineYTall{
  from{transform:scaleY(0)}
  to{transform:scaleY(1)}
}

@keyframes giSlashLarge{
  from{transform:translate(-50%,-50%) rotate(-27deg) scaleX(0)}
  to{transform:translate(-50%,-50%) rotate(-27deg) scaleX(1)}
}

@keyframes giMonoWrap{
  from{opacity:0; transform:scale(.92) translateY(12px); filter:blur(8px)}
  to{opacity:1; transform:scale(1) translateY(0); filter:blur(0)}
}

@keyframes giDraw{
  to{stroke-dashoffset:0}
}

@keyframes giTextRise{
  from{opacity:0; transform:translateX(-50%) translateY(10px)}
  to{opacity:1; transform:translateX(-50%) translateY(0)}
}

@keyframes giFadeOutV49{
  to{
    opacity:0;
    transform:scale(1.012);
    visibility:hidden;
  }
}

@media(max-width:980px){
  .graphic-intro-inner{
    width:94vw;
    height:min(76vh, 760px);
  }
  .gi-monogram{
    width:min(84vw, 920px);
  }
  .gi-frame-a{
    inset:8% 3%;
  }
  .gi-frame-b{
    inset:18% 9%;
  }
}

@media(max-width:700px){
  .graphic-intro-inner{
    width:96vw;
    height:62vh;
  }
  .gi-monogram{
    width:92vw;
  }
  .gi-frame-a{
    inset:7% 2%;
    border-radius:24px;
  }
  .gi-frame-b{
    inset:19% 8%;
  }
  .gi-meta{
    bottom:10%;
    gap:8px;
  }
  .gi-kicker{
    font-size:10px;
    letter-spacing:.16em;
  }
  .gi-sub{
    max-width:90vw;
    white-space:normal;
    text-align:center;
    line-height:1.4;
    font-size:9px;
    letter-spacing:.16em;
  }
}


/* V50 - intro avec signature manuscrite de Charles */
.gi-signature-scene{
  width:min(94vw, 1640px) !important;
  height:min(84vh, 980px) !important;
}

.gi-signature-wrap{
  position:relative;
  z-index:2;
  width:min(88vw, 1320px);
  display:grid;
  place-items:center;
  animation:giSigWrapIn 1s cubic-bezier(.76,0,.24,1) .16s both;
}

.gi-signature-wrap::before{
  content:"";
  position:absolute;
  inset:50% auto auto 50%;
  width:min(58vw, 820px);
  height:min(20vw, 280px);
  transform:translate(-50%,-50%);
  border:1px solid rgba(241,234,223,.10);
  border-radius:999px;
  opacity:.5;
}

.gi-signature{
  position:relative;
  display:block;
  width:min(78vw, 1180px);
  height:auto;
  filter:drop-shadow(0 10px 30px rgba(241,234,223,.10));
  clip-path:inset(0 100% 0 0);
  animation:giSignatureReveal .9s cubic-bezier(.76,0,.24,1) .34s forwards, giSignatureFloat 2.6s ease-in-out 1.4s infinite alternate;
}

.gi-meta{
  bottom:7.5% !important;
}

.gi-kicker{
  font-size:clamp(13px, 1vw, 18px) !important;
}

.gi-sub{
  font-size:clamp(10px, .8vw, 13px) !important;
}

@keyframes giSigWrapIn{
  from{opacity:0; transform:scale(.96) translateY(10px); filter:blur(6px)}
  to{opacity:1; transform:scale(1) translateY(0); filter:blur(0)}
}

@keyframes giSignatureReveal{
  from{opacity:0; clip-path:inset(0 100% 0 0)}
  40%{opacity:1}
  to{opacity:1; clip-path:inset(0 0 0 0)}
}

@keyframes giSignatureFloat{
  from{transform:translateY(0)}
  to{transform:translateY(-6px)}
}

@media(max-width:980px){
  .gi-signature-scene{
    width:96vw !important;
    height:min(76vh, 760px) !important;
  }
  .gi-signature-wrap{
    width:92vw;
  }
  .gi-signature{
    width:min(86vw, 940px);
  }
  .gi-signature-wrap::before{
    width:min(70vw, 700px);
    height:min(26vw, 250px);
  }
}

@media(max-width:700px){
  .gi-signature-scene{
    width:96vw !important;
    height:60vh !important;
  }
  .gi-signature-wrap{
    width:92vw;
  }
  .gi-signature{
    width:90vw;
  }
  .gi-signature-wrap::before{
    width:80vw;
    height:30vw;
  }
  .gi-meta{
    bottom:9% !important;
  }
}


/* V51 - signature plus petite, centrée, plus élégante */
.gi-signature-wrap{
  width:min(72vw, 980px) !important;
  margin:0 auto !important;
}

.gi-signature{
  width:min(42vw, 590px) !important;
  max-width:590px !important;
  margin:0 auto !important;
}

.gi-signature-wrap::before{
  width:min(34vw, 470px) !important;
  height:min(12vw, 150px) !important;
}

.gi-meta{
  left:50% !important;
  transform:translateX(-50%) !important;
}

@media(max-width:980px){
  .gi-signature-wrap{
    width:min(76vw, 760px) !important;
  }
  .gi-signature{
    width:min(46vw, 430px) !important;
    max-width:430px !important;
  }
  .gi-signature-wrap::before{
    width:min(38vw, 350px) !important;
    height:min(14vw, 120px) !important;
  }
}

@media(max-width:700px){
  .gi-signature-wrap{
    width:78vw !important;
  }
  .gi-signature{
    width:min(54vw, 280px) !important;
    max-width:280px !important;
  }
  .gi-signature-wrap::before{
    width:min(52vw, 220px) !important;
    height:min(18vw, 84px) !important;
  }
}


/* V53 - projets architecture + fashion show */
.projects-page-v53{background:#000!important;color:#f1eadf!important}
.projects-hero-v53 h1{max-width:10ch!important;color:#f1eadf!important}
.project-feature{display:grid;grid-template-columns:minmax(300px,.34fr) minmax(0,1fr);min-height:100vh;border-top:1px solid rgba(241,234,223,.14)}
.project-copy{position:sticky;top:96px;height:calc(100vh - 96px);align-self:start;padding:clamp(28px,3vw,52px);display:flex;flex-direction:column;justify-content:flex-end;gap:18px;border-right:1px solid rgba(241,234,223,.12);background:#000}
.project-copy span{color:rgba(241,234,223,.48);font-size:12px;letter-spacing:.22em}
.project-copy h2{margin:0;font-family:var(--font-heading);color:#f1eadf;text-transform:uppercase;font-size:clamp(54px,6vw,118px);line-height:.82;letter-spacing:.025em;max-width:8ch}
.project-copy p{max-width:39ch;margin:0;color:rgba(241,234,223,.78);font-size:clamp(16px,1.3vw,21px);line-height:1.55}
.project-copy ul{margin:8px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.project-copy li{color:rgba(241,234,223,.62);font-size:12px;letter-spacing:.13em;text-transform:uppercase;border-top:1px solid rgba(241,234,223,.12);padding-top:10px}
.project-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;background:rgba(241,234,223,.12)}
.project-image-card{margin:0;min-height:430px;background:#070707;position:relative;overflow:hidden}
.project-image-card:first-child{grid-column:span 2;min-height:640px}
.project-image-card:nth-child(5){grid-column:span 2;min-height:560px}
.project-image-card img{width:100%;height:100%;min-height:inherit;object-fit:cover;display:block;filter:saturate(.92) contrast(1.02);transition:transform .7s cubic-bezier(.2,.8,.2,1),filter .7s cubic-bezier(.2,.8,.2,1)}
.project-image-card:hover img{transform:scale(1.035);filter:saturate(1) contrast(1.08)}
.project-image-card figcaption{position:absolute;left:18px;bottom:18px;z-index:2;color:#f1eadf;font-size:11px;letter-spacing:.18em;text-transform:uppercase;background:rgba(0,0,0,.48);border:1px solid rgba(241,234,223,.14);border-radius:999px;padding:8px 11px;backdrop-filter:blur(10px)}
.project-next{padding:clamp(60px,8vw,140px) clamp(18px,3vw,48px);border-top:1px solid rgba(241,234,223,.14)}
.project-next p{margin:0;max-width:1040px;font-family:var(--font-display);color:#f1eadf;font-size:clamp(48px,7vw,118px);line-height:.9;letter-spacing:-.05em}
@media(max-width:1100px){.project-feature{grid-template-columns:1fr;min-height:auto}.project-copy{position:relative;top:auto;height:auto;border-right:0;border-bottom:1px solid rgba(241,234,223,.12)}.project-copy h2{max-width:none}}
@media(max-width:760px){.project-gallery{grid-template-columns:1fr}.project-image-card,.project-image-card:first-child,.project-image-card:nth-child(5){grid-column:auto;min-height:360px}.project-copy h2{font-size:clamp(46px,15vw,82px)}.project-next p{font-size:clamp(42px,13vw,78px)}}


/* V54 - intro sans textes + signature vectorisée plus petite */
.gi-meta,
.gi-kicker,
.gi-sub{
  display:none !important;
}

.gi-signature-scene{
  width:min(94vw, 1640px) !important;
  height:min(84vh, 980px) !important;
}

.gi-signature-wrap{
  position:relative;
  z-index:2;
  width:min(50vw, 760px) !important;
  display:grid;
  place-items:center;
  margin:0 auto;
  animation:giSigWrapIn 1s cubic-bezier(.76,0,.24,1) .16s both;
}

.gi-signature-wrap::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(28vw, 420px) !important;
  height:min(10vw, 130px) !important;
  border:1px solid rgba(241,234,223,.10);
  border-radius:999px;
  opacity:.45;
}

.gi-signature{
  position:relative;
  display:block;
  width:min(24vw, 340px) !important;
  max-width:340px !important;
  height:auto;
  margin:0 auto;
  filter:drop-shadow(0 8px 20px rgba(241,234,223,.08));
  clip-path:inset(0 100% 0 0);
  animation:giSignatureReveal .9s cubic-bezier(.76,0,.24,1) .34s forwards, giSignatureFloat 2.6s ease-in-out 1.4s infinite alternate;
}

@media(max-width:980px){
  .gi-signature-wrap{
    width:min(58vw, 560px) !important;
  }
  .gi-signature{
    width:min(30vw, 260px) !important;
    max-width:260px !important;
  }
  .gi-signature-wrap::before{
    width:min(34vw, 300px) !important;
    height:min(12vw, 100px) !important;
  }
}

@media(max-width:700px){
  .gi-signature-scene{
    height:58vh !important;
  }
  .gi-signature-wrap{
    width:64vw !important;
  }
  .gi-signature{
    width:min(40vw, 190px) !important;
    max-width:190px !important;
  }
  .gi-signature-wrap::before{
    width:min(50vw, 210px) !important;
    height:min(18vw, 76px) !important;
  }
}


/* V55 - fix footer overlap + stronger editorial home hero + spray dot */
.site-footer{
  display:grid !important;
  grid-template-columns:1fr auto auto !important;
  align-items:center !important;
  gap:18px !important;
  padding-left:clamp(126px, 11vw, 200px) !important;
}
.chaos-button{
  left:18px !important;
  bottom:18px !important;
  z-index:95 !important;
}
.footer-domain{
  white-space:nowrap;
}

.home-hero-v18{
  grid-template-columns:minmax(420px,.45fr) minmax(580px,.55fr) !important;
  gap:clamp(34px,4vw,82px) !important;
  align-items:center !important;
}
.home-copy-poster-v28{
  align-items:flex-start !important;
  text-align:left !important;
  padding-left:clamp(42px,4.5vw,98px) !important;
}
.hero-poster-text-v28{
  align-items:flex-start !important;
}
.poster-line-v28{
  position:relative;
  white-space:nowrap;
}
.poster-line-a{
  font-size:clamp(108px, 10.6vw, 176px) !important;
  margin-left:0 !important;
}
.poster-line-b{
  font-size:clamp(108px, 10.6vw, 176px) !important;
  margin-left:clamp(18px,1.8vw,42px) !important;
}
.poster-line-c{
  font-size:clamp(56px, 4.8vw, 82px) !important;
  margin:8px 0 0 clamp(126px,7vw,170px) !important;
}
.poster-line-d{
  font-size:clamp(104px, 9.8vw, 170px) !important;
  margin-top:-10px !important;
  margin-left:0 !important;
  display:inline-flex !important;
  align-items:flex-end !important;
  gap:clamp(10px,1vw,18px) !important;
}
.poster-spray-dot{
  width:clamp(40px, 3.8vw, 74px);
  height:auto;
  transform:translateY(-0.06em);
  filter:drop-shadow(0 4px 10px rgba(255,255,255,.08));
}
.poster-lead-v28{
  text-align:left !important;
  max-width:18ch !important;
  color:rgba(241,234,223,.76) !important;
}
.home-actions-v28{
  justify-content:flex-start !important;
}
.home-actions-v28 a{
  background:transparent !important;
  color:#f1eadf !important;
  border-color:rgba(241,234,223,.18) !important;
}
.home-actions-v28 a:first-child{
  background:#f1eadf !important;
  color:#111 !important;
}
.home-video-shell{
  clip-path:inset(0 round 40px 12px 40px 12px);
}
.tv-video-alone{
  width:100%;
  aspect-ratio:16 / 10;
  object-fit:cover;
  background:#000;
  border:1px solid rgba(241,234,223,.08);
  border-radius:32px 12px 32px 12px;
}
.sound-stable{
  right:22px !important;
  top:22px !important;
  border-color:rgba(241,234,223,.22) !important;
  background:rgba(0,0,0,.58) !important;
}
.sound-stable:hover{
  background:#f1eadf !important;
  color:#111 !important;
}

@media(max-width:1100px){
  .home-hero-v18{
    grid-template-columns:1fr !important;
  }
  .home-copy-poster-v28{
    align-items:center !important;
    text-align:center !important;
    padding-left:0 !important;
  }
  .hero-poster-text-v28{
    align-items:center !important;
  }
  .poster-line-b,
  .poster-line-c,
  .poster-line-d{
    margin-left:0 !important;
  }
  .poster-lead-v28{
    text-align:center !important;
    max-width:24ch !important;
  }
  .home-actions-v28{
    justify-content:center !important;
  }
  .site-footer{
    grid-template-columns:1fr !important;
    justify-items:start !important;
    padding-left:18px !important;
    padding-bottom:98px !important;
  }
}

@media(max-width:700px){
  .chaos-button{
    bottom:18px !important;
    left:14px !important;
    font-size:8px !important;
    padding:7px 9px !important;
  }
  .site-footer{
    padding-bottom:92px !important;
  }
}


/* V56 - finition éditoriale premium + stabilité traduction */
html[lang="en"] [data-en]{
  transition:opacity .18s ease;
}

.projects-page-v53 .project-copy h2,
.premium-cards article h2,
.process-list span{
  text-wrap:balance;
}

.project-gallery{
  align-items:stretch;
}

.project-image-card{
  border-radius:0;
}

.project-image-card:nth-child(2),
.project-image-card:nth-child(6){
  clip-path:inset(0 round 42px 0 0 0);
}

.project-image-card:nth-child(3),
.project-image-card:nth-child(7){
  clip-path:inset(0 round 0 42px 0 0);
}

@media(max-width:760px){
  .project-image-card,
  .project-image-card:nth-child(2),
  .project-image-card:nth-child(3),
  .project-image-card:nth-child(6),
  .project-image-card:nth-child(7){
    clip-path:none;
    border-radius:24px;
  }
}


/* V58 - home conforme au modèle + footer propre */
.home-hero-v58{grid-template-columns:minmax(430px,.44fr) minmax(600px,.56fr)!important;gap:clamp(42px,5vw,96px)!important;align-items:center!important;min-height:calc(100svh - 118px)!important;padding:clamp(36px,5vw,74px) clamp(18px,3vw,44px) clamp(70px,8vw,120px)!important}
.home-hero-v58::before{border-radius:48px 16px 48px 16px!important;border-color:rgba(241,234,223,.10)!important}
.home-copy-poster-v58{align-items:center!important;justify-content:center!important;text-align:center!important;min-height:auto!important;padding:0!important;max-width:none!important}
.home-copy-poster-v58 .poster-logo-link-v28{width:clamp(120px,11vw,210px)!important;height:clamp(120px,11vw,210px)!important;margin-bottom:clamp(8px,1.4vw,20px)!important}
.home-copy-poster-v58 .poster-logo-v28{width:66%!important;height:66%!important}
.hero-poster-text-v58{display:grid!important;justify-items:center!important;width:100%!important;text-align:center!important}
.hero-poster-text-v58 .poster-line{font-family:'League Spartan',Impact,sans-serif!important;font-weight:900!important;text-transform:uppercase!important;color:#fff!important;letter-spacing:-.065em!important;line-height:.82!important;white-space:nowrap!important}
.hero-poster-text-v58 .poster-line-a,.hero-poster-text-v58 .poster-line-b{font-size:clamp(94px,10.6vw,178px)!important}
.hero-poster-text-v58 .poster-line-c{font-size:clamp(48px,5vw,86px)!important;letter-spacing:-.055em!important;margin:clamp(18px,2vw,34px) 0!important}
.hero-poster-text-v58 .poster-line-d{font-size:clamp(94px,10.6vw,178px)!important;display:inline-flex!important;align-items:flex-end!important;gap:clamp(10px,1.2vw,20px)!important}
.poster-spray-dot{width:clamp(44px,4.4vw,82px)!important;height:auto!important;display:inline-block!important;object-fit:contain!important;transform:translateY(-.06em)!important;filter:drop-shadow(0 4px 10px rgba(255,255,255,.12))!important}
.home-copy-poster-v58 .poster-lead-v28{text-align:center!important;max-width:27ch!important;color:rgba(241,234,223,.78)!important}
.home-copy-poster-v58 .home-actions-v28{justify-content:center!important}
.home-video-shell-v58{position:relative!important;overflow:hidden!important;border:1px solid rgba(241,234,223,.12)!important;border-radius:48px 16px 48px 16px!important;background:#000!important;box-shadow:0 28px 90px rgba(0,0,0,.32)!important}
.home-video-shell-v58 .tv-video-alone{display:block!important;width:100%!important;aspect-ratio:16/10!important;min-height:520px!important;height:auto!important;object-fit:cover!important;background:#000!important;border:0!important;opacity:1!important}
body.hero-video-missing .home-video-shell-v58::before{content:"AJOUTE TA VIDÉO DANS assets/videos/hero-tv.mp4";position:absolute;inset:0;display:grid;place-items:center;padding:40px;text-align:center;z-index:3;color:rgba(241,234,223,.72);font-size:11px;letter-spacing:.22em;text-transform:uppercase;background:#000}
.home-video-shell-v58 figcaption{z-index:5!important;left:20px!important;right:20px!important;bottom:18px!important;color:#f1eadf!important}
.sound-stable{z-index:6!important}
.site-footer-v58{display:grid!important;grid-template-columns:1fr auto auto!important;align-items:center!important;gap:clamp(16px,2vw,32px)!important;min-height:94px!important;padding:24px clamp(130px,9vw,180px) 24px clamp(170px,11vw,240px)!important;background:#000!important;border-top:1px solid rgba(241,234,223,.16)!important;color:rgba(241,234,223,.72)!important}
.footer-brand,.footer-nav a,.footer-copy{font-size:12px!important;line-height:1!important;letter-spacing:.26em!important;text-transform:uppercase!important;color:rgba(241,234,223,.72)!important;white-space:nowrap!important}
.footer-nav{display:flex!important;flex-wrap:wrap!important;justify-content:center!important;gap:clamp(18px,2vw,34px)!important}
.footer-copy{justify-self:end!important}
.footer-brand:hover,.footer-nav a:hover{color:#f1eadf!important}
.chaos-button{left:18px!important;bottom:28px!important;z-index:120!important;background:rgba(0,0,0,.72)!important;color:#f1eadf!important;border-color:rgba(241,234,223,.28)!important;max-width:150px!important}
.back-top{right:28px!important;bottom:28px!important;z-index:119!important}
@media(max-width:1100px){.home-hero-v58{grid-template-columns:1fr!important;gap:36px!important}.home-video-shell-v58 .tv-video-alone{min-height:360px!important}.site-footer-v58{grid-template-columns:1fr!important;justify-items:start!important;padding:28px 18px 118px!important;gap:18px!important}.footer-nav{justify-content:flex-start!important}.footer-copy{justify-self:start!important}}
@media(max-width:700px){.hero-poster-text-v58 .poster-line-a,.hero-poster-text-v58 .poster-line-b,.hero-poster-text-v58 .poster-line-d{font-size:clamp(62px,17vw,96px)!important}.hero-poster-text-v58 .poster-line-c{font-size:clamp(34px,9vw,50px)!important;margin:18px 0!important}.poster-spray-dot{width:clamp(38px,10vw,56px)!important}.home-video-shell-v58 .tv-video-alone{min-height:280px!important}.footer-brand,.footer-nav a,.footer-copy{font-size:10px!important;letter-spacing:.18em!important}.chaos-button{left:14px!important;bottom:20px!important}.back-top{right:16px!important;bottom:20px!important}}


/* V59 - home, vidéo, projets, footer */
.home-hero-v59{grid-template-columns:minmax(460px,.44fr) minmax(580px,.56fr)!important;gap:clamp(42px,5vw,96px)!important;align-items:center!important;padding:clamp(34px,5vw,72px) clamp(18px,3vw,44px) clamp(76px,8vw,124px)!important;min-height:calc(100svh - 118px)!important}.home-copy-poster-v59{align-items:center!important;text-align:center!important;justify-content:center!important;max-width:none!important;min-height:auto!important;padding:0!important}.poster-logo-link-v59{width:clamp(300px,25vw,520px)!important;height:clamp(300px,25vw,520px)!important;border-radius:999px!important;border:1px solid rgba(241,234,223,.12)!important;margin-bottom:clamp(8px,1.3vw,20px)!important}.poster-logo-v59{width:70%!important;height:70%!important;object-fit:contain!important}.hero-poster-text-v59{display:grid!important;justify-items:center!important;width:100%!important}.hero-poster-text-v59 .poster-line{font-family:'League Spartan',Impact,sans-serif!important;font-weight:900!important;text-transform:uppercase!important;color:#fff!important;letter-spacing:-.065em!important;line-height:.82!important;white-space:nowrap!important}.hero-poster-text-v59 .line-dont,.hero-poster-text-v59 .line-panic,.hero-poster-text-v59 .line-doart{font-size:clamp(92px,10.2vw,178px)!important}.hero-poster-text-v59 .line-and{font-size:clamp(48px,5vw,86px)!important;margin:clamp(18px,2vw,34px) 0!important}.hero-poster-text-v59 .line-doart{display:inline-flex!important;align-items:flex-end!important;gap:clamp(10px,1.2vw,20px)!important}.poster-spray-dot{width:clamp(44px,4.5vw,84px)!important;display:inline-block!important;transform:translateY(-.04em)!important}.poster-lead-v59{text-align:center!important;max-width:28ch!important;color:rgba(241,234,223,.78)!important}.home-actions-v59{justify-content:center!important;gap:12px!important}.home-video-shell-v59{position:relative!important;overflow:hidden!important;background:#000!important;border:1px solid rgba(241,234,223,.13)!important;border-radius:48px 16px 48px 16px!important;box-shadow:0 30px 90px rgba(0,0,0,.34)!important}.home-video-shell-v59 .tv-video-alone{width:100%!important;display:block!important;aspect-ratio:16/10!important;min-height:520px!important;height:auto!important;object-fit:cover!important;background:#000!important}.site-footer-v59{display:grid!important;grid-template-columns:1fr auto auto!important;align-items:center!important;gap:clamp(16px,2vw,32px)!important;min-height:98px!important;padding:24px clamp(140px,9vw,190px) 24px clamp(190px,12vw,260px)!important;background:#000!important;border-top:1px solid rgba(241,234,223,.16)!important}.footer-brand,.footer-nav a,.footer-copy{color:rgba(241,234,223,.72)!important;font-size:12px!important;letter-spacing:.24em!important;text-transform:uppercase!important;white-space:nowrap!important}.footer-nav{display:flex!important;flex-wrap:wrap!important;gap:clamp(18px,2vw,34px)!important;justify-content:center!important}.footer-copy{justify-self:end!important}.chaos-button{left:18px!important;bottom:30px!important;z-index:120!important;max-width:160px!important}.back-top{right:30px!important;bottom:30px!important;z-index:119!important}.projects-page-v59{background:#000!important;color:#f1eadf!important}.projects-intro-v59{min-height:72svh;display:grid;align-content:end;padding:clamp(70px,8vw,130px) clamp(18px,3vw,48px) clamp(50px,6vw,90px);border-bottom:1px solid rgba(241,234,223,.14)}.projects-intro-v59 h1{font-family:var(--font-display);max-width:11ch;font-size:clamp(64px,9vw,148px);line-height:.88;letter-spacing:-.055em;color:#f1eadf}.projects-intro-v59 .lead{max-width:720px}.project-editorial{display:grid;grid-template-columns:minmax(320px,.32fr) minmax(0,1fr);border-bottom:1px solid rgba(241,234,223,.14)}.project-text-panel{position:sticky;top:92px;height:calc(100svh - 92px);padding:clamp(28px,3vw,52px);display:flex;flex-direction:column;justify-content:flex-end;gap:18px;border-right:1px solid rgba(241,234,223,.12);background:#000}.project-text-panel span{color:rgba(241,234,223,.48);font-size:12px;letter-spacing:.22em}.project-text-panel h2{font-family:var(--font-heading);color:#f1eadf;font-size:clamp(46px,5.4vw,104px);line-height:.86;letter-spacing:.02em;text-transform:uppercase;max-width:9ch;overflow-wrap:normal;word-break:normal;hyphens:none}.project-text-panel p{color:rgba(241,234,223,.78);line-height:1.58;font-size:clamp(16px,1.25vw,20px);max-width:39ch}.project-text-panel ul{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:10px}.project-text-panel li{border-top:1px solid rgba(241,234,223,.12);padding-top:10px;color:rgba(241,234,223,.64);text-transform:uppercase;letter-spacing:.13em;font-size:12px}.project-mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(170px,13vw);gap:12px;padding:clamp(18px,2vw,32px)}.project-card{margin:0;position:relative;overflow:hidden;background:#080808;border:1px solid rgba(241,234,223,.10);border-radius:28px}.project-card-1{grid-column:span 4;grid-row:span 3;border-radius:44px 14px 44px 14px}.project-card-2{grid-column:span 2;grid-row:span 2}.project-card-3{grid-column:span 2;grid-row:span 2;border-radius:14px 44px 14px 44px}.project-card-4,.project-card-5,.project-card-6{grid-column:span 2;grid-row:span 2}.project-card img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.94) contrast(1.04)}.project-card figcaption{position:absolute;left:14px;bottom:14px;background:rgba(0,0,0,.54);color:#f1eadf;border:1px solid rgba(241,234,223,.16);border-radius:999px;padding:8px 11px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;backdrop-filter:blur(10px)}@media(max-width:1100px){.home-hero-v59{grid-template-columns:1fr!important}.poster-logo-link-v59{width:clamp(220px,38vw,360px)!important;height:clamp(220px,38vw,360px)!important}.home-video-shell-v59 .tv-video-alone{min-height:360px!important}.site-footer-v59{grid-template-columns:1fr!important;justify-items:start!important;padding:28px 18px 118px!important}.footer-nav{justify-content:flex-start!important}.footer-copy{justify-self:start!important}.project-editorial{grid-template-columns:1fr}.project-text-panel{position:relative;top:auto;height:auto;border-right:0;border-bottom:1px solid rgba(241,234,223,.12)}.project-text-panel h2{max-width:none}}@media(max-width:700px){.hero-poster-text-v59 .line-dont,.hero-poster-text-v59 .line-panic,.hero-poster-text-v59 .line-doart{font-size:clamp(58px,16vw,92px)!important}.hero-poster-text-v59 .line-and{font-size:clamp(34px,9vw,48px)!important;margin:18px 0!important}.poster-logo-link-v59{width:190px!important;height:190px!important}.poster-spray-dot{width:clamp(34px,10vw,54px)!important}.home-video-shell-v59 .tv-video-alone{min-height:280px!important}.footer-brand,.footer-nav a,.footer-copy{font-size:10px!important;letter-spacing:.18em!important}.chaos-button{left:14px!important;bottom:22px!important}.back-top{right:16px!important;bottom:22px!important}.projects-intro-v59 h1{font-size:clamp(48px,14vw,86px)}.project-mosaic{grid-template-columns:1fr;grid-auto-rows:auto}.project-card,.project-card-1,.project-card-2,.project-card-3,.project-card-4,.project-card-5,.project-card-6{grid-column:auto;grid-row:auto;min-height:320px;border-radius:24px}}


/* V61 - suppression écran noir */
.graphic-intro,
.welcome-intro,
.intro-overlay{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

body{
  background:#000 !important;
}

/* V61 - home */
.poster-logo-link-v59{
  width:clamp(300px,25vw,520px) !important;
  height:clamp(300px,25vw,520px) !important;
}

.poster-spray-dot-wrap{
  display:inline-flex !important;
  align-items:flex-end !important;
  justify-content:flex-start !important;
  width:clamp(42px,4.8vw,88px) !important;
  height:clamp(54px,6.2vw,112px) !important;
  margin-left:clamp(4px,.7vw,12px) !important;
  overflow:visible !important;
}

.poster-spray-dot{
  display:block !important;
  width:100% !important;
  height:auto !important;
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  object-fit:contain !important;
  filter:drop-shadow(0 4px 10px rgba(255,255,255,.12)) !important;
}

/* V61 - projets éditoriaux lisibles */
.projects-page-v61{
  background:#000 !important;
  color:#f1eadf !important;
}

.projects-intro-v61{
  padding:clamp(78px,8vw,132px) clamp(18px,3vw,48px) clamp(48px,6vw,88px) !important;
  border-bottom:1px solid rgba(241,234,223,.14);
}

.projects-intro-v61 h1{
  margin:0 0 20px !important;
  max-width:12ch !important;
  color:#f1eadf !important;
  font-family:var(--font-display);
  font-size:clamp(54px,8.6vw,136px);
  line-height:.9;
  letter-spacing:-.055em;
}

.projects-intro-v61 .lead{
  max-width:760px !important;
  color:rgba(241,234,223,.78) !important;
}

.project-block-v61{
  padding:clamp(28px,4vw,58px) clamp(18px,3vw,48px) clamp(46px,5vw,78px);
  border-bottom:1px solid rgba(241,234,223,.14);
}

.project-header-v61{
  display:grid;
  grid-template-columns:64px minmax(320px,.95fr) minmax(320px,1.05fr);
  gap:clamp(18px,3vw,44px);
  align-items:end;
  margin-bottom:clamp(24px,3vw,44px);
}

.project-number{
  color:rgba(241,234,223,.52);
  font-size:12px;
  letter-spacing:.22em;
  align-self:start;
  padding-top:10px;
}

.project-header-v61 h2{
  margin:0 !important;
  color:#f1eadf !important;
  font-family:var(--font-heading) !important;
  text-transform:uppercase !important;
  line-height:.88 !important;
  letter-spacing:.02em !important;
  max-width:none !important;
  overflow:visible !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  hyphens:none !important;
}

.project-header-v61 h2 span,
.project-header-v61 h2 em{
  display:block;
  font-style:normal;
  white-space:nowrap;
}

.project-header-v61 h2 span{
  font-size:clamp(58px,7.6vw,126px) !important;
}

.project-header-v61 h2 em{
  font-size:clamp(38px,4.8vw,78px) !important;
}

.project-copy-v61 p{
  margin:0;
  max-width:34ch;
  color:rgba(241,234,223,.82);
  font-size:clamp(18px,1.8vw,28px);
  line-height:1.38;
}

.project-copy-v61 ul{
  list-style:none;
  margin:18px 0 0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}

.project-copy-v61 li{
  border-top:1px solid rgba(241,234,223,.14);
  padding-top:10px;
  color:rgba(241,234,223,.62);
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:11px;
  line-height:1.3;
}

.project-mosaic-v61{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-auto-rows:minmax(140px,12vw);
  gap:14px;
}

.project-mosaic-v61 .project-card{
  margin:0;
  position:relative;
  overflow:hidden;
  background:#080808;
  border:1px solid rgba(241,234,223,.10);
  border-radius:28px;
}

.project-mosaic-v61 .project-card-1{
  grid-column:span 7;
  grid-row:span 4;
  border-radius:44px 14px 44px 14px;
}

.project-mosaic-v61 .project-card-2,
.project-mosaic-v61 .project-card-3{
  grid-column:span 5;
  grid-row:span 2;
}

.project-mosaic-v61 .project-card-3{
  border-radius:14px 44px 14px 44px;
}

.project-mosaic-v61 .project-card-4,
.project-mosaic-v61 .project-card-5,
.project-mosaic-v61 .project-card-6{
  grid-column:span 4;
  grid-row:span 2;
}

.project-mosaic-v61 img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  filter:saturate(.94) contrast(1.04);
}

.project-mosaic-v61 figcaption{
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:2;
  background:rgba(0,0,0,.52);
  color:#f1eadf;
  border:1px solid rgba(241,234,223,.16);
  border-radius:999px;
  padding:8px 10px;
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  backdrop-filter:blur(10px);
}

@media(max-width:1100px){
  .project-header-v61{
    grid-template-columns:1fr;
    align-items:start;
  }

  .project-copy-v61 ul{
    grid-template-columns:1fr;
  }

  .project-mosaic-v61{
    grid-template-columns:repeat(2,1fr);
    grid-auto-rows:minmax(220px,30vw);
  }

  .project-mosaic-v61 .project-card-1,
  .project-mosaic-v61 .project-card-2,
  .project-mosaic-v61 .project-card-3,
  .project-mosaic-v61 .project-card-4,
  .project-mosaic-v61 .project-card-5,
  .project-mosaic-v61 .project-card-6{
    grid-column:auto;
    grid-row:auto;
  }
}

@media(max-width:700px){
  .poster-logo-link-v59{
    width:190px !important;
    height:190px !important;
  }

  .project-header-v61 h2 span{
    font-size:clamp(46px,13vw,76px) !important;
    white-space:normal;
  }

  .project-header-v61 h2 em{
    font-size:clamp(30px,9vw,46px) !important;
  }

  .project-mosaic-v61{
    grid-template-columns:1fr;
    grid-auto-rows:auto;
  }

  .project-mosaic-v61 .project-card{
    min-height:300px;
    border-radius:24px !important;
  }
}


/* V62 - home poster image, no TV frame, reduced top space, sound fixed */
main{padding-top:82px!important}
.home-hero-v59{padding-top:0!important;min-height:calc(100svh - 82px)!important;align-items:center!important}
.home-copy-poster-v59{padding-top:0!important}
.poster-logo-link-v59{width:clamp(300px,24vw,500px)!important;height:clamp(300px,24vw,500px)!important;margin-bottom:clamp(0px,.6vw,8px)!important}
.hero-poster-image-v62{width:min(100%,720px);margin:0 auto;display:grid;place-items:center;background:#000}
.hero-poster-image-v62 img{width:100%;height:auto;display:block;object-fit:contain;filter:contrast(1.04) brightness(1.02)}
.home-video-shell-v59{border:0!important;border-radius:0!important;box-shadow:none!important;background:transparent!important;overflow:visible!important}
.home-video-shell-v59::before,.home-video-shell-v59::after{display:none!important;content:none!important}
.home-video-shell-v59 .tv-video-alone{border:0!important;border-radius:0!important;box-shadow:none!important;background:#000!important;min-height:480px!important;object-fit:contain!important;aspect-ratio:4/3!important}
.home-video-shell-v59 figcaption{bottom:8px!important;left:8px!important;right:8px!important}
.sound-stable{top:16px!important;right:16px!important;background:rgba(0,0,0,.58)!important}
@media(max-width:1100px){main{padding-top:88px!important}.home-hero-v59{padding-top:0!important}.home-video-shell-v59 .tv-video-alone{min-height:340px!important}.poster-logo-link-v59{width:clamp(200px,34vw,340px)!important;height:clamp(200px,34vw,340px)!important}.hero-poster-image-v62{width:min(100%,620px)}}
@media(max-width:700px){main{padding-top:74px!important}.home-hero-v59{padding-top:0!important}.home-video-shell-v59 .tv-video-alone{min-height:260px!important}.poster-logo-link-v59{width:170px!important;height:170px!important}.hero-poster-image-v62{width:min(100%,430px)}}


/* V63 - volume icon white, home spacing tighter, projects header fixed */
.home-hero-v59{padding:clamp(12px,2vw,28px) clamp(18px,3vw,44px) clamp(54px,6vw,92px)!important;min-height:calc(100svh - 96px)!important;align-items:start!important;gap:clamp(30px,4vw,70px)!important}
.home-copy-poster-v59{align-self:start!important;padding-top:0!important}
.poster-logo-link-v59{width:clamp(360px,28vw,620px)!important;height:clamp(360px,28vw,620px)!important;margin-bottom:clamp(2px,.5vw,10px)!important}
.hero-poster-image-v62{width:min(100%,760px)!important;margin-top:-6px!important}
.home-video-shell-v59{align-self:start!important;margin-top:18px!important}
.home-video-shell-v59 .tv-video-alone{min-height:420px!important;max-height:72svh!important;aspect-ratio:4/3!important;object-fit:contain!important}
.sound-stable{top:8px!important;right:8px!important;min-width:146px!important;height:54px!important;padding:0 16px!important;gap:10px!important;border:1px solid rgba(241,234,223,.28)!important;background:rgba(0,0,0,.58)!important;box-shadow:0 10px 28px rgba(0,0,0,.32)!important}
.sound-stable-icon{display:block!important;width:28px!important;height:28px!important;flex:0 0 28px!important;object-fit:contain!important;filter:none!important}
.sound-stable-icon-on{display:none!important}
.sound-stable.is-on .sound-stable-icon-off{display:none!important}
.sound-stable.is-on .sound-stable-icon-on{display:block!important}
.sound-stable::before,.sound-stable::after,.sound-stable .sound-stable-icon::before,.sound-stable .sound-stable-icon::after{content:none!important;display:none!important}
.sound-stable-text{font-size:11px!important;letter-spacing:.15em!important}
.home-video-shell-v59 figcaption{left:0!important;right:0!important;bottom:-4px!important;padding-inline:0!important}
@media(max-width:1100px){.home-hero-v59{padding-top:8px!important;gap:28px!important}.poster-logo-link-v59{width:clamp(230px,42vw,420px)!important;height:clamp(230px,42vw,420px)!important}.hero-poster-image-v62{width:min(100%,680px)!important}.home-video-shell-v59{margin-top:0!important}.home-video-shell-v59 .tv-video-alone{min-height:320px!important;max-height:none!important}.sound-stable{top:6px!important;right:6px!important}}
@media(max-width:700px){.home-hero-v59{padding-top:0!important;padding-bottom:34px!important}.poster-logo-link-v59{width:220px!important;height:220px!important}.hero-poster-image-v62{width:min(100%,520px)!important}.home-video-shell-v59 .tv-video-alone{min-height:240px!important}.sound-stable{min-width:120px!important;height:46px!important;padding:0 12px!important;top:4px!important;right:4px!important}.sound-stable-icon{width:24px!important;height:24px!important;flex-basis:24px!important}}

.project-header-v61{grid-template-columns:52px minmax(0,1.1fr) minmax(280px,.9fr)!important;gap:clamp(14px,2.2vw,30px)!important;align-items:start!important;margin-bottom:clamp(22px,2.5vw,34px)!important}
.project-header-v61 > div:first-of-type{min-width:0!important}
.project-header-v61 h2{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:0!important;max-width:none!important}
.project-header-v61 h2 span,.project-header-v61 h2 em{display:block!important;white-space:nowrap!important;word-break:keep-all!important;overflow-wrap:normal!important;hyphens:none!important;text-wrap:nowrap!important}
.project-header-v61 h2 span{font-size:clamp(50px,6.5vw,108px)!important;line-height:.88!important}
.project-header-v61 h2 em{font-size:clamp(34px,4.1vw,58px)!important;line-height:.92!important;margin-top:4px!important}
.project-copy-v61 p{font-size:clamp(16px,1.5vw,22px)!important;line-height:1.48!important;max-width:30ch!important}
.project-copy-v61 ul{margin-top:14px!important}
.project-copy-v61 li{font-size:10px!important;letter-spacing:.14em!important}
.project-mosaic-v61{gap:12px!important}
.project-mosaic-v61 .project-card{border-radius:24px!important}
.project-mosaic-v61 .project-card-1{border-radius:38px 14px 38px 14px!important}
.project-mosaic-v61 .project-card-3{border-radius:14px 38px 14px 38px!important}
@media(max-width:1100px){.project-header-v61{grid-template-columns:1fr!important;gap:12px!important}.project-number{padding-top:0!important}.project-header-v61 h2 span{font-size:clamp(46px,9vw,82px)!important}.project-header-v61 h2 em{font-size:clamp(28px,6vw,44px)!important}.project-copy-v61 p{max-width:44ch!important}.project-copy-v61 ul{grid-template-columns:repeat(3,minmax(0,1fr))!important}}
@media(max-width:700px){.project-block-v61{padding:24px 16px 38px!important}.project-header-v61 h2 span{font-size:clamp(36px,10.6vw,52px)!important;white-space:nowrap!important}.project-header-v61 h2 em{font-size:clamp(22px,6.4vw,30px)!important}.project-copy-v61 p{font-size:16px!important;max-width:none!important}.project-copy-v61 ul{grid-template-columns:1fr!important;gap:10px!important}.project-mosaic-v61 .project-card{min-height:260px!important}}


/* V64 - intro lignes, home video full, oeuvres title single line */
body.intro-lock{overflow:hidden!important}
.intro-lines-v64{position:fixed!important;inset:0!important;z-index:9999!important;background:#000!important;display:block!important;opacity:1!important;visibility:visible!important;transition:opacity .65s ease, visibility .65s ease!important;pointer-events:none!important;overflow:hidden!important}
.intro-lines-v64.off{opacity:0!important;visibility:hidden!important}
.intro-lines-wrap{position:absolute!important;inset:0!important}
.intro-stroke{position:absolute!important;display:block!important;height:2px!important;background:#fff!important;opacity:0;transform-origin:left center;will-change:transform,opacity}
.intro-lines-v64.is-on .intro-stroke{animation:cbLineSweep 1.15s cubic-bezier(.22,.61,.36,1) forwards}
.intro-stroke.s1{top:16%;left:-8%;width:46vw;animation-delay:.02s}.intro-stroke.s2{top:28%;right:-12%;width:38vw;animation-delay:.08s}.intro-stroke.s3{top:42%;left:-14%;width:54vw;animation-delay:.14s}.intro-stroke.s4{top:58%;right:-10%;width:42vw;animation-delay:.20s}.intro-stroke.s5{top:72%;left:-8%;width:46vw;animation-delay:.26s}.intro-stroke.s6{top:85%;right:-14%;width:52vw;animation-delay:.32s}.intro-stroke.s7{top:8%;left:42%;width:2px;height:44vh!important;animation:cbLineSweepVertical 1.15s cubic-bezier(.22,.61,.36,1) forwards;animation-delay:.18s}.intro-stroke.s8{top:24%;left:66%;width:2px;height:34vh!important;animation:cbLineSweepVertical 1.15s cubic-bezier(.22,.61,.36,1) forwards;animation-delay:.28s}
@keyframes cbLineSweep{0%{opacity:0;transform:translateX(0) scaleX(0)}18%{opacity:1}58%{opacity:1;transform:translateX(18vw) scaleX(1)}100%{opacity:0;transform:translateX(34vw) scaleX(.16)}}
@keyframes cbLineSweepVertical{0%{opacity:0;transform:translateY(-6vh) scaleY(0)}18%{opacity:1}58%{opacity:1;transform:translateY(6vh) scaleY(1)}100%{opacity:0;transform:translateY(16vh) scaleY(.12)}}

.home-video-shell-v59{align-self:start!important;margin-top:-12px!important;overflow:visible!important}
.home-video-shell-v59 .tv-video-alone{display:block!important;width:100%!important;height:auto!important;min-height:0!important;max-height:76svh!important;aspect-ratio:auto!important;object-fit:contain!important;background:#000!important}
.home-video-shell-v59 figcaption{position:absolute!important;left:14px!important;right:14px!important;bottom:12px!important;z-index:6!important;display:flex!important;justify-content:space-between!important;align-items:center!important;gap:12px!important;padding:10px 12px!important;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.46))!important;border-radius:999px!important;color:#f1eadf!important;white-space:nowrap!important}
.sound-stable{top:-18px!important;right:0!important;z-index:7!important}
@media(max-width:1100px){.home-video-shell-v59{margin-top:-8px!important}.home-video-shell-v59 .tv-video-alone{max-height:none!important}.sound-stable{top:-12px!important;right:0!important}}
@media(max-width:700px){.home-video-shell-v59{margin-top:-4px!important}.home-video-shell-v59 figcaption{left:10px!important;right:10px!important;bottom:10px!important;font-size:10px!important}.sound-stable{top:-10px!important;right:0!important}}

.section-title{grid-template-columns:56px minmax(520px,.95fr) minmax(280px,1fr)!important;align-items:end!important}
.section-title h2{font-size:clamp(46px,6.4vw,108px)!important;line-height:.9!important;white-space:nowrap!important;overflow-wrap:normal!important;word-break:keep-all!important;hyphens:none!important}
.section-title p{font-size:clamp(15px,1.8vw,22px)!important;max-width:26ch!important;justify-self:end!important}
@media(max-width:1100px){.section-title{grid-template-columns:1fr!important;gap:14px!important}.section-title h2{white-space:normal!important;font-size:clamp(40px,8.5vw,72px)!important}.section-title p{justify-self:start!important;max-width:none!important}}


/* V65 - intro graphique élégante avec cercles et barre transversale */
body.intro-lock{
  overflow:hidden !important;
}

.intro-lines-v65{
  position:fixed !important;
  inset:0 !important;
  z-index:9999 !important;
  background:#000 !important;
  display:block !important;
  opacity:1 !important;
  visibility:visible !important;
  pointer-events:auto !important;
  overflow:hidden !important;
  transition:opacity .65s ease, visibility .65s ease !important;
}

.intro-lines-v65.off{
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

.intro-lines-v65 .intro-lines-wrap{
  position:absolute !important;
  inset:0 !important;
}

.intro-lines-v65 .intro-stroke,
.intro-lines-v65 .intro-crossbar{
  position:absolute !important;
  display:block !important;
  height:2px !important;
  background:#f1eadf !important;
  opacity:0;
  transform-origin:left center;
}

.intro-lines-v65 .intro-circle{
  position:absolute !important;
  display:block !important;
  border:1px solid rgba(241,234,223,.42) !important;
  border-radius:999px !important;
  opacity:0;
  transform:scale(.7) rotate(-12deg);
}

.intro-lines-v65 .s1{top:18%;left:-12%;width:50vw}
.intro-lines-v65 .s2{top:32%;right:-14%;width:42vw}
.intro-lines-v65 .s3{top:50%;left:-10%;width:62vw}
.intro-lines-v65 .s4{top:66%;right:-12%;width:48vw}
.intro-lines-v65 .s5{top:80%;left:-16%;width:55vw}
.intro-lines-v65 .s6{top:10%;right:18%;width:28vw}

.intro-lines-v65 .c1{
  width:34vmin;
  height:34vmin;
  left:14%;
  top:20%;
}

.intro-lines-v65 .c2{
  width:52vmin;
  height:52vmin;
  right:12%;
  top:18%;
}

.intro-lines-v65 .c3{
  width:74vmin;
  height:74vmin;
  left:50%;
  top:50%;
  margin-left:-37vmin;
  margin-top:-37vmin;
  border-color:rgba(241,234,223,.18) !important;
}

.intro-lines-v65 .intro-crossbar{
  width:128vw !important;
  left:-14vw !important;
  top:52% !important;
  transform:rotate(-18deg) scaleX(0);
  height:2px !important;
}

.intro-lines-v65.is-on .intro-stroke{
  animation:cbIntroLineV65 1.15s cubic-bezier(.22,.61,.36,1) forwards;
}

.intro-lines-v65.is-on .s1{animation-delay:.02s}
.intro-lines-v65.is-on .s2{animation-delay:.08s}
.intro-lines-v65.is-on .s3{animation-delay:.14s}
.intro-lines-v65.is-on .s4{animation-delay:.20s}
.intro-lines-v65.is-on .s5{animation-delay:.26s}
.intro-lines-v65.is-on .s6{animation-delay:.32s}

.intro-lines-v65.is-on .intro-circle{
  animation:cbIntroCircleV65 1.35s cubic-bezier(.22,.61,.36,1) forwards;
}

.intro-lines-v65.is-on .c1{animation-delay:.05s}
.intro-lines-v65.is-on .c2{animation-delay:.16s}
.intro-lines-v65.is-on .c3{animation-delay:.28s}

.intro-lines-v65.is-on .intro-crossbar{
  animation:cbIntroCrossV65 1.25s cubic-bezier(.22,.61,.36,1) .34s forwards;
}

@keyframes cbIntroLineV65{
  0%{opacity:0;transform:translateX(0) scaleX(0)}
  18%{opacity:1}
  62%{opacity:1;transform:translateX(18vw) scaleX(1)}
  100%{opacity:0;transform:translateX(38vw) scaleX(.08)}
}

@keyframes cbIntroCircleV65{
  0%{opacity:0;transform:scale(.72) rotate(-18deg)}
  35%{opacity:.75}
  70%{opacity:.55;transform:scale(1) rotate(0)}
  100%{opacity:0;transform:scale(1.12) rotate(8deg)}
}

@keyframes cbIntroCrossV65{
  0%{opacity:0;transform:rotate(-18deg) translateX(-12vw) scaleX(0)}
  22%{opacity:1}
  68%{opacity:1;transform:rotate(-18deg) translateX(0) scaleX(1)}
  100%{opacity:0;transform:rotate(-18deg) translateX(18vw) scaleX(.12)}
}

/* V65 - vraie vidéo sans logo en fallback */
.home-video-shell-v59 .tv-video-alone{
  background:#000 !important;
  object-fit:contain !important;
}

.home-video-shell-v59 .tv-video-alone[poster]{
  background:#000 !important;
}

.home-video-shell-v59{
  background:transparent !important;
}

@media(max-width:700px){
  .intro-lines-v65 .c1{left:4%;top:24%}
  .intro-lines-v65 .c2{right:0;top:18%}
  .intro-lines-v65 .c3{width:88vmin;height:88vmin;margin-left:-44vmin;margin-top:-44vmin}
}


/* V66 - vidéo entière + bouton son hors TV */
.home-hero-v59{
  position:relative !important;
  overflow:visible !important;
  align-items:flex-start !important;
}

.home-video-shell-v59{
  position:relative !important;
  overflow:visible !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  margin-top:0 !important;
  padding:0 !important;
  align-self:start !important;
}

.home-video-shell-v59::before,
.home-video-shell-v59::after{
  display:none !important;
  content:none !important;
}

.home-video-shell-v59 .tv-video-alone{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  min-height:0 !important;
  max-height:none !important;
  aspect-ratio:auto !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:transparent !important;
  border:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  clip-path:none !important;
}

.home-video-shell-v59 figcaption{
  position:absolute !important;
  left:0 !important;
  right:0 !important;
  bottom:6px !important;
  z-index:4 !important;
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  padding:0 clamp(6px,1vw,14px) !important;
  background:transparent !important;
  border:0 !important;
  color:#f1eadf !important;
  border-radius:0 !important;
  white-space:nowrap !important;
  pointer-events:none !important;
}

#soundStableButton.sound-stable{
  position:absolute !important;
  top:clamp(12px,2.2vw,34px) !important;
  right:clamp(18px,3vw,46px) !important;
  z-index:80 !important;
  overflow:visible !important;
  transform:none !important;
  min-width:150px !important;
  height:56px !important;
  padding:0 16px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:10px !important;
  border-radius:999px !important;
  border:1px solid rgba(241,234,223,.30) !important;
  background:rgba(0,0,0,.66) !important;
  backdrop-filter:blur(12px) !important;
  color:#f1eadf !important;
  box-shadow:none !important;
  cursor:pointer !important;
}

#soundStableButton .sound-stable-icon{
  width:28px !important;
  height:28px !important;
  flex:0 0 28px !important;
  display:block !important;
  object-fit:contain !important;
}

#soundStableButton .sound-stable-icon-on{
  display:none !important;
}

#soundStableButton.is-on .sound-stable-icon-off{
  display:none !important;
}

#soundStableButton.is-on .sound-stable-icon-on{
  display:block !important;
}

#soundStableButton::before,
#soundStableButton::after,
#soundStableButton .sound-stable-icon::before,
#soundStableButton .sound-stable-icon::after{
  display:none !important;
  content:none !important;
}

#soundStableButton .sound-stable-text{
  font-size:11px !important;
  letter-spacing:.15em !important;
  white-space:nowrap !important;
}

@media(max-width:1100px){
  #soundStableButton.sound-stable{
    top:10px !important;
    right:18px !important;
  }

  .home-video-shell-v59 .tv-video-alone{
    width:100% !important;
    max-height:none !important;
  }
}

@media(max-width:700px){
  #soundStableButton.sound-stable{
    top:8px !important;
    right:12px !important;
    min-width:118px !important;
    height:46px !important;
    padding:0 11px !important;
  }

  #soundStableButton .sound-stable-icon{
    width:23px !important;
    height:23px !important;
    flex-basis:23px !important;
  }

  #soundStableButton .sound-stable-text{
    font-size:9px !important;
    letter-spacing:.12em !important;
  }
}


/* V67 final tweaks */
#soundStableButton.sound-stable{
  top: clamp(4px, 1.2vw, 16px) !important;
  right: clamp(18px, 3vw, 46px) !important;
}
@media(max-width:1100px){
  #soundStableButton.sound-stable{ top: 2px !important; right: 16px !important; }
}
@media(max-width:700px){
  #soundStableButton.sound-stable{ top: 0 !important; right: 10px !important; }
}


/* V69 cookie banner */
.cookie-banner-v69{
  position:fixed;
  left:clamp(16px,2vw,28px);
  right:clamp(16px,2vw,28px);
  bottom:clamp(76px,6vw,96px);
  z-index:300;
  display:flex;
  justify-content:center;
  pointer-events:none;
  animation:cookieInV69 .38s cubic-bezier(.22,.61,.36,1) both;
}

.cookie-banner-v69.is-hiding{
  animation:cookieOutV69 .28s ease both;
}

.cookie-banner-inner-v69{
  width:min(760px,100%);
  pointer-events:auto;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:clamp(14px,2vw,24px);
  padding:14px 14px 14px 18px;
  border:1px solid rgba(241,234,223,.18);
  border-radius:999px;
  background:rgba(0,0,0,.78);
  color:#f1eadf;
  backdrop-filter:blur(18px);
  box-shadow:0 18px 60px rgba(0,0,0,.38);
}

.cookie-title-v69{
  margin:0;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#f1eadf;
}

.cookie-text-v69{
  margin:0;
  font-size:12px;
  line-height:1.4;
  color:rgba(241,234,223,.72);
}

.cookie-actions-v69{
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
}

.cookie-actions-v69 a,
.cookie-actions-v69 button{
  appearance:none;
  border:1px solid rgba(241,234,223,.22);
  border-radius:999px;
  background:transparent;
  color:#f1eadf;
  font:inherit;
  font-size:10px;
  line-height:1;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:10px 12px;
  cursor:pointer;
}

.cookie-actions-v69 button{
  background:#f1eadf;
  color:#050505;
  border-color:#f1eadf;
}

.cookie-actions-v69 a:hover{
  border-color:rgba(241,234,223,.58);
}

.cookie-actions-v69 button:hover{
  opacity:.86;
}

@keyframes cookieInV69{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes cookieOutV69{
  from{opacity:1;transform:translateY(0)}
  to{opacity:0;transform:translateY(18px)}
}

@media(max-width:760px){
  .cookie-banner-v69{
    bottom:78px;
  }

  .cookie-banner-inner-v69{
    grid-template-columns:1fr;
    border-radius:24px;
    padding:16px;
    gap:12px;
  }

  .cookie-actions-v69{
    justify-content:space-between;
    width:100%;
  }
}


/* V70 cookie preferences */
.cookie-banner-v69{
  display:none !important;
}

.cookie-panel-v70{
  position:fixed;
  left:clamp(16px,2vw,28px);
  right:clamp(16px,2vw,28px);
  bottom:clamp(78px,6vw,98px);
  z-index:320;
  display:flex;
  justify-content:center;
  pointer-events:none;
  animation:cookieInV70 .38s cubic-bezier(.22,.61,.36,1) both;
}

.cookie-panel-v70.is-hiding{
  animation:cookieOutV70 .28s ease both;
}

.cookie-card-v70{
  width:min(940px,100%);
  pointer-events:auto;
  display:grid;
  grid-template-columns:minmax(280px,1fr) auto;
  align-items:center;
  gap:clamp(14px,2vw,24px);
  padding:16px;
  border:1px solid rgba(241,234,223,.18);
  border-radius:28px;
  background:rgba(0,0,0,.82);
  color:#f1eadf;
  backdrop-filter:blur(18px);
  box-shadow:0 18px 60px rgba(0,0,0,.38);
}

.cookie-card-prefs-v70{
  grid-template-columns:1fr;
  width:min(760px,100%);
}

.cookie-main-v70{
  display:grid;
  gap:8px;
}

.cookie-title-v70{
  margin:0;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#f1eadf;
}

.cookie-text-v70{
  margin:0;
  max-width:66ch;
  font-size:12px;
  line-height:1.45;
  color:rgba(241,234,223,.72);
}

.cookie-actions-v70{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:10px;
}

.cookie-btn-v70,
.cookie-learn-v70{
  appearance:none;
  border:1px solid rgba(241,234,223,.22);
  border-radius:999px;
  background:transparent;
  color:#f1eadf;
  font:inherit;
  font-size:10px;
  line-height:1;
  letter-spacing:.15em;
  text-transform:uppercase;
  padding:11px 13px;
  cursor:pointer;
  text-decoration:none;
  white-space:nowrap;
}

.cookie-accept-v70,
.cookie-save-v70{
  background:#f1eadf;
  color:#050505;
  border-color:#f1eadf;
}

.cookie-reject-v70{
  color:rgba(241,234,223,.70);
}

.cookie-learn-v70{
  position:absolute;
  left:20px;
  bottom:-34px;
  background:rgba(0,0,0,.58);
}

.cookie-toggles-v70{
  display:grid;
  gap:12px;
}

.cookie-toggle-v70{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:18px;
  padding:14px;
  border:1px solid rgba(241,234,223,.12);
  border-radius:18px;
  background:rgba(241,234,223,.04);
}

.cookie-toggle-copy-v70{
  display:grid;
  gap:5px;
}

.cookie-toggle-copy-v70 strong{
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#f1eadf;
}

.cookie-toggle-copy-v70 em{
  font-style:normal;
  font-size:12px;
  line-height:1.35;
  color:rgba(241,234,223,.62);
}

.cookie-switch-v70{
  position:relative;
  display:block;
  width:48px;
  height:28px;
}

.cookie-switch-v70 input{
  position:absolute;
  inset:0;
  opacity:0;
}

.cookie-switch-v70 span{
  position:absolute;
  inset:0;
  border-radius:999px;
  border:1px solid rgba(241,234,223,.22);
  background:rgba(241,234,223,.08);
}

.cookie-switch-v70 span::after{
  content:"";
  position:absolute;
  top:4px;
  left:4px;
  width:18px;
  height:18px;
  border-radius:999px;
  background:rgba(241,234,223,.72);
  transition:transform .22s ease, background .22s ease;
}

.cookie-switch-v70 input:checked + span{
  background:#f1eadf;
  border-color:#f1eadf;
}

.cookie-switch-v70 input:checked + span::after{
  transform:translateX(20px);
  background:#050505;
}

.cookie-switch-v70 input:disabled + span{
  opacity:.55;
}

.cookie-actions-prefs-v70{
  justify-content:space-between;
}

@keyframes cookieInV70{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes cookieOutV70{
  from{opacity:1;transform:translateY(0)}
  to{opacity:0;transform:translateY(18px)}
}

@media(max-width:840px){
  .cookie-panel-v70{
    bottom:78px;
  }

  .cookie-card-v70{
    grid-template-columns:1fr;
    border-radius:24px;
    gap:14px;
  }

  .cookie-actions-v70{
    justify-content:flex-start;
  }

  .cookie-learn-v70{
    position:static;
    width:max-content;
  }
}

@media(max-width:520px){
  .cookie-actions-v70{
    display:grid;
    grid-template-columns:1fr;
    width:100%;
  }

  .cookie-btn-v70,
  .cookie-learn-v70{
    width:100%;
    text-align:center;
  }

  .cookie-toggle-v70{
    grid-template-columns:1fr;
  }
}


/* V71 cookie bar, petite et discrète */
.cookie-banner-v69,
.cookie-panel-v70{
  display:none !important;
}

.cookie-bar-v71{
  position:fixed;
  left:50%;
  bottom:clamp(18px,2vw,30px);
  z-index:320;
  width:min(760px,calc(100vw - 36px));
  transform:translateX(-50%);
  animation:cookieInV71 .32s cubic-bezier(.22,.61,.36,1) both;
}

.cookie-bar-v71.is-hiding{
  animation:cookieOutV71 .22s ease both;
}

.cookie-compact-v71{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 12px 10px 16px;
  border:1px solid rgba(241,234,223,.16);
  border-radius:999px;
  background:rgba(0,0,0,.76);
  color:#f1eadf;
  backdrop-filter:blur(16px);
  box-shadow:0 12px 44px rgba(0,0,0,.34);
}

.cookie-compact-v71 p{
  margin:0;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  font-size:11px;
  line-height:1.25;
  color:rgba(241,234,223,.66);
}

.cookie-compact-v71 strong{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#f1eadf;
  white-space:nowrap;
}

.cookie-compact-v71 span{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.cookie-buttons-v71{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex:0 0 auto;
}

.cookie-buttons-v71 button{
  appearance:none;
  border:1px solid rgba(241,234,223,.22);
  border-radius:999px;
  background:transparent;
  color:#f1eadf;
  font:inherit;
  font-size:10px;
  line-height:1;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:10px 12px;
  cursor:pointer;
  white-space:nowrap;
}

.cookie-buttons-v71 .cookie-accept-v71,
.cookie-buttons-v71 .cookie-save-v71{
  background:#f1eadf;
  color:#050505;
  border-color:#f1eadf;
}

.cookie-preferences-v71{
  padding:14px;
  border:1px solid rgba(241,234,223,.16);
  border-radius:24px;
  background:rgba(0,0,0,.82);
  color:#f1eadf;
  backdrop-filter:blur(18px);
  box-shadow:0 12px 44px rgba(0,0,0,.34);
}

.cookie-preferences-head-v71{
  margin-bottom:12px;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.cookie-preferences-grid-v71{
  display:grid;
  gap:8px;
  margin-bottom:12px;
}

.cookie-mini-toggle-v71{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  border:1px solid rgba(241,234,223,.10);
  border-radius:16px;
  background:rgba(241,234,223,.035);
}

.cookie-mini-toggle-v71 span{
  display:grid;
  gap:4px;
}

.cookie-mini-toggle-v71 strong{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#f1eadf;
}

.cookie-mini-toggle-v71 em{
  font-style:normal;
  font-size:11px;
  color:rgba(241,234,223,.62);
}

.cookie-mini-toggle-v71 input{
  width:18px;
  height:18px;
  accent-color:#f1eadf;
}

@keyframes cookieInV71{
  from{opacity:0;transform:translateX(-50%) translateY(12px)}
  to{opacity:1;transform:translateX(-50%) translateY(0)}
}

@keyframes cookieOutV71{
  from{opacity:1;transform:translateX(-50%) translateY(0)}
  to{opacity:0;transform:translateX(-50%) translateY(12px)}
}

@media(max-width:760px){
  .cookie-bar-v71{
    bottom:74px;
  }

  .cookie-compact-v71{
    align-items:flex-start;
    border-radius:22px;
    flex-direction:column;
    padding:14px;
  }

  .cookie-compact-v71 p{
    display:grid;
    gap:6px;
  }

  .cookie-compact-v71 span{
    white-space:normal;
  }

  .cookie-buttons-v71{
    width:100%;
    justify-content:space-between;
  }

  .cookie-buttons-v71 button{
    flex:1;
  }
}


/* V72 SEO H1, accessible but visually hidden */
.seo-home-h1{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}


/* V73 typography safety, no word cutting, no letter overlap */
*{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
}

h1,h2,h3,h4,
.section-title h2,
.service-title,
.method-title,
.project-header-v61 h2,
.project-header-v61 h2 span,
.project-header-v61 h2 em,
.category-title,
.tool-list p span,
.entry-grid a strong,
.home-seo-links a strong{
  overflow-wrap:normal !important;
  word-break:normal !important;
  hyphens:none !important;
  text-wrap:normal !important;
}

/* Services / cards : stop the huge split titles */
.service-card,
.service-card-v46,
.service-item,
.service-block,
.method-card,
.vision-card,
.entry-grid a,
.home-seo-links a{
  overflow:hidden;
}

.service-card h2,
.service-card h3,
.service-card-v46 h2,
.service-card-v46 h3,
.service-item h2,
.service-item h3,
.service-block h2,
.service-block h3,
.method-card h2,
.method-card h3,
.vision-card h2,
.vision-card h3{
  font-size:clamp(38px,4.6vw,78px) !important;
  line-height:.92 !important;
  letter-spacing:.015em !important;
  max-width:none !important;
  white-space:normal !important;
}

/* Force specific long headings to stay readable */
.service-card h2,
.service-card h3,
.service-card-v46 h2,
.service-card-v46 h3,
.service-item h2,
.service-item h3{
  min-width:0 !important;
}

/* Keep Storytelling as one word on one line whenever possible */
.service-card h2,
.service-card h3,
.service-card-v46 h2,
.service-card-v46 h3,
.service-item h2,
.service-item h3,
.service-block h2,
.service-block h3{
  text-wrap:balance;
}

/* Prevent the two-column service layout from crushing text */
.services-grid,
.services-list,
.service-grid,
.services-page-grid,
.service-layout,
.cards-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,360px),1fr)) !important;
}

/* If a card contains very long title blocks, reduce type before it overlaps */
@media(max-width:1200px){
  .service-card h2,
  .service-card h3,
  .service-card-v46 h2,
  .service-card-v46 h3,
  .service-item h2,
  .service-item h3,
  .service-block h2,
  .service-block h3{
    font-size:clamp(34px,6vw,66px) !important;
    line-height:.94 !important;
  }
}

@media(max-width:760px){
  .service-card h2,
  .service-card h3,
  .service-card-v46 h2,
  .service-card-v46 h3,
  .service-item h2,
  .service-item h3,
  .service-block h2,
  .service-block h3,
  .method-card h2,
  .method-card h3,
  .vision-card h2,
  .vision-card h3{
    font-size:clamp(32px,10vw,54px) !important;
    line-height:.96 !important;
    letter-spacing:.01em !important;
  }

  .services-grid,
  .services-list,
  .service-grid,
  .services-page-grid,
  .service-layout,
  .cards-grid{
    grid-template-columns:1fr !important;
  }
}

/* Target the services page blocks used by this portfolio */
.premium-page h2,
.premium-page h3{
  overflow-wrap:normal !important;
  word-break:normal !important;
  hyphens:none !important;
}

/* Stop massive display titles from colliding in tight columns */
.premium-page article h2,
.premium-page article h3,
.premium-page .card h2,
.premium-page .card h3{
  font-size:clamp(34px,4.4vw,74px) !important;
  line-height:.94 !important;
  white-space:normal !important;
}

/* Mobile cookie bar reappears above system buttons */
.cookie-bar-v71{
  z-index:999 !important;
}


/* V74 final typography fix, no overlap and one-line manifesto sentence */

/* Large editorial cards, safer layout */
.premium-page article,
.premium-page .card,
.premium-page .service-card,
.premium-page .service-item,
.premium-page .service-block,
.vision-card,
.method-card{
  min-width:0 !important;
  overflow:hidden !important;
}

/* Stop titles from invading the next column */
.premium-page article h2,
.premium-page article h3,
.premium-page .card h2,
.premium-page .card h3,
.premium-page .service-card h2,
.premium-page .service-card h3,
.premium-page .service-item h2,
.premium-page .service-item h3,
.premium-page .service-block h2,
.premium-page .service-block h3,
.vision-card h2,
.vision-card h3,
.method-card h2,
.method-card h3{
  max-width:100% !important;
  width:100% !important;
  overflow:visible !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  hyphens:none !important;
  white-space:normal !important;
  text-wrap:balance !important;
  font-size:clamp(44px,3.55vw,72px) !important;
  line-height:.92 !important;
  letter-spacing:.01em !important;
}

/* Specific protection for the horizontal competency / vision grids */
.competences-grid,
.competence-grid,
.vision-grid,
.services-grid,
.services-list,
.service-grid,
.services-page-grid,
.service-layout,
.cards-grid{
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr)) !important;
}

/* Five-column desktop sections need smaller titles to avoid overlap */
@media(min-width:1101px){
  .competences-grid > *,
  .competence-grid > *,
  .vision-grid > *,
  .services-grid > *,
  .services-list > *,
  .service-grid > *,
  .cards-grid > *{
    min-width:0 !important;
  }

  .competences-grid h2,
  .competences-grid h3,
  .competence-grid h2,
  .competence-grid h3,
  .vision-grid h2,
  .vision-grid h3,
  .services-grid h2,
  .services-grid h3,
  .services-list h2,
  .services-list h3,
  .service-grid h2,
  .service-grid h3,
  .cards-grid h2,
  .cards-grid h3{
    font-size:clamp(38px,3.15vw,64px) !important;
    line-height:.94 !important;
    letter-spacing:.005em !important;
  }
}

/* If the exact words appear in service titles, keep them readable */
.premium-page h2,
.premium-page h3{
  contain:layout paint;
}

/* Manifesto sentence on one line */
.manifesto-sentence,
.big-sentence,
.hero-sentence,
.quote-final,
#quoteFinal,
[data-fr="Une image. Un film. Une idée. Une direction. Un monde."],
[data-en="An image. A film. An idea. A direction. A world."]{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  white-space:nowrap !important;
  overflow:visible !important;
  text-wrap:nowrap !important;
  word-break:normal !important;
  overflow-wrap:normal !important;
  hyphens:none !important;
  font-size:clamp(28px,4.2vw,82px) !important;
  line-height:1 !important;
  letter-spacing:-.02em !important;
}

/* Paragraphs stay normal and readable */
.premium-page p,
.service-card p,
.service-item p,
.service-block p,
.vision-card p,
.method-card p{
  word-break:normal !important;
  overflow-wrap:normal !important;
  hyphens:none !important;
}

/* Mobile and tablet, one column prevents compressed words */
@media(max-width:1100px){
  .competences-grid,
  .competence-grid,
  .vision-grid,
  .services-grid,
  .services-list,
  .service-grid,
  .services-page-grid,
  .service-layout,
  .cards-grid{
    grid-template-columns:1fr !important;
  }

  .premium-page article h2,
  .premium-page article h3,
  .premium-page .card h2,
  .premium-page .card h3,
  .premium-page .service-card h2,
  .premium-page .service-card h3,
  .premium-page .service-item h2,
  .premium-page .service-item h3,
  .premium-page .service-block h2,
  .premium-page .service-block h3,
  .vision-card h2,
  .vision-card h3,
  .method-card h2,
  .method-card h3{
    font-size:clamp(34px,8vw,64px) !important;
    line-height:.96 !important;
  }
}

@media(max-width:760px){
  .manifesto-sentence,
  .big-sentence,
  .hero-sentence,
  .quote-final,
  #quoteFinal,
  [data-fr="Une image. Un film. Une idée. Une direction. Un monde."],
  [data-en="An image. A film. An idea. A direction. A world."]{
    font-size:clamp(21px,6.2vw,42px) !important;
    white-space:nowrap !important;
  }
}


/* V76 link fix and corrected poster */
.hero-poster-image-v62 img,
.hero-poster-image-v62 img[src*="dont-panic-do-art-corrected"]{
  width:100% !important;
  height:auto !important;
  object-fit:contain !important;
  display:block !important;
  filter:none !important;
}
.poster-logo-link-v59,
.footer-nav a,
.contact-links a,
a[href*="linkedin.com"]{
  position:relative !important;
  z-index:500 !important;
  pointer-events:auto !important;
  cursor:pointer !important;
}
.intro-overlay,
.intro-lines-v65,
.intro-lines-v64,
.graphic-intro,
.welcome-intro,
.home-hero-v18::before,
.home-video-shell-v59::before,
.home-video-shell-v59::after,
.hero-poster-image-v62::before,
.hero-poster-image-v62::after{
  pointer-events:none !important;
}
.site-header,
.site-footer,
.home-actions,
.home-actions-v59{
  position:relative;
  z-index:80;
}


/* V77 link and poster hard fix */
a[href*="linkedin.com"]{
  cursor:pointer !important;
  pointer-events:auto !important;
}
.poster-logo-link,
.poster-logo-link-v59{
  position:relative !important;
  z-index:80 !important;
  pointer-events:auto !important;
}
.hero-poster-corrected-v77{
  width:min(760px,100%);
  margin:clamp(14px,2vw,28px) 0;
  position:relative;
  z-index:3;
}
.hero-poster-corrected-v77 img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
}
.intro-overlay.off,
.cookie-banner[hidden],
.cookie-panel[hidden]{
  pointer-events:none !important;
}
.work-section-v77 .section-title p{
  max-width:780px;
}
.art-pong-v77{
  margin-top:clamp(28px,5vw,64px);
  display:grid;
  grid-template-columns:minmax(240px,.62fr) minmax(0,1fr);
  gap:clamp(18px,4vw,54px);
  align-items:stretch;
  border:1px solid rgba(244,239,230,.22);
  background:rgba(244,239,230,.035);
  padding:clamp(18px,3vw,34px);
}
.art-pong-copy h3{
  margin:.1em 0 .25em;
  font-family:'Big Shoulders Display', Impact, sans-serif;
  font-size:clamp(48px,8vw,118px);
  line-height:.82;
  letter-spacing:.03em;
}
.art-pong-copy p{
  color:rgba(244,239,230,.78);
  max-width:520px;
}
.art-pong-start{
  margin-top:18px;
  min-height:44px;
  border:1px solid rgba(244,239,230,.45);
  border-radius:999px;
  background:#f4efe6;
  color:#050505;
  padding:0 20px;
  font:700 11px Inter,Arial,sans-serif;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
}
.art-pong-frame{
  min-width:0;
}
.art-pong-frame canvas{
  display:block;
  width:100%;
  height:auto;
  border:1px solid rgba(244,239,230,.22);
  background:#050505;
  touch-action:none;
}
.art-pong-score{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:12px;
  color:#f4efe6;
  font:700 12px Inter,Arial,sans-serif;
  letter-spacing:.1em;
  text-transform:uppercase;
}
@media (max-width:860px){
  .art-pong-v77{grid-template-columns:1fr;}
}


/* V78 professional assets + art history pong */
.work-section-v78 .works-grid{grid-template-columns:1.35fr 1fr 1fr;}
.work-section-v78 .work-card img{min-height:320px;}
.work-section-v78 .work-card figcaption{font-size:11px;letter-spacing:.18em;}
.art-pong-era{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin:0 0 12px;color:#f4efe6;}
.art-pong-era-kicker{display:inline-block;color:rgba(244,239,230,.58);font:600 10px Inter,Arial,sans-serif;letter-spacing:.18em;text-transform:uppercase;}
.art-pong-era strong{font:700 22px Big Shoulders Display,Impact,sans-serif;letter-spacing:.03em;text-transform:uppercase;}
.art-pong-era em{font-style:normal;color:rgba(244,239,230,.62);font:500 12px Inter,Arial,sans-serif;letter-spacing:.08em;text-transform:uppercase;}
@media (max-width:860px){.work-section-v78 .works-grid{grid-template-columns:1fr;}.work-section-v78 .work-card img{min-height:260px;}}


/* V80 full multimedia category */
.work-section-v80 .works-grid{grid-template-columns:1.2fr 1fr 1fr;}
.work-section-v80 .work-card img{min-height:320px;}
.work-section-v80 .work-card figcaption{font-size:11px;letter-spacing:.18em;}
.art-pong-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:14px;}
.art-pong-hint{margin:0;color:rgba(244,239,230,.58);font-size:13px;line-height:1.4;}
.art-pong-timeline{margin-top:16px;padding-top:14px;border-top:1px solid rgba(244,239,230,.12);color:rgba(244,239,230,.52);font-size:11px;line-height:1.8;letter-spacing:.08em;text-transform:uppercase;}
.art-pong-frame{position:relative;overflow:hidden;}
@media (max-width:860px){.work-section-v80 .works-grid{grid-template-columns:1fr;}.work-section-v80 .work-card img{min-height:250px;}.art-pong-actions{flex-direction:column;align-items:flex-start;}}


/* V81 works refinements */
.work-section-v81 .works-grid{grid-template-columns:1.2fr 1fr 1fr;}
.work-section-v81 .work-card figcaption{font-size:11px;letter-spacing:.18em;}
.work-section-v81-game .art-pong-v77{margin-top:28px;}
.work-section-v81-game .art-pong-frame{max-width:1100px;}
.work-section-v81-game .art-pong-timeline{margin-top:16px;padding-top:14px;border-top:1px solid rgba(244,239,230,.12);color:rgba(244,239,230,.56);font-size:11px;line-height:1.8;letter-spacing:.08em;text-transform:uppercase;}
@media (max-width:860px){.work-section-v81 .works-grid{grid-template-columns:1fr;}}


/* V82 mobile header tap targets */
@media (max-width:700px){
  .site-header{
    padding:14px 14px 16px !important;
  }

  .header-right,
  .header-right-only{
    gap:12px !important;
    align-items:stretch !important;
  }

  .site-header nav{
    width:100% !important;
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:10px !important;
    justify-content:stretch !important;
  }

  .site-header nav a{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    min-height:48px !important;
    padding:12px 10px !important;
    border:1px solid rgba(255,255,255,.14) !important;
    border-radius:14px !important;
    background:rgba(255,255,255,.04) !important;
    color:#f4efe6 !important;
    font-size:11px !important;
    letter-spacing:.12em !important;
    line-height:1.15 !important;
    text-align:center !important;
    white-space:normal !important;
    -webkit-tap-highlight-color:transparent;
  }

  .site-header nav a:hover,
  .site-header nav a:active{
    background:rgba(255,255,255,.09) !important;
  }

  .lang-toggle{
    width:52px !important;
    height:52px !important;
    align-self:flex-end !important;
  }
}


/* V83 style diversity + 100 pong */
.work-section-v83 .works-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
.work-section-v83 .work-card img{min-height:280px;object-fit:cover;}
.work-section-v83 .work-card figcaption{font-size:10px;letter-spacing:.16em;line-height:1.5;}
.work-section-v83-game .art-pong-frame{max-width:1100px;}
@media (max-width:1100px){.work-section-v83 .works-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media (max-width:860px){.work-section-v83 .works-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.work-section-v83 .work-card img{min-height:220px;}}
@media (max-width:560px){.work-section-v83 .works-grid{grid-template-columns:1fr;}}


/* V85 uploaded assets integration */
.work-section-v85-assets .works-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
.work-section-v85-assets .work-card img{min-height:280px;object-fit:cover;background:#080808;}
.work-section-v85-assets .work-card figcaption{font-size:10px;letter-spacing:.15em;line-height:1.5;}
.work-section-v85-game .art-pong-v77{margin-top:28px;}
.work-section-v85-game .art-pong-frame{max-width:1120px;}
@media (max-width:1100px){.work-section-v85-assets .works-grid{grid-template-columns:repeat(3,minmax(0,1fr));}}
@media (max-width:860px){.work-section-v85-assets .works-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.work-section-v85-assets .work-card img{min-height:220px;}}
@media (max-width:560px){.work-section-v85-assets .works-grid{grid-template-columns:1fr;}}


/* V86 project PDF access */
.project-pdf-access{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.project-pdf-link{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 16px;border:1px solid rgba(241,234,223,.22);border-radius:999px;background:rgba(241,234,223,.07);color:#f1eadf;text-transform:uppercase;letter-spacing:.12em;font-size:11px;text-decoration:none}
.project-pdf-link:hover{background:rgba(241,234,223,.14)}
@media(max-width:700px){.project-pdf-access{flex-direction:column}.project-pdf-link{width:100%;border-radius:16px}}


/* V89 corrections */
.projects-intro-v89{width:min(1180px,calc(100% - 40px));margin:0 auto 70px;padding-top:120px;}
.projects-intro-v89 h1{margin:0;max-width:1050px;font-family:'Big Shoulders Display',sans-serif;font-size:clamp(64px,12vw,170px);line-height:.82;text-transform:uppercase;letter-spacing:-.04em;}
.project-block-v89{width:min(1180px,calc(100% - 40px));margin:0 auto 100px;border-top:1px solid rgba(244,239,230,.18);padding-top:36px;}
.project-header-v89 h2 em{display:block;margin-top:8px;color:rgba(244,239,230,.55);font-size:clamp(22px,3vw,38px);font-style:normal;letter-spacing:.04em;}
.project-card-pdf-links{justify-content:flex-start;margin-top:18px;}
.project-pdf-access-v89{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px;}
.project-pdf-link{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 14px;border:1px solid rgba(244,239,230,.22);border-radius:999px;color:#f4efe6;background:rgba(244,239,230,.04);text-decoration:none;font-size:12px;letter-spacing:.08em;text-transform:uppercase;}
.project-pdf-link:hover{background:rgba(244,239,230,.12);}
.cookie-bar-v71{position:fixed!important;left:max(14px,env(safe-area-inset-left))!important;right:max(14px,env(safe-area-inset-right))!important;bottom:max(14px,env(safe-area-inset-bottom))!important;width:auto!important;max-width:none!important;z-index:2147483000!important;pointer-events:auto!important;}
.cookie-compact-v71,.cookie-preferences-v71{max-width:980px;margin:0 auto;}
@media (max-width:900px){.project-header-v89{grid-template-columns:1fr!important;gap:24px!important;}.project-mosaic-v89{grid-template-columns:1fr!important;}.projects-intro-v89{padding-top:92px;}.cookie-bar-v71{left:10px!important;right:10px!important;bottom:10px!important;}.cookie-compact-v71{display:grid!important;gap:14px!important;}.cookie-buttons-v71{display:grid!important;grid-template-columns:1fr 1fr!important;width:100%!important;}.cookie-buttons-v71 button{min-height:48px!important;}}
@media (min-width:901px) and (max-width:1200px){.cookie-bar-v71{left:24px!important;right:24px!important;}}


/* V90 fixes: single thin cookie bar, detachable video, modal gallery, 3 video cards */
.cookie-banner,
.cookie-panel,
.cookie-banner-v69,
.cookie-panel-v70{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

.video-detach-button{
  position:absolute;
  right:18px;
  top:18px;
  z-index:12;
  border:1px solid rgba(244,239,230,.45);
  border-radius:999px;
  background:rgba(5,5,5,.58);
  color:#f4efe6;
  padding:10px 14px;
  font:700 11px/1 Inter,Arial,sans-serif;
  letter-spacing:.12em;
  text-transform:uppercase;
  cursor:pointer;
  backdrop-filter:blur(12px);
}
.video-detach-button:hover{background:rgba(244,239,230,.12)}
.home-video-shell{position:relative}
.home-video-shell.is-video-detached{
  position:fixed!important;
  right:24px!important;
  bottom:24px!important;
  width:min(520px,calc(100vw - 32px))!important;
  max-width:min(520px,calc(100vw - 32px))!important;
  height:auto!important;
  z-index:2147482500!important;
  transform:none!important;
  margin:0!important;
  border:1px solid rgba(244,239,230,.28)!important;
  box-shadow:0 28px 90px rgba(0,0,0,.72)!important;
  background:#050505!important;
  border-radius:24px!important;
  overflow:hidden!important;
}
.home-video-shell.is-video-detached .tv-video-alone,
.home-video-shell.is-video-detached video{
  width:100%!important;
  height:auto!important;
  aspect-ratio:16/9!important;
  object-fit:cover!important;
  display:block!important;
}
.home-video-shell.is-video-detached figcaption{
  left:18px!important;
  bottom:14px!important;
}
.home-video-shell.is-video-detached .video-detach-button{
  right:12px;
  top:12px;
  background:rgba(244,239,230,.92);
  color:#050505;
}
@media (max-width:700px){
  .home-video-shell.is-video-detached{
    left:10px!important;
    right:10px!important;
    bottom:calc(10px + env(safe-area-inset-bottom))!important;
    width:auto!important;
    max-width:none!important;
    border-radius:18px!important;
  }
  .video-detach-button{
    top:12px;
    right:12px;
    min-height:42px;
    padding:10px 12px;
    font-size:10px;
  }
}

.video-grid-three{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  align-items:stretch!important;
}
.video-grid-three .video-link-card{
  min-height:100%;
}
.video-grid-three .video-thumb-picto{
  aspect-ratio:16/10!important;
}
.video-grid-three .video-text{
  min-height:150px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
@media (max-width:900px){
  .video-grid-three{grid-template-columns:1fr!important;}
  .video-grid-three .video-text{min-height:auto;}
}

body.gallery-open-v90{overflow:hidden}
.gallery-modal-v90{
  position:fixed;
  inset:0;
  z-index:2147483200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.gallery-modal-v90.is-open{display:flex}
.gallery-modal-backdrop-v90{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(16px);
}
.gallery-modal-dialog-v90{
  position:relative;
  width:min(1240px,100%);
  max-height:calc(100vh - 48px);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:18px;
}
.gallery-figure-v90{
  margin:0;
  min-width:0;
  background:#050505;
  border:1px solid rgba(244,239,230,.16);
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 28px 110px rgba(0,0,0,.8);
}
.gallery-image-v90{
  width:100%;
  max-height:calc(100vh - 170px);
  object-fit:contain;
  display:block;
  background:#050505;
}
.gallery-figure-v90 figcaption{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 18px;
  color:#f4efe6;
  border-top:1px solid rgba(244,239,230,.12);
}
.gallery-title-v90{
  font:700 13px/1.25 Inter,Arial,sans-serif;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.gallery-count-v90{
  color:rgba(244,239,230,.62);
  font:600 12px/1 Inter,Arial,sans-serif;
  white-space:nowrap;
}
.gallery-close-v90,
.gallery-nav-v90{
  border:1px solid rgba(244,239,230,.22);
  background:rgba(244,239,230,.08);
  color:#f4efe6;
  cursor:pointer;
  backdrop-filter:blur(12px);
}
.gallery-close-v90{
  position:absolute;
  right:0;
  top:-52px;
  width:42px;
  height:42px;
  border-radius:999px;
  font-size:28px;
  line-height:1;
}
.gallery-nav-v90{
  width:54px;
  height:88px;
  border-radius:999px;
  font-size:58px;
  line-height:.8;
}
.gallery-close-v90:hover,
.gallery-nav-v90:hover{background:rgba(244,239,230,.18)}
@media (max-width:820px){
  .gallery-modal-v90{padding:12px;}
  .gallery-modal-dialog-v90{grid-template-columns:1fr;gap:10px;}
  .gallery-nav-v90{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    width:46px;
    height:72px;
    z-index:3;
    background:rgba(5,5,5,.55);
  }
  .gallery-prev-v90{left:8px;}
  .gallery-next-v90{right:8px;}
  .gallery-close-v90{right:8px;top:8px;z-index:4;background:rgba(5,5,5,.55);}
  .gallery-image-v90{max-height:calc(100vh - 132px);}
  .gallery-figure-v90 figcaption{padding:12px;display:grid;}
  .gallery-title-v90{font-size:11px;}
}


/* V91 corrections: cookie bar centered and compact */
.cookie-bar-v71{
  left:50%!important;
  right:auto!important;
  bottom:max(18px,env(safe-area-inset-bottom))!important;
  width:min(760px,calc(100vw - 28px))!important;
  max-width:760px!important;
  transform:translateX(-50%)!important;
  z-index:2147483000!important;
}
.cookie-compact-v71{
  width:100%!important;
  min-height:54px!important;
  margin:0 auto!important;
  padding:10px 12px!important;
  border-radius:999px!important;
}
.cookie-preferences-v71{
  width:min(620px,calc(100vw - 28px))!important;
  margin:0 auto!important;
}
.cookie-bar-v71.is-open{
  width:min(620px,calc(100vw - 28px))!important;
}
@media(max-width:760px){
  .cookie-bar-v71{
    left:50%!important;
    right:auto!important;
    bottom:max(12px,env(safe-area-inset-bottom))!important;
    width:calc(100vw - 24px)!important;
    transform:translateX(-50%)!important;
  }
  .cookie-compact-v71{
    border-radius:20px!important;
    padding:12px!important;
  }
}


/* V92 corrections: remove detachable video, expand arts list, prevent text overlap */
.video-detach-button,
[data-detach-video]{
  display:none!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
.home-video-shell.is-video-detached{
  position:relative!important;
  right:auto!important;
  bottom:auto!important;
  width:auto!important;
  max-width:none!important;
  border-radius:inherit!important;
  box-shadow:none!important;
  transform:none!important;
}

.tool-list-section .tool-list{
  overflow:visible!important;
}
.tool-list-section .tool-list p{
  min-height:clamp(64px,7vw,92px)!important;
  height:auto!important;
  grid-template-columns:minmax(0,1fr) clamp(30px,4vw,54px) minmax(0,1fr)!important;
  align-items:center!important;
  gap:clamp(10px,2vw,18px)!important;
  padding:12px clamp(10px,2vw,18px)!important;
}
.tool-list-section .tool-list p.tool-list-long{
  min-height:clamp(78px,8.5vw,112px)!important;
}
.tool-list-section .tool-list span,
.tool-list-section .tool-list em{
  font-size:clamp(28px,4.55vw,78px)!important;
  line-height:.88!important;
  white-space:normal!important;
  max-width:100%!important;
  overflow:visible!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  hyphens:none!important;
}
.tool-list-section .tool-list p.tool-list-long span{
  font-size:clamp(25px,4vw,66px)!important;
}
.tool-list-section .tool-list p.tool-list-long em{
  font-size:clamp(26px,4vw,68px)!important;
}
.tool-list-section .tool-list strong{
  font-size:clamp(18px,3vw,42px)!important;
}
@media(max-width:760px){
  .tool-list-section .tool-list p,
  .tool-list-section .tool-list p.tool-list-long{
    grid-template-columns:1fr 28px 1fr!important;
    min-height:64px!important;
    padding:12px 8px!important;
  }
  .tool-list-section .tool-list span,
  .tool-list-section .tool-list em,
  .tool-list-section .tool-list p.tool-list-long span,
  .tool-list-section .tool-list p.tool-list-long em{
    font-size:clamp(22px,7vw,38px)!important;
    line-height:.9!important;
  }
}

.work-section > .section-title{
  grid-template-columns:70px minmax(0,1fr)!important;
  align-items:start!important;
  column-gap:clamp(14px,3vw,28px)!important;
  row-gap:12px!important;
  overflow:visible!important;
}
.work-section > .section-title > span{
  grid-column:1!important;
  grid-row:1 / span 2!important;
  padding-top:.32em!important;
}
.work-section > .section-title > h2{
  grid-column:2!important;
  grid-row:1!important;
  max-width:100%!important;
  overflow:visible!important;
  font-size:clamp(48px,8.2vw,118px)!important;
  line-height:.84!important;
  white-space:normal!important;
  text-wrap:balance!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  hyphens:none!important;
  margin:0!important;
}
.work-section > .section-title > p{
  grid-column:2!important;
  grid-row:2!important;
  max-width:min(760px,100%)!important;
  position:relative!important;
  z-index:2!important;
  margin:6px 0 0!important;
  padding:0!important;
  align-self:start!important;
}
@media(max-width:900px){
  .work-section > .section-title{
    grid-template-columns:1fr!important;
  }
  .work-section > .section-title > span,
  .work-section > .section-title > h2,
  .work-section > .section-title > p{
    grid-column:1!important;
    grid-row:auto!important;
  }
  .work-section > .section-title > h2{
    font-size:clamp(42px,13vw,88px)!important;
  }
}

.page-intro,
.section-title,
.project-header-v89,
.project-header-v61,
.service-card,
.method-card,
.video-text,
.entry-grid a,
.home-seo-links a{
  overflow-wrap:normal!important;
  word-break:normal!important;
  hyphens:none!important;
}
body{
  overflow-x:hidden!important;
}
