/* ============================================================
   ETERNAL — Memorial stylesheet
   Palette: deep ink + champagne gold (candlelight at dusk)
   ============================================================ */

:root{
  --ink:        #0b0d13;
  --ink-2:      #11141d;
  --ink-3:      #171b27;
  --gold:       #c9a86a;
  --gold-soft:  #e4d3a8;
  --gold-deep:  #9c8147;
  --ivory:      #ece7dc;
  --muted:      #8b909c;
  --line:       rgba(201,168,106,.16);
  --line-soft:  rgba(236,231,220,.08);

  --serif: "Cormorant Garamond", Georgia, serif;
  --sans:  "Inter", system-ui, sans-serif;

  --wrap: 1120px;
  --ease: cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--ivory);
  line-height:1.7;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:var(--wrap); margin:0 auto; padding:0 28px; }
.center{ text-align:center; }
.muted{ color:var(--muted); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-size:.78rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  padding:15px 30px; border-radius:2px; cursor:pointer;
  border:1px solid transparent; transition:.4s var(--ease);
}
.btn--sm{ padding:10px 18px; font-size:.68rem; }
.btn--block{ width:100%; }
.btn--gold{
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  color:#1a1408; border-color:var(--gold);
  box-shadow:0 10px 30px -12px rgba(201,168,106,.6);
}
.btn--gold:hover{ filter:brightness(1.08); transform:translateY(-2px);
  box-shadow:0 18px 40px -14px rgba(201,168,106,.7); }
.btn--ghost{
  background:transparent; color:var(--gold-soft);
  border-color:var(--line);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold); }

/* ---------- eyebrow / titles ---------- */
.eyebrow,.hero__eyebrow{
  font-size:.72rem; letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold); font-weight:500;
}
.section__head{ text-align:center; margin-bottom:64px; }
.section__title{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(2.2rem,5vw,3.6rem); line-height:1.05;
  margin-top:14px; letter-spacing:.5px;
}
.section{ padding:120px 0; position:relative; }
.section:nth-child(even){ background:var(--ink-2); }

/* ---------- ambient motes ---------- */
.ambient{ position:fixed; inset:0; pointer-events:none; z-index:1; }
.ambient span{
  position:absolute; width:4px; height:4px; border-radius:50%;
  background:radial-gradient(circle,var(--gold-soft),transparent 70%);
  opacity:0; animation:float 14s linear infinite;
}
.ambient span:nth-child(1){ left:12%; animation-delay:0s; }
.ambient span:nth-child(2){ left:28%; animation-delay:3s; }
.ambient span:nth-child(3){ left:46%; animation-delay:6s; }
.ambient span:nth-child(4){ left:64%; animation-delay:2s; }
.ambient span:nth-child(5){ left:80%; animation-delay:8s; }
.ambient span:nth-child(6){ left:92%; animation-delay:5s; }
@keyframes float{
  0%{ transform:translateY(100vh) scale(.5); opacity:0; }
  10%{ opacity:.8; }
  90%{ opacity:.6; }
  100%{ transform:translateY(-10vh) scale(1.2); opacity:0; }
}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 28px; transition:.4s var(--ease);
}
.nav.scrolled{
  background:rgba(11,13,19,.86); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line); padding:14px 28px;
}
.nav__brand{
  font-family:var(--serif); font-size:1.4rem; letter-spacing:2px;
  color:var(--gold-soft);
}
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ivory); opacity:.8; transition:.3s; position:relative;
}
.nav__links a:hover{ opacity:1; color:var(--gold); }
.nav__cta{
  border:1px solid var(--line); padding:9px 20px; border-radius:2px;
  color:var(--gold)!important; opacity:1!important;
}
.nav__cta:hover{ background:var(--gold); color:#1a1408!important; }
.nav__burger{ display:none; background:none; border:0; cursor:pointer;
  flex-direction:column; gap:5px; }
.nav__burger span{ width:24px; height:1.5px; background:var(--gold-soft); display:block; }

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:120px 24px 80px; overflow:hidden;
}
.hero__glow{
  position:absolute; top:38%; left:50%; transform:translate(-50%,-50%);
  width:900px; height:900px; max-width:140vw;
  background:radial-gradient(circle, rgba(201,168,106,.16), transparent 60%);
  filter:blur(20px); z-index:0;
}
.hero__inner{ position:relative; z-index:2; max-width:760px; }
.hero__eyebrow{ display:block; margin-bottom:34px; }

