/* ==========================================================
   OESSH Luxembourg — Refonte
   Aesthetic: pierre de Jérusalem · bleu nuit · accent cardinalice
   ========================================================== */

:root{
  /* Palette inspirée du site original : crème + bruns chauds + rouge OESSH */
  --bg:        #ffffff;        /* crème chaude */
  --bg-soft:   #f7f4ee;        /* sable */
  --paper:     #fbf8f2;        /* parchemin */
  --ink:       #1a1a1a;        /* brun sépia profond */
  --ink-soft:  #333333;
  --ink-mute:  #6e6e6e;
  --line:      rgba(26,26,26,.16);
  --line-soft: rgba(26,26,26,.08);
  --gold:      #b08a4f;
  --cardinal:  #b10103;        /* rouge OESSH (croix de Jérusalem) */

  --serif:  "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sans:   "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:   "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --maxw: 1280px;
  --gutter: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
/* Empêche le « balancement » horizontal sur mobile sans bloquer le pinch-zoom */
html,body{overflow-x:clip; max-width:100%}
img,svg,video,iframe{max-width:100%}
html{scroll-behavior:smooth; scroll-padding-top:80px !important}
section[id]{scroll-margin-top:80px !important}
section[id]{padding-top:36px !important}
section[id] > .container > .section-head .meta{padding-top:0 !important}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ---------- Typographic system ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink-mute);
}
.eyebrow .dot{
  display:inline-block; width:5px;height:5px;border-radius:50%;
  background:var(--cardinal); margin:0 10px 2px 0; vertical-align:middle;
}
h1,h2,h3,h4{font-family:var(--serif); font-weight:500; color:var(--ink); margin:0; letter-spacing:-.005em}
h1{font-size:clamp(44px, 6.4vw, 92px); line-height:1.02;}
h2{font-size:clamp(32px, 3.6vw, 52px); line-height:1.08;}
h3{font-size:clamp(22px, 2vw, 28px); line-height:1.18;}
h4{font-size:18px; line-height:1.3;}
p{margin:0 0 1em; color:var(--ink-soft); text-wrap:pretty}
em.italic{font-style:italic}

.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}

.container{max-width:var(--maxw); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter)}

/* ---------- Calendrier — événements passés ---------- */
.cal-row.past{opacity:.62; filter:grayscale(.6)}
.cal-row.past .date,
.cal-row.past .ev,
.cal-row.past .where{color:var(--ink-mute)}
.cal-row.past .date{text-decoration:line-through; text-decoration-thickness:1px; text-decoration-color:rgba(11,15,20,.3)}

/* ---------- Topbar ---------- */
.topbar{
  background:#faf7f0;
  border-bottom:1px solid rgba(11,15,20,.08);
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
}
.topbar-inner{
  max-width:var(--maxw); margin:0 auto;
  padding:10px 32px;
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:24px;
}
.tb-left{display:flex; align-items:center; gap:10px; justify-self:start}
.tb-dot{width:6px; height:6px; border-radius:50%; background:var(--red); display:inline-block}
.tb-center{justify-self:end; color:var(--ink-soft); font-weight:400; white-space:nowrap}
.tb-center strong{font-weight:700; letter-spacing:.18em}
.tb-sep{color:var(--ink-soft); margin:0 4px}
.tb-accent{color:var(--ink-soft)}
.tb-right{justify-self:end}
@media (max-width:780px){
  .topbar-inner{grid-template-columns:1fr; gap:6px; text-align:center; padding:10px 20px}
  .tb-left{justify-self:center}
}

/* ---------- Header ---------- */
header.site{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  background: rgba(255, 255, 255, 0.92);
  border-bottom:1px solid var(--line-soft);
}
.nav{
  display:grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  column-gap:32px; row-gap:0;
  align-items:center;
  padding:14px var(--gutter) 0;
  max-width:var(--maxw); margin:0 auto;
}
.brand{display:flex; align-items:center; gap:18px; flex:0 0 auto; grid-row:1; grid-column:1; text-decoration:none}
.nav-cta{display:flex; gap:10px; align-items:center; flex:0 0 auto; grid-row:1; grid-column:3}
.brand .cross{width:84px;height:84px;flex:0 0 auto;display:block; background:transparent}
.brand-text{display:flex; flex-direction:column; line-height:1.2; gap:5px; max-width:none; min-width:0; white-space:nowrap}
.brand-text .l1{font-family:var(--serif); font-size:28px; letter-spacing:.005em; color:var(--cardinal); line-height:1.1; font-weight:500; white-space:nowrap}
.brand-text .l2{font-family:var(--sans); font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-mute); font-weight:500}
@media (max-width: 1100px){.brand .cross{width:64px;height:64px}.brand-text .l1{font-size:21px}.brand-text .l2{font-size:10px}}
@media (max-width: 760px){
  .brand .cross{width:54px;height:54px;flex:0 0 auto}
  .brand-text .l1{font-size:18px; line-height:1.15; white-space:normal}
  .brand-text .l1 .w{display:block; white-space:nowrap}
  .brand-text .l2{font-size:9px;letter-spacing:.18em}
  .brand{gap:12px}
}

