/* =================================================================
   SILLAGE — Feuille de style principale
   Maison de signature olfactive · luxe discret & statuaire
   Palette minérale, or sourd jamais brillant, motif halo en filigrane.
   ================================================================= */

@import url("../fonts/fonts.css");

:root{
  /* — Couleurs de la charte — */
  --albatre:#faf8f3;   /* fond clair principal */
  --platre:#f4f1ea;    /* aplats secondaires */
  --gold:#9a7b4f;      /* or sourd — accents, filets, icônes (charte) */
  --gold-ink:#7d5f37;  /* or profond — petit texte sur fond clair (contraste AA ≥ 4.5:1) */
  --gold-l:#c9a86f;    /* or clair — accents sur fond sombre */
  --stone:#6e6a63;     /* texte secondaire */
  --ink:#1c1916;       /* texte, fonds sombres */
  --ink-2:#13110f;     /* noir plus profond */
  --line:#d8d2c7;      /* filets clairs */
  --line-d:#2c2620;    /* filets sur fond sombre */

  /* — Typographies — */
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Jost','Helvetica Neue',Arial,sans-serif;

  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* — Reset léger — */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);font-weight:300;color:var(--ink);
  background:var(--albatre);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--gold);color:var(--albatre)}

/* — Accessibilité : focus visible & skip-link — */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--albatre);
  padding:12px 20px;z-index:200;font-size:13px;letter-spacing:.1em}
.skip:focus{left:8px;top:8px}

/* =================================================================
   Primitives typographiques
   ================================================================= */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.wrap-narrow{max-width:860px;margin:0 auto;padding:0 40px}

.kicker{font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold-ink);font-weight:500}
.kicker.light{color:var(--gold-l)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:.01em;line-height:1.12}
h2{font-size:clamp(30px,4vw,50px)}
h3{font-weight:500;font-size:clamp(22px,2.4vw,28px)}

p.lead{font-family:var(--serif);font-size:clamp(19px,2.2vw,24px);
  color:#34302a;line-height:1.65;font-weight:400}
.muted{color:var(--stone)}
.serif-italic{font-family:var(--serif);font-style:italic}

.rule{width:64px;height:1px;background:var(--gold);border:0;margin:34px 0}
.rule.center{margin-left:auto;margin-right:auto}

/* — Boutons — */
.btn{display:inline-block;font-family:var(--sans);font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;font-weight:400;padding:16px 34px;border:1px solid currentColor;
  color:var(--ink);text-decoration:none;background:transparent;cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease)}
.btn:hover,.btn:focus-visible{background:var(--ink);color:var(--albatre);border-color:var(--ink)}
.btn.light{color:var(--albatre)}
.btn.light:hover,.btn.light:focus-visible{background:var(--albatre);color:var(--ink);border-color:var(--albatre)}
.btn.solid{background:var(--ink);color:var(--albatre);border-color:var(--ink)}
.btn.solid:hover,.btn.solid:focus-visible{background:transparent;color:var(--ink)}

/* =================================================================
   En-tête / navigation
   ================================================================= */
header.site{position:fixed;top:0;left:0;right:0;z-index:90;padding:24px 0;
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px}
header.site.scrolled{background:rgba(250,248,243,.92);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  padding:13px 0;box-shadow:0 1px 0 var(--line)}

/* Logotype texte — gravé, capitales espacées */
.brandmark{display:flex;align-items:center;gap:14px;text-decoration:none}
.brandmark .seal{width:30px;height:30px;opacity:.95;transition:opacity .4s}
.brandmark .wordmark{font-family:var(--serif);font-size:24px;letter-spacing:.34em;
  padding-left:.34em;line-height:1;color:var(--albatre);transition:color .4s var(--ease)}
header.site.scrolled .brandmark .wordmark{color:var(--ink)}
/* Sur les pages à héros clair, forcer l'encre dès le départ */
header.site.on-light .brandmark .wordmark{color:var(--ink)}
header.site.on-light nav.primary a{color:var(--ink)}

nav.primary{display:flex;align-items:center;gap:30px}
nav.primary a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--albatre);text-decoration:none;opacity:.86;transition:color .35s,opacity .35s}
nav.primary a:hover{opacity:1;color:var(--gold-l)}
nav.primary a[aria-current="page"]{opacity:1;color:var(--gold-l)}
header.site.scrolled nav.primary a{color:var(--ink)}
header.site.scrolled nav.primary a:hover,
header.site.scrolled nav.primary a[aria-current="page"]{color:var(--gold)}

/* Sélecteur de langue */
.lang{display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase}
.lang a{text-decoration:none;color:inherit;opacity:.55;transition:opacity .3s}
.lang a:hover{opacity:.9}
.lang a.active{opacity:1;color:var(--gold-l)}
.lang .sep{opacity:.35}
header.site.scrolled .lang,header.site.on-light .lang{color:var(--ink)}
header.site.scrolled .lang a.active,header.site.on-light .lang a.active{color:var(--gold)}

/* CTA d'en-tête */
.nav-cta{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;
  text-decoration:none;color:var(--albatre);border:1px solid rgba(201,168,111,.5);
  padding:10px 18px;transition:.35s}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
header.site.scrolled .nav-cta,header.site.on-light .nav-cta{color:var(--ink);border-color:var(--line)}
header.site.scrolled .nav-cta:hover,header.site.on-light .nav-cta:hover{background:var(--ink);color:var(--albatre);border-color:var(--ink)}

/* Bouton menu mobile */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;
  cursor:pointer;padding:8px;z-index:120}
.burger span{width:24px;height:1.4px;background:var(--albatre);transition:.35s var(--ease)}
header.site.scrolled .burger span,header.site.on-light .burger span{background:var(--ink)}
.menu-open .burger span:nth-child(1){transform:translateY(6.4px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-6.4px) rotate(-45deg)}
.menu-open .burger span{background:var(--albatre)!important}

/* =================================================================
   Héros — accueil (sombre, halo animé) & héros de page
   ================================================================= */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;
  background:radial-gradient(120% 80% at 50% 18%,#2b2620 0%,var(--ink) 55%,var(--ink-2) 100%);
  color:var(--albatre)}
.hero .wrap{position:relative;z-index:3;text-align:center;
  padding-top:96px;padding-bottom:64px;width:100%}
.hero .name{font-family:var(--serif);font-weight:300;
  font-size:clamp(58px,13vw,150px);letter-spacing:.32em;padding-left:.32em;
  line-height:1;margin-bottom:18px}
.hero .base{font-family:var(--serif);font-style:italic;
  font-size:clamp(20px,3vw,30px);color:#cbbfaa}
.hero .sub{font-size:12px;letter-spacing:.34em;text-transform:uppercase;
  color:#9d958a;margin-bottom:38px}
.hero-halo{position:absolute;inset:0;z-index:1;display:flex;align-items:center;
  justify-content:center;pointer-events:none}
.hero-halo img,.hero-halo svg{width:min(980px,98vw);height:auto;opacity:.85;
  animation:breathe 9s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:.92;transform:scale(1.035)}}
/* Révélation lente du nom au chargement */
.hero .name,.hero .base,.hero .kicker,.hero .btn,.hero .rule{
  opacity:0;animation:rise 1.2s var(--ease) forwards}
.hero .kicker{animation-delay:.15s}
.hero .name{animation-delay:.3s}
.hero .base{animation-delay:.6s}
.hero .rule{animation-delay:.8s}
.hero .btn{animation-delay:.95s}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .hero-halo img,.hero-halo svg{animation:none}
  .hero .name,.hero .base,.hero .kicker,.hero .btn,.hero .rule{opacity:1;animation:none}
}
.hero-glow{position:absolute;inset:0;z-index:0;
  background:radial-gradient(50% 38% at 50% 34%,rgba(154,123,79,.20),transparent 70%)}
.scroll-i{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#9d958a;z-index:3}
.scroll-i::after{content:"";display:block;width:1px;height:34px;margin:12px auto 0;
  background:linear-gradient(var(--gold),transparent);animation:scrolldot 2.4s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:scaleY(.2)}40%{opacity:1}100%{opacity:0;transform:scaleY(1) translateY(8px)}}

