:root{
  --paper:#f5efe0;
  --paper-2:#ede4cf;
  --ink:#1c1a14;
  --ink-soft:#3d362a;
  --rule:#1c1a1430;
  --accent:#9a2a1f;
  --accent-soft:#c4533e;
  --gold:#c9a04a;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:20px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(154,42,31,.04) 0, transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(28,26,20,.04) 0, transparent 40%);
}
body::before{
  content:"";
  position:fixed;inset:0;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(28,26,20,.012) 3px 4px),
    repeating-linear-gradient(90deg, transparent 0 3px, rgba(28,26,20,.012) 3px 4px);
  pointer-events:none;z-index:1;
}
a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;}
a:hover{color:var(--accent-soft);}
.wrap{max-width:1080px;margin:0 auto;padding:0 32px;position:relative;z-index:2;}
.wrap-narrow{max-width:780px;margin:0 auto;padding:0 32px;position:relative;z-index:2;}

/* Top bar */
.topbar{
  border-bottom:1px solid var(--rule);
  padding:14px 0;
  font-family:Inter,sans-serif;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  background:var(--paper);
  position:sticky;top:0;z-index:40;
  backdrop-filter:blur(20px);
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.topbar a{color:var(--ink);text-decoration:none;}
.topbar nav{display:flex;gap:24px;}
.topbar nav a{color:var(--ink-soft);}
.topbar nav a:hover{color:var(--accent);}
.topbar nav a.active{color:var(--accent);}
@media (max-width:680px){.topbar nav{display:none;}}

/* Masthead */
.mast{
  text-align:center;
  padding:48px 0 28px;
  border-bottom:3px double var(--ink);
}
.mast-eyebrow{
  font-family:Inter,sans-serif;
  font-size:11.5px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:14px;
}
.mast-title{
  font-family:"Cormorant Garamond",serif;
  font-weight:800;
  font-size:clamp(48px,8vw,108px);
  line-height:.9;
  letter-spacing:-.02em;
  margin-bottom:14px;
}
.mast-title em{
  font-style:italic;
  color:var(--accent);
  font-weight:500;
}
.mast-tag{
  font-family:Inter,sans-serif;
  font-size:12px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* Issue strip */
.issue{
  padding:18px 0;
  border-bottom:1px solid var(--rule);
  font-family:Inter,sans-serif;
  font-size:11.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
}

/* Hero */
.hero{padding:80px 0 60px;}
.hero-grid{display:grid;grid-template-columns:7fr 5fr;gap:64px;align-items:start;}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr;gap:32px;}}

.h1{
  font-size:clamp(40px,5.4vw,72px);
  font-weight:600;
  line-height:1.02;
  letter-spacing:-.025em;
  margin-bottom:24px;
}
.h1 em{font-style:italic;color:var(--accent);}
.dropcap::first-letter{
  font-size:84px;
  font-weight:700;
  float:left;
  line-height:.8;
  padding:4px 10px 0 0;
  color:var(--accent);
}
.lede{
  font-size:21px;
  line-height:1.55;
  color:var(--ink-soft);
  margin-bottom:18px;
}
.lede strong{color:var(--ink);}

/* CTA */
.cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--ink);
  color:var(--paper);
  font-family:Inter,sans-serif;
  font-weight:700;
  font-size:14.5px;
  letter-spacing:.08em;
  padding:18px 32px;
  text-decoration:none;
  border-radius:0;
  transition:all .2s ease;
  text-transform:uppercase;
}
.cta::after{content:"→";font-size:18px;}
.cta:hover{background:var(--accent);color:var(--paper);}
.cta-block{margin:32px 0 16px;}
.cta-sub{
  font-family:Inter,sans-serif;
  font-size:12px;
  color:var(--ink-soft);
  letter-spacing:.04em;
}

/* Book cover image */
.book-display{
  perspective:1400px;
  display:flex;justify-content:center;align-items:center;
  padding:8px;
}
.book-cover-img{
  max-width:340px;width:100%;
  height:auto;
  display:block;
  transform:rotateY(-18deg) rotateX(2deg);
  box-shadow:
    0 30px 60px rgba(28,26,20,.4),
    0 60px 120px rgba(28,26,20,.2);
  transition:transform .6s ease;
}
.book-display:hover .book-cover-img{transform:rotateY(-8deg) rotateX(0);}

