:root {
  --bg: #faf6ef;
  --bg-soft: #f2ebde;
  --ink: #1c1917;
  --ink-soft: #44403c;
  --accent: #8a5a44;
  --accent-soft: #b5886f;
  --sage: #6b8275;
  --line: #d9cfbf;
  --max: 1120px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font:400 17px/1.65 "Inter",-apple-system,system-ui,"Segoe UI",sans-serif;
  background:var(--bg);color:var(--ink);}
a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:2px}
a:hover{text-decoration-color:var(--accent)}
h1,h2,h3,h4{font-family:"Lora","Georgia",serif;font-weight:500;line-height:1.2;margin-top:0}
h1{font-size:clamp(2rem,5vw,3.1rem);letter-spacing:-.01em}
h2{font-size:1.75rem}
h3{font-size:1.35rem}
img{max-width:100%;height:auto;border-radius:4px}

header.site{padding:1.25rem 1.5rem;border-bottom:1px solid var(--line);background:var(--bg)}
header.site .wrap{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
header.site .brand{font-family:"Lora",serif;font-size:1.5rem;color:var(--ink);text-decoration:none;letter-spacing:.02em}
header.site .brand em{font-style:italic;color:var(--accent)}
header.site nav a{margin-left:1.25rem;color:var(--ink-soft);text-decoration:none;font-size:.95rem}
header.site nav a:hover{color:var(--accent)}

.hero{padding:4.5rem 1.5rem 3rem;text-align:center;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 100%);border-bottom:1px solid var(--line)}
.hero .wrap{max-width:780px;margin:0 auto}
.hero .kicker{text-transform:uppercase;letter-spacing:.18em;color:var(--sage);font-size:.82rem;margin-bottom:1rem}
.hero h1{margin-bottom:1rem}
.hero p{font-size:1.1rem;color:var(--ink-soft);max-width:560px;margin:0 auto}

main{max-width:var(--max);margin:0 auto;padding:3rem 1.5rem}
section{margin-bottom:4rem}
.section-title{display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:.75rem;margin-bottom:1.5rem}
.section-title h2{margin:0}
.section-title a{font-size:.9rem}

.grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:1.25rem 1.35rem;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(60,40,20,.07)}
.card .tag{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--sage);margin-bottom:.5rem}
.card h3{margin:0 0 .35rem;font-size:1.15rem}
.card h3 a{color:var(--ink);text-decoration:none}
.card h3 a:hover{color:var(--accent)}
.card p{margin:0;color:var(--ink-soft);font-size:.95rem}

.cats{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.cat{display:block;padding:1rem 1.2rem;background:#fff;border:1px solid var(--line);border-radius:6px;text-decoration:none;color:var(--ink)}
.cat:hover{border-color:var(--accent);color:var(--accent)}
.cat .count{color:var(--sage);font-size:.85rem;margin-left:.25em}

article.post{max-width:720px;margin:0 auto}
article.post .meta{color:var(--sage);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;margin-bottom:1rem}
article.post h1{margin-bottom:1.25rem}
article.post p{margin:0 0 1.1rem}
article.post h3,article.post h4{margin-top:2rem;margin-bottom:.75rem;color:var(--accent)}
article.post ul,article.post ol{padding-left:1.5rem;margin:0 0 1.1rem}
article.post li{margin-bottom:.4rem}
article.post blockquote{border-left:3px solid var(--accent-soft);padding:.25rem 0 .25rem 1.25rem;margin:1.5rem 0;color:var(--ink-soft);font-style:italic}

.post-footer{max-width:720px;margin:3rem auto 0;padding-top:2rem;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.9rem}
.post-footer a{color:var(--accent)}

footer.site{margin-top:5rem;padding:2.5rem 1.5rem;border-top:1px solid var(--line);background:var(--bg-soft);color:var(--ink-soft);font-size:.9rem}
footer.site .wrap{max-width:var(--max);margin:0 auto;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}
footer.site a{color:var(--ink-soft)}
footer.site a:hover{color:var(--accent)}

.notice{background:#fff;border:1px solid var(--line);border-left:3px solid var(--sage);padding:1rem 1.25rem;margin:1.5rem 0;border-radius:4px;color:var(--ink-soft);font-size:.95rem}

@media (max-width:600px){
  header.site nav a{margin:.25rem .75rem .25rem 0;display:inline-block}
  .hero{padding:3rem 1.25rem 2.25rem}
  main{padding:2.25rem 1.25rem}
}