/* Héros de page intérieure (sombre, sobre) */
.page-hero{position:relative;padding:190px 0 96px;
  background:radial-gradient(120% 120% at 50% 0%,#2b2620,var(--ink) 60%,var(--ink-2));
  color:var(--albatre);overflow:hidden}
.page-hero .wrap{position:relative;z-index:2;max-width:900px}
.page-hero .kicker{color:var(--gold-l)}
.page-hero h1{font-size:clamp(40px,6vw,76px);margin:18px 0 22px;font-weight:300;letter-spacing:.02em}
.page-hero p.lead{color:#efe9dd;max-width:640px}
/* Lisibilité du texte de héros sur fonds photo clairs : halo sombre (sans re-teinter l'image) */
.page-hero .wrap .kicker,.page-hero .wrap h1,.page-hero .wrap p.lead{
  text-shadow:0 2px 10px rgba(8,7,5,.85),0 1px 30px rgba(8,7,5,.6)}
.page-hero .motif-bg{position:absolute;inset:0;z-index:1;opacity:.5;
  background-image:url("../img/motif.svg");background-size:520px;mix-blend-mode:screen}
/* Héros avec photographie de fond (volute / atmosphère) + voile pour lisibilité */
.page-hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
/* Voile universel (robuste sur images claires ET sombres) :
   - dégradé gauche solide → texte + navigation lisibles partout ;
   - transparent à droite → couleurs réelles, image impactante ;
   - léger assombrissement en haut pour la navigation fixe. */
.page-hero .hero-veil{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(102deg,rgba(12,11,9,.72) 0%,rgba(12,11,9,.48) 28%,rgba(12,11,9,.16) 50%,rgba(12,11,9,0) 68%),
    linear-gradient(180deg,rgba(12,11,9,.34) 0%,rgba(12,11,9,0) 16%)}

/* =================================================================
   Sections génériques
   ================================================================= */
section{padding:clamp(80px,11vw,128px) 0}
.section-head{max-width:720px;margin:0 auto 60px}
.section-head.center{text-align:center}
.section-head h2{margin-top:16px}
.section-head p.lead{margin-top:22px}

.bg-albatre{background:var(--albatre)}
.bg-platre{background:var(--platre)}
.bg-ink{background:var(--ink);color:var(--albatre)}
.bg-ink h2,.bg-ink h3{color:var(--albatre)}
.bg-ink .kicker{color:var(--gold-l)}

/* Filigrane du motif halo */
.motif-soft{position:relative}
.motif-soft::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("../img/motif.svg");background-size:560px;opacity:.35}
.motif-soft>*{position:relative;z-index:1}

/* — Manifeste — */
.manifeste{text-align:center}
.manifeste .wrap-narrow>p{font-family:var(--serif);font-size:clamp(22px,2.8vw,30px);
  line-height:1.6;color:#2c2823;margin-top:26px}
.manifeste .q{color:var(--gold);font-style:italic}

/* — Bloc fendu texte / visuel — */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split.reverse .visual{order:2}
.split .txt{padding:clamp(56px,8vw,110px) clamp(34px,5vw,70px);
  display:flex;flex-direction:column;justify-content:center;gap:20px}
.split .visual{min-height:480px;position:relative;overflow:hidden}

/* Surfaces "matière" (marbre/albâtre/plâtre) en CSS — substitut photo */
.matter{background:
  radial-gradient(120% 90% at 20% 10%,#fdfcf9,transparent 55%),
  radial-gradient(120% 120% at 90% 90%,#cabfa9,transparent 60%),
  linear-gradient(150deg,#efe9df 0%,#e0d6c5 55%,#cabda7 100%);
  background-color:#e6ddcf}
.matter-dark{background:
  radial-gradient(120% 90% at 80% 10%,#36302a,transparent 55%),
  linear-gradient(150deg,#211d18,#13110f);
  background-color:var(--ink)}
.matter-veined{position:absolute;inset:0;opacity:.5}

.photo-slot{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:flex-start}
.photo-slot .tag{margin:18px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(28,25,22,.45);background:rgba(250,248,243,.55);padding:6px 12px;border:1px dashed rgba(28,25,22,.25)}

/* =================================================================
   Deux univers (accueil) — Hôtellerie / Aéroports
   ================================================================= */
.universes{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-d)}
.universe{position:relative;min-height:560px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:clamp(40px,5vw,64px);overflow:hidden;
  background:var(--ink);color:var(--albatre);text-decoration:none}
.universe .uvisual{position:absolute;inset:0;z-index:0;transition:transform 1.2s var(--ease)}
.universe:hover .uvisual{transform:scale(1.04)}
.universe::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(19,17,15,.15) 0%,rgba(19,17,15,.78) 78%)}
.universe>*{position:relative;z-index:2}
.universe .kicker{color:var(--gold-l)}
.universe h3{font-size:clamp(26px,3vw,36px);margin:14px 0 12px;color:var(--albatre)}
.universe p{color:#c4bbac;max-width:42ch;font-size:15px}
.universe .more{margin-top:22px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold-l);display:inline-flex;align-items:center;gap:10px}
.universe .more::after{content:"→";transition:transform .4s var(--ease)}
.universe:hover .more::after{transform:translateX(6px)}

/* =================================================================
   Collections (sombre)
   ================================================================= */
.collection-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line-d);border:1px solid var(--line-d)}
.collection{background:var(--ink);padding:46px 30px;min-height:300px;
  display:flex;flex-direction:column;transition:background .4s var(--ease)}
.collection:hover{background:#221d18}
.collection .n{font-family:var(--serif);font-size:42px;color:var(--gold);opacity:.55;line-height:1}
.collection h3{color:var(--albatre);margin:18px 0 14px}
.collection p{font-size:14px;color:#a89e8f;line-height:1.7}
.collection .tag{margin-top:auto;padding-top:18px;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold-l)}

/* =================================================================
   Approche — étapes
   ================================================================= */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.steps.three{grid-template-columns:repeat(3,1fr)}
.step .num{font-family:var(--serif);font-size:19px;color:var(--gold-ink);
  border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:18px}
.step h3{margin-bottom:10px}
.step p{font-size:15px;color:var(--stone)}

/* =================================================================
   Listes de bénéfices / arguments (pages univers)
   ================================================================= */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.features.two{grid-template-columns:repeat(2,1fr)}
.feature .ic{font-size:26px;color:var(--gold);line-height:1}
.feature h3{margin:16px 0 10px;font-size:23px}
.feature p{font-size:15px;color:var(--stone)}

/* Cas d'usage (chips/cartes) */
.usecases{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.usecase{background:var(--albatre);padding:40px 38px}
.usecase .lab{font-family:var(--serif);font-size:24px;color:var(--ink)}
.usecase p{font-size:14.5px;color:var(--stone);margin-top:10px}
.bg-ink .usecases{background:var(--line-d)}
.bg-ink .usecase{background:var(--ink)}
.bg-ink .usecase .lab{color:var(--albatre)}
.bg-ink .usecase p{color:#a89e8f}

/* Bandeau de preuve / héritage */
.proof{display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line-d);border-bottom:1px solid var(--line-d)}
.proof .it{padding:44px 30px;text-align:center;border-right:1px solid var(--line-d)}
.proof .it:last-child{border-right:0}
.proof .it .big{font-family:var(--serif);font-size:clamp(28px,4vw,40px);color:var(--gold-l)}
.proof .it p{font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;
  color:#9d958a;margin-top:10px}

/* =================================================================
   Diffusion — échelle de couverture, stats CVC, photos, cartes lieux
   ================================================================= */
/* Échelle de couverture (30 m² → 1 700 m²+) */
.scale-bar{display:flex;flex-wrap:wrap;border:1px solid var(--line);margin-top:42px;overflow:hidden}
.scale-bar div{flex:1 1 0;min-width:130px;padding:18px 12px;border-right:1px solid var(--line);text-align:center}
.scale-bar div:last-child{border-right:0}
.scale-bar b{display:block;font-family:var(--serif);font-size:24px;color:var(--gold-ink);font-weight:500}
.scale-bar span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);margin-top:5px;display:block}
.bg-ink .scale-bar,.page-hero .scale-bar{border-color:var(--line-d)}
.bg-ink .scale-bar div,.page-hero .scale-bar div{border-color:var(--line-d)}
.bg-ink .scale-bar b,.page-hero .scale-bar b{color:var(--gold-l)}
.bg-ink .scale-bar span,.page-hero .scale-bar span{color:#9d958a}

/* Stats techniques CVC (fond sombre) */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:36px}
.stat-grid .stat{background:#211c16;border:1px solid var(--line-d);padding:22px 20px}
.stat-grid .stat b{font-family:var(--serif);font-size:24px;color:var(--gold-l);font-weight:500;display:block;margin-bottom:6px}
.stat-grid .stat span{font-size:12.5px;color:#a89e8f;line-height:1.5}
@media(max-width:820px){.stat-grid{grid-template-columns:1fr 1fr}}

/* Photographie pleine dans un bloc fendu */
.split .visual.photo{padding:0;background:none;border:0}
.split .visual.photo img{width:100%;height:100%;min-height:460px;object-fit:cover;display:block}
@media(max-width:820px){.split .visual.photo img{min-height:300px}}

/* Image CVC encadrée (section sombre) */
.feature-photo{margin-top:26px;border:1px solid var(--line-d);overflow:hidden}
.feature-photo img{width:100%;height:auto;display:block}

/* Chip de couverture sur les cartes « lieux » */
.cov{display:inline-block;margin-top:14px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold-ink);border:1px solid var(--line);border-radius:40px;padding:4px 13px}
.feature .ic{display:block}
.feature .ic svg{width:40px;height:40px;color:var(--gold)}

/* =================================================================
   Gammes de diffusion (page Diffusion, sobre)
   ================================================================= */
.ranges{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line)}
.range{background:var(--albatre);padding:46px 42px}
.range .code{font-family:var(--serif);font-size:13px;letter-spacing:.26em;
  color:var(--gold-ink);padding-left:.26em}
.range h3{margin:10px 0 12px}
.range p{font-size:15px;color:var(--stone)}
.range .meta{margin-top:18px;font-size:12px;letter-spacing:.1em;color:var(--stone);
  border-top:1px solid var(--line);padding-top:14px}

/* =================================================================
   La fondatrice — récit + portrait traité
   Le traitement d'image (filtre + voile chaud) harmonise AUTOMATIQUEMENT
   toute photographie déposée avec le thème : lumière rasante, désaturation
   minérale, touche d'or sourd. Remplacer simplement le src de l'image.
   ================================================================= */
.founder{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(38px,6vw,84px);
  align-items:center}
.founder.reverse{grid-template-columns:1.18fr .82fr}
.founder.reverse .founder-portrait{order:2}
.founder-portrait{position:relative;aspect-ratio:4/5;overflow:hidden;
  background:#e6ddcf;border:1px solid var(--line);
  box-shadow:0 26px 60px rgba(28,25,22,.14)}
.founder-portrait img{width:100%;height:100%;object-fit:cover;display:block;
  /* harmonisation au thème : désaturation minérale + chaleur + contraste doux */
  filter:grayscale(.42) sepia(.20) contrast(1.04) brightness(1.02) saturate(.9)}
.founder-portrait::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(160deg,rgba(154,123,79,.14),rgba(28,25,22,.20));
  mix-blend-mode:multiply}
.founder-portrait .photo-tag{position:absolute;left:16px;bottom:16px;z-index:2;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(28,25,22,.55);background:rgba(250,248,243,.7);
  padding:6px 12px;border:1px dashed rgba(28,25,22,.3)}
.founder-text .lead.quote{font-style:italic;color:#2c2823}
.founder-text .sign{font-family:var(--serif);font-style:italic;font-size:20px;
  color:var(--gold-ink);margin-top:26px;padding-top:18px;
  border-top:1px solid var(--line);display:inline-block}
/* Signature manuscrite de la fondatrice */
.founder-text .sign-block{margin-top:28px;padding-top:22px;border-top:1px solid var(--line)}
.founder-text .sign-img{width:180px;max-width:60%;height:auto;display:block;margin-bottom:8px}
.founder-text .sign-cap{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-ink)}
@media (max-width:820px){
  .founder,.founder.reverse{grid-template-columns:1fr;gap:34px}
  .founder.reverse .founder-portrait{order:0}
  .founder-portrait{max-width:420px;margin:0 auto}
}

/* =================================================================
   Engagement / RSE
   ================================================================= */
.rse-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:34px;margin-top:50px}
.rse-it{font-family:var(--serif)}
.rse-it .ic{font-size:30px;color:var(--gold)}
.rse-it h4{font-family:var(--serif);font-weight:500;font-size:18px;margin:12px 0 6px}
.rse-it p{font-family:var(--sans);font-size:13px;color:var(--stone)}
.disclaimer{font-size:11.5px;color:var(--stone);margin-top:38px;letter-spacing:.03em;font-style:italic}

/* =================================================================
   Contact + formulaire
   ================================================================= */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch}
.contact-aside{background:var(--ink);color:var(--albatre);
  padding:clamp(56px,7vw,96px) clamp(34px,5vw,64px);display:flex;flex-direction:column;justify-content:center}
.contact-aside h2{color:var(--albatre)}
.contact-aside .lead{color:#cbbfaa;margin-top:22px}
.contact-aside .coords{margin-top:46px;font-size:13.5px;letter-spacing:.04em;line-height:2.1;color:#b7ad9d}
.contact-aside .coords a{color:var(--gold-l);text-decoration:none}
.contact-aside .coords .lab{display:block;font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:#8a8175;margin:18px 0 4px}

.contact-form{background:var(--platre);
  padding:clamp(56px,7vw,96px) clamp(34px,5vw,64px);display:flex;flex-direction:column;justify-content:center}
.form-row{margin-bottom:24px}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:20px}
label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--stone);margin-bottom:9px}
.req{color:var(--gold)}
input,select,textarea{width:100%;font-family:var(--sans);font-weight:300;font-size:15px;
  color:var(--ink);background:var(--albatre);border:1px solid var(--line);
  padding:13px 15px;transition:border-color .3s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}
textarea{resize:vertical;min-height:130px}
select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239a7b4f' fill='none' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:12px;color:var(--stone);margin-top:6px}
.form-status{margin-top:18px;font-size:14px;display:none}
.form-status.show{display:block}
.form-status.ok{color:#5a7d52}
.form-status.err{color:#9a4f4f}
.consent{display:flex;align-items:flex-start;gap:12px;font-size:12.5px;color:var(--stone);
  letter-spacing:0;text-transform:none}
.consent input{width:auto;margin-top:3px}

/* =================================================================
   Pied de page
   ================================================================= */
footer.site{background:var(--ink-2);color:#8a8175;padding:72px 0 44px}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:48px;border-bottom:1px solid var(--line-d)}
footer.site .wordmark{font-family:var(--serif);font-size:30px;letter-spacing:.3em;
  padding-left:.3em;color:#a89e8f;margin-bottom:14px}
footer.site .tag{font-family:var(--serif);font-style:italic;font-size:16px;color:#9a9183}
footer.site h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-l);font-family:var(--sans);font-weight:500;margin-bottom:18px}
footer.site nav a,footer.site .fcoord{display:block;font-size:13px;color:#9d948a;
  text-decoration:none;padding:6px 0;letter-spacing:.04em;transition:color .3s}
footer.site nav a:hover{color:var(--gold-l)}
footer.site .legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding-top:28px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#928979}

/* =================================================================
   Animations au défilement
   ================================================================= */
.fade{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.fade.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .fade{opacity:1;transform:none;transition:none}
  .universe:hover .uvisual{transform:none}
}

/* =================================================================
   Responsive
   ================================================================= */
@media (max-width:980px){
  .collection-grid,.steps,.features,.rse-grid{grid-template-columns:1fr 1fr}
  .steps.three,.features.two{grid-template-columns:1fr 1fr}
  footer.site .cols{grid-template-columns:1fr 1fr;gap:34px}
}
@media (max-width:820px){
  .split,.universes,.contact-grid,.ranges,.usecases{grid-template-columns:1fr}
  .split.reverse .visual{order:0}
  .split .visual{min-height:320px}
  .universe{min-height:440px}
  .proof{grid-template-columns:1fr}
  .proof .it{border-right:0;border-bottom:1px solid var(--line-d)}
  .proof .it:last-child{border-bottom:0}
}
@media (max-width:900px){
  .wrap,.wrap-narrow{padding:0 24px}
  nav.primary,.lang.head,.nav-cta{display:none}
  .burger{display:flex}
  /* Menu mobile en plein écran */
  .mobile-menu{position:fixed;inset:0;z-index:110;background:var(--ink);
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
    opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
  .menu-open .mobile-menu{opacity:1;visibility:visible}
  .mobile-menu a{font-family:var(--serif);font-size:26px;color:var(--albatre);
    text-decoration:none;padding:10px 0;letter-spacing:.04em}
  .mobile-menu a:hover,.mobile-menu a[aria-current="page"]{color:var(--gold-l)}
  .mobile-menu .mlang{margin-top:30px;display:flex;gap:14px;font-size:12px;
    letter-spacing:.18em;text-transform:uppercase;color:#8a8175}
  .mobile-menu .mlang a{font-family:var(--sans);font-size:12px}
  .steps,.steps.three,.features,.features.two,.collection-grid,.rse-grid{grid-template-columns:1fr}
  section{padding:72px 0}
}
@media (min-width:901px){.mobile-menu{display:none}}

@media (max-width:560px){
  footer.site .cols{grid-template-columns:1fr}
  .form-row.two{grid-template-columns:1fr}
  /* Le mot SILLAGE ne doit jamais déborder sur petit écran */
  .hero .name{font-size:clamp(44px,12.5vw,150px);letter-spacing:.18em;padding-left:.18em}
  .page-hero h1{font-size:clamp(34px,8.5vw,76px)}
}
