/* =========================================================
   Jacqueline Levesque — site commémoratif
   Palette warm ivory · espresso · sauge · or
   ========================================================= */

:root{
  --bg:        #f6f1e8;
  --bg-2:      #efe7d9;
  --bg-deep:   #2b2823;
  --ink:       #3a342c;
  --ink-soft:  #6e6557;
  --ink-faint: #978c7b;
  --line:      rgba(58,52,44,.14);
  --line-soft: rgba(58,52,44,.08);
  --paper:     #fbf8f2;

  --accent:     #7c8a6f;   /* sauge */
  --accent-ink: #5f6e53;
  --accent-tint: rgba(124,138,111,.12);
  --gold:       #c2974a;
  --gold-tint:  rgba(194,151,74,.14);

  --display: "Cormorant Garamond", Georgia, serif;
  --body:    "Spectral", Georgia, serif;
  --ui:      "Spectral", Georgia, serif;

  --maxw: 1180px;
  --gutter: clamp(22px, 5vw, 64px);
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  font-size:clamp(17px,1.15vw,19px);
  line-height:1.75;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }

/* selection */
::selection{ background:var(--accent-tint); }

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:500;
  line-height:1.06;
  letter-spacing:.004em;
  margin:0;
  color:var(--ink);
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.narrow{ max-width:760px; margin-inline:auto; }

.eyebrow{
  font-family:var(--ui);
  font-weight:500;
  font-size:.74rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--accent-ink);
  margin:0 0 1.1rem;
}
.script{ font-family:var(--display); font-style:italic; }

/* ornament — a slim sprig/divider */
.ornament{
  display:flex; align-items:center; justify-content:center; gap:.85rem;
  color:var(--accent); margin:0 auto;
}
.ornament::before,.ornament::after{
  content:""; height:1px; width:clamp(34px,8vw,72px);
  background:linear-gradient(90deg,transparent,currentColor);
}
.ornament::after{ transform:scaleX(-1); }
.ornament .dot{ width:5px; height:5px; border-radius:50%; background:currentColor; }

/* ============================ NAV ============================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .5s var(--ease), box-shadow .5s var(--ease), padding .5s var(--ease);
}
.nav.solid{
  background:color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter:blur(12px) saturate(1.1);
  box-shadow:0 1px 0 var(--line-soft);
  padding-top:13px; padding-bottom:13px;
}
.nav__name{
  font-family:var(--display); font-size:1.5rem; font-weight:500;
  letter-spacing:.02em; text-decoration:none; color:var(--ink);
  opacity:0; transition:opacity .5s var(--ease);
}
.nav.solid .nav__name{ opacity:1; }
.nav__links{ display:flex; gap:clamp(14px,2.4vw,34px); align-items:center; }
.nav__links a{
  font-family:var(--ui); text-decoration:none; color:var(--ink-soft);
  font-size:.82rem; letter-spacing:.18em; text-transform:uppercase;
  position:relative; padding:4px 0; transition:color .3s var(--ease);
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-1px; height:1px;
  background:var(--accent); transition:right .35s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ right:0; }
.nav__toggle{
  display:none; background:none; border:0; cursor:pointer;
  flex-direction:column; gap:5px; padding:8px; margin:-8px -8px -8px 0; z-index:2;
}
.nav__toggle span{
  display:block; width:24px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s var(--ease), opacity .3s var(--ease);
}
.nav.open .nav__toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.open .nav__toggle span:nth-child(2){ opacity:0; }
.nav.open .nav__toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (max-width:720px){
  .nav__toggle{ display:flex; }
  .nav__links{
    position:absolute; top:calc(100% + 6px); right:var(--gutter); left:var(--gutter);
    flex-direction:column; gap:0; align-items:stretch;
    background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:6px;
    box-shadow:0 24px 56px -22px rgba(43,40,35,.45);
    opacity:0; transform:translateY(-8px); pointer-events:none;
    transition:opacity .3s var(--ease), transform .3s var(--ease);
  }
  .nav.open .nav__links{ opacity:1; transform:none; pointer-events:auto; }
  .nav__links a{ padding:13px 14px; font-size:.95rem; letter-spacing:.16em; }
  .nav__links a::after{ display:none; }
  .nav__name{ opacity:1; }
}

/* ============================ HERO ============================ */
.hero{ position:relative; }
[data-hero] .hero-variant{ display:none; }
[data-hero="a"] .hero-variant--a{ display:flex; }
[data-hero="b"] .hero-variant--b{ display:grid; }
[data-hero="c"] .hero-variant--c{ display:flex; }

