:root{
  --bg:#e8d7b8;
  --paper:#f7efdf;
  --paper-2:#efe2c7;
  --ink:#332416;
  --muted:#6b5946;
  --line:rgba(81,54,27,.16);
  --gold:#8f6f42;
  --deep:#4d3824;
  --shadow:0 18px 45px rgba(72,49,24,.15);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Georgia, serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.4), transparent 28%),
    radial-gradient(circle at bottom right, rgba(126,91,45,.12), transparent 30%),
    linear-gradient(180deg, #d9c3a0, #efdfc1);
}
.page{
  width:min(1180px, calc(100% - 20px));
  margin:12px auto;
  background:linear-gradient(180deg, rgba(250,245,236,.82), rgba(241,230,208,.92));
  border:1px solid rgba(83,58,31,.18);
  box-shadow:var(--shadow);
}
.site-header{padding:28px 28px 18px; border-bottom:1px solid var(--line)}
.brand-wrap{
  display:flex; justify-content:space-between; gap:16px; align-items:flex-start; flex-wrap:wrap;
}
.site-kicker{
  margin:0 0 6px; color:var(--muted); text-transform:uppercase; letter-spacing:.16em; font-size:.76rem;
}
.site-brand{margin:0; font-size:2.3rem; line-height:1}
.meta-box{
  min-width:160px; padding:12px 14px; border:1px solid var(--line); background:rgba(255,249,240,.65); text-align:center;
}
.meta-box span{display:block; color:var(--muted); font-size:.86rem}
.meta-box strong{font-size:1.6rem}
.nav-row{margin-top:18px; display:flex; justify-content:space-between; gap:16px; align-items:center; flex-wrap:wrap}
.menu{display:flex; flex-wrap:wrap; gap:18px}
.menu a{text-decoration:none; color:var(--ink); font-size:1rem; position:relative;}
.menu a::after{content:""; position:absolute; left:0; bottom:-5px; width:0; height:1px; background:currentColor; transition:.25s ease;}
.menu a:hover::after{width:100%}
.ad-box{
  border:1px dashed rgba(88,61,33,.28);
  padding:12px 18px; min-width:240px; text-align:center; color:var(--deep);
  background:rgba(226,209,176,.4);
}
main{padding:26px 28px 34px}
.hero{display:grid; grid-template-columns:1.2fr .9fr; gap:26px; align-items:center; margin-bottom:24px;}
.section-label{margin:0 0 8px; color:var(--gold); text-transform:uppercase; letter-spacing:.18em; font-size:.76rem;}
.hero h2,.person-copy h2{margin:0; font-size:3.8rem; line-height:.96}
.hero p{font-size:1.05rem; line-height:1.8; color:#513f2f}
.hero-actions,.admin-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:22px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:160px; padding:12px 18px; border-radius:999px; text-decoration:none; border:1px solid rgba(63,45,23,.18);
  font-weight:bold; cursor:pointer;
}
.btn-primary{background:linear-gradient(180deg, #775733, #5c4226); color:#fff}
.btn-secondary{background:rgba(255,250,240,.8); color:var(--ink)}
.candle-card{
  min-height:420px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  position:relative; border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,248,235,.72), rgba(226,209,176,.46));
  overflow:hidden;
}
.glow{
  position:absolute; width:220px; height:220px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,205,110,.35), rgba(255,205,110,0) 70%);
  top:86px;
}
.candle{position:relative; width:70px; height:170px}
.flame{
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:24px; height:38px;
  background:radial-gradient(circle at 50% 35%, #fff8bf 0%, #ffcf68 35%, #ef8d2c 62%, rgba(239,141,44,0) 72%);
  border-radius:50% 50% 50% 50% / 60% 60% 40% 40%;
}
.wax{position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:58px; height:118px; border-radius:14px 14px 8px 8px; background:linear-gradient(180deg, #f5ecdd, #d6c3a1); border:1px solid rgba(82,58,31,.15);}
.candle-card blockquote{margin:34px 0 0; max-width:280px; text-align:center; font-size:1.65rem; color:#5b4835; font-style:italic;}
.stats{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px; margin-bottom:24px;}
.stats article{padding:18px; border:1px solid var(--line); background:rgba(255,250,242,.6)}
.stats strong{display:block; font-size:2rem}
.stats span{color:var(--muted)}
.panel{margin-top:22px; padding:22px; border:1px solid var(--line); background:rgba(255,249,240,.52)}
.panel-head h3{margin:0; font-size:2.2rem}
.card-grid,.messages{display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin-top:18px;}
.memorial-card,.message-card{padding:20px; border:1px solid var(--line); background:rgba(255,252,246,.75)}
.years{font-size:.84rem; color:var(--muted); letter-spacing:.12em}
.memorial-card h4{margin:10px 0 12px; font-size:1.9rem}
.memorial-card p,.message-card p,.long-text{line-height:1.75; color:#54402d}
.memorial-card a{color:#5c4324; text-decoration:none; font-weight:bold}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.field{margin-bottom:14px}
label{display:block; margin-bottom:8px; font-weight:bold}
input,textarea{width:100%; padding:13px 14px; border:1px solid rgba(88,61,33,.18); background:#fffdf8; color:var(--ink); font:inherit;}
textarea{min-height:150px; resize:vertical}
.form-note{margin:8px 0 0; color:var(--muted)}
.message-card strong{display:block; margin-bottom:6px}
.message-card span{display:inline-block; margin-bottom:10px; color:var(--gold); font-size:.92rem}
.message-card small{color:var(--muted)}
.empty-box{padding:24px; border:1px dashed rgba(83,58,31,.24); color:var(--muted); text-align:center;}
.person-hero{display:grid; grid-template-columns:.95fr 1.05fr; gap:22px; align-items:center;}
.person-media img{width:100%; display:block; border:1px solid var(--line); box-shadow:var(--shadow)}
.years-line{margin:10px 0 14px; color:var(--gold); letter-spacing:.12em}
.site-footer{display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; padding:22px 28px 30px; border-top:1px solid var(--line)}
.footer-brand{margin:0 0 6px; font-size:1.4rem}
.footer-text,.footer-copy{margin:0; color:var(--muted)}
.admin-table-wrap{overflow:auto}
.admin-table{width:100%; border-collapse:collapse; margin-top:16px; background:rgba(255,252,246,.75)}
.admin-table th,.admin-table td{border:1px solid var(--line); padding:12px; text-align:left; vertical-align:top}
.admin-table th{background:rgba(230,214,185,.46)}
.actions a{margin-right:10px; color:#5c4324; text-decoration:none; font-weight:bold}
.actions a.danger{color:#8a2d21}
.alert{padding:12px 14px; background:#f4dfd5; color:#7a3228; border:1px solid #d9aa9b; margin-bottom:14px;}
.alert.success{background:#ddebd6; color:#3d6a33; border-color:#b5cfaa}
@media (max-width: 980px){
  .hero,.person-hero{grid-template-columns:1fr}
  .card-grid,.messages{grid-template-columns:1fr}
}
@media (max-width: 740px){
  .page{width:min(100% - 10px, 1180px)}
  .site-header,main,.site-footer{padding-left:16px; padding-right:16px}
  .hero h2,.person-copy h2{font-size:2.7rem}
  .stats,.field-row{grid-template-columns:1fr}
  .panel-head h3{font-size:1.9rem}
}