.nav-links{
  display:flex; flex-wrap:nowrap;
  grid-row:2; grid-column:1 / -1;
  justify-content:flex-start;
  padding:0; margin:14px calc(var(--gutter) * -1) 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow-x:auto;
  scrollbar-width:none;
}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{
  display:inline-flex; align-items:center; gap:10px;
  white-space:nowrap;
  padding:18px 26px;
  border-right:1px solid var(--line);
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:600;
  position:relative;
  transition:background .15s ease, color .15s ease;
}
.nav-links a:hover{background:#fbf8f2; color:var(--cardinal)}
.nav-links a:not(:first-child)::after{
  content:"\2197";
  font-size:13px; letter-spacing:0; font-weight:500;
  display:inline-block; transform:translateY(-1px);
  transition:transform .2s ease;
}
.nav-links a:not(:first-child):hover::after{transform:translate(2px,-3px)}
.nav-links a:first-child{color:var(--cardinal)}
.nav-links a:first-child::before{
  content:"";
  width:7px; height:7px; border-radius:50%;
  background:var(--cardinal);
  display:inline-block;
  flex:0 0 auto;
}

.nav-cta-spacer{display:none}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-size:13.5px; font-weight:500;
  padding:11px 20px; border-radius:2px;
  transition:all .2s ease; letter-spacing:.01em;
}
.btn-primary{background:var(--cardinal); color:#ffffff}
.btn-primary:hover{background:#8a0102}
.btn-ghost{border:1px solid var(--line); color:var(--ink-soft)}
.btn-ghost:hover{border-color:var(--ink); color:var(--ink)}

/* FR / EN language switcher */
.lang-switch{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.16em;
  margin-right:6px;
}
.lang-switch .lang-opt{
  color:var(--ink-mute);
  text-decoration:none;
  padding:4px 2px;
  transition:color .2s ease;
}
.lang-switch .lang-opt:hover{color:var(--ink)}
.lang-switch .lang-opt.is-active{
  color:var(--ink);
  font-weight:500;
}
.lang-switch .lang-sep{color:var(--line); font-weight:300}
@media (max-width: 760px){
  .lang-switch{display:none}
}
.mobile-menu:not(.is-open){visibility:hidden !important; pointer-events:none}
.mobile-menu.is-open{visibility:visible}
.btn .arr{display:inline-block; transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

.menu-btn{
  display:none;
  width:44px; height:44px; padding:0;
  background:#fff; border:1px solid var(--line);
  cursor:pointer; align-items:center; justify-content:center;
  border-radius:0;
}
.menu-btn .bars{display:flex;flex-direction:column;gap:5px;width:18px}
.menu-btn .bars span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s ease, opacity .2s ease}
.menu-btn[aria-expanded="true"] .bars span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn[aria-expanded="true"] .bars span:nth-child(2){opacity:0}
.menu-btn[aria-expanded="true"] .bars span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  display:none;
  position:fixed; top:0; left:0; right:0;
  background:#fff;
  border-bottom:1px solid var(--line);
  padding:80px 24px 28px;
  z-index:90;
  flex-direction:column; gap:4px;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.15);
  transform:translateY(-100%);
  transition:transform .28s ease;
}
.mobile-menu.is-open{transform:translateY(0)}
.mobile-menu a{
  display:block;
  font-family:var(--serif); font-size:22px;
  color:var(--ink); text-decoration:none;
  padding:14px 4px; border-bottom:1px solid var(--line-soft);
}
.mobile-menu a:last-child{border-bottom:none}

@media (max-width: 960px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .menu-btn{display:inline-flex}
  .mobile-menu{display:flex}
  .nav-cta{gap:8px}
  .nav-cta .btn-primary{
    width:44px; height:44px; padding:0;
    justify-content:center;
    font-size:0;
  }
  .nav-cta .btn-primary .lbl{display:none}
  .nav-cta .btn-primary .arr{
    display:inline-block; font-size:18px; margin:0;
    transform:none;
  }
  .nav-cta .btn-primary::before{
    content:"♥";
    font-size:18px; line-height:1;
    color:#fff;
  }
  .nav-cta .btn-primary .arr{display:none}
}
@media (max-width: 480px){
  .nav{padding:14px 16px}
}

/* ---------- Sections ---------- */
section{padding:clamp(72px, 9vw, 130px) 0; position:relative}
.section-divider{height:1px; background:var(--line-soft); max-width:var(--maxw); margin:0 auto}