.hero-name{
  font-size:clamp(3.4rem,11vw,8.2rem);
  font-weight:500; line-height:.92; letter-spacing:.005em;
}
.hero-dates{
  font-family:var(--ui); font-style:italic; font-size:clamp(1.05rem,2.2vw,1.45rem);
  color:var(--ink-soft); letter-spacing:.06em;
}
.hero-tag{
  font-family:var(--display); font-style:italic;
  font-size:clamp(1.3rem,3vw,2rem); color:var(--ink-soft); font-weight:400;
}

/* --- Variant A : l'affiche commémorative existante, encadrée --- */
.hero-variant--a{
  min-height:100svh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:clamp(104px,15vh,156px) var(--gutter) clamp(58px,9vh,92px); text-align:center;
  background:radial-gradient(120% 92% at 50% 0%, var(--paper), var(--bg) 64%);
}
.hero-variant--a .eyebrow{ margin-bottom:1.7rem; }
.affiche{
  margin:0; position:relative; max-width:min(940px,94vw);
  padding:clamp(10px,1.4vw,16px); background:var(--paper); border-radius:3px;
  box-shadow:0 46px 100px -48px rgba(43,40,35,.62), 0 0 0 1px var(--line);
}
.affiche::after{
  content:""; position:absolute; inset:clamp(10px,1.4vw,16px); pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(58,52,44,.22);
}
.affiche img{ width:100%; height:auto; display:block; }
.hero-variant--a .scroll-cue{ position:static; transform:none; margin-top:clamp(34px,5vh,52px); color:var(--ink-soft); }

/* --- Variant B : éditorial en deux temps --- */
.hero-variant--b{ min-height:100svh; display:grid; grid-template-columns:1.05fr 1fr; }
.hero-variant--b .hero-figure{
  position:relative; display:flex; align-items:center; justify-content:center;
  padding:clamp(40px,7vh,96px) clamp(28px,5vw,64px);
  background:radial-gradient(120% 100% at 30% 20%, var(--paper), var(--bg) 70%);
}
.hero-variant--b .hero-figure img{
  width:100%; max-width:430px; aspect-ratio:4/4.6; object-fit:cover; object-position:50% 24%;
  border-radius:3px; box-shadow:0 34px 70px -34px rgba(43,40,35,.55), 0 0 0 1px var(--line);
}
.hero-variant--b .hero-copy{
  display:flex; flex-direction:column; justify-content:center;
  padding:clamp(60px,10vh,120px) var(--gutter); background:var(--bg);
}
.hero-variant--b .hero-name{ font-size:clamp(3rem,7vw,6rem); margin:.4rem 0 1.3rem; }
.hero-variant--b .hero-lead{ max-width:46ch; color:var(--ink-soft); }
@media (max-width:840px){
  .hero-variant--b{ grid-template-columns:1fr; }
  .hero-variant--b .hero-figure{ height:56svh; }
}

/* --- Variant C : portrait encadré, classique --- */
.hero-variant--c{
  min-height:100svh; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:clamp(110px,16vh,170px) var(--gutter) clamp(56px,9vh,90px);
  background:
    radial-gradient(120% 90% at 50% 0%, var(--paper), var(--bg) 60%);
}
.hero-portrait{
  width:clamp(190px,26vw,288px); aspect-ratio:1/1.16; margin-bottom:2.2rem;
  border-radius:50% 50% 50% 50% / 46% 46% 54% 54%;
  overflow:hidden; box-shadow:0 24px 60px -28px rgba(43,40,35,.5), 0 0 0 1px var(--line);
  position:relative;
}
.hero-portrait::after{
  content:""; position:absolute; inset:8px; border-radius:inherit;
  box-shadow:inset 0 0 0 1px rgba(251,248,242,.55);
}
.hero-portrait img{ width:100%; height:100%; object-fit:cover; object-position:50% 26%; }
.hero-variant--c .hero-name{ margin:.2rem 0 1rem; font-size:clamp(2.6rem,6.5vw,4.6rem); }
.hero-variant--c .ornament{ margin-top:1.6rem; }

