/* ============================================================
   VSM — Stylesheet commun (toutes les pages)
   Charte : Suisse Intl, monochrome noir/blanc/gris, zéro arrondi
   ============================================================ */

/* ============ FONTS ============ */
@font-face{font-family:'Suisse Intl';src:url('../fonts/SuisseIntl-UltraLight.woff2') format('woff2');font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:'Suisse Intl';src:url('../fonts/SuisseIntl-Light.woff2') format('woff2');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Suisse Intl';src:url('../fonts/SuisseIntl-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Suisse Intl';src:url('../fonts/SuisseIntl-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Suisse Intl';src:url('../fonts/SuisseIntl-Thin.woff2') format('woff2');font-weight:100;font-style:normal;font-display:swap}

/* ============ RESET / BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}

:root{
  --black:#000000;
  --ink:#0a0a0a;
  --g-900:#111111;
  --g-700:#2a2a2a;
  --g-600:#525252;
  --g-400:#9a9a9a;
  --g-300:#d4d4d4;
  --g-200:#e5e5e5;
  --g-100:#f2f2f2;
  --g-50:#f8f8f8;
  --white:#ffffff;
  --pad-x:clamp(18px,4vw,64px);
  --t-display:clamp(30px,11vw,220px);
  --t-h1:clamp(36px,6vw,96px);
  --t-h2:clamp(30px,4vw,64px);
  --t-h3:clamp(20px,1.4vw,28px);
  --t-body:clamp(15px,1.05vw,18px);
  --t-eyebrow:11px;
}

body{
  font-family:'Suisse Intl','Helvetica Neue',Arial,sans-serif;
  font-weight:300;
  background:var(--white);
  color:var(--ink);
  font-size:var(--t-body);
  line-height:1.5;
  overflow-x:hidden;
  cursor:none;
}
@media (hover:none){body{cursor:auto}}

img,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:none}
::selection{background:#000;color:#fff}

/* ============ CUSTOM CURSOR ============ */
.cursor{position:fixed;top:0;left:0;width:10px;height:10px;background:#000;border-radius:50%;pointer-events:none;z-index:9999;box-shadow:0 0 0 1px rgba(255,255,255,.9),0 0 12px rgba(0,0,0,.35);transform:translate(-50%,-50%);transition:width .3s cubic-bezier(.2,.8,.2,1),height .3s cubic-bezier(.2,.8,.2,1),background .3s,box-shadow .3s}
.cursor.cursor--ring{width:38px;height:38px;background:rgba(0,0,0,.08);box-shadow:0 0 0 1.5px #000,inset 0 0 0 1px rgba(255,255,255,.85),0 0 16px rgba(0,0,0,.25)}
.cursor.cursor--big{width:96px;height:96px;background:rgba(255,255,255,.92);box-shadow:0 0 0 1px rgba(0,0,0,.55),0 8px 32px rgba(0,0,0,.35)}
@media (hover:none){.cursor{display:none}}

/* ============ PRELOADER ============ */
.preloader{position:fixed;inset:0;z-index:9000;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:32px}
.preloader__logo{width:200px;height:auto;opacity:0;filter:none}
.preloader__count{font-weight:200;font-size:14vw;line-height:.9;letter-spacing:-.04em;font-variant-numeric:tabular-nums;opacity:0}
.preloader__bar{position:absolute;bottom:0;left:0;height:1px;background:#fff;width:0}
.preloader__label{position:absolute;bottom:32px;right:var(--pad-x);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#777}

/* ============ NAVIGATION ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;padding:22px var(--pad-x);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;mix-blend-mode:difference;color:#fff;transition:padding .4s ease}
.nav.is-scrolled{padding:14px var(--pad-x)}
.nav__logo{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:400}
.nav__logo img{width:auto;height:58px;filter:none;transition:height .4s ease}
.nav.is-scrolled .nav__logo img{height:48px}
.nav__links{justify-self:center;display:flex;align-items:center;gap:32px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:300}
.nav__links a, .nav__links .nav__group-btn{position:relative;padding:8px 0;color:inherit;transition:opacity .3s}
.nav__links a::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.65,0,.35,1)}
.nav__links a:hover::after, .nav__links a.is-active::after{transform:scaleX(1)}
.nav__links .nav__dot{display:inline-block;width:6px;height:6px;background:currentColor;border-radius:50%;margin-right:8px;vertical-align:middle;animation:nav-dot 2.4s ease-in-out infinite}
@keyframes nav-dot{0%,100%{opacity:1}50%{opacity:.45}}

/* Dropdown groupes */
.nav__group{position:relative}
.nav__group-btn{background:none;border:0;font:inherit;color:inherit;display:inline-flex;align-items:center;gap:6px;cursor:none;padding:8px 0;text-transform:inherit;letter-spacing:inherit}
.nav__group-btn svg{width:10px;height:10px;transition:transform .3s ease;opacity:.7}
.nav__group.is-open .nav__group-btn svg{transform:rotate(180deg)}
.nav__group-panel{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);min-width:240px;background:#000;color:#fff;padding:14px 0;opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;border-top:1px solid #1a1a1a;mix-blend-mode:normal;isolation:isolate}
.nav__group.is-open .nav__group-panel{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(8px)}
.nav__group-panel::before{content:'';position:absolute;top:-16px;left:0;right:0;height:16px}
.nav__group-panel a{display:block;padding:11px 22px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:300;color:#cfcfcf;white-space:nowrap;transition:background .3s,color .3s,padding-left .3s}
.nav__group-panel a::after{display:none}
.nav__group-panel a:hover, .nav__group-panel a.is-active{background:rgba(255,255,255,.06);color:#fff;padding-left:28px}

.nav__cta{justify-self:end;display:flex;align-items:center;gap:18px}
.nav__burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:6px;color:#fff}
.nav__burger span{display:block;width:22px;height:1px;background:currentColor;transition:transform .4s ease,opacity .3s ease}
.nav__burger.is-open span:nth-child(1){transform:translateY(3.5px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){transform:translateY(-3.5px) rotate(-45deg)}

@media (max-width:1180px){.nav__links{gap:22px}.nav__links{font-size:11px}}
@media (max-width:1020px){
  .nav__links{display:none}
  .nav{grid-template-columns:1fr auto;padding:16px var(--pad-x)}
  .nav__burger{display:flex}
  .nav__logo span{display:none}
  .nav__logo img{width:auto;height:44px}
}

/* ============ MOBILE MENU OVERLAY ============ */
.menu{position:fixed;inset:0;z-index:75;background:#000;color:#fff;display:flex;flex-direction:column;padding:96px var(--pad-x) 32px;pointer-events:none;opacity:0;transform:translateX(100%);transition:transform .55s cubic-bezier(.77,0,.18,1),opacity .35s ease}
.menu.is-open{transform:translateX(0);opacity:1;pointer-events:auto}
.menu__list{list-style:none;display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1}
.menu__list > li{border-bottom:1px solid #1a1a1a}
.menu__list a{display:block;font-weight:300;font-size:clamp(22px,6vw,32px);line-height:1.2;letter-spacing:-.01em;text-transform:uppercase;padding:22px 0;color:#e5e5e5;transition:color .3s,padding-left .3s}
.menu__list a:hover, .menu__list a.is-active{color:#fff;padding-left:8px}
.menu__group-btn{background:none;border:0;font:inherit;color:#e5e5e5;font-weight:300;font-size:clamp(22px,6vw,32px);line-height:1.2;letter-spacing:-.01em;text-transform:uppercase;padding:22px 0;display:flex;justify-content:space-between;align-items:center;width:100%;cursor:none;transition:color .3s}
.menu__group-btn:hover, .menu__group.is-open .menu__group-btn{color:#fff}
.menu__group-btn svg{width:14px;height:14px;transition:transform .35s ease;opacity:.6}
.menu__group.is-open .menu__group-btn svg{transform:rotate(180deg);opacity:1}
.menu__sub{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.65,0,.35,1);background:rgba(255,255,255,.03)}
.menu__group.is-open .menu__sub{max-height:600px}
.menu__sub a{font-size:14px;letter-spacing:.08em;padding:14px 24px;color:#9a9a9a;font-weight:300}
.menu__sub a:hover{color:#fff;background:rgba(255,255,255,.05)}
.menu__dot{display:inline-block;width:7px;height:7px;background:currentColor;border-radius:50%;margin-right:10px;vertical-align:middle;animation:nav-dot 2.4s ease-in-out infinite}
.menu__foot{display:flex;justify-content:space-between;align-items:end;gap:24px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--g-400);border-top:1px solid #1a1a1a;padding-top:24px;margin-top:24px}
.menu__foot a{color:#fff}

/* ============ MARQUEE (réutilisable) ============ */
.marquee{background:#000;color:#fff;padding:22px 0;overflow:hidden;border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a}
.marquee__track{display:flex;gap:40px;white-space:nowrap;font-weight:200;font-size:clamp(28px,6vw,96px);line-height:1;letter-spacing:-.02em;text-transform:uppercase;will-change:transform}
.marquee__track span{display:inline-flex;align-items:center;gap:40px}
.marquee__track .dot{width:8px;height:8px;background:#fff;border-radius:50%;display:inline-block;flex:none}
@media (max-width:700px){.marquee{padding:18px 0}.marquee__track{gap:28px}.marquee__track span{gap:28px}}

/* ============ SECTIONS GÉNÉRIQUES ============ */
section{position:relative}
.section{padding:140px var(--pad-x)}
@media (max-width:700px){.section{padding:88px var(--pad-x)}}
.section--dark{background:#000;color:#fff}
.section--gray{background:var(--g-50)}
.sec-head{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:end;margin-bottom:88px}
.eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;color:var(--g-600);display:flex;align-items:center;gap:14px}
.eyebrow::before{content:'';width:32px;height:1px;background:currentColor}
.section--dark .eyebrow{color:#a5a5a5}
.sec-head h2{font-weight:200;font-size:var(--t-h2);line-height:1;letter-spacing:-.025em}
.sec-head h2 em{font-style:italic;font-weight:200;color:var(--g-600)}
.section--dark .sec-head h2 em{color:var(--g-400)}
@media (max-width:800px){.sec-head{grid-template-columns:1fr;gap:24px;margin-bottom:56px}}

/* ============ HERO INTÉRIEUR (pages secondaires) ============ */
.page-hero{position:relative;min-height:80vh;display:flex;align-items:flex-end;padding:140px var(--pad-x) 80px;background:#000;color:#fff;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;z-index:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover;filter:saturate(0) brightness(.55)}
.page-hero__bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,transparent 35%,rgba(0,0,0,.85) 100%)}
.page-hero__noise{position:absolute;inset:0;z-index:1;opacity:.05;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>")}
.page-hero__inner{position:relative;z-index:2;width:100%;max-width:1600px;margin:0 auto}
.page-hero__eyebrow{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;color:#cfcfcf;margin-bottom:32px}
.page-hero__eyebrow::before{content:'';width:48px;height:1px;background:#fff}
.page-hero__title{font-weight:200;font-size:clamp(30px,9vw,160px);line-height:.94;letter-spacing:-.035em;text-transform:uppercase;max-width:18ch}
.page-hero__title em{font-style:normal;font-weight:200;color:var(--g-400)}
.page-hero__lead{font-size:clamp(17px,1.4vw,22px);color:var(--g-300);max-width:60ch;margin-top:32px;line-height:1.55;font-weight:300}
.page-hero__crumb{position:absolute;top:96px;left:var(--pad-x);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--g-400);z-index:3}
.page-hero__crumb a{color:inherit;border-bottom:1px solid transparent;transition:border-color .3s}
.page-hero__crumb a:hover{border-color:currentColor}
@media (max-width:700px){.page-hero{min-height:70vh;padding:120px var(--pad-x) 60px}}

/* ============ BLOCS DE CONTENU RÉUTILISABLES ============ */
.prose{max-width:68ch;font-size:17px;line-height:1.7;color:var(--g-700)}
.prose p+p{margin-top:1.4em}
.prose strong{color:var(--ink);font-weight:400}
.prose ul{list-style:none;padding-left:0;margin-top:1.4em}
.prose ul li{position:relative;padding-left:28px;margin-bottom:.8em}
.prose ul li::before{content:'';position:absolute;left:0;top:.7em;width:14px;height:1px;background:var(--g-400)}
.prose h3{font-size:clamp(22px,2vw,32px);font-weight:300;letter-spacing:-.02em;line-height:1.15;margin:2.2em 0 .8em;color:var(--ink)}

/* Split 2 colonnes : texte + visuel */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,120px);align-items:center}
.split--reverse{direction:rtl}
.split--reverse > *{direction:ltr}
.split__media{position:relative;aspect-ratio:4/5;overflow:hidden;background:#000}
.split__media img{width:100%;height:100%;object-fit:cover;filter:saturate(0) brightness(.92);transition:transform 1.4s cubic-bezier(.2,.8,.2,1),filter .6s ease}
.split__media:hover img{transform:scale(1.04);filter:saturate(1) brightness(1) contrast(1.02)}
.split__media--wide{aspect-ratio:3/2}
.split__text h2{font-weight:200;font-size:var(--t-h2);line-height:1;letter-spacing:-.025em;margin-bottom:32px}
.split__text h2 em{font-style:italic;font-weight:200;color:var(--g-600)}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:40px}.split--reverse{direction:ltr}}

/* Grille de cartes services / liens */
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tile{position:relative;aspect-ratio:4/5;overflow:hidden;background:#000;color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:32px}
.tile__num{font-size:11px;letter-spacing:.22em;color:var(--g-400)}
.tile__title{font-weight:200;font-size:clamp(24px,2.2vw,36px);line-height:1.05;letter-spacing:-.02em;text-transform:uppercase}
.tile__arrow{display:inline-flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;transition:gap .3s}
.tile:hover .tile__arrow{gap:24px}
.tile__bg{position:absolute;inset:0;z-index:0}
.tile__bg img{width:100%;height:100%;object-fit:cover;filter:saturate(0) brightness(.55);transition:filter .8s ease,transform 1.4s cubic-bezier(.2,.8,.2,1)}
.tile:hover .tile__bg img{filter:saturate(.95) brightness(.7);transform:scale(1.06)}
.tile > *:not(.tile__bg){position:relative;z-index:2}
@media (max-width:900px){.tile-grid{grid-template-columns:1fr}}

/* Stats généraux */
.stats{background:#000;color:#fff;padding:140px var(--pad-x);display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
@media (max-width:700px){.stats{padding:80px var(--pad-x);gap:20px}}
.stat{border-top:1px solid #2a2a2a;padding-top:28px}
.stat__num{font-weight:200;font-size:clamp(30px,7vw,128px);line-height:.9;letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.stat__num sup{font-size:.35em;letter-spacing:0;font-weight:200;vertical-align:top;margin-left:6px;color:var(--g-400)}
.stat__lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--g-400);margin-top:18px}
@media (max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}

/* Liste d'accordéons (FAQ) */
.faq{max-width:1200px;margin:0 auto}
.faq__item{border-top:1px solid var(--g-200)}
.faq__item:last-child{border-bottom:1px solid var(--g-200)}
.section--dark .faq__item{border-top-color:var(--g-700)}
.section--dark .faq__item:last-child{border-bottom-color:var(--g-700)}
.faq__q{display:flex;justify-content:space-between;align-items:center;width:100%;padding:32px 0;text-align:left;cursor:none;font-weight:300;font-size:clamp(18px,1.6vw,26px);letter-spacing:-.01em;color:inherit;line-height:1.3;gap:32px}
.faq__q-icon{flex:none;width:24px;height:24px;position:relative}
.faq__q-icon::before,.faq__q-icon::after{content:'';position:absolute;left:50%;top:50%;width:18px;height:1px;background:currentColor;transform:translate(-50%,-50%);transition:transform .4s ease}
.faq__q-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq__item.is-open .faq__q-icon::after{transform:translate(-50%,-50%) rotate(0)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.65,0,.35,1)}
.faq__a-inner{padding-bottom:32px;font-size:16px;line-height:1.7;color:var(--g-600);max-width:80ch}
.section--dark .faq__a-inner{color:var(--g-300)}

/* CTA générique en pleine largeur */
.cta-band{background:#000;color:#fff;padding:clamp(30px,10vw,160px) var(--pad-x);text-align:center;position:relative;overflow:hidden}
.cta-band__bg{position:absolute;inset:0;z-index:0}
.cta-band__bg img{width:100%;height:100%;object-fit:cover;opacity:.18;filter:saturate(0)}
.cta-band__inner{position:relative;z-index:2;max-width:1200px;margin:0 auto}
.cta-band__title{font-weight:200;font-size:clamp(36px,6vw,96px);line-height:.96;letter-spacing:-.03em;text-transform:uppercase}
.cta-band__title em{font-style:italic;font-weight:200;color:var(--g-400)}
.cta-band__sub{margin:36px auto 48px;max-width:60ch;color:var(--g-300);font-size:17px;line-height:1.6}
.cta-band__actions{display:inline-flex;flex-wrap:wrap;gap:16px;justify-content:center}
.btn{display:inline-flex;align-items:center;gap:18px;padding:20px 32px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:400;transition:all .4s cubic-bezier(.65,0,.35,1);border:1px solid currentColor}
.btn--solid{background:#fff;color:#000;border-color:#fff}
.btn--solid:hover{background:transparent;color:#fff}
.btn--ghost{background:transparent;color:#fff}
.btn--ghost:hover{background:#fff;color:#000}
.btn--ink{background:#000;color:#fff;border-color:#000}
.btn--ink:hover{background:transparent;color:#000}
.btn svg{transition:transform .4s cubic-bezier(.65,0,.35,1)}
.btn:hover svg{transform:translateX(6px)}

/* ============ FOOTER ============ */
.footer{background:#000;color:#fff;padding:96px var(--pad-x) 28px;border-top:1px solid #1a1a1a}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:80px;border-bottom:1px solid #1a1a1a}
.footer h4{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--g-400);margin-bottom:24px;font-weight:400}
.footer__col p, .footer__col a{display:block;font-size:15px;color:#e5e5e5;margin-bottom:10px;font-weight:300;transition:color .3s}
.footer__col a:hover{color:#fff;text-decoration:underline}
.footer__brand p{max-width:38ch;color:var(--g-400);margin-top:18px}
.footer__brand img{width:64px;filter:invert(1)}
.ig-feed{padding:80px 0 24px;display:flex;flex-direction:column;gap:32px}
.ig-feed__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.ig-feed__handle{display:flex;align-items:center;gap:18px;color:#fff}
.ig-feed__icon{width:36px;height:36px;color:#fff;flex:none}
.ig-feed__eyebrow{display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--g-400);font-weight:400;margin-bottom:6px}
.ig-feed__name{font-weight:200;font-size:clamp(28px,3.2vw,48px);line-height:1;letter-spacing:-.02em}
.ig-feed__follow{display:inline-flex;align-items:center;gap:14px;border:1px solid #2a2a2a;padding:14px 22px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;transition:background .3s ease,border-color .3s ease}
.ig-feed__follow:hover{background:#fff;color:#000;border-color:#fff}
.ig-feed__follow svg{width:16px;height:16px}
.ig-feed__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.ig-feed__grid--live{display:block;min-height:280px;background:transparent}
.ig-feed__grid--live behold-widget{display:block;min-height:280px;--behold-row-gap:6px;--behold-column-gap:6px;--behold-border-radius:0;color-scheme:dark}
.ig-feed__grid--live behold-widget img{filter:saturate(0) brightness(.78);transition:filter .6s ease,transform 1.2s cubic-bezier(.2,.8,.2,1)}
.ig-feed__grid--live behold-widget a:hover img{filter:saturate(1) brightness(1);transform:scale(1.04)}
.ig-post{position:relative;overflow:hidden;aspect-ratio:1/1;background:#0a0a0a;display:block}
.ig-post img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(0) brightness(.78);transition:filter .6s ease,transform 1.2s cubic-bezier(.2,.8,.2,1)}
.ig-post:hover img{filter:saturate(1) brightness(1);transform:scale(1.05)}
.ig-post::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.55) 100%);pointer-events:none;opacity:0;transition:opacity .3s ease}
.ig-post:hover::after{opacity:1}
.ig-feed__cta{display:inline-flex;align-items:center;gap:14px;align-self:flex-start;color:var(--g-400);font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:18px 0;border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a;width:100%;justify-content:space-between;transition:color .3s ease}
.ig-feed__cta:hover{color:#fff}
.ig-feed__cta svg{width:16px;height:16px}
.ig-feed behold-widget{--behold-row-gap:6px;--behold-column-gap:6px;--behold-border-radius:0;color-scheme:dark}
@media (max-width:900px){
  .ig-feed{padding:56px 0 16px}
  .ig-feed__grid{grid-template-columns:repeat(3,1fr)}
  .ig-feed__head{flex-direction:column;align-items:flex-start}
}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--g-400);padding-top:24px}
.footer__bottom .legal a{margin-left:24px}
@media (max-width:900px){.footer__grid{grid-template-columns:1fr 1fr;gap:32px}.footer__bottom{flex-direction:column;gap:16px;text-align:center}.footer__bottom .legal a{margin:0 12px}}

/* ============ HELPERS REVEAL / FADE ============ */
.fade-up{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.8,.2,1)}
.fade-up.is-in{opacity:1;transform:none}

/* ============ NOISE OVERLAY ============ */
.noise{position:fixed;inset:0;z-index:8000;pointer-events:none;opacity:.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>")}

/* ============ FORMS ============ */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-field{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}
.form-field--full{grid-column:1/-1}
.form-field label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--g-600);font-weight:400}
.form-field input,
.form-field select,
.form-field textarea{font:inherit;font-size:16px;color:var(--ink);background:transparent;border:0;border-bottom:1px solid var(--g-300);padding:14px 0;outline:0;transition:border-color .3s}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{border-bottom-color:var(--ink)}
.form-field textarea{min-height:120px;resize:vertical}
.section--dark .form-field label{color:var(--g-400)}
.section--dark .form-field input,
.section--dark .form-field select,
.section--dark .form-field textarea{color:#fff;border-bottom-color:var(--g-700)}
.section--dark .form-field input:focus,
.section--dark .form-field select:focus,
.section--dark .form-field textarea:focus{border-bottom-color:#fff}
@media (max-width:700px){.form-row{grid-template-columns:1fr}}

/* ====== Mobile : les titres XL s'enroulent naturellement (on neutralise les retours forcés) ====== */
@media (max-width:600px){
  h1 br, h2 br, .teaser__title br, .hero__title br, .page-hero__title br, .search-hero h1 br, .cta-band__title br, .cta-conf__title br { display:none; }
  .hero__title, .page-hero__title, .search-hero h1, .teaser__title, .sec-head h2, .cta-band__title, .cta-conf__title { overflow-wrap:break-word; }
}
/* ====== Mobile : empêche les colonnes de grille de déborder (min-width:auto -> 0) ====== */
@media (max-width:1100px){
  .contact-grid > *, .vh-grid > *, .svc-page-intro > *, .manifesto__grid > *,
  .teaser-points__grid > *, .feature-grid > *, .detail-item > *, .footer__grid > * { min-width:0; }
}