.section-head{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:64px;
  margin-bottom:60px;
  align-items:start;
}
.section-head .meta{padding-top:8px}
.section-head .meta .num{
  font-family:var(--mono); font-size:11px; color:var(--ink-mute);
  letter-spacing:.16em;
}
.section-head .meta .label{
  margin-top:6px; font-family:var(--sans); font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink); font-weight:500;
}
.section-head h2{max-width:18ch}
.section-head .lede{
  margin-top:18px; font-family:var(--serif); font-size:clamp(18px,1.6vw,22px);
  line-height:1.45; color:var(--ink-soft); max-width:55ch; font-style:italic;
}
@media (max-width:760px){
  .section-head{grid-template-columns:1fr; gap:24px; margin-bottom:40px}
}

/* ---------- Hero ---------- */
.hero{
  padding-top:clamp(60px, 7vw, 90px);
  padding-bottom:clamp(60px, 8vw, 110px);
  position:relative; overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:end;
}
@media (max-width:880px){.hero-grid{grid-template-columns:1fr; gap:36px}}

.hero h1{font-style:italic; margin-bottom:32px}
.hero h1 .accent{
  font-style:normal; font-family:var(--serif);
  display:inline-block; position:relative;
}
.hero h1 .accent::after{
  content:""; position:absolute; left:0; right:0; bottom:.06em; height:.07em;
  background:var(--gold); opacity:.7;
}
.hero .kicker{
  display:flex; align-items:center; gap:14px;
  margin-bottom:36px;
}
.hero .kicker .rule{flex:0 0 64px; height:1px; background:var(--ink)}
.hero .lede{
  font-family:var(--serif); font-size:clamp(20px, 1.8vw, 26px);
  line-height:1.45; color:var(--ink-soft); max-width:42ch;
  margin-bottom:36px;
}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; align-items:center}

.hero-aside{
  position:relative;
}
.hero-quote{
  border-left:1px solid var(--gold);
  padding:6px 0 6px 28px;
  margin-bottom:30px;
}
.hero-quote p{
  font-family:var(--serif); font-style:italic; font-size:22px;
  line-height:1.4; color:var(--ink); margin:0;
}
.hero-quote cite{
  display:block; margin-top:14px;
  font-family:var(--sans); font-style:normal;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-mute);
}

.hero-stats{
  display:grid; grid-template-columns:repeat(2, 1fr);
  grid-auto-rows:1fr;
  gap:1px;
  background:var(--line-soft);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.hero-stats .stat{
  background:#ffffff; padding:28px 14px 26px;
  display:flex; flex-direction:column; justify-content:flex-start; align-items:flex-start;
  text-align:left;
  min-height:190px;
}
.hero-stats .num{
  font-family:var(--serif);
  line-height:1; color:var(--ink); font-weight:400;
  font-style:italic;
  letter-spacing:-.01em;
  display:flex; flex-direction:column; align-items:flex-start; gap:6px;
}
.hero-stats .num .figure{
  font-size:clamp(42px, 4vw, 60px);
  font-style:italic;
  line-height:1;
}
.hero-stats .num .unit{
  font-size:clamp(15px, 1.2vw, 18px);
  font-style:italic;
  color:var(--ink-soft);
  letter-spacing:.01em;
  font-family:var(--serif);
}
.hero-stats .lab{
  margin-top:18px; font-size:13px; color:var(--ink-mute);
  letter-spacing:.02em; line-height:1.45;
  text-transform:none;
  text-wrap:pretty;
}

/* Hero ornament — Jerusalem cross watermark */
.hero-ornament{
  position:absolute; right:-60px; top:30%;
  width:380px; height:380px; opacity:.05;
  pointer-events:none;
}

/* ---------- Mission section ---------- */
.mission{
  background:var(--paper);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.pillars{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:1px; background:var(--line-soft);
  margin-top:30px;
}
.pillar{
  background:var(--paper); padding:38px 32px;
  display:flex; flex-direction:column; gap:14px;
  min-height:240px;
}
.pillar .pn{
  font-family:var(--mono); font-size:11px; color:var(--gold);
  letter-spacing:.16em;
}
.pillar h3{font-family:var(--serif); font-size:24px; line-height:1.2; margin:0}
.pillar p{font-size:14.5px; color:var(--ink-mute); margin:0; line-height:1.55}
@media (max-width:880px){.pillars{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.pillars{grid-template-columns:1fr}}

/* ---------- News (Actualités) ---------- */
.news-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap:48px;
}
@media (max-width:980px){.news-grid{grid-template-columns:1fr 1fr; gap:36px}}
@media (max-width:680px){.news-grid{grid-template-columns:1fr}}

.news-card{display:flex; flex-direction:column; cursor:pointer; group}
.news-card .thumb{
  aspect-ratio:4/3;
  background:var(--bg-soft);
  position:relative; overflow:hidden;
  margin-bottom:22px;
  border:1px solid var(--line-soft);
}
.news-card.feature .thumb{aspect-ratio:5/4}
.news-card .thumb::before{
  content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(
    45deg, transparent 0 18px,
    rgba(22,24,35,.04) 18px 19px
  );
}
.news-card .thumb-label{
  position:absolute; left:14px; bottom:14px;
  font-family:var(--mono); font-size:10px;
  color:var(--ink-mute); letter-spacing:.12em;
  background:rgba(244,237,224,.85); padding:6px 10px;
  text-transform:uppercase;
  z-index:2;
}
.news-card .thumb.has-image{background:#1a1614}
.news-card .thumb.has-image::before{display:none}
.news-card .thumb.has-image img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform .6s ease;
}
.news-card:hover .thumb.has-image img{transform:scale(1.03)}
.news-card .thumb.has-image .thumb-label{
  background:rgba(28,24,20,.78); color:#f4ede0;
}
.news-card .meta-line{
  display:flex; gap:16px; font-size:11px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-mute); margin-bottom:14px;
}
.news-card .meta-line .tag{color:var(--cardinal); font-weight:500}
.news-card h3{
  font-size:clamp(20px,1.7vw,28px); line-height:1.18;
  margin-bottom:14px;
}
.news-card.feature h3{font-size:clamp(28px, 2.4vw, 38px); line-height:1.1}
.news-card p{font-size:14.5px; color:var(--ink-mute); line-height:1.55; margin-bottom:18px}
.news-card .read{
  margin-top:auto;
  font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink); display:inline-flex; align-items:center; gap:8px;
  padding-bottom:4px; border-bottom:1px solid var(--ink);
  align-self:flex-start; text-decoration:none;
}
.news-card:hover .read{color:var(--cardinal); border-color:var(--cardinal)}