.portrait{ position:relative; width:230px; margin:0 auto 38px; }
.portrait__arch{
  width:230px; height:300px; margin:0 auto;
  border-radius:115px 115px 8px 8px;
  overflow:hidden; position:relative;
  border:1px solid var(--gold);
  box-shadow:0 0 0 8px rgba(201,168,106,.08),
             0 30px 70px -20px rgba(0,0,0,.8),
             inset 0 0 60px rgba(201,168,106,.12);
}
.portrait__arch img{ width:100%; height:100%; object-fit:cover; filter:sepia(.12) contrast(1.02); }
.portrait__placeholder{
  width:100%; height:100%;
  background:linear-gradient(160deg,var(--ink-3),var(--ink-2));
  display:flex; align-items:center; justify-content:center;
}
.portrait__placeholder span{
  font-family:var(--serif); font-size:6rem; color:var(--gold); opacity:.5;
}
.portrait__flame{
  position:absolute; bottom:-26px; left:50%; transform:translateX(-50%);
  width:14px; height:22px; border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:radial-gradient(circle at 50% 70%, #fff6d8, var(--gold) 55%, transparent 75%);
  box-shadow:0 0 24px 8px rgba(201,168,106,.55);
  animation:flicker 2.4s ease-in-out infinite;
}
@keyframes flicker{
  0%,100%{ transform:translateX(-50%) scaleY(1) rotate(-1deg); opacity:.95; }
  25%{ transform:translateX(-52%) scaleY(1.08) rotate(2deg); opacity:1; }
  50%{ transform:translateX(-48%) scaleY(.94) rotate(-2deg); opacity:.85; }
  75%{ transform:translateX(-51%) scaleY(1.05) rotate(1deg); opacity:1; }
}

.hero__name{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(3rem,9vw,6.2rem); line-height:1; letter-spacing:1px;
  margin-bottom:14px;
  background:linear-gradient(180deg,#fff,var(--gold-soft) 70%,var(--gold));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__title{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--gold-soft); margin-bottom:24px; }
.hero__dates{
  display:flex; align-items:center; justify-content:center; gap:18px;
  font-family:var(--serif); font-size:1.5rem; letter-spacing:3px; color:var(--ivory);
  margin-bottom:26px;
}
.hero__dates em{ color:var(--gold); font-size:.9rem; }
.hero__epitaph{
  font-family:var(--serif); font-style:italic; font-size:1.5rem;
  max-width:580px; margin:0 auto 40px; color:var(--ivory); opacity:.9; line-height:1.5;
}
.hero__scroll{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%); z-index:2;
}
.hero__scroll span{
  display:block; width:22px; height:36px; border:1px solid var(--line);
  border-radius:14px; position:relative;
}
.hero__scroll span::after{
  content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%);
  width:3px; height:7px; border-radius:2px; background:var(--gold);
  animation:scroll 1.8s ease infinite;
}
@keyframes scroll{ 0%{opacity:0;top:7px;} 40%{opacity:1;} 100%{opacity:0;top:18px;} }

/* ---------- story ---------- */
.story__body{ max-width:720px; margin:0 auto; }
.story__body p{
  font-family:var(--serif); font-size:1.4rem; line-height:1.75;
  color:var(--ivory); margin-bottom:1.4em; text-align:center; opacity:.92;
}
.story__body p:first-child::first-letter{
  font-size:3.6rem; float:left; line-height:.8; padding:6px 14px 0 0;
  color:var(--gold); font-weight:500;
}
.story__meta{
  display:flex; gap:60px; justify-content:center; margin-top:54px;
  flex-wrap:wrap;
}
.story__meta div{ text-align:center; }
.story__meta .k{ display:block; font-size:.72rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.story__meta .v{ font-family:var(--serif); font-size:1.3rem; }

/* ---------- timeline ---------- */
.timeline{ list-style:none; position:relative; max-width:820px; margin:0 auto; }
.timeline::before{
  content:""; position:absolute; left:90px; top:0; bottom:0; width:1px;
  background:linear-gradient(var(--line),transparent);
}
.timeline__item{ position:relative; display:grid; grid-template-columns:90px 1fr; gap:34px; padding-bottom:46px; }
.timeline__year{
  font-family:var(--serif); font-size:1.5rem; color:var(--gold);
  text-align:right; padding-top:18px; position:relative;
}
.timeline__year::after{
  content:""; position:absolute; right:-37px; top:26px;
  width:11px; height:11px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 14px var(--gold);
}
.timeline__card{
  background:var(--ink-3); border:1px solid var(--line);
  border-radius:6px; padding:26px 28px;
}
.timeline__card h3{ font-family:var(--serif); font-size:1.5rem; font-weight:500; margin-bottom:8px; }
.timeline__card p{ color:var(--muted); font-size:.96rem; }
.timeline__img{ width:100%; border-radius:4px; margin-bottom:16px; max-height:220px; object-fit:cover; }

/* ---------- gallery ---------- */
.grid{ columns:3; column-gap:18px; }
.grid__item{
  break-inside:avoid; margin-bottom:18px; position:relative;
  border-radius:6px; overflow:hidden; cursor:pointer;
  border:1px solid var(--line-soft);
}
.grid__item img{ width:100%; transition:.6s var(--ease); filter:grayscale(.2); }
.grid__item:hover img{ transform:scale(1.06); filter:grayscale(0); }
.grid__item figcaption{
  position:absolute; bottom:0; left:0; right:0;
  padding:30px 18px 14px; font-size:.85rem;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
  opacity:0; transition:.4s;
}
.grid__item:hover figcaption{ opacity:1; }

/* ---------- service ---------- */
.service__card{
  max-width:860px; margin:0 auto; text-align:center;
  background:var(--ink-3); border:1px solid var(--line); border-radius:8px;
  padding:54px 40px;
}
.service__row{ display:grid; grid-template-columns:repeat(4,1fr); gap:34px; }
.service__cell{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.service__icon{ color:var(--gold); font-size:1rem; margin-bottom:8px; }
.service__cell .k{ font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }
.service__cell .v{ font-family:var(--serif); font-size:1.25rem; }
.service__note{ margin:38px auto 26px; max-width:560px; color:var(--muted); font-style:italic; font-family:var(--serif); font-size:1.1rem; }

/* ---------- tributes ---------- */
.tributes__list{ columns:2; column-gap:24px; margin-bottom:64px; }
.tribute{
  break-inside:avoid; margin-bottom:24px;
  background:var(--ink-3); border:1px solid var(--line); border-radius:8px;
  padding:30px 32px; position:relative;
}
.tribute::before{
  content:"“"; font-family:var(--serif); font-size:4rem; color:var(--gold);
  opacity:.3; position:absolute; top:6px; left:16px; line-height:1;
}
.tribute p{ font-family:var(--serif); font-size:1.22rem; line-height:1.6; margin:14px 0 18px; }
.tribute footer{ display:flex; flex-direction:column; }
.tribute__name{ color:var(--gold-soft); letter-spacing:.05em; font-size:.95rem; font-weight:500; }
.tribute__rel{ color:var(--muted); font-size:.8rem; }

.tribute-form{
  max-width:640px; margin:0 auto; text-align:center;
  background:var(--ink-3); border:1px solid var(--line); border-radius:10px; padding:48px 40px;
}
.tribute-form h3{ font-family:var(--serif); font-size:2rem; font-weight:400; margin-bottom:8px; }

/* ---------- forms ---------- */
.form{ margin-top:24px; text-align:left; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.form input,.form textarea,.field input,.field textarea{
  width:100%; background:var(--ink); border:1px solid var(--line);
  color:var(--ivory); padding:14px 16px; border-radius:4px;
  font-family:var(--sans); font-size:.95rem; transition:.3s;
}
.form input:focus,.form textarea:focus,.field input:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,106,.12);
}
.form textarea{ margin-bottom:18px; resize:vertical; }
.form .btn{ width:100%; }
.form__ok{ margin-top:18px; color:var(--gold-soft); }

/* ---------- donate ---------- */
.donate__grid{ display:grid; grid-template-columns:1fr 420px; gap:54px; align-items:start; }
.donate__intro p{ font-family:var(--serif); font-size:1.25rem; color:var(--ivory); opacity:.92; margin-bottom:34px; }

.progress{ margin-bottom:40px; }
.progress__bar{ height:8px; border-radius:6px; background:var(--ink-3); overflow:hidden; border:1px solid var(--line); }
.progress__bar span{ display:block; height:100%;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));
  box-shadow:0 0 14px var(--gold); transition:width 1.4s var(--ease); }