/* Section general */
.section{padding:80px 0;border-top:1px solid var(--rule);}
.section-head{
  text-align:center;
  margin-bottom:48px;
}
.kicker{
  font-family:Inter,sans-serif;
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:14px;
}
.h2{
  font-size:clamp(34px,4.2vw,54px);
  font-weight:600;
  line-height:1.05;
  letter-spacing:-.02em;
  max-width:780px;margin:0 auto;
}
.h2 em{font-style:italic;color:var(--accent);}
.section-sub{
  font-size:20px;color:var(--ink-soft);
  max-width:680px;margin:18px auto 0;
  line-height:1.55;
}

/* Two-column long-form */
.lf-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:48px;column-gap:60px;
}
@media (max-width:760px){.lf-grid{grid-template-columns:1fr;gap:24px;}}
.lf-grid p{margin-bottom:14px;font-size:19px;line-height:1.6;}
.lf-grid p strong{color:var(--ink);font-weight:600;}

/* Chapters list */
.chapters{
  max-width:780px;margin:0 auto;
  border-top:1px solid var(--rule);
}
.chapter{
  display:grid;grid-template-columns:60px 1fr auto;
  align-items:center;gap:20px;
  padding:22px 0;
  border-bottom:1px solid var(--rule);
  transition:padding .2s ease;
}
.chapter:hover{padding-left:8px;}
.chapter-num{
  font-family:Inter,sans-serif;
  font-size:13px;
  letter-spacing:.18em;
  color:var(--ink-soft);
}
.chapter-title{
  font-size:22px;font-weight:500;
  letter-spacing:-.01em;
}
.chapter-title em{font-style:italic;color:var(--accent);}
.chapter-pages{
  font-family:Inter,sans-serif;
  font-size:12px;
  color:var(--ink-soft);
  letter-spacing:.08em;
  white-space:nowrap;
}

/* Pull quote */
.pullquote{
  text-align:center;
  padding:64px 24px;
  background:var(--paper-2);
  border-top:3px double var(--ink);
  border-bottom:3px double var(--ink);
}
.pullquote-text{
  font-size:clamp(28px,3.6vw,42px);
  font-weight:500;
  font-style:italic;
  max-width:880px;margin:0 auto 18px;
  line-height:1.25;
}
.pullquote-text::before{content:"\201C";color:var(--accent);font-size:1.2em;}
.pullquote-text::after{content:"\201D";color:var(--accent);font-size:1.2em;}
.pullquote-author{
  font-family:Inter,sans-serif;
  font-size:12px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-soft);
}

/* What's inside grid */
.inside-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
@media (max-width:860px){.inside-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.inside-grid{grid-template-columns:1fr;}}
.inside-card{
  padding:28px 4px;
  border-top:1px solid var(--ink);
}
.inside-num{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.28em;
  color:var(--accent);text-transform:uppercase;
  margin-bottom:10px;
}
.inside-card h3{
  font-size:24px;line-height:1.15;
  font-weight:600;letter-spacing:-.015em;
  margin-bottom:8px;
}
.inside-card h3 em{font-style:italic;color:var(--accent);}
.inside-card p{font-size:17px;color:var(--ink-soft);line-height:1.55;}

