:root {
  --gold: #C8973A;
  --gold-light: #E4B96A;
  --gold-pale: #F5E9D0;
  --espresso: #1A0A04;
  --forest: #1B4332;
  --cream: #FAF5EC;
  --off-white: #FEF9F2;
  --text-dark: #1C1109;
  --text-mid: #5A3D22;
  --border: rgba(200,151,58,0.25);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: "Jost", sans-serif; background: var(--off-white); color: var(--text-dark); }

/* NAV */
.blog-nav { background: var(--espresso); padding: 1.1rem 4rem; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid rgba(200,151,58,0.2); }
.blog-nav-logo { display: flex; align-items: center; gap: 0.75rem; text-decoration: none; }
.blog-nav-logo img { width: 38px; height: 38px; border-radius: 50%; object-fit: cover; border: 1.5px solid var(--gold); }
.blog-nav-logo span { font-family: "Cormorant Garamond", serif; font-size: 1.4rem; font-weight: 700; letter-spacing: 0.1em; color: var(--gold-pale); }
.blog-nav-links { display: flex; gap: 2rem; align-items: center; }
.blog-nav-links a { font-size: 0.74rem; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase; text-decoration: none; color: rgba(250,245,236,0.55); transition: color 0.2s; }
.blog-nav-links a:hover { color: var(--gold-light); }

/* BLOG LISTING */
.blog-hero { background: var(--espresso); padding: 5rem 4rem 4rem; text-align: center; }
.blog-hero h1 { font-family: "Cormorant Garamond", serif; font-size: clamp(2.2rem, 4vw, 3.2rem); font-weight: 300; color: var(--gold-pale); margin-bottom: 0.6rem; }
.blog-hero h1 em { font-style: italic; color: var(--gold-light); }
.blog-hero p { font-size: 0.88rem; color: rgba(250,245,236,0.45); max-width: 480px; margin: 0 auto; line-height: 1.8; }

.blog-grid { max-width: 960px; margin: 0 auto; padding: 3rem 2rem 5rem; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 2rem; }
.blog-card { background: white; border: 1px solid var(--border); overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; text-decoration: none; display: block; color: inherit; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(44,26,14,0.1); }
.blog-card-img { width: 100%; height: 180px; object-fit: cover; display: block; }
.blog-card-body { padding: 1.3rem 1.4rem; }
.blog-card-tag { font-size: 0.62rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.5rem; }
.blog-card-title { font-family: "Cormorant Garamond", serif; font-size: 1.35rem; font-weight: 600; color: var(--espresso); margin-bottom: 0.5rem; line-height: 1.3; }
.blog-card-excerpt { font-size: 0.82rem; color: var(--text-mid); line-height: 1.7; margin-bottom: 1rem; }
.blog-card-link { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); text-decoration: none; transition: color 0.2s; }
.blog-card-link:hover { color: var(--espresso); }

/* ARTICLE */
.article-header { background: var(--espresso); padding: 5rem 4rem 3.5rem; text-align: center; }
.article-tag { font-size: 0.65rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 1rem; display: inline-block; }
.article-header h1 { font-family: "Cormorant Garamond", serif; font-size: clamp(2rem, 4.5vw, 3rem); font-weight: 300; color: var(--gold-pale); line-height: 1.2; max-width: 700px; margin: 0 auto 1rem; }
.article-header h1 em { font-style: italic; color: var(--gold-light); }
.article-meta { font-size: 0.76rem; color: rgba(250,245,236,0.4); letter-spacing: 0.06em; }

.article-body { max-width: 680px; margin: 0 auto; padding: 3rem 2rem 5rem; }
.article-body h2 { font-family: "Cormorant Garamond", serif; font-size: 1.6rem; font-weight: 600; color: var(--espresso); margin: 2.5rem 0 0.8rem; line-height: 1.3; }
.article-body h3 { font-family: "Cormorant Garamond", serif; font-size: 1.25rem; font-weight: 600; color: var(--espresso); margin: 2rem 0 0.6rem; }
.article-body p { font-size: 0.92rem; color: var(--text-mid); line-height: 1.9; margin-bottom: 1.2rem; }
.article-body strong { color: var(--espresso); }
.article-body ul, .article-body ol { padding-left: 1.4rem; margin-bottom: 1.2rem; }
.article-body li { font-size: 0.92rem; color: var(--text-mid); line-height: 1.9; margin-bottom: 0.4rem; }
.article-body blockquote { border-left: 3px solid var(--gold); padding: 0.8rem 1.2rem; background: rgba(200,151,58,0.06); margin: 1.5rem 0; }
.article-body blockquote p { color: var(--text-dark); font-style: italic; margin-bottom: 0; }

.article-cta { background: var(--espresso); padding: 3rem 2rem; text-align: center; margin-top: 2rem; }
.article-cta p { font-family: "Cormorant Garamond", serif; font-size: 1.4rem; color: var(--gold-pale); margin-bottom: 1.2rem; }
.article-cta a { display: inline-block; background: var(--gold); color: var(--espresso); padding: 0.75rem 1.8rem; font-family: "Jost", sans-serif; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; text-decoration: none; transition: background 0.2s; }
.article-cta a:hover { background: var(--gold-light); }

/* FOOTER */
.blog-footer { background: var(--espresso); padding: 2rem 4rem; border-top: 1px solid rgba(200,151,58,0.15); text-align: center; }
.blog-footer span { font-size: 0.72rem; color: rgba(250,245,236,0.3); letter-spacing: 0.08em; }

@media (max-width: 640px) {
  .blog-nav { padding: 0.9rem 1.4rem; }
  .blog-nav-links { gap: 1rem; }
  .blog-hero { padding: 3.5rem 1.4rem 3rem; }
  .blog-grid { padding: 2rem 1.2rem 4rem; }
  .article-header { padding: 3.5rem 1.4rem 2.5rem; }
  .article-body { padding: 2rem 1.2rem 4rem; }
  .blog-footer { padding: 1.5rem 1.4rem; }
}