/* ---------- Quote band ---------- */
.quote-band{
  background:#fbf8f2;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  color:var(--ink);
  padding:clamp(80px, 10vw, 140px) 0;
}
.quote-band blockquote{
  margin:0; max-width:1000px;
  font-family:var(--serif); font-style:italic;
  font-size:clamp(28px, 3.6vw, 48px); line-height:1.25;
  color:var(--ink); font-weight:400;
}
.quote-band blockquote .q{color:var(--cardinal); font-style:normal}
.quote-band cite{
  display:block; margin-top:36px;
  font-family:var(--sans); font-style:normal;
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-mute);
}

/* ---------- Engagements / Œuvres ---------- */
.oeuvres{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:48px 32px;
}
.oeuvre{grid-column:span 4; display:flex; flex-direction:column; gap:14px}
.oeuvre h3{
  font-size:22px; margin:0 0 4px;
  padding-bottom:14px;
  border-bottom:1px solid var(--cardinal);
  color:var(--ink);
}
.oeuvre p{font-size:14.5px; color:var(--ink-mute); margin:0}
@media (max-width:880px){.oeuvre{grid-column:span 6}}
@media (max-width:560px){.oeuvre{grid-column:span 12}}

/* Project highlight */
.project-feature{
  margin-top:80px;
  display:grid; grid-template-columns:5fr 7fr; gap:0;
  border:1px solid var(--line);
}
@media (max-width:880px){.project-feature{grid-template-columns:1fr}}
.project-feature .image{
  background:var(--bg-soft);
  min-height:380px; position:relative;
}
.project-feature .image::before{
  content:""; position:absolute; inset:0;
  background:repeating-linear-gradient(45deg, transparent 0 18px, rgba(22,24,35,.04) 18px 19px);
}
.project-feature .image.has-image{
  background:#1a1614;
  min-height:auto;
  display:flex; align-items:stretch; justify-content:center;
}
.project-feature .image.has-image::before{display:none}
.project-feature .image.has-image .blur-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  filter:blur(36px) brightness(.55) saturate(.9);
  transform:scale(1.15);
  z-index:0;
}
.project-feature .image.has-image img{
  position:relative;
  width:100%; height:100%;
  max-width:100%; max-height:100%;
  object-fit:cover; display:block;
  z-index:1;
}
.project-feature .image.has-image .image-label{
  background:rgba(28,24,20,.78); color:#f4ede0;
}
.project-feature .image-label{
  position:absolute; left:18px; bottom:18px;
  z-index:2;
  font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  color:var(--ink-mute); text-transform:uppercase;
  background:rgba(244,237,224,.9); padding:6px 10px;
}
.project-feature .body{padding:48px 56px}
.project-feature .where{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  color:var(--cardinal); text-transform:uppercase; margin-bottom:14px;
}
.project-feature h3{font-size:32px; line-height:1.15; margin-bottom:18px}
.project-feature p{font-size:15px; color:var(--ink-soft); margin-bottom:14px}
.project-feature .figures{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--line-soft);
  margin-top:30px; border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
}
.project-feature .figures .f{background:var(--bg); padding:18px 16px}
.project-feature .figures .num{
  font-family:var(--serif); font-size:28px; color:var(--ink); line-height:1;
}
.project-feature .figures .lab{font-size:11px; color:var(--ink-mute); margin-top:8px; letter-spacing:.06em}
.project-feature .figures.two{grid-template-columns:repeat(2,1fr)}
.project-feature.compact .figures{grid-template-columns:1fr}

/* Year groups */
.year-group{margin-top:64px}
.year-group:first-of-type{margin-top:80px}
.year-tag{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em;
  color:var(--cardinal); text-transform:uppercase;
  display:flex; align-items:center; gap:14px;
  margin-bottom:18px;
}
.year-tag .bar{display:inline-block; width:42px; height:2px; background:var(--cardinal)}
.year-intro{
  font-family:var(--serif); font-size:18px; line-height:1.5;
  color:var(--ink-soft); max-width:62ch; margin-bottom:28px;
}
.year-group .project-feature{margin-top:0}
.projects-pair{
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
}
@media (max-width:980px){.projects-pair{grid-template-columns:1fr}}
.project-feature.compact{grid-template-columns:1fr}
.project-feature.compact .image{min-height:260px}
.project-feature.compact .body{padding:36px 40px}
.project-feature.compact h3{font-size:24px}

/* ---------- Don ---------- */
.don{
  background:#fbf8f2;
  color:var(--ink);
  padding:clamp(80px, 10vw, 140px) 0;
  position:relative; overflow:hidden;
  border-top:3px solid var(--cardinal);
}
.don .container{position:relative}
.don .ornament{
  position:absolute; right:-100px; top:-80px;
  width:520px; height:520px; opacity:.06;
  pointer-events:none;
}
.don-grid{
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:80px; align-items:start;
}
@media (max-width:880px){.don-grid{grid-template-columns:1fr; gap:48px}}

.don .eyebrow{color:var(--ink-mute)}
.don .eyebrow .dot{background:var(--cardinal)}
.don h2{color:var(--ink); margin:24px 0 28px; font-style:italic; max-width:14ch}
.don .intro{font-family:var(--serif); font-size:20px; line-height:1.5; color:var(--ink-soft); max-width:42ch; margin-bottom:36px}

.don-card{
  background:#ffffff;
  color:var(--ink);
  padding:36px 36px 30px;
  border:1px solid var(--line);
  border-top:3px solid var(--cardinal);
}
.don-card .label{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink-mute); margin-bottom:18px;
}
.don-card h4{font-family:var(--serif); font-size:22px; margin-bottom:10px}
.don-card .iban{
  margin:18px 0;
  padding:14px 16px;
  background:var(--bg);
  border:1px dashed var(--line);
  font-family:var(--mono); font-size:15px; color:var(--ink);
  letter-spacing:.04em;
  display:flex; justify-content:space-between; align-items:center; gap:12px;
}
.don-card .iban-copy{
  font-size:10px; letter-spacing:.16em; color:var(--ink-mute);
  text-transform:uppercase; cursor:pointer;
  padding:6px 10px; border:1px solid var(--line);
  font-family:var(--sans); transition:all .2s;
  white-space:nowrap;
}
.don-card .iban-copy:hover{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.don-card .mention{
  font-size:13px; color:var(--ink-mute); margin-bottom:20px;
}
.don-card .mention strong{color:var(--ink); font-weight:500}
.don-card .fiscal{
  display:flex; align-items:flex-start; gap:10px;
  font-size:12.5px; line-height:1.5; color:var(--ink-mute);
  border-top:1px solid var(--line-soft); padding-top:18px;
}
.don-card .fiscal::before{
  content:"✓"; color:var(--gold); font-size:14px; flex-shrink:0;
}

.don-alt{
  margin-top:24px; padding:24px;
  display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:center;
  background:#ffffff;
  border:1px solid var(--line);
}
.payconiq-card{
  display:block; width:160px; flex-shrink:0;
  border-radius:6px; overflow:hidden;
  box-shadow:0 2px 14px rgba(0,0,0,.08);
  transition:transform .25s ease, box-shadow .25s ease;
}
.payconiq-card:hover{transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.12)}
.payconiq-card img{display:block; width:100%; height:auto}
.don-alt .qr-info{font-size:13.5px; color:var(--ink-soft); line-height:1.5}
.don-alt .qr-info strong{color:var(--ink); display:block; margin-bottom:4px; font-size:14px; font-weight:500}
.don-alt a{color:var(--cardinal); text-decoration:underline; text-underline-offset:3px}

.don-photo{
  margin:0 0 28px; padding:0;
  position:relative;
  border:1px solid var(--line-soft);
  background:#1a1614;
  overflow:hidden;
}
.don-photo img{
  display:block; width:100%; height:auto;
  max-height:340px; object-fit:cover; object-position:center;
}
.don-photo figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding:12px 16px;
  background:linear-gradient(0deg, rgba(20,16,14,.92), rgba(20,16,14,0));
  color:#f4ede0;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.04em; line-height:1.4;
}

/* ---------- Moments / gallery strip ---------- */
.moments{
  background:var(--paper);
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  padding:64px 0 80px;
}
.moments-head{
  display:flex; align-items:center; gap:18px;
  margin-bottom:32px;
}
.moments-head .rule{
  height:1px; flex:0 0 64px; background:var(--cardinal);
}
.moments-head .label{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--ink-mute); text-transform:uppercase;
}
.moments-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:18px;
}
@media (max-width:880px){.moments-grid{grid-template-columns:repeat(2,1fr)}}
.moment{margin:0; display:flex; flex-direction:column; gap:10px}
.moment .img{
  position:relative; overflow:hidden;
  background:#1a1614;
  aspect-ratio:4/3;
  border:1px solid var(--line-soft);
}
.moment .img img{
  width:100%; height:100%;
  object-fit:cover; display:block;
  transition:transform .5s ease, filter .5s ease;
  filter:saturate(.94);
}
.moment:hover .img img{transform:scale(1.04); filter:saturate(1.05)}
.moment figcaption{
  display:flex; flex-direction:column; gap:2px;
  padding:0 2px;
}
.moment .when{
  font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  color:var(--ink-mute); text-transform:uppercase;
}
.moment .what{
  font-family:var(--serif); font-size:14.5px; line-height:1.25;
  color:var(--ink); font-style:italic;
}