/* Author block */
.author{
  display:grid;grid-template-columns:200px 1fr;gap:36px;
  align-items:start;
  max-width:880px;margin:0 auto;
}
@media (max-width:640px){.author{grid-template-columns:1fr;text-align:center;}}
.author-photo{
  width:200px;height:240px;
  background:linear-gradient(135deg,#9a2a1f,#3d100c);
  overflow:hidden;
  border:4px solid var(--paper);
  box-shadow:0 0 0 1px var(--ink),0 20px 40px rgba(28,26,20,.16);
  margin:0 auto;
}
.author-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.author h3{font-size:32px;font-weight:600;letter-spacing:-.015em;margin-bottom:6px;}
.author-role{
  font-family:Inter,sans-serif;font-size:13px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:18px;
}
.author p{font-size:18px;line-height:1.6;color:var(--ink-soft);margin-bottom:10px;}
.signature{
  font-family:"Caveat",cursive;
  font-size:42px;
  color:var(--accent);
  line-height:1;margin-top:8px;
}

/* Latest from the blog (on homepage) */
.latest-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
  margin-top:8px;
}
@media (max-width:860px){.latest-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.latest-grid{grid-template-columns:1fr;}}
.post-card{
  display:block;
  text-decoration:none;
  color:inherit;
  padding:28px 0 0;
  border-top:1px solid var(--ink);
  transition:padding .2s ease;
}
.post-card:hover{padding-top:24px;border-top-width:5px;}
.post-card .meta{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--accent);font-weight:600;
  margin-bottom:14px;
}
.post-card h3{
  font-size:24px;line-height:1.15;
  font-weight:600;letter-spacing:-.015em;
  margin-bottom:10px;
}
.post-card h3 em{font-style:italic;color:var(--accent);}
.post-card p{font-size:16px;color:var(--ink-soft);line-height:1.5;margin-bottom:14px;}
.post-card .more{
  font-family:Inter,sans-serif;
  font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:700;
  color:var(--ink);
}
.post-card:hover .more{color:var(--accent);}

/* Blog index page */
.blog-mast{
  text-align:center;padding:64px 0 32px;
  border-bottom:3px double var(--ink);
}
.blog-list{padding:48px 0;}
.blog-row{
  display:grid;grid-template-columns:180px 1fr auto;
  gap:32px;align-items:start;
  padding:36px 0;
  border-bottom:1px solid var(--rule);
}
.blog-row:hover{background:linear-gradient(180deg,rgba(154,42,31,.02),transparent);}
@media (max-width:760px){.blog-row{grid-template-columns:1fr;gap:14px;padding:24px 0;}}
.blog-row .date{
  font-family:Inter,sans-serif;
  font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);
  font-weight:500;line-height:1.5;padding-top:5px;
}
.blog-row .body h2{
  font-size:28px;line-height:1.2;
  font-weight:600;letter-spacing:-.015em;
  margin-bottom:8px;
}
.blog-row .body h2 em{font-style:italic;color:var(--accent);}
.blog-row .body h2 a{text-decoration:none;color:var(--ink);}
.blog-row .body h2 a:hover{color:var(--accent);}
.blog-row .body p{font-size:16px;color:var(--ink-soft);line-height:1.55;}
.blog-row .read{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);white-space:nowrap;padding-top:8px;
}

/* Article (blog post) */
.article{padding:48px 0 32px;}
.article-head{
  text-align:center;
  padding-bottom:32px;
  margin-bottom:32px;
  border-bottom:3px double var(--ink);
}
.article-cat{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent);font-weight:700;
  margin-bottom:18px;
}
.article-title-h1{
  font-size:clamp(40px,5.4vw,68px);
  font-weight:600;line-height:1.05;letter-spacing:-.022em;
  margin-bottom:18px;max-width:880px;margin-left:auto;margin-right:auto;
}
.article-title-h1 em{font-style:italic;color:var(--accent);}
.article-sub{
  font-style:italic;font-size:22px;color:var(--ink-soft);
  max-width:680px;margin:0 auto 24px;line-height:1.4;
}
.article-byline{
  display:inline-flex;align-items:center;gap:12px;
  font-family:Inter,sans-serif;font-size:13px;
  color:var(--ink-soft);
}
.article-byline img{width:42px;height:42px;border-radius:50%;object-fit:cover;}
.article-byline strong{color:var(--ink);font-weight:600;}
.article-body{
  max-width:720px;margin:0 auto;
  font-size:19px;line-height:1.75;
}
.article-body p{margin-bottom:18px;color:var(--ink);}
.article-body p:first-of-type::first-letter{
  font-family:"Cormorant Garamond",serif;
  font-weight:600;font-size:78px;
  float:left;line-height:.85;padding:4px 12px 0 0;color:var(--accent);
}
.article-body h2{
  font-size:32px;font-weight:600;letter-spacing:-.015em;line-height:1.15;
  margin:48px 0 18px;color:var(--ink);
}
.article-body h2 em{font-style:italic;color:var(--accent);}
.article-body h3{
  font-size:24px;font-weight:600;letter-spacing:-.01em;line-height:1.2;
  margin:36px 0 14px;
}
.article-body ul,.article-body ol{margin:0 0 18px 22px;}
.article-body li{margin-bottom:8px;font-size:18px;line-height:1.7;}
.article-body blockquote{
  border-left:3px solid var(--accent);
  padding:8px 0 8px 22px;
  margin:28px 0;
  font-style:italic;color:var(--ink-soft);
  font-size:22px;line-height:1.5;
}
.article-body code{
  font-family:"JetBrains Mono",monospace;
  background:var(--paper-2);
  padding:2px 6px;border-radius:3px;
  font-size:.9em;
}
.article-body img{max-width:100%;height:auto;margin:24px auto;display:block;border:1px solid var(--rule);}
.article-body a{color:var(--accent);}

