
:root{
  --bg:#fbf7f0; --ink:#1a1410; --muted:#6b5d4f;
  --accent:#c2410c; --accent-2:#7c2d12; --gold:#b8860b;
  --card:#fff8ec; --line:#e8dcc4;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, sans-serif;
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans); background:var(--bg); color:var(--ink);
  font-size:18px; line-height:1.7; -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:var(--accent); text-decoration:none; border-bottom:1px solid transparent; transition:border-color .2s}
a:hover{border-bottom-color:var(--accent)}

/* Top nav */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(251,247,240,.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1200px; margin:0 auto; padding:.9rem 1.5rem;
  display:flex; gap:2rem; align-items:center; justify-content:space-between;
}
.brand{
  font-family:var(--serif); font-weight:600; font-size:1.4rem;
  letter-spacing:.02em; color:var(--ink); border:none;
}
.brand span{color:var(--accent)}
.nav-links{display:flex; gap:1.4rem; flex-wrap:wrap; font-size:.85rem; text-transform:uppercase; letter-spacing:.08em}
.nav-links a{color:var(--muted); border:none; font-weight:500}
.nav-links a:hover, .nav-links a.active{color:var(--accent)}

/* Hero */
.hero{
  position:relative; height:78vh; min-height:520px; max-height:780px;
  display:flex; align-items:flex-end; overflow:hidden;
}
.hero-img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:-2;
}
.hero::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,20,16,.85) 0%, rgba(26,20,16,.35) 40%, rgba(26,20,16,.1) 100%);
  z-index:-1;
}
.hero-inner{
  max-width:1200px; margin:0 auto; padding:3rem 1.5rem 4rem; color:#fff8ec; width:100%;
}
.kicker{
  display:inline-block; font-size:.78rem; letter-spacing:.2em; text-transform:uppercase;
  color:#f5d9a8; border:1px solid #f5d9a8; padding:.35rem .9rem; border-radius:2px;
  margin-bottom:1.4rem; font-weight:500;
}
.hero h1{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.4rem, 6vw, 4.8rem); line-height:1.05;
  max-width:900px; letter-spacing:-.01em;
}
.hero .sub{
  margin-top:1.2rem; max-width:620px; font-size:1.15rem;
  color:#f5ead2; font-weight:300;
}

/* Article */
.article{max-width:760px; margin:0 auto; padding:4rem 1.5rem 2rem}
.meta{
  font-size:.8rem; letter-spacing:.15em; text-transform:uppercase;
  color:var(--muted); margin-bottom:1rem;
}
.meta span{color:var(--accent)}
.article h1.title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2rem,4.5vw,3.2rem); line-height:1.1; margin-bottom:1.2rem; letter-spacing:-.01em;
}
.lede{
  font-family:var(--serif); font-size:1.55rem; line-height:1.45;
  color:var(--accent-2); margin:1.5rem 0 2.5rem; font-weight:400;
  border-left:3px solid var(--accent); padding-left:1.2rem;
}
.article h2{
  font-family:var(--serif); font-weight:600;
  font-size:1.9rem; margin:2.8rem 0 1rem; color:var(--ink);
}
.article p{margin:0 0 1.2rem}
.article ul, .article ol{margin:1.2rem 0 1.5rem 1.5rem}
.article li{margin-bottom:.6rem}
.article blockquote{
  font-family:var(--serif); font-style:italic; font-size:1.4rem; line-height:1.4;
  margin:2.5rem 0; padding:1rem 0 1rem 1.5rem;
  border-left:3px solid var(--gold); color:var(--accent-2);
}
.article strong{color:var(--ink); font-weight:600}

/* Page nav */
.page-nav{
  max-width:760px; margin:3rem auto; padding:0 1.5rem;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
}
.page-nav a{
  flex:1 1 280px; padding:1.2rem 1.4rem; background:var(--card);
  border:1px solid var(--line); border-radius:4px; border-bottom:1px solid var(--line);
  transition:all .2s; color:var(--ink);
}
.page-nav a:hover{border-color:var(--accent); transform:translateY(-2px)}
.page-nav .label{font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted)}
.page-nav .title{font-family:var(--serif); font-size:1.2rem; margin-top:.3rem; line-height:1.3}
.page-nav .next{text-align:right}

/* Index grid */
.toc{
  max-width:1200px; margin:4rem auto; padding:0 1.5rem;
}
.toc h2{
  font-family:var(--serif); font-size:2rem; margin-bottom:.5rem; text-align:center;
}
.toc-sub{text-align:center; color:var(--muted); margin-bottom:3rem}
.grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
}
.card{
  background:var(--card); border:1px solid var(--line);
  border-radius:4px; overflow:hidden; transition:all .25s;
  display:flex; flex-direction:column; border-bottom:1px solid var(--line);
}
.card:hover{transform:translateY(-4px); box-shadow:0 12px 30px -10px rgba(26,20,16,.18)}
.card img{aspect-ratio:4/3; object-fit:cover; width:100%}
.card-body{padding:1.4rem 1.4rem 1.6rem}
.card .num{font-size:.72rem; letter-spacing:.18em; color:var(--accent); text-transform:uppercase; font-weight:600}
.card h3{font-family:var(--serif); font-size:1.4rem; margin:.4rem 0 .6rem; line-height:1.25}
.card p{color:var(--muted); font-size:.95rem; line-height:1.5}

/* Footer */
footer{
  margin-top:5rem; padding:3rem 1.5rem; background:var(--ink); color:#f5ead2;
  text-align:center;
}
footer .brand{color:#f5ead2}
footer p{margin-top:.6rem; font-size:.9rem; color:#bba88a}

@media (max-width:640px){
  .nav-links{display:none}
  .hero{height:auto; min-height:480px; padding-bottom:3rem}
  .lede{font-size:1.3rem}
}