/* ---------- Newsletter archive ---------- */
.newsletters{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:32px;
}
@media (max-width:880px){.newsletters{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.newsletters{grid-template-columns:1fr 1fr; gap:18px}}
.nl{display:flex; flex-direction:column; gap:14px; cursor:pointer}
.nl .cover{
  aspect-ratio: 627/900;
  background:linear-gradient(180deg, #d8c5a8 0%, #c2a785 100%);
  border:1px solid var(--line-soft);
  position:relative; overflow:hidden;
  transition:transform .3s ease;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:18px;
}
.nl:hover .cover{transform:translateY(-4px)}
.nl.featured .cover{
  background:linear-gradient(180deg, var(--cardinal) 0%, #6f0102 100%);
}
.nl.has-image .cover{
  background:#1a1614;
  padding:0;
  overflow:hidden;
}
.nl.has-image .cover img{
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  display:block;
}
.nl.featured .cover *{color:#ffffff !important}
.nl .cover .top{font-family:var(--mono); font-size:9px; letter-spacing:.18em; color:var(--ink); opacity:.5; text-transform:uppercase}
.nl .cover .title{font-family:var(--serif); font-size:18px; line-height:1.1; color:var(--ink); font-style:italic}
.nl .cover .num{font-family:var(--serif); font-size:12px; color:var(--ink); opacity:.6; margin-top:4px}
.nl .info{display:flex; justify-content:space-between; align-items:baseline}
.nl .info .name{font-size:13px; color:var(--ink); font-weight:500}
.nl .info .pages{font-family:var(--mono); font-size:10px; color:var(--ink-mute); letter-spacing:.1em}

/* ---------- Lectures (ouvrages) ---------- */
.lectures{display:grid; grid-template-columns:1fr; gap:64px}
.book{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:48px;
  align-items:start;
}
.book .cover{
  aspect-ratio: 627/900;
  background:#e9e2d5;
  overflow:hidden;
  border:1px solid var(--line-soft);
  box-shadow:0 24px 48px -28px rgba(0,0,0,.35), 0 2px 6px rgba(0,0,0,.06);
  position:relative;
}
.book .cover img{width:100%; height:100%; object-fit:cover; display:block}
.book .body .eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--ink-mute); text-transform:uppercase; margin-bottom:14px;
}
.book .body h3{
  font-family:var(--serif); font-size:clamp(24px,2.4vw,32px);
  line-height:1.15; color:var(--ink); margin:0 0 6px 0; font-weight:500;
  text-wrap:balance;
}
.book .body .author{
  font-family:var(--serif); font-style:italic; font-size:16px;
  color:var(--ink-soft); margin-bottom:22px;
}
.book .body .summary{
  font-family:var(--serif); font-size:17px; line-height:1.65;
  color:var(--ink-soft); max-width:60ch; margin:0 0 18px 0;
}
.book .body .summary + .summary{margin-top:14px}
.book .body .quote{
  font-family:var(--serif); font-style:italic; font-size:17px; line-height:1.55;
  color:var(--ink); border-left:2px solid var(--accent, #8a7a5c);
  padding:6px 0 6px 18px; margin:20px 0; max-width:55ch;
}
.book .body .meta-row{
  display:flex; flex-wrap:wrap; gap:18px 28px; align-items:center;
  margin-top:26px; padding-top:20px; border-top:1px solid var(--line-soft);
}
.book .body .meta-row .item{
  font-family:var(--mono); font-size:11px; letter-spacing:.1em;
  color:var(--ink-mute); text-transform:uppercase;
}
.book .body .meta-row .item strong{
  display:block; font-family:var(--serif); font-style:normal;
  font-size:14px; color:var(--ink); letter-spacing:0;
  text-transform:none; font-weight:500; margin-top:3px;
}
.book .body .links{display:flex; flex-wrap:wrap; gap:14px; margin-top:22px}
.book .body .links a{
  font-family:var(--mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink);
  text-decoration:none; border-bottom:1px solid var(--ink);
  padding-bottom:2px; transition:opacity .2s;
}
.book .body .links a:hover{opacity:.55}
.book .body .links a.muted{color:var(--ink-mute); border-bottom-color:var(--line)}
@media (max-width:760px){
  .book{grid-template-columns:1fr; gap:28px}
  .book .cover{max-width:220px}
}
.nl.featured-tag{position:relative}
.nl .new-tag{
  position:absolute; top:14px; right:14px;
  font-family:var(--mono); font-size:9px;
  letter-spacing:.16em; text-transform:uppercase;
  background:var(--cardinal); color:#ffffff;
  padding:4px 8px;
}

/* ---------- Calendrier ---------- */
.calendar{display:flex; flex-direction:column}
.cal-row{
  display:grid;
  grid-template-columns: 110px 1fr 220px;
  gap:24px; padding:22px 0;
  border-bottom:1px solid var(--line-soft);
  align-items:baseline;
}
.cal-row:first-child{border-top:1px solid var(--line)}
.cal-row .date{font-family:var(--mono); font-size:13px; color:var(--ink); letter-spacing:.04em}
.cal-row .date .month{color:var(--cardinal)}
.cal-row .ev{font-family:var(--serif); font-size:20px; color:var(--ink); line-height:1.25}
.cal-row .where{font-size:13px; color:var(--ink-soft)}
@media (max-width:760px){
  .cal-row{grid-template-columns:90px 1fr; gap:16px}
  .cal-row .where{grid-column:1/-1; padding-left:106px; font-size:12px}
}

/* ---------- Conseil ---------- */
.lieu-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:64px;
  align-items:start;
}
@media (max-width:880px){.lieu-grid{grid-template-columns:1fr; gap:36px}}
.conseil{display:flex; flex-direction:column; gap:0}
.conseil-row{
  display:grid; grid-template-columns:180px 1fr; gap:20px;
  padding:18px 0; border-bottom:1px solid var(--line-soft);
}
.conseil-row:first-child{border-top:1px solid var(--line)}
.conseil-row .role{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); padding-top:4px}
.conseil-row .name{font-family:var(--serif); font-size:19px; color:var(--ink); line-height:1.25}
.conseil-row .name small{display:block; font-family:var(--sans); font-size:12px; color:var(--ink-mute); margin-top:2px; letter-spacing:.02em}

/* ---------- Footer ---------- */
footer.site{
  background:#fbf8f2; color:var(--ink-soft);
  padding:80px 0 30px;
  border-top:3px solid var(--cardinal);
}
.footer-grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:60px; border-bottom:1px solid var(--line-soft);
}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr; gap:36px}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
footer.site .col h3,
footer.site .col h4,
footer.site .col h5{
  font-family:var(--sans); font-size:11px; letter-spacing:.22em; font-weight:500;
  text-transform:uppercase; color:var(--ink-mute);
  margin:0 0 18px; font-weight:500;
}
footer.site .col a{
  display:block; padding:5px 0;
  font-size:14px; color:var(--ink-soft);
  transition:color .15s;
}
footer.site .col a:hover{color:var(--cardinal)}
footer.site .brand{margin-bottom:22px}
footer.site .brand-text .l1{color:var(--ink)}
footer.site .brand-text .l2{color:var(--ink-mute)}
footer.site .baseline{
  font-family:var(--serif); font-style:italic; font-size:18px;
  line-height:1.45; color:var(--ink-soft); max-width:35ch;
}
.foot-bottom{
  padding-top:30px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px;
  font-size:12px; color:var(--ink-mute);
}
.foot-bottom a{color:var(--ink-soft)}

