/* Honored Ancestors — shared stylesheet */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:#0a0604}
html{scroll-behavior:smooth;color-scheme:dark}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  color:#f5e6c4;
  min-height:100vh;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
body::after{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:600px;
  background:radial-gradient(ellipse at top, #1a1208 0%, #0a0604 70%);
  pointer-events:none;
  z-index:0;
}
body::before{
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(212,165,77,0.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(180,120,50,0.05) 0%, transparent 50%);
  pointer-events:none;
  z-index:0;
}
.wrap{max-width:1080px;margin:0 auto;padding:2rem 1.5rem;position:relative;z-index:1;background:transparent}
.narrow{max-width:760px;margin:0 auto}

/* Nav */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(10,6,4,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(212,165,77,0.18);
}
.nav-inner{
  max-width:1080px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.5rem;flex-wrap:wrap;gap:1rem;
}
.brand{
  font-family:Georgia,'Times New Roman',serif;
  font-size:1.15rem;letter-spacing:0.15em;text-transform:uppercase;
  color:#f5e6c4;text-decoration:none;
}
.brand .gold{color:#d4a54d;font-weight:600}
.nav-links{display:flex;gap:1.5rem;flex-wrap:wrap;list-style:none}
.nav-links a{
  color:#c9a876;text-decoration:none;font-size:0.9rem;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:0.25rem 0;border-bottom:1px solid transparent;
  transition:color 0.2s,border-color 0.2s;
}
.nav-links a:hover,.nav-links a.active{color:#d4a54d;border-bottom-color:#d4a54d}

/* Headings */
h1,h2,h3{font-family:Georgia,'Times New Roman',serif;font-weight:400;letter-spacing:0.03em;color:#f5e6c4}
h1{font-size:clamp(2rem,5vw,3.25rem);margin-bottom:1rem;text-transform:uppercase;letter-spacing:0.05em}
h2{font-size:clamp(1.5rem,3.5vw,2.25rem);margin:2.5rem 0 1rem}
h3{font-size:1.25rem;margin:1.5rem 0 0.75rem;color:#d4a54d}
.gold{color:#d4a54d;font-weight:600}

/* Hero block */
.hero{text-align:center;padding:3rem 0 2rem}
.symbol{
  font-size:3.5rem;margin-bottom:1.5rem;
  filter:drop-shadow(0 4px 20px rgba(212,165,77,0.3));
  animation:float 6s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.tagline{
  font-size:clamp(1rem,2vw,1.2rem);font-style:italic;color:#c9a876;
  margin:0 auto 1.5rem;max-width:560px;
}
.divider{width:80px;height:2px;background:linear-gradient(90deg,transparent,#d4a54d,transparent);margin:2rem auto}
.eyebrow{
  display:inline-block;padding:0.5rem 1.5rem;
  border:1px solid rgba(212,165,77,0.5);border-radius:2px;
  font-size:0.75rem;letter-spacing:0.3em;color:#d4a54d;
  text-transform:uppercase;margin-bottom:1.5rem;
  background:rgba(212,165,77,0.05);
}

/* Body content */
p{margin-bottom:1.1rem;color:#d4c5a0}
.lede{font-size:1.15rem;color:#e8d8b0;margin-bottom:1.5rem}
ul.bul{list-style:none;padding:0;margin:1rem 0 1.5rem}
ul.bul li{padding-left:1.5rem;margin-bottom:0.6rem;position:relative;color:#d4c5a0}
ul.bul li::before{content:'◆';color:#d4a54d;position:absolute;left:0;top:0;font-size:0.7rem;line-height:1.8}

/* Buttons */
.btn{
  display:inline-block;padding:0.85rem 2rem;
  background:#d4a54d;color:#1a1208 !important;
  border:none;border-radius:2px;
  font-size:0.85rem;font-weight:600;letter-spacing:0.15em;
  text-transform:uppercase;cursor:pointer;text-decoration:none;
  transition:background 0.2s,transform 0.1s;font-family:inherit;
}
.btn:hover{background:#e6b85f}
.btn:active{transform:translateY(1px)}
.btn-ghost{
  background:transparent;color:#d4a54d !important;
  border:2px solid #d4a54d;padding:0.75rem 1.85rem;
}
.btn-ghost:hover{background:rgba(212,165,77,0.1)}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin:2rem 0}

/* Cards / panels */
.panel{
  background:rgba(245,230,196,0.04);
  border:1px solid rgba(212,165,77,0.2);
  border-radius:4px;padding:2rem;margin:1.5rem 0;
}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin:2rem 0}
.card{
  background:rgba(245,230,196,0.04);
  border:1px solid rgba(212,165,77,0.2);
  border-radius:4px;padding:1.5rem;
}
.card h3{margin-top:0}

/* Forms */
form.std{display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}
.field{display:flex;flex-direction:column;gap:0.4rem}
.field label{font-size:0.85rem;letter-spacing:0.08em;text-transform:uppercase;color:#c9a876}
.field .hint{font-size:0.8rem;color:rgba(245,230,196,0.7);font-style:italic}
.field input,.field textarea,.field select{
  padding:0.85rem 1rem;
  background:rgba(245,230,196,0.05);
  border:1px solid rgba(212,165,77,0.4);
  border-radius:2px;color:#f5e6c4;
  font-size:1rem;font-family:inherit;line-height:1.5;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:#d4a54d;background:rgba(245,230,196,0.08);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,230,196,0.4)}
.checkrow{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.95rem;color:#d4c5a0}
.checkrow input[type=checkbox]{
  width:18px;height:18px;margin-top:3px;flex-shrink:0;
  accent-color:#d4a54d;
}
.email-form{display:flex;flex-wrap:wrap;gap:0.5rem;margin:1.5rem 0;max-width:500px}
.email-form input{
  flex:1;min-width:220px;padding:0.85rem 1.25rem;
  background:rgba(245,230,196,0.05);
  border:1px solid rgba(212,165,77,0.4);
  border-radius:2px;color:#f5e6c4;font-size:1rem;font-family:inherit;
}
.email-form input:focus{outline:none;border-color:#d4a54d}

/* Story page */
.story-hero{text-align:center;padding:3rem 0 2rem;border-bottom:1px solid rgba(212,165,77,0.2);margin-bottom:2.5rem}
.portrait{
  width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,#3a2a14,#1a1208);
  border:3px solid #d4a54d;margin:0 auto 1.5rem;
  display:flex;align-items:center;justify-content:center;
  font-size:4rem;color:#d4a54d;
  font-family:Georgia,serif;font-weight:600;
  box-shadow:0 0 40px rgba(212,165,77,0.2);
}
.dates{font-size:0.95rem;letter-spacing:0.15em;color:#c9a876;margin-bottom:0.5rem}
.life-summary{font-size:1.2rem;font-style:italic;color:#e8d8b0;max-width:640px;margin:0 auto 1rem}
.remembrance p{font-size:1.05rem;line-height:1.85}
.closing-line{
  text-align:center;font-style:italic;color:#d4a54d;
  margin:3rem auto 1rem;letter-spacing:0.1em;
  border-top:1px solid rgba(212,165,77,0.3);padding-top:2rem;max-width:400px;
}

/* Footer */
footer{
  margin-top:5rem;padding:2.5rem 1.5rem 2rem;
  border-top:1px solid rgba(212,165,77,0.2);
  text-align:center;font-size:0.85rem;color:rgba(245,230,196,0.7);
  letter-spacing:0.05em;line-height:1.9;
}
footer a{color:#d4a54d;text-decoration:none}
footer a:hover{color:#e6b85f;text-decoration:underline}
footer .footnav{margin-bottom:1rem}
footer .footnav a{margin:0 0.6rem;text-transform:uppercase;letter-spacing:0.15em;font-size:0.75rem}
footer .copy{color:rgba(245,230,196,0.4);letter-spacing:0.1em;font-size:0.75rem;margin-top:0.5rem}

/* Utility */
.center{text-align:center}
.muted{color:rgba(245,230,196,0.75)}
.spacer{height:2rem}
@media (max-width:560px){
  .nav-inner{justify-content:center;text-align:center}
  .nav-links{justify-content:center;gap:1rem}
  .nav-links a{font-size:0.78rem}
  .symbol{font-size:2.75rem}
  .wrap{padding:1.5rem 1.25rem}
}
