
:root{
  --bg:#f7f2ec;
  --panel:#fffaf6;
  --text:#1f1a18;
  --muted:#6f645c;
  --line:#e2d6c9;
  --berry:#7a3f5c;
  --forest:#2f5c54;
  --shadow:0 18px 40px rgba(31,26,24,.08);
  --radius:22px;
  --max:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  background:
    radial-gradient(circle at top right, rgba(122,63,92,.08), transparent 24%),
    radial-gradient(circle at bottom left, rgba(47,92,84,.08), transparent 22%),
    var(--bg);
  color:var(--text);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{width:min(var(--max),92vw);margin:auto}
.site-header{
  position:sticky; top:0; z-index:20;
  background:rgba(247,242,236,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:15px 0}
.brand{text-decoration:none;font-weight:700;font-size:1.2rem}
.nav-links{display:flex;flex-wrap:wrap;gap:16px}
.nav-links a{text-decoration:none;color:var(--muted)}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--berry)}
.hero{padding:82px 0 58px}
.hero-grid,.grid{display:grid;gap:24px}
.hero-grid{grid-template-columns:1.12fr .88fr}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card,.creature-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.card{padding:30px}
.hero-copy{padding:36px}
.hero-art-card{overflow:hidden}
.hero-art-copy{padding:24px 28px 28px}
.sigil-wrap{
  padding:26px;
  background:
    radial-gradient(circle at 22% 22%, rgba(255,255,255,.95), transparent 16%),
    radial-gradient(circle at 75% 26%, rgba(255,255,255,.78), transparent 12%),
    linear-gradient(145deg, rgba(47,92,84,1) 0%, rgba(55,69,82,1) 34%, rgba(122,63,92,1) 100%);
}
.eyebrow{
  display:inline-block;
  margin-bottom:12px;
  color:var(--berry);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.78rem;
  font-weight:700;
}
h1,h2,h3{margin:0 0 14px;line-height:1.08;font-weight:700}
h1{font-size:clamp(2.55rem,4.8vw,4.25rem)}
h2{font-size:clamp(2rem,3vw,2.7rem)}
h3{font-size:1.35rem}
p{margin:0 0 14px}
.lead{font-size:1.08rem;color:var(--muted);max-width:58ch}
.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.button{
  display:inline-block;text-decoration:none;border-radius:999px;padding:12px 18px;
  font-weight:700;border:1px solid var(--line)
}
.button.primary{color:#fff;background:var(--berry);border-color:var(--berry)}
.button.secondary{background:transparent;color:var(--text)}
.section{padding:22px 0 72px}
.alt{background:rgba(255,255,255,.46);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.clean{margin:0;padding-left:18px}
.diagram{width:100%;border-radius:18px;border:1px solid var(--line);background:#fff}
.creature-card{padding:22px;background:linear-gradient(180deg,#fff 0%,#f7f1ea 100%)}
.creature-name{font-size:1.2rem;font-weight:700;margin-bottom:4px}
.creature-type{
  color:var(--berry);font-size:.92rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;margin-bottom:12px
}
.muted{color:var(--muted)}
.site-footer{padding:24px 0 48px;color:var(--muted)}
.footer-inner{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:16px
}
@media (max-width:950px){
  .hero-grid,.grid-2,.grid-3{grid-template-columns:1fr}
}
@media (max-width:640px){
  .nav{align-items:flex-start}
  .hero-copy,.card,.creature-card{padding:22px}
  .hero{padding-top:64px}
}