/* In-article book CTA */
.article-cta{
  background:var(--ink);color:var(--paper);
  padding:48px 40px;text-align:center;
  margin:48px 0;
  display:grid;grid-template-columns:1fr 200px;gap:32px;align-items:center;
}
@media (max-width:640px){.article-cta{grid-template-columns:1fr;text-align:center;}}
.article-cta-text{text-align:left;}
@media (max-width:640px){.article-cta-text{text-align:center;}}
.article-cta .eye{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:8px;
}
.article-cta h3{
  font-size:28px;font-weight:600;line-height:1.15;
  letter-spacing:-.015em;margin-bottom:10px;
}
.article-cta h3 em{font-style:italic;color:var(--gold);}
.article-cta p{font-size:16px;color:rgba(245,239,224,.7);margin-bottom:20px;line-height:1.5;}
.article-cta .cta{background:var(--paper);color:var(--ink);}
.article-cta .cta:hover{background:var(--gold);color:var(--ink);}
.article-cta img{width:160px;height:auto;margin:0 auto;display:block;}

/* Author bio at bottom of article */
.article-author{
  max-width:720px;margin:48px auto 0;
  padding:32px;border:1px solid var(--rule);
  display:grid;grid-template-columns:80px 1fr;gap:24px;align-items:center;
  background:rgba(154,42,31,.02);
}
@media (max-width:640px){.article-author{grid-template-columns:1fr;text-align:center;}}
.article-author img{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto;}
.article-author h4{font-size:18px;font-weight:600;margin-bottom:2px;}
.article-author p{font-size:14.5px;color:var(--ink-soft);line-height:1.5;font-family:Inter,sans-serif;}
.article-author a{color:var(--accent);}

/* Related posts at bottom */
.related{padding:48px 0;border-top:1px solid var(--rule);}
.related-head{
  text-align:center;font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:32px;
}

/* Final CTA */
.final{
  text-align:center;
  padding:96px 24px;
  background:var(--ink);
  color:var(--paper);
}
.final .kicker{color:var(--gold);}
.final h2{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(40px,5.4vw,72px);
  font-weight:600;
  line-height:1.05;
  letter-spacing:-.02em;
  max-width:900px;margin:0 auto 28px;
}
.final h2 em{font-style:italic;color:var(--gold);}
.final p{font-size:20px;color:rgba(245,239,224,.7);max-width:640px;margin:0 auto 32px;}
.final .cta{background:var(--paper);color:var(--ink);}
.final .cta:hover{background:var(--gold);color:var(--ink);}

/* Footer */
.foot{
  padding:48px 0 32px;
  border-top:1px solid var(--rule);
  background:var(--paper);
  color:var(--ink-soft);
  font-family:Inter,sans-serif;
  font-size:13px;
}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px;}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;}}
.foot h4{
  font-family:Inter,sans-serif;
  font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink);margin-bottom:12px;
}
.foot a{display:block;color:var(--ink-soft);text-decoration:none;padding:4px 0;}
.foot a:hover{color:var(--accent);text-decoration:underline;}
.foot-bottom{
  padding-top:24px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:12px;
}