/* scroll cue */
.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:7px;
  font-family:var(--ui); font-size:.66rem; letter-spacing:.28em; text-transform:uppercase;
  opacity:.8;
}
.scroll-cue .line{ width:1px; height:34px; background:currentColor; animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{transform:scaleY(0);} 40%{transform:scaleY(1);} 100%{transform:scaleY(0); transform-origin:bottom;} }

/* ============================ SECTIONS ============================ */
section{ position:relative; }
.section{ padding:clamp(72px,12vh,140px) 0; }
.section--paper{ background:var(--paper); }
.section--deep{ background:var(--bg-deep); color:#ece4d4; }
.section--deep h2,.section--deep h3{ color:#fbf6ec; }
.section--deep .eyebrow{ color:#c9b88e; }

.section-head{ text-align:center; margin-bottom:clamp(40px,7vh,76px); }
.section-head h2{ font-size:clamp(2.3rem,5.2vw,3.8rem); }
.section-head .ornament{ margin-top:1.5rem; }

/* lead intro */
.lead{
  font-size:clamp(1.32rem,2.5vw,1.72rem);
  line-height:1.6; color:var(--ink); font-weight:400;
  text-wrap:pretty;
}
.lead .script{ color:var(--accent-ink); }

/* tribute pillars */
.pillars{
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:clamp(34px,5vw,70px) clamp(40px,6vw,90px); margin-top:clamp(48px,8vh,86px);
}
.pillar{ }
.pillar h3{
  font-size:1.95rem; margin-bottom:.5rem; display:flex; align-items:baseline; gap:.7rem;
}
.pillar h3 .num{
  font-family:var(--ui); font-style:italic; font-size:.9rem; color:var(--accent);
  letter-spacing:.05em;
}
.pillar p{ color:var(--ink-soft); margin:.2rem 0 0; text-wrap:pretty; }
.pillar .rule{ width:38px; height:2px; background:var(--accent); margin:1rem 0 1.1rem; opacity:.7; }
@media (max-width:680px){ .pillars{ grid-template-columns:1fr; } }

/* pull quote */
.pullquote{ text-align:center; }
.pullquote blockquote{
  margin:0; font-family:var(--display); font-weight:500; font-style:italic;
  font-size:clamp(1.9rem,4.4vw,3.2rem); line-height:1.22; color:var(--ink);
  text-wrap:balance;
}
.pullquote cite{
  display:block; margin-top:1.6rem; font-style:normal;
  font-family:var(--ui); font-size:.82rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-faint);
}

/* ============================ GALLERY ============================ */
.gallery{
  columns: 3 260px; column-gap:16px;
}
.gallery figure{
  margin:0 0 16px; break-inside:avoid; position:relative; overflow:hidden;
  border-radius:3px; cursor:pointer; background:var(--bg-2);
  box-shadow:0 12px 30px -22px rgba(43,40,35,.6);
}
.gallery img{
  width:100%; height:auto; transition:transform .9s var(--ease), filter .6s var(--ease);
  filter:saturate(.96);
}
.gallery figure::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(30,26,20,.34));
  opacity:0; transition:opacity .5s var(--ease);
}
.gallery figure:hover img{ transform:scale(1.045); filter:saturate(1.04); }
.gallery figure:hover::after{ opacity:1; }
.gallery .plus{
  position:absolute; right:12px; bottom:11px; z-index:2; color:#fff;
  font-family:var(--ui); letter-spacing:.04em; font-size:.78rem;
  opacity:0; transform:translateY(6px); transition:.45s var(--ease);
}
.gallery figure:hover .plus{ opacity:1; transform:none; }

/* lightbox */
.lightbox{
  position:fixed; inset:0; z-index:120; display:none;
  background:rgba(22,19,15,.92); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:4vh 4vw;
}
.lightbox.open{ display:flex; animation:lbfade .4s var(--ease); }
@keyframes lbfade{ from{opacity:0;} to{opacity:1;} }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:2px; box-shadow:0 30px 80px rgba(0,0,0,.5); }
.lb-btn{
  position:absolute; background:none; border:0; color:#f3ebd9; cursor:pointer;
  font-family:var(--display); transition:opacity .3s var(--ease); opacity:.78;
}
.lb-btn:hover{ opacity:1; }
.lb-close{ top:3vh; right:4vw; font-size:2.4rem; line-height:1; }
.lb-prev,.lb-next{ top:50%; transform:translateY(-50%); font-size:3.2rem; padding:0 1.2rem; }
.lb-prev{ left:1vw; } .lb-next{ right:1vw; }
@media (max-width:680px){ .lb-prev,.lb-next{ font-size:2.2rem; } }

/* ============================ VIDEO / CIMETIÈRE ============================ */
.tribute-video{
  position:relative; max-width:980px; margin:0 auto; border-radius:4px; overflow:hidden;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.6); background:#000; aspect-ratio:16/9;
}
.tribute-video video{ width:100%; height:100%; object-fit:cover; display:block; }
.video-play{
  position:absolute; inset:0; width:100%; height:100%; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.1rem;
  border:0; background:linear-gradient(180deg,rgba(20,17,13,.34),rgba(20,17,13,.5));
  color:#fbf6ec; transition:background .4s var(--ease);
}
.video-play:hover{ background:linear-gradient(180deg,rgba(20,17,13,.28),rgba(20,17,13,.44)); }
.video-play__ring{
  width:80px; height:80px; border-radius:50%; border:1px solid rgba(251,246,236,.7);
  display:flex; align-items:center; justify-content:center; backdrop-filter:blur(2px);
  background:rgba(251,246,236,.1); transition:transform .4s var(--ease), background .4s var(--ease);
}
.video-play:hover .video-play__ring{ transform:scale(1.06); background:rgba(251,246,236,.18); }
.video-play__tri{
  width:0; height:0; margin-left:5px;
  border-top:11px solid transparent; border-bottom:11px solid transparent; border-left:18px solid #fbf6ec;
}
.video-play__label{
  font-family:var(--ui); font-size:.78rem; letter-spacing:.24em; text-transform:uppercase;
}
.video-fallback{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1rem; text-align:center; padding:2rem; color:#ece4d4;
  background:linear-gradient(180deg,rgba(20,17,13,.55),rgba(20,17,13,.7));
}
.video-fallback a{
  font-family:var(--ui); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase;
  color:#241f15; background:var(--gold); padding:.9em 1.8em; border-radius:999px; text-decoration:none;
}
.cimetiere-copy{ max-width:680px; margin:clamp(40px,7vh,72px) auto 0; text-align:center; }
.cimetiere-copy p{ color:#d8cfbe; text-wrap:pretty; }
.section--deep .leaf{ color:var(--gold); }

/* ============================ CANDLE ============================ */
.candle-stage{
  display:flex; flex-wrap:wrap; gap:clamp(14px,2.4vw,30px); justify-content:center;
  align-items:flex-end; min-height:150px; margin:0 auto clamp(34px,6vh,56px);
}
.candle{
  width:30px; display:flex; flex-direction:column; align-items:center; gap:0;
  animation:candleIn .7s var(--ease) both;
}
@keyframes candleIn{ from{ opacity:0; transform:translateY(10px) scale(.9);} to{opacity:1;transform:none;} }
.candle .flame{
  width:11px; height:18px; border-radius:50% 50% 50% 50% / 64% 64% 36% 36%;
  background:radial-gradient(circle at 50% 72%, #fff5cf 0%, #ffcf5c 38%, #f59a2a 72%, #e76d1f 100%);
  box-shadow:0 0 14px 5px rgba(255,179,71,.55), 0 0 30px 10px rgba(255,150,40,.28);
  transform-origin:50% 100%; animation:flicker 2.6s ease-in-out infinite;
  margin-bottom:2px;
}
@keyframes flicker{
  0%,100%{ transform:rotate(-1.5deg) scaleY(1);}
  25%{ transform:rotate(2deg) scaleY(1.06);}
  50%{ transform:rotate(-1deg) scaleY(.96);}
  75%{ transform:rotate(1.5deg) scaleY(1.03);}
}
.candle .stick{
  width:13px; height:46px; border-radius:3px;
  background:linear-gradient(180deg,#f7eede,#e7d6b6 60%,#d9c39a);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);
}
.candle .wick{ width:2px; height:5px; background:#5a4a35; }
.candle-meta{ text-align:center; }
.btn-candle{
  font-family:var(--ui); font-size:.8rem; letter-spacing:.2em; text-transform:uppercase;
  border:1px solid var(--gold); color:var(--gold); background:var(--gold-tint);
  padding:.95em 1.9em; border-radius:999px; cursor:pointer;
  display:inline-flex; align-items:center; gap:.7em; transition:.4s var(--ease);
}
.btn-candle:hover{ background:var(--gold); color:#241f15; transform:translateY(-1px); }
.candle-count{ margin-top:1.1rem; font-family:var(--display); font-style:italic; color:#cdbf9e; font-size:1.15rem; }

/* ============================ GUESTBOOK ============================ */
.guestbook-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(34px,5vw,68px); align-items:start; }
@media (max-width:820px){ .guestbook-grid{ grid-template-columns:1fr; } }
.gb-form{ display:flex; flex-direction:column; gap:1rem; }
.gb-form label{ font-family:var(--ui); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.4rem; display:block; }
.gb-form input,.gb-form textarea{
  width:100%; font-family:var(--body); font-size:1rem; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:4px;
  padding:.8em .9em; transition:border-color .3s var(--ease), box-shadow .3s var(--ease);
}
.gb-form textarea{ min-height:130px; resize:vertical; line-height:1.6; }
.gb-form input:focus,.gb-form textarea:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-tint);
}
.btn-primary{
  align-self:flex-start; font-family:var(--ui); font-size:.8rem; letter-spacing:.2em; text-transform:uppercase;
  background:var(--accent); color:#fbf8f2; border:0; padding:1em 2em; border-radius:999px; cursor:pointer;
  transition:.4s var(--ease);
}
.btn-primary:hover{ background:var(--accent-ink); transform:translateY(-1px); }
.gb-note{ font-size:.8rem; color:var(--ink-faint); font-style:italic; margin-top:.3rem; }

.gb-entries{ display:flex; flex-direction:column; gap:16px; max-height:560px; overflow:auto; padding-right:4px; }
.gb-card{
  background:var(--paper); border:1px solid var(--line-soft); border-radius:6px;
  padding:1.3rem 1.5rem; box-shadow:0 10px 26px -22px rgba(43,40,35,.5);
  animation:gbIn .5s var(--ease) both;
}
@keyframes gbIn{ from{opacity:0; transform:translateY(8px);} to{opacity:1;transform:none;} }
.gb-card p{ margin:0 0 .8rem; font-style:italic; color:var(--ink); text-wrap:pretty; }
.gb-card .who{ font-family:var(--ui); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-ink); display:flex; gap:.7rem; align-items:center; }
.gb-card .who .when{ color:var(--ink-faint); letter-spacing:.1em; }

/* ============================ FOOTER ============================ */
.footer{ background:var(--bg-deep); color:#cfc6b6; padding:clamp(64px,10vh,110px) 0 40px; text-align:center; }
.footer .ornament{ color:var(--gold); margin-bottom:2rem; }
.footer h3{ color:#fbf6ec; font-size:clamp(2rem,4.6vw,3rem); margin-bottom:1.1rem; }
.footer p{ color:#bdb3a1; max-width:54ch; margin:0 auto 1.6rem; }
.footer .cond-btn{
  display:inline-flex; align-items:center; gap:.7em; text-decoration:none;
  font-family:var(--ui); font-size:.82rem; letter-spacing:.18em; text-transform:uppercase;
  color:#241f15; background:var(--gold); padding:1em 2.1em; border-radius:999px; transition:.4s var(--ease);
}
.footer .cond-btn:hover{ background:#d8a957; transform:translateY(-1px); }
.footer .meta{ margin-top:clamp(48px,8vh,80px); font-size:.78rem; color:#8c8474; letter-spacing:.04em; }
.footer .meta a{ color:#b6ab98; }

/* ============================ REVEAL ============================ */
body.no-candle #candle, body.no-guestbook #souvenirs{ display:none; }

.reveal{ opacity:0; transform:translateY(22px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; }
.reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  *{ scroll-behavior:auto !important; }
  .flicker,.candle .flame{ animation:none; }
}
