:root{
  --bg:#faf6ed;
  --bg-alt:#f0e9d8;
  --paper:#ffffff;
  --ink:#0a0807;
  --ink-soft:#2a2520;
  --muted:#7a6f63;
  --line:#dccfb5;
  --line-soft:#ebe2d0;
  --accent:#9a7438;
  --accent-dark:#6e5023;
  --shadow:0 20px 60px -20px rgba(10,8,6,.15);
  --shadow-lg:0 40px 100px -30px rgba(10,8,6,.22);
  --max:1400px;
  --max-text:720px;
  --gutter:clamp(1.25rem, 4vw, 3rem);
  --grain:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .07 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Texture grain ultra-discrète sur le body — donne de la profondeur */
body::before{
  content:"";position:fixed;inset:0;
  background-image:var(--grain);
  opacity:.5;pointer-events:none;z-index:1000;
  mix-blend-mode:multiply;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:"Inter","Helvetica Neue",Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:16.5px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"liga","kern","calt";
}
img,svg{max-width:100%;display:block}
a{color:var(--ink);text-decoration:none;transition:color .25s,opacity .25s}
a:hover{color:var(--accent-dark)}
::selection{background:var(--ink);color:var(--bg)}

/* ---------- Bandeau de transition entre pages ---------- */
@keyframes curtainRise{
  0%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}
.page-transition{
  position:fixed;inset:0;
  background:#0a0a0a;
  z-index:9999;
  transform-origin:bottom;
  animation:curtainRise 1s cubic-bezier(.7,.0,.3,1) forwards;
  pointer-events:none;
}

/* ---------- Type ---------- */
h1,h2,h3,h4{
  font-family:"Cormorant Garamond","Times New Roman",serif;
  font-weight:400;
  letter-spacing:-.005em;
  color:var(--ink);
  line-height:1.04;
  margin:0 0 .4em;
  text-wrap:balance;
}
.display{
  font-size:clamp(2.8rem, 7.5vw, 6.5rem);
  font-weight:300;
  line-height:.98;
  letter-spacing:-.025em;
}
h1{font-size:clamp(2.4rem, 5.2vw, 4.4rem);font-weight:300;letter-spacing:-.018em;line-height:1.05}
h2{font-size:clamp(1.9rem, 3.8vw, 3.2rem);font-weight:300;letter-spacing:-.014em;line-height:1.08}
h3{font-size:clamp(1.3rem, 1.8vw, 1.55rem);font-weight:500;letter-spacing:-.005em;line-height:1.2}
/* Accent italique poétique sur des mots-clés à mettre dans <em> à l'intérieur des h1/h2 */
h1 em, h2 em{
  font-style:italic;
  font-weight:300;
  color:var(--accent-dark);
}
.dark h1 em, .dark h2 em{color:#e6c98a}
.hero h1 em{color:#e6c98a}
p{margin:0 0 1.2em}
em{font-style:italic;color:var(--ink-soft)}
.lead{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.15rem, 1.6vw, 1.5rem);
  line-height:1.5;
  color:var(--ink-soft);
  font-weight:400;
  letter-spacing:-.003em;
  text-wrap:pretty;
}
.eyebrow{
  font-family:"Inter",sans-serif;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.7rem;
  font-weight:500;
  color:var(--ink);
  margin:0 0 1.4rem;
  font-feature-settings:"tnum";
}
.eyebrow.muted{color:var(--muted)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:1.25rem var(--gutter);
  transition:background .35s ease,border-color .35s ease,padding .35s ease,backdrop-filter .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.transparent{background:transparent}
.site-header.solid{
  background:rgba(250,246,237,.92);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom-color:rgba(220,207,181,.6);
  padding:.85rem var(--gutter);
}
.nav{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.brand{
  display:inline-block;line-height:0;
  transition:opacity .25s;
}
.brand:hover{opacity:.7}
.brand img{
  height:36px;width:auto;
  transition:height .35s cubic-bezier(.4,0,.2,1);
}
.site-header.solid .brand img{height:28px}
.brand .logo-light{display:none}
.site-header.transparent .brand .logo-dark{display:none}
.site-header.transparent .brand .logo-light{display:block}

.nav-links{
  display:flex;gap:2.2rem;align-items:center;list-style:none;margin:0;padding:0;
}
.nav-links a{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  font-weight:500;color:var(--ink);position:relative;padding:.45rem 0;
  transition:color .3s ease;
}
.site-header.transparent .nav-links a{color:#fff}
.nav-links a::after{
  content:"";position:absolute;left:50%;right:50%;bottom:0;
  height:1px;background:currentColor;
  transition:left .35s cubic-bezier(.2,.7,.2,1),right .35s cubic-bezier(.2,.7,.2,1);
}
.nav-links a:hover::after,.nav-links a.active::after{left:0;right:0}
.nav-links a.active{color:var(--accent-dark)}
.site-header.transparent .nav-links a.active{color:#e6c98a}
.nav-cta{
  border:1px solid currentColor;padding:.65rem 1.4rem;
  font-weight:500;
}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--ink);color:var(--bg) !important;border-color:var(--ink)}
.site-header.transparent .nav-cta:hover{background:#fff;color:var(--ink) !important;border-color:#fff}

.menu-toggle{
  display:none;background:none;border:0;cursor:pointer;
  width:36px;height:36px;padding:0;color:var(--ink);
}
.site-header.transparent .menu-toggle{color:#fff}
.menu-toggle span{
  display:block;width:24px;height:1px;background:currentColor;
  margin:6px auto;transition:transform .25s;
}

/* ---------- Hero ---------- */
.hero{
  position:relative;height:100vh;height:100svh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  background:#0a0807;color:#fff;overflow:hidden;
  padding:0 var(--gutter);
}
.hero-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.55) saturate(.9);
  transform:scale(1.04);
  animation:heroBreath 18s ease-in-out infinite alternate;
}
@keyframes heroBreath{
  0%{transform:scale(1.04)}
  100%{transform:scale(1.08)}
}
.hero-img::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at center, transparent 0%, rgba(10,8,6,.4) 100%),
    linear-gradient(180deg, rgba(10,8,6,.4) 0%, rgba(10,8,6,0) 30%, rgba(10,8,6,0) 65%, rgba(10,8,6,.75) 100%);
}
.hero-inner{
  position:relative;z-index:2;
  max-width:var(--max);width:100%;margin:0 auto;
  text-align:center;
}
.hero-mark{
  display:block;margin:0 auto 2.8rem;
  max-width:min(520px, 58vw);
  filter:drop-shadow(0 4px 30px rgba(0,0,0,.35));
}
.hero h1{
  font-size:clamp(1.3rem, 2.2vw, 2rem);
  font-weight:300;font-style:italic;
  color:#f0e6d2;
  max-width:36ch;margin:0 auto;
  letter-spacing:.005em;
  line-height:1.35;
  text-wrap:balance;
}
.hero-cite{
  margin:1.5rem 0 0;
  font-family:"Inter",sans-serif;
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  font-weight:500;
}
.hero-cite a{
  color:#d4a86a;
  display:inline-block;
  padding:.7rem 1.4rem;
  border:1px solid #d4a86a;
  position:relative;
  overflow:hidden;
  transition:color .4s ease, border-color .4s ease;
  z-index:1;
}
.hero-cite a::before{
  content:"";
  position:absolute;
  inset:0;
  background:#d4a86a;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
  z-index:-1;
}
.hero-cite a:hover{
  color:#fff;
  border-color:#fff;
}
.hero-cite a:hover::before{
  transform:translateY(0);
  background:rgba(255,255,255,.08);
}
.hero-meta{
  position:absolute;bottom:2.5rem;left:var(--gutter);right:var(--gutter);
  display:flex;justify-content:space-between;align-items:flex-end;
  z-index:2;color:#cdbfa8;
  font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;
}
.hero-meta a{color:#fff;text-decoration:none;transition:opacity .3s}
.hero-meta a:hover{opacity:.7}
.hero-meta .scroll{
  display:inline-flex;align-items:center;gap:.8rem;
}
.hero-meta .scroll::before{
  content:"";width:32px;height:1px;background:currentColor;
  transition:width .4s cubic-bezier(.2,.7,.2,1);
}
.hero-meta .scroll:hover::before{width:48px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:.95rem 2rem;
  font-family:"Inter",sans-serif;
  font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;font-weight:500;
  border:1px solid currentColor;cursor:pointer;
  background:transparent;color:var(--ink);
  transition:background .35s ease,color .35s ease,border-color .35s ease,transform .25s ease;
  position:relative;
}
.btn:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-dark:hover{background:var(--accent-dark);border-color:var(--accent-dark);color:var(--bg)}
.btn-light{color:#fff;border-color:#fff}
.btn-light:hover{background:#fff;color:var(--ink)}
.btn-arrow::after{
  content:"→";letter-spacing:0;margin-left:.6rem;
  display:inline-block;transition:transform .3s cubic-bezier(.2,.7,.2,1);
}
.btn-arrow:hover::after{transform:translateX(4px)}

/* ---------- Layout ---------- */
section{padding:clamp(4rem, 8.5vw, 8rem) var(--gutter)}
.wrap{max-width:var(--max);margin:0 auto}
.wrap-text{max-width:var(--max-text);margin:0 auto}
.alt{background:var(--bg-alt)}
.paper{background:var(--paper)}
.dark{background:#0a0a0a;color:#cdbfa8}
.dark h1,.dark h2,.dark h3{color:#fbf8f2}
.dark .eyebrow{color:#d4a86a}
.dark a{color:#e6c98a}
.dark .lead{color:#d4c9b3}

.split{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
}
.split.text-first{grid-template-columns:1.1fr 1fr}
.split.image-first{grid-template-columns:1fr 1.1fr}
.split-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2rem, 4vw, 3.5rem)}

/* En-tête de section : eyebrow+h2 à gauche, lead à droite, collapse en mobile */
.section-head{
  display:grid;grid-template-columns:1fr 2fr;
  gap:clamp(2rem, 5vw, 5rem);align-items:end;
  margin-bottom:3rem;
}

/* ---------- Manifeste / massive type block ---------- */
.manifeste{
  text-align:center;padding:clamp(6rem, 12vw, 11rem) var(--gutter);
}
.manifeste .display{max-width:18ch;margin:0 auto;}
.manifeste .lead{max-width:46ch;margin:2rem auto 0}

/* ---------- Featured (à l'affiche) ---------- */
.featured{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(2.5rem, 6vw, 5.5rem);align-items:center;
}
.featured-img{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:#1a1410;
  display:block;
  box-shadow:var(--shadow);
}
.featured-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1),opacity .3s,filter .5s;
}
a.featured-img{cursor:pointer}
a.featured-img:hover img{transform:scale(1.04);filter:brightness(1.05)}
.featured-tag{
  position:absolute;top:1.5rem;left:1.5rem;
  background:#fbf8f2;color:var(--ink);
  font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  padding:.55rem 1.1rem;
}
.featured h2{margin-bottom:1rem}
.featured-date{
  display:flex;gap:1.2rem;align-items:baseline;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.4rem 0;margin:1.8rem 0;
  font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted);
}
.featured-date strong{
  font-family:"Cormorant Garamond",serif;
  font-size:2.2rem;letter-spacing:-.01em;text-transform:none;
  color:var(--ink);font-weight:400;line-height:1;
}

/* ---------- Espaces (3 cards) ---------- */
.space-card{
  display:flex;flex-direction:column;gap:1.5rem;
}
.space-card .img{
  aspect-ratio:4/5;overflow:hidden;background:#1a1410;
}
.space-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.space-card:hover img{transform:scale(1.04)}
.space-card .num{
  font-family:"Cormorant Garamond",serif;
  font-size:.95rem;color:var(--accent);
  font-feature-settings:"tnum";
}
.space-card h3{margin:.2rem 0 .4rem;font-weight:400}
.space-card p{font-size:.95rem;color:var(--muted);margin:0}

/* ---------- Mizette feature ---------- */
.mizette-feature{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:clamp(2rem, 5vw, 5rem);align-items:flex-end;
}
.mizette-feature .img{aspect-ratio:3/4;overflow:hidden;background:#1a1410}
.mizette-feature .img img{width:100%;height:100%;object-fit:cover}

/* ---------- Quote ---------- */
.pull-quote{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.5rem, 3vw, 2.4rem);
  line-height:1.32;font-weight:300;font-style:italic;
  color:var(--ink-soft);
  max-width:32ch;margin:0 auto;text-align:center;
  letter-spacing:-.012em;
  text-wrap:balance;
}
.pull-quote::before,.pull-quote::after{
  content:"";display:block;width:36px;height:1px;background:var(--accent);
  margin:2.2rem auto;
}
.dark .pull-quote{color:#e8dfd0}
.dark .pull-quote::before,.dark .pull-quote::after{background:#d4a86a}

/* ---------- Page header ---------- */
.page-head{
  padding:clamp(7rem, 12vw, 10rem) var(--gutter) clamp(2.5rem, 5vw, 5rem);
  text-align:left;
  border-bottom:1px solid var(--line);
}
.page-head h1{
  font-size:clamp(2.6rem, 6vw, 5.2rem);
  line-height:1;
}
.page-head .wrap{display:grid;grid-template-columns:1fr 2fr;gap:clamp(2rem, 6vw, 6rem);align-items:end}
.page-head h1{margin:0}
.page-head .lead{margin:0;max-width:50ch}
@media (max-width:900px){
  .page-head .wrap{grid-template-columns:1fr}
}

/* ---------- Timeline ---------- */
.timeline{margin-top:2.5rem}
.timeline-row{
  display:grid;grid-template-columns:160px 1fr;gap:2.5rem;
  padding:2rem 0;
  border-bottom:1px solid var(--line);
}
.timeline-row:first-child{border-top:1px solid var(--line)}
.t-year{
  font-family:"Cormorant Garamond",serif;
  font-size:1.8rem;color:var(--ink);font-weight:400;line-height:1;
}
.t-content h3{margin:.1rem 0 .4rem;font-size:1.15rem;font-weight:500}
.t-content p{margin:0;color:var(--muted);font-size:.95rem}

/* ---------- Names list (illustres voyageurs) ---------- */
.names{
  columns:3;column-gap:3rem;
  font-family:"Cormorant Garamond",serif;
  font-size:1.25rem;line-height:2;
  list-style:none;padding:0;margin:0;
  color:var(--ink-soft);
}
.names li{
  break-inside:avoid;
  border-bottom:1px solid var(--line-soft);
  padding:.4rem 0;
}
.dark .names{color:#d4c9b3}
.dark .names li{border-color:#2a2018}

/* ---------- Gallery ---------- */
.gallery{
  display:grid;grid-template-columns:repeat(12,1fr);gap:6px;
}
.gallery a{
  display:block;overflow:hidden;background:#0a0907;position:relative;
  grid-column:span 4;aspect-ratio:1/1;
}
.gallery a.tall{grid-column:span 4;aspect-ratio:3/4}
.gallery a.wide{grid-column:span 8;aspect-ratio:16/9}
.gallery a.small{grid-column:span 3;aspect-ratio:1/1}
.gallery img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.7,.2,1),opacity .3s;
  opacity:.96;
}
.gallery a:hover img{transform:scale(1.04);opacity:1}

.lightbox{
  position:fixed;inset:0;background:rgba(8,7,6,.97);
  display:none;align-items:center;justify-content:center;z-index:100;
  padding:2rem;cursor:zoom-out;
}
.lightbox.open{display:flex}
.lightbox img{max-width:96vw;max-height:92vh;object-fit:contain}
.lightbox-close{
  position:absolute;top:1.5rem;right:1.5rem;
  background:none;border:0;color:#fff;font-size:2.4rem;cursor:pointer;
  line-height:1;
}

/* ---------- Media embed ---------- */
.media-embed{
  position:relative;width:100%;aspect-ratio:16/9;
  background:#0a0a0a;margin:1.5rem 0;
}
.media-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- Audio player ---------- */
.audio-card{
  background:var(--paper);border:1px solid var(--line);
  padding:2rem;display:flex;flex-direction:column;gap:1.4rem;
  margin:1.5rem 0;
}
.audio-card h3{margin:0;font-size:1.4rem;font-weight:500}
.audio-card .audio-meta{font-size:.86rem;color:var(--muted)}
.audio-card audio{
  width:100%;height:48px;
  filter:grayscale(.4) contrast(1.05);
}
.dark .audio-card{
  background:#15110d;border-color:#2a2018;color:#cdbfa8;
}
.dark .audio-card h3{color:#fbf8f2}

/* ---------- Citations / quotes block ---------- */
.quotes-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem, 3vw, 3rem);
  margin:2.5rem 0;
}
.quote-card{
  background:var(--bg);border-left:1px solid var(--accent);
  padding:1.8rem 2rem;
}
.quote-card p{
  font-family:"Cormorant Garamond",serif;
  font-size:1.4rem;line-height:1.4;
  font-style:italic;font-weight:400;
  color:var(--ink-soft);margin:0 0 1rem;
}
.quote-card cite{
  font-style:normal;font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
}
.dark .quote-card{background:#15110d;color:#cdbfa8}
.dark .quote-card p{color:#e8dfd0}

/* ---------- Archives gallery (articles scannés) ---------- */
.archives-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:.6rem;margin-top:2rem;
}
.archives-grid a{
  display:block;background:#0a0907;overflow:hidden;
  aspect-ratio:3/4;
}
.archives-grid img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s,opacity .3s;opacity:.95;
}
.archives-grid a:hover img{transform:scale(1.03);opacity:1}

/* ---------- Manuscripts (citations Mizette manuscrites) ---------- */
.manuscripts{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:clamp(1rem, 2.5vw, 2rem);
  margin-top:2.5rem;
}
.manuscript{
  background:var(--paper);
  padding:.5rem;
  box-shadow:var(--shadow);
}
.manuscript img{width:100%;height:auto;display:block}
.manuscript figcaption{
  font-family:"Cormorant Garamond",serif;
  font-style:italic;font-size:1rem;line-height:1.4;
  color:var(--ink-soft);padding:1rem .8rem .4rem;
  border-top:1px solid var(--line-soft);margin-top:.5rem;
  text-align:center;
}

/* ---------- Painting cards ---------- */
.paintings{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(1.5rem, 3vw, 3rem);
  margin-top:2.5rem;
}
.painting figure{margin:0}
.painting img{width:100%;height:auto;display:block;background:#1a1410}
.painting figcaption{
  margin-top:1.2rem;
  font-family:"Cormorant Garamond",serif;
}
.painting .p-title{
  font-size:1.5rem;font-style:italic;display:block;color:var(--ink);
  line-height:1.2;
}
.painting .p-meta{
  display:block;font-family:"Inter",sans-serif;
  font-size:.82rem;letter-spacing:.05em;
  color:var(--muted);margin-top:.5rem;line-height:1.5;
}
.painting .p-source{
  display:block;font-family:"Inter",sans-serif;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);margin-top:.6rem;font-weight:500;
}
.dark .painting .p-title{color:#fbf8f2}
.dark .painting .p-meta{color:#a39483}
.dark .painting .p-source{color:#d4a86a}

/* ---------- Axes Fondation (5 piliers) ---------- */
.axes{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:0;
  border-top:1px solid var(--line);
  margin-top:2.5rem;
}
.axe{
  border-bottom:1px solid var(--line);
  padding:2rem 1.5rem 2rem 0;
}
.axe + .axe{border-left:1px solid var(--line);padding-left:2rem}
.axe .axe-num{
  font-family:"Cormorant Garamond",serif;
  font-size:.85rem;letter-spacing:0;color:var(--accent);
  display:block;margin-bottom:.4rem;
}
.axe h3{font-size:1.3rem;margin:0 0 .8rem;font-weight:500}
.axe p{font-size:.95rem;color:var(--muted);margin:0}
.dark .axe{border-color:#2a2018}
.dark .axe + .axe{border-left-color:#2a2018}
.dark .axe p{color:#a39483}
@media (max-width:700px){
  .axe + .axe{border-left:0;padding-left:0}
}

/* ---------- Bio facts (medals/honors) ---------- */
.facts{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:0;border-top:1px solid var(--line);
  margin:2.5rem 0;
}
.fact{
  border-bottom:1px solid var(--line);
  padding:1.5rem 0;
}
.fact + .fact{border-left:1px solid var(--line);padding-left:2rem}
.fact .fact-num{
  font-family:"Cormorant Garamond",serif;
  font-size:2.2rem;line-height:1;display:block;margin-bottom:.4rem;
  color:var(--ink);font-weight:400;
}
.fact .fact-label{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
}
.dark .fact{border-color:#2a2018}
.dark .fact + .fact{border-left-color:#2a2018}
.dark .fact .fact-num{color:#fbf8f2}

@media (max-width:700px){
  .quotes-grid{grid-template-columns:1fr}
  .fact + .fact{border-left:0;padding-left:0;border-top:0}
}

/* ---------- Link list ---------- */
.link-list{list-style:none;padding:0;margin:0;border-top:1px solid var(--line)}
.link-list li{border-bottom:1px solid var(--line)}
.link-list a{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.6rem 0;color:var(--ink);
  transition:padding .25s,color .25s;
}
.link-list a:hover{color:var(--accent-dark);padding-left:.8rem}
.link-list .ll-source{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
}
.link-list .ll-title{
  font-family:"Cormorant Garamond",serif;
  font-size:1.4rem;line-height:1.2;display:block;margin-top:.3rem;
}
.link-list a::after{content:"→";color:var(--ink);font-size:1.2rem}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.4rem;max-width:600px}
.form label{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);display:block;margin-bottom:.5rem;font-weight:500;
}
.form input,.form textarea{
  width:100%;padding:0 0 .9rem;border:0;border-bottom:1px solid var(--line);
  background:transparent;font-family:inherit;font-size:1.05rem;color:var(--ink);
  transition:border-color .3s;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--ink)}
.form textarea{min-height:140px;resize:vertical}

/* ---------- Footer ---------- */
.site-footer{
  background:#0a0807;color:#a39483;
  padding:clamp(4rem, 7vw, 5.5rem) var(--gutter) 2rem;
  font-size:.9rem;
  position:relative;z-index:2;
}
.footer-top{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:3rem;
  padding-bottom:2.5rem;border-bottom:1px solid #2a2018;
}
.footer-brand img{height:38px;width:auto;margin-bottom:1.5rem;opacity:.92}
.site-footer h4{
  font-family:"Inter",sans-serif;
  color:#fbf8f2;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;
  font-weight:500;margin:0 0 1.4rem;
}
.site-footer a{color:#a39483;transition:color .3s ease}
.site-footer a:hover{color:#e6c98a}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:.6rem}
.site-footer li a{position:relative}
.site-footer li a:hover{padding-left:.4rem;transition:padding-left .3s ease,color .3s ease}
.footer-bottom{
  max-width:var(--max);margin:2rem auto 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.72rem;color:#5a4f44;letter-spacing:.08em;text-transform:uppercase;
}

/* ---------- Social ---------- */
.social{display:flex;gap:.6rem;align-items:center;margin-top:.8rem}
.social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;border:1px solid currentColor;border-radius:50%;
  color:#a39483;transition:all .25s;
}
.social a:hover{background:#e6c98a;color:#0a0a0a;border-color:#e6c98a}
.social svg{width:15px;height:15px;fill:currentColor}

/* ---------- Map ---------- */
.map-block{position:relative;padding:0}
.map-block iframe{display:block;width:100%;height:520px;border:0}
.map-meta{
  position:absolute;left:var(--gutter);bottom:2rem;
  background:var(--bg);padding:1.5rem 2rem;max-width:340px;
  box-shadow:var(--shadow);
}
.map-meta h3{margin:0 0 .5rem;font-size:1.3rem}
.map-meta p{margin:0;font-size:.92rem;color:var(--muted)}

/* ---------- Reveal animations ---------- */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s cubic-bezier(.2,.7,.2,1),
             transform 1s cubic-bezier(.2,.7,.2,1);
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:none}

/* Stagger les enfants des grilles : décale chaque carte de 80ms */
.reveal.in > *:nth-child(1){animation:fadeUp .8s .05s both}
.reveal.in > *:nth-child(2){animation:fadeUp .8s .15s both}
.reveal.in > *:nth-child(3){animation:fadeUp .8s .25s both}
.reveal.in > *:nth-child(4){animation:fadeUp .8s .35s both}
.reveal.in > *:nth-child(5){animation:fadeUp .8s .45s both}
.reveal.in > *:nth-child(6){animation:fadeUp .8s .55s both}
.reveal.in > *:nth-child(7){animation:fadeUp .8s .65s both}
.reveal.in > *:nth-child(8){animation:fadeUp .8s .75s both}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:none}
}

/* Respecte les préférences d'accessibilité */
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.in > *,*{
    animation:none !important;
    transition:none !important;
  }
}

/* ---------- Drop cap pour les paragraphes longs ---------- */
.wrap-text > p.first-letter::first-letter,
.dropcap::first-letter{
  font-family:"Cormorant Garamond",serif;
  float:left;
  font-size:5.2rem;
  line-height:.9;
  font-weight:400;
  padding:.3rem .6rem 0 0;
  color:var(--accent);
}

/* ---------- Séparateurs décoratifs ---------- */
.divider{
  display:block;width:60px;height:1px;
  background:var(--accent);
  margin:3rem auto;
  position:relative;
}
.divider::before,.divider::after{
  content:"";position:absolute;top:-2px;
  width:5px;height:5px;
  background:var(--accent);
  border-radius:50%;
}
.divider::before{left:-12px}
.divider::after{right:-12px}
.dark .divider{background:#d4a86a}
.dark .divider::before,.dark .divider::after{background:#d4a86a}

/* ---------- Smooth scroll ---------- */
html{scroll-behavior:smooth;scroll-padding-top:80px}

/* ---------- Lien souligné animé pour les liens inline dans wrap-text ---------- */
.wrap-text p a:not(.btn):not(.ll-source):not(.ll-title),
.wrap-text a:not(.btn):not([class]){
  position:relative;
  background-image:linear-gradient(currentColor, currentColor);
  background-size:100% 1px;
  background-repeat:no-repeat;
  background-position:0 100%;
  transition:background-size .4s cubic-bezier(.2,.7,.2,1);
}
.wrap-text p a:not(.btn):not(.ll-source):not(.ll-title):hover{
  background-size:100% 0;
}

/* ---------- Hover smooth sur les images cards (paintings) ---------- */
.painting figure{
  overflow:hidden;
  position:relative;
}
.painting img{
  transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .5s;
}
.painting figure:hover img{
  transform:scale(1.04);
  filter:brightness(1.05);
}

/* ---------- Manuscript cards : hover plus marqué ---------- */
.manuscript{
  transition:transform .4s cubic-bezier(.2,.7,.2,1),
             box-shadow .4s cubic-bezier(.2,.7,.2,1);
}
.manuscript:hover{
  transform:translateY(-6px);
  box-shadow:0 25px 50px -15px rgba(10,8,6,.25);
}

/* ---------- Manuscripts img reveal ---------- */
.manuscript img{transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.manuscript:hover img{transform:scale(1.02)}

/* ---------- Quote cards : élégance accrue ---------- */
.quote-card{
  transition:border-color .4s,transform .4s;
}
.quote-card:hover{
  border-left-width:3px;
  border-left-color:var(--accent-dark);
  transform:translateX(4px);
}

/* ---------- Pull-quote : entrée animée ---------- */
.pull-quote{
  position:relative;
}
.pull-quote::before{
  display:block;
  width:40px;height:1px;
  background:var(--accent);
  margin:0 auto 2rem;
  transition:width .9s cubic-bezier(.2,.7,.2,1) .2s;
}
.reveal:not(.in) .pull-quote::before{width:0}

/* ---------- Buttons : effet de remplissage ---------- */
.btn{
  position:relative;
  overflow:hidden;
  z-index:1;
}
.btn::before{
  content:"";position:absolute;inset:0;
  background:currentColor;
  transform:translateY(101%);
  transition:transform .4s cubic-bezier(.2,.7,.2,1);
  z-index:-1;
  opacity:.08;
}
.btn:hover::before{transform:translateY(0)}

/* ---------- Featured-img : overlay subtil au hover ---------- */
a.featured-img{position:relative;overflow:hidden}
a.featured-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 50%, rgba(0,0,0,.35) 100%);
  opacity:0;transition:opacity .4s;
}
a.featured-img:hover::after{opacity:1}

/* ---------- Bouton flottant "S'abonner" ---------- */
.float-subscribe{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:45;
  background:#0a0a0a;color:#fbf8f2;
  padding:1rem 1.4rem;
  font-family:"Inter",sans-serif;font-size:.74rem;
  letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  border:1px solid #0a0a0a;border-radius:50px;
  box-shadow:0 8px 30px -8px rgba(10,8,6,.4);
  text-decoration:none;
  display:inline-flex;gap:.6rem;align-items:center;
  transition:transform .3s,background .3s,color .3s,border-color .3s;
}
.float-subscribe:hover{
  transform:translateY(-2px);
  background:#d4a86a;color:#0a0a0a;border-color:#d4a86a;
}
.float-subscribe svg{width:14px;height:14px}
@media (max-width:600px){
  .float-subscribe{
    right:1rem;bottom:1rem;
    padding:.85rem 1.1rem;font-size:.7rem;
  }
  .float-subscribe span{display:none}
  .float-subscribe::after{content:"S'abonner"}
}

/* ---------- "La Voûte en 3 mots" ---------- */
.intro-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.intro-card{
  padding:clamp(3rem, 6vw, 4.5rem) clamp(1.5rem, 3vw, 2.5rem);
  text-align:center;
  position:relative;
  transition:background .45s ease;
}
.intro-card + .intro-card{border-left:1px solid var(--line)}
.intro-card:hover{background:rgba(154,116,56,.04)}
.intro-card .icon{
  display:block;width:36px;height:1px;background:var(--accent);
  margin:0 auto 2.2rem;
  transition:width .45s cubic-bezier(.2,.7,.2,1);
}
.intro-card:hover .icon{width:64px}
.intro-card h3{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.5rem,2.4vw,1.9rem);
  font-weight:400;font-style:italic;
  margin:0 0 1.1rem;color:var(--ink);
  letter-spacing:-.005em;
}
.intro-card p{
  font-size:.92rem;color:var(--muted);margin:0 0 1.8rem;line-height:1.65;
  max-width:32ch;margin-left:auto;margin-right:auto;
}
.intro-card a.more{
  font-family:"Inter",sans-serif;
  font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  color:var(--accent-dark);
  position:relative;
  padding-bottom:.25rem;
  transition:color .3s;
}
.intro-card a.more::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:currentColor;
  transform:scaleX(.4);transform-origin:left;
  transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.intro-card:hover a.more{color:var(--ink)}
.intro-card:hover a.more::after{transform:scaleX(1)}
@media (max-width:768px){
  .intro-card + .intro-card{border-left:0;border-top:1px solid var(--line)}
}

/* ---------- Articles list ---------- */
.articles-list{
  display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--line);
}
.article-row{
  display:grid;grid-template-columns:140px 1fr auto;gap:2rem;
  padding:2rem 0;
  border-bottom:1px solid var(--line);
  align-items:center;
  transition:background .3s,padding-left .3s;
}
.article-row:hover{background:rgba(160,122,63,.04);padding-left:1rem}
.article-row .date{
  font-family:"Cormorant Garamond",serif;
  font-size:1.4rem;color:var(--accent-dark);font-weight:500;
}
.article-row .body{}
.article-row .source{
  font-family:"Inter",sans-serif;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:.3rem;
}
.article-row .title{
  font-family:"Cormorant Garamond",serif;
  font-size:1.3rem;line-height:1.3;margin:0 0 .3rem;
  font-weight:500;
}
.article-row p{font-size:.92rem;color:var(--muted);margin:.3rem 0 0;line-height:1.5}
.article-row .action{
  font-family:"Inter",sans-serif;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:var(--accent-dark);
  white-space:nowrap;
}
@media (max-width:768px){
  .article-row{grid-template-columns:1fr;gap:.5rem;padding-left:0 !important}
  .article-row .action{justify-self:start;margin-top:.5rem}
}

/* ---------- Catalogues showcase ---------- */
.catalogues-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:clamp(1.5rem, 3vw, 3rem);
  margin-top:2rem;
}
.catalogue-item{
  background:var(--paper);
  padding:1.5rem;
  transition:transform .4s,box-shadow .4s;
  text-align:center;
}
.catalogue-item:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.catalogue-item img{
  width:100%;height:auto;
  aspect-ratio:3/4;object-fit:cover;
  background:#1a1410;
  margin-bottom:1.2rem;
  box-shadow:var(--shadow);
}
.catalogue-item h4{
  font-family:"Cormorant Garamond",serif;
  font-size:1.2rem;font-style:italic;margin:0 0 .3rem;
}
.catalogue-item p{
  font-size:.85rem;color:var(--muted);margin:0;line-height:1.5;
}
.catalogue-item .year{
  font-family:"Inter",sans-serif;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);margin-top:.5rem;display:block;font-weight:500;
}

/* ---------- Mécénat ---------- */
.support-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:clamp(1.5rem, 3vw, 2.5rem);
  margin-top:2rem;
}
.support-card{
  background:var(--paper);border:1px solid var(--line);
  padding:2.5rem 2rem;
  text-align:center;
  transition:transform .4s,box-shadow .4s,border-color .4s;
}
.support-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:var(--accent);
}
.support-card .level{
  font-family:"Cormorant Garamond",serif;
  font-size:3rem;color:var(--accent);font-weight:300;
  display:block;margin-bottom:.4rem;line-height:1;
}
.support-card h3{
  font-family:"Cormorant Garamond",serif;
  font-size:1.4rem;font-weight:500;margin:0 0 1rem;
}
.support-card p{font-size:.92rem;color:var(--muted);margin:0 0 1.5rem;line-height:1.6}
.support-card .amount{
  font-family:"Cormorant Garamond",serif;
  font-size:1.6rem;color:var(--ink);font-weight:500;display:block;margin-bottom:1.5rem;
}

/* Contributeurs listing */
.contributors-list{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:0;
  border-top:1px solid var(--line);
}
.contributor{
  padding:1.5rem 0;
  border-bottom:1px solid var(--line);
}
.contributor + .contributor{border-left:1px solid var(--line);padding-left:1.5rem}
.contributor .role{
  font-family:"Inter",sans-serif;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:.4rem;
}
.contributor .name{
  font-family:"Cormorant Garamond",serif;
  font-size:1.2rem;color:var(--ink);font-weight:500;
}
@media (max-width:700px){
  .contributor + .contributor{border-left:0;padding-left:0}
}

/* ---------- Lien FR / EN ---------- */
.lang-toggle{
  font-family:"Inter",sans-serif;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;
  background:transparent;
  border:1px solid currentColor;
  border-radius:50px;
  cursor:pointer;
  color:inherit;
  padding:.5rem 1rem;
  display:inline-flex;gap:.5rem;align-items:center;
  margin-left:1rem;
  text-decoration:none;
  transition:background .3s,color .3s,border-color .3s;
}
.lang-toggle::before{
  content:"";display:inline-block;
  width:12px;height:12px;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2a10 10 0 100 20 10 10 0 000-20zm6.93 6h-2.95a15.65 15.65 0 00-1.38-3.56A8.03 8.03 0 0118.92 8zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2s.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56A7.987 7.987 0 015.08 16zm2.95-8H5.08a7.987 7.987 0 014.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2s.07-1.35.16-2h4.68c.09.65.16 1.32.16 2s-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95a8.03 8.03 0 01-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2s-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2a10 10 0 100 20 10 10 0 000-20zm6.93 6h-2.95a15.65 15.65 0 00-1.38-3.56A8.03 8.03 0 0118.92 8zM12 4.04c.83 1.2 1.48 2.53 1.91 3.96h-3.82c.43-1.43 1.08-2.76 1.91-3.96zM4.26 14C4.1 13.36 4 12.69 4 12s.1-1.36.26-2h3.38c-.08.66-.14 1.32-.14 2s.06 1.34.14 2H4.26zm.82 2h2.95c.32 1.25.78 2.45 1.38 3.56A7.987 7.987 0 015.08 16zm2.95-8H5.08a7.987 7.987 0 014.33-3.56C8.81 5.55 8.35 6.75 8.03 8zM12 19.96c-.83-1.2-1.48-2.53-1.91-3.96h3.82c-.43 1.43-1.08 2.76-1.91 3.96zM14.34 14H9.66c-.09-.66-.16-1.32-.16-2s.07-1.35.16-2h4.68c.09.65.16 1.32.16 2s-.07 1.34-.16 2zm.25 5.56c.6-1.11 1.06-2.31 1.38-3.56h2.95a8.03 8.03 0 01-4.33 3.56zM16.36 14c.08-.66.14-1.32.14-2s-.06-1.34-.14-2h3.38c.16.64.26 1.31.26 2s-.1 1.36-.26 2h-3.38z'/></svg>") center/contain no-repeat;
}
.lang-toggle .sep{opacity:.3;margin:0 .1rem}
.lang-toggle [data-on]{opacity:.4;transition:opacity .25s}
/* On highlight la langue courante selon data-to (langue cible = NON courante) */
.lang-toggle[data-to="en"] [data-on="fr"]{opacity:1;font-weight:600}
.lang-toggle[data-to="en"] [data-on="en"]{opacity:.4}
.lang-toggle[data-to="fr"] [data-on="fr"]{opacity:.4}
.lang-toggle[data-to="fr"] [data-on="en"]{opacity:1;font-weight:600}
.lang-toggle:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.lang-toggle:hover [data-on]{opacity:1}
.site-header.transparent .lang-toggle:hover{background:#fff;color:var(--ink);border-color:#fff}

@media (max-width:900px){
  .lang-toggle{margin-left:0;margin-top:1rem;padding:.7rem 1.2rem;font-size:.78rem}
}

/* ---------- "Le projet" / Manifeste ---------- */
.manifeste-projet{
  display:grid;grid-template-columns:1fr;
  gap:clamp(2rem, 5vw, 4rem);
  text-align:center;
  padding:clamp(5rem, 10vw, 9rem) var(--gutter);
}
.manifeste-projet .display{font-size:clamp(2.6rem, 6.5vw, 5.5rem);max-width:18ch;margin:0 auto;line-height:1}
.manifeste-projet .lead{max-width:54ch;margin:0 auto;font-size:clamp(1.2rem, 1.8vw, 1.6rem)}

/* ---------- Cinq axes — version "héro" pour le projet ---------- */
.axes-hero{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:0;
  border-top:1px solid var(--line);
}
.axes-hero .axe-card{
  border-bottom:1px solid var(--line);
  padding:clamp(2rem, 4vw, 3rem) clamp(1rem, 2vw, 2rem);
  position:relative;
  transition:background .4s, transform .4s;
}
.axes-hero .axe-card + .axe-card{border-left:1px solid var(--line)}
.axes-hero .axe-card:hover{background:rgba(160,122,63,.06);transform:translateY(-2px)}
.axes-hero .axe-num{
  font-family:"Cormorant Garamond",serif;
  font-size:3rem;line-height:1;color:var(--accent);
  display:block;margin-bottom:.5rem;font-weight:300;
}
.axes-hero h3{font-size:1.5rem;margin:0 0 .6rem;font-weight:500;line-height:1.1}
.axes-hero p{font-size:.95rem;color:var(--muted);margin:0;line-height:1.6}
.dark .axes-hero{border-color:#2a2018}
.dark .axes-hero .axe-card{border-color:#2a2018}
.dark .axes-hero .axe-card:hover{background:rgba(212,168,106,.08)}
.dark .axes-hero p{color:#a39483}
@media (max-width:700px){
  .axes-hero .axe-card + .axe-card{border-left:0}
}

/* ---------- Timeline visuelle Mizette ---------- */
.mp-timeline{
  position:relative;
  padding:2rem 0;
  margin-top:2rem;
}
.mp-timeline::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;
  width:1px;background:var(--line);transform:translateX(-.5px);
}
.mp-timeline-item{
  position:relative;
  width:calc(50% - 3rem);
  padding:1.5rem 1.8rem;
  margin-bottom:2rem;
  background:var(--paper);
  border:1px solid var(--line);
  transition:transform .4s,box-shadow .4s,border-color .4s;
}
.mp-timeline-item:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--accent);
}
.mp-timeline-item:nth-child(odd){margin-right:auto;margin-left:0}
.mp-timeline-item:nth-child(even){margin-left:auto;margin-right:0}
.mp-timeline-item::before{
  content:"";position:absolute;top:1.8rem;
  width:11px;height:11px;border-radius:50%;
  background:var(--paper);border:2px solid var(--accent);
  transition:background .3s;
}
.mp-timeline-item:nth-child(odd)::before{right:-3.5rem;transform:translateX(0)}
.mp-timeline-item:nth-child(even)::before{left:-3.5rem}
.mp-timeline-item:hover::before{background:var(--accent)}
.mp-timeline-item .mp-year{
  font-family:"Cormorant Garamond",serif;
  font-size:1.6rem;color:var(--accent-dark);font-weight:500;line-height:1;
  display:block;margin-bottom:.4rem;
}
.mp-timeline-item h4{
  font-family:"Cormorant Garamond",serif;
  font-size:1.2rem;margin:0 0 .4rem;font-weight:500;
}
.mp-timeline-item p{font-size:.9rem;color:var(--muted);margin:0;line-height:1.5}
@media (max-width:768px){
  .mp-timeline::before{left:1rem}
  .mp-timeline-item,
  .mp-timeline-item:nth-child(odd),
  .mp-timeline-item:nth-child(even){
    width:calc(100% - 3rem);margin-left:3rem;margin-right:0;
  }
  .mp-timeline-item:nth-child(odd)::before,
  .mp-timeline-item:nth-child(even)::before{left:-2.5rem;right:auto}
}

/* ---------- Couleur sections (5 thèmes) ---------- */
.couleur-theme{
  padding:clamp(3rem, 6vw, 5rem) 0;
  border-bottom:1px solid var(--line);
}
.couleur-theme:last-child{border-bottom:0}
.couleur-theme h3{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  font-weight:400;font-style:italic;
  margin:0 0 1.5rem;color:var(--ink);
}
.couleur-theme h3 .num{
  display:inline-block;margin-right:1rem;
  font-style:normal;font-size:.75em;
  color:var(--accent);font-feature-settings:"tnum";
  vertical-align:.1em;
}

/* ---------- Newsletter ---------- */
.newsletter{
  background:linear-gradient(135deg, #0a0a0a 0%, #1a1410 100%);
  color:#fbf8f2;
  padding:clamp(4rem, 8vw, 7rem) var(--gutter);
  text-align:center;
  position:relative;overflow:hidden;
}
.newsletter::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 40%, rgba(212,168,106,.08) 0%, transparent 50%),
              radial-gradient(circle at 70% 60%, rgba(212,168,106,.06) 0%, transparent 50%);
  pointer-events:none;
}
.newsletter-inner{
  max-width:560px;margin:0 auto;position:relative;
}
.newsletter h2{
  color:#fbf8f2;
  font-size:clamp(2rem, 4vw, 3.2rem);
  font-weight:300;
  margin-bottom:1rem;
}
.newsletter p.lead{
  color:#cdbfa8;margin-bottom:2.5rem;
}
.newsletter-form{
  display:flex;gap:.5rem;flex-wrap:wrap;
  margin-bottom:1.2rem;
}
.newsletter-form input[type="email"]{
  flex:1;min-width:240px;
  background:transparent;
  border:0;
  border-bottom:1px solid #cdbfa8;
  padding:.9rem 0;
  color:#fbf8f2;
  font-family:inherit;font-size:1rem;
  outline:none;
  transition:border-color .3s;
}
.newsletter-form input[type="email"]:focus{border-color:#d4a86a}
.newsletter-form input[type="email"]::placeholder{color:#7a6f63}
.newsletter-form button{
  background:#d4a86a;color:#0a0a0a;border:0;
  padding:.9rem 2rem;
  font-family:"Inter",sans-serif;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  cursor:pointer;
  transition:background .25s,transform .25s;
}
.newsletter-form button:hover{background:#fff;transform:translateY(-1px)}
.newsletter small{
  color:#7a6f63;font-size:.78rem;
  display:block;margin-top:1rem;
}
.newsletter-status{
  display:none;
  margin-top:1rem;padding:.8rem 1rem;
  font-size:.92rem;border-radius:2px;
}
.newsletter-status.ok{display:block;background:rgba(160,200,140,.18);color:#cdebac}
.newsletter-status.err{display:block;background:rgba(220,90,60,.18);color:#f0b6a0}

/* ---------- Interior photos section (Espace en mouvement) ---------- */
.espace-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:0;
}
.espace-grid figure{
  margin:0;
  position:relative;overflow:hidden;
  aspect-ratio:4/5;
  background:#0a0a0a;
}
.espace-grid img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s cubic-bezier(.2,.7,.2,1),opacity .4s;
}
.espace-grid figure:hover img{transform:scale(1.06)}
.espace-grid figcaption{
  position:absolute;bottom:0;left:0;right:0;
  padding:2rem 1.5rem 1.5rem;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.85));
  color:#fbf8f2;
  font-family:"Cormorant Garamond",serif;
  font-size:1.1rem;font-style:italic;
}

/* ---------- École de Savièse pillar ---------- */
.saviese-block{
  background:var(--bg-alt);
  padding:clamp(3rem, 6vw, 5rem) clamp(2rem, 5vw, 4rem);
  border-left:3px solid var(--accent);
  margin:3rem 0;
}
.saviese-block h3{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(1.6rem, 2.4vw, 2.2rem);
  font-weight:400;font-style:italic;
  margin:0 0 1rem;
}
.saviese-block .eyebrow{margin-bottom:.5rem}

/* ---------- Page transitions (fade-in sur le body) ---------- */
@keyframes pageFadeIn{
  from{opacity:0}
  to{opacity:1}
}
body{animation:pageFadeIn .5s ease both}

/* ---------- Eyebrow : ligne décorative ---------- */
.eyebrow{
  position:relative;
  display:inline-block;
  padding-left:2rem;
}
.eyebrow::before{
  content:"";
  position:absolute;
  left:0;top:50%;
  width:1.25rem;height:1px;
  background:currentColor;
}
.section-head .eyebrow,
.page-head .eyebrow,
.manifeste .eyebrow,
.hero .eyebrow{padding-left:0}
.section-head .eyebrow::before,
.page-head .eyebrow::before,
.manifeste .eyebrow::before,
.hero .eyebrow::before{display:none}

/* ---------- Featured-date strong : entrée typo ---------- */
.featured-date strong{
  position:relative;
}

/* ---------- Timeline rows : hover-emphasis ---------- */
.timeline-row{
  transition:background .4s, padding-left .4s;
  padding-left:0;
  border-radius:2px;
}
.timeline-row:hover{
  background:rgba(160,122,63,.05);
  padding-left:.5rem;
}

/* ---------- Names list : hover ---------- */
.names li{
  transition:color .3s,padding-left .3s;
}
.names li:hover{
  color:var(--accent);
  padding-left:.4rem;
}

/* ---------- Improved card hover (space-card) ---------- */
.space-card .img{
  position:relative;
  overflow:hidden;
}
.space-card .img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(0,0,0,.4) 100%);
  opacity:0;transition:opacity .4s;
  pointer-events:none;
}
.space-card:hover .img::after{opacity:1}

/* ---------- Axes (Fondation 5 piliers) : hover ---------- */
.axe{
  transition:background .4s, transform .4s;
}
.axe:hover{
  background:rgba(160,122,63,.06);
  transform:translateY(-4px);
}
.dark .axe:hover{
  background:rgba(212,168,106,.08);
}

/* ---------- Facts (médailles) : hover ---------- */
.fact{transition:transform .4s}
.fact:hover{transform:translateY(-3px)}
.fact:hover .fact-num{color:var(--accent)}
.fact .fact-num{transition:color .3s}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .nav-links{gap:1.8rem}
}
@media (max-width:900px){
  body{font-size:16px}
  .split,.split.text-first,.split.image-first,
  .featured,.mizette-feature,.section-head{grid-template-columns:1fr;gap:2.5rem}
  .split-3{grid-template-columns:1fr;gap:2.5rem}
  .section-head{margin-bottom:2rem}
  .featured-img{aspect-ratio:1/1;max-height:560px}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
  .names{columns:2}
  .timeline-row{grid-template-columns:90px 1fr;gap:1.2rem}
  .t-year{font-size:1.3rem}

  /* — Mobile menu —
     Important: on désactive backdrop-filter sur le header solide en mobile
     car il "piège" les position:fixed enfants sur Safari (le menu plein écran
     restait coincé dans le rectangle du header). */
  .site-header.solid{
    -webkit-backdrop-filter:none;
    backdrop-filter:none;
    background:rgba(251,248,242,.98);
  }

  .menu-toggle{
    display:block;
    position:relative;z-index:60;
    width:44px;height:44px;            /* WCAG : tap target ≥ 44px */
  }
  .nav-links{
    display:none;
    position:fixed;inset:0;
    z-index:55;
    background:#0a0a0a;color:#fff;
    flex-direction:column;justify-content:center;align-items:center;
    gap:1.5rem;
    padding:max(4rem, env(safe-area-inset-top, 4rem)) 2rem max(2rem, env(safe-area-inset-bottom, 2rem));
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%;text-align:center}
  .nav-links a{
    font-size:1.1rem;color:#fff !important;
    display:inline-block;padding:.6rem 1rem;
  }
  .nav-links a::after{background:#fff}
  .nav-cta{
    margin-top:1rem;
    border:1px solid #fff !important;
    padding:.9rem 1.6rem !important;
  }
  .menu-toggle[aria-expanded="true"]{color:#fff !important}
  .menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* Body lock quand le menu est ouvert (classe ajoutée par JS) */
  body.menu-open{overflow:hidden;position:fixed;width:100%}

  .gallery a,.gallery a.tall,.gallery a.wide,.gallery a.small{grid-column:span 6;aspect-ratio:1/1}
  .map-meta{position:static;max-width:100%;box-shadow:none;border-bottom:1px solid var(--line)}
  .map-block iframe{height:380px}
}
@media (max-width:520px){
  .footer-top{grid-template-columns:1fr;gap:2rem}
  .names{columns:1}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gallery a,.gallery a.tall,.gallery a.wide,.gallery a.small{grid-column:span 1;aspect-ratio:1/1}
}