.progress__meta{ display:flex; align-items:baseline; gap:10px; margin-top:14px; }
.progress__meta strong{ font-family:var(--serif); font-size:1.8rem; color:var(--gold-soft); }
.progress__meta span{ color:var(--muted); font-size:.9rem; }
.progress__donors{ color:var(--gold); font-size:.82rem; letter-spacing:.06em; margin-top:4px; }

.qr{ display:flex; gap:22px; align-items:center; margin-top:30px;
  background:var(--ink-3); border:1px solid var(--line); border-radius:10px; padding:22px; }
.qr__code{ background:#fff; padding:10px; border-radius:8px; width:128px; height:128px; flex:0 0 auto; }
.qr__code img,.qr__code canvas{ width:108px!important; height:108px!important; }
.qr__text{ display:flex; flex-direction:column; gap:6px; }
.qr__text strong{ color:var(--gold-soft); font-size:1.05rem; }
.qr__text span{ color:var(--muted); font-size:.85rem; }
.qr__text .btn{ align-self:flex-start; margin-top:6px; }

.donate__card{ background:var(--ink-3); border:1px solid var(--gold); border-radius:12px;
  padding:40px 34px; box-shadow:0 30px 80px -30px rgba(201,168,106,.4); }
.donate__card h3{ font-family:var(--serif); font-size:1.9rem; font-weight:400; margin-bottom:22px; text-align:center; }
.amounts{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:22px; }
.amounts button{
  background:var(--ink); border:1px solid var(--line); color:var(--ivory);
  padding:12px 0; border-radius:4px; cursor:pointer; font-family:var(--serif);
  font-size:1.1rem; transition:.3s;
}
.amounts button:hover,.amounts button.active{ border-color:var(--gold); background:rgba(201,168,106,.12); color:var(--gold-soft); }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
.field label .opt{ letter-spacing:.04em; text-transform:none; color:var(--muted); opacity:.7; font-size:.92em; }
.donate__secure{ text-align:center; color:var(--muted); font-size:.78rem; margin-top:16px; }
.donate__status{ margin-top:16px; text-align:center; font-size:.92rem; }
.donate__status.ok{ color:#7ee0a8; }
.donate__status.err{ color:#e08b8b; }

/* ---------- footer ---------- */
.footer{ padding:90px 0 50px; text-align:center; border-top:1px solid var(--line); position:relative; }
.footer__flame{
  width:14px; height:22px; margin:0 auto 28px;
  border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:radial-gradient(circle at 50% 70%, #fff6d8, var(--gold) 55%, transparent 75%);
  box-shadow:0 0 24px 8px rgba(201,168,106,.5);
  animation:flicker 2.4s ease-in-out infinite;
}
.footer__name{ font-family:var(--serif); font-size:2rem; color:var(--gold-soft); }
.footer__dates{ font-family:var(--serif); letter-spacing:3px; color:var(--muted); margin:6px 0 20px; }
.footer__quote{ font-family:var(--serif); font-style:italic; font-size:1.2rem; opacity:.85; margin-bottom:26px; }
.footer__contact{ display:flex; gap:26px; justify-content:center; color:var(--muted); font-size:.88rem; margin-bottom:22px; flex-wrap:wrap; }
.footer__credit{ font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.footer__credit a{ color:var(--gold); }

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:100; background:rgba(6,7,11,.96);
  display:none; align-items:center; justify-content:center; padding:40px;
}
.lightbox.open{ display:flex; }
.lightbox figure{ max-width:90vw; max-height:90vh; text-align:center; }
.lightbox img{ max-width:100%; max-height:82vh; border-radius:6px; border:1px solid var(--line); }
.lightbox figcaption{ color:var(--gold-soft); margin-top:16px; font-family:var(--serif); font-size:1.2rem; }
.lightbox__close{ position:absolute; top:24px; right:34px; background:none; border:0;
  color:var(--ivory); font-size:2.6rem; cursor:pointer; line-height:1; }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:.9s var(--ease); transition-delay:var(--d,0ms); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .donate__grid{ grid-template-columns:1fr; gap:36px; }
  .grid{ columns:2; }
  .tributes__list{ columns:1; }
  .service__row{ grid-template-columns:1fr 1fr; gap:28px; }
}
@media (max-width:680px){
  .nav__links{ position:fixed; inset:0 0 auto 0; top:0; flex-direction:column;
    background:rgba(11,13,19,.97); padding:90px 28px 30px; gap:22px;
    transform:translateY(-110%); transition:.4s var(--ease); border-bottom:1px solid var(--line); }
  .nav__links.open{ transform:none; }
  .nav__burger{ display:flex; z-index:60; }
  .section{ padding:84px 0; }
  .grid{ columns:1; }
  .service__row{ grid-template-columns:1fr; }
  .form__row{ grid-template-columns:1fr; }
  .qr{ flex-direction:column; text-align:center; }
  .qr__text .btn{ align-self:center; }
  .story__body p{ font-size:1.2rem; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; }
  .reveal{ opacity:1; transform:none; }
}