/* ---------- Subtle reveal animation ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s ease}
  .reveal.in{opacity:1; transform:translateY(0)}
}


/* ---------- Cookie banner ---------- */
.cookie-banner{
  position:fixed; left:20px; right:20px; bottom:20px; z-index:9999;
  background:#1a1614; color:#f4ede0;
  border:1px solid rgba(244,237,224,.14);
  box-shadow:0 18px 50px rgba(0,0,0,.35);
  opacity:0; transform:translateY(20px);
  transition:opacity .28s ease, transform .28s ease;
  max-width:780px; margin:0 auto;
}
.cookie-banner.show{opacity:1; transform:translateY(0)}
.cookie-inner{
  display:grid; grid-template-columns:1fr auto; gap:24px;
  align-items:center; padding:20px 24px;
}
@media (max-width:640px){
  .cookie-inner{grid-template-columns:1fr; gap:16px}
  .cookie-banner{left:12px; right:12px; bottom:12px}
}
.cookie-text{display:flex; flex-direction:column; gap:6px; font-size:13.5px; line-height:1.5}
.cookie-text strong{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:#ff8a8c; text-transform:uppercase; font-weight:500;
}
.cookie-text span{color:rgba(244,237,224,.82)}
.cookie-actions{display:flex; gap:10px; flex-wrap:wrap}
.cookie-btn{
  font:inherit; font-size:13px; letter-spacing:.04em;
  padding:10px 20px; border:1px solid rgba(244,237,224,.2);
  background:transparent; color:#f4ede0; cursor:pointer;
  transition:background .18s ease, border-color .18s ease;
}
.cookie-btn:hover{background:rgba(244,237,224,.08); border-color:rgba(244,237,224,.4)}
.cookie-accept{background:var(--cardinal); border-color:var(--cardinal); color:#fff}
.cookie-accept:hover{background:#7a1822; border-color:#7a1822}


/* ---------- Payconiq QR modal ---------- */
.qr-modal{
  position:fixed; inset:0; z-index:9999;
  display:none; align-items:center; justify-content:center;
  padding:24px;
}
.qr-modal.is-open{ display:flex }
.qr-modal-backdrop{
  position:absolute; inset:0;
  background:rgba(20,16,10,.65);
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  animation:qrFade .18s ease-out;
}
.qr-modal-card{
  position:relative; z-index:1;
  background:var(--paper, #fbf8f2);
  max-width:440px; width:100%;
  padding:38px 36px 32px;
  border:1px solid var(--line-soft, rgba(0,0,0,.08));
  box-shadow:0 30px 80px -20px rgba(0,0,0,.4);
  text-align:center;
  animation:qrPop .22s cubic-bezier(.2,.9,.3,1.1);
}
.qr-modal-close{
  position:absolute; top:10px; right:14px;
  background:none; border:none;
  font-size:30px; line-height:1;
  color:var(--ink-mute, #6b6357);
  cursor:pointer; padding:4px 10px;
}
.qr-modal-close:hover{ color:var(--cardinal, #b00020) }
.qr-modal-card h3{
  font-size:22px; margin:0 0 8px;
  letter-spacing:-.01em;
}
.qr-modal-lede{
  font-size:14px; color:var(--ink-mute,#6b6357);
  margin:0 0 22px; line-height:1.5;
}
.qr-modal-card img{
  width:100%; max-width:300px;
  height:auto; display:block;
  margin:0 auto 18px;
  background:#fff; padding:12px;
  border:1px solid var(--line-soft,rgba(0,0,0,.08));
}
.qr-modal-foot{
  font-size:13px; color:var(--ink-mute,#6b6357);
  margin:0;
}
.qr-modal-foot a{
  color:var(--ink,#14100a);
  text-decoration:underline; text-underline-offset:3px;
}
@keyframes qrFade{ from{opacity:0} to{opacity:1} }
@keyframes qrPop{
  from{ opacity:0; transform:translateY(8px) scale(.97) }
  to{ opacity:1; transform:translateY(0) scale(1) }
}
@media (max-width:520px){
  .qr-modal-card{ padding:32px 24px 26px }
  .qr-modal-card img{ max-width:240px }
}

/* unify .payconiq-card button reset */
button.payconiq-card{
  background:none; border:0; padding:0;
  cursor:pointer; font:inherit; color:inherit;
  text-align:left;
}


/* PDF link card (project figures) */
.pdf-link{
  display:inline-flex; align-items:center; gap:16px;
  padding:14px 18px;
  border:1px solid var(--line);
  background:#fff;
  text-decoration:none; color:var(--ink);
  transition:border-color .15s ease, background .15s ease;
  max-width:420px;
}
.pdf-link:hover{ border-color:var(--cardinal); background:#fbf8f2 }
.pdf-link .ico{
  font-family:var(--sans); font-size:11px; font-weight:600;
  letter-spacing:.12em; color:#fff;
  background:var(--cardinal);
  padding:8px 10px; line-height:1; flex:0 0 auto;
}
.pdf-link .lbl{display:flex; flex-direction:column; gap:2px; line-height:1.3}
.pdf-link .lbl strong{font-weight:500; font-size:14.5px; color:var(--ink)}
.pdf-link .lbl span{font-size:12.5px; color:var(--ink-mute)}
.pdf-link .arr{margin-left:auto; color:var(--ink-mute); font-size:18px}
.pdf-link:hover .arr{color:var(--cardinal)}
