:root {
  --primary: #7a1f2b;
  --primary-dark: #561520;
  --accent: #c19a4b;
  --accent-soft: #f3e9d6;
  --ink: #2b2422;
  --muted: #6e6660;
  --surface: #ffffff;
  --background: #faf6f1;
  --border: #e7dccd;
}

html { font-size: 17px; }
body {
  font-family: 'Source Sans 3', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 17px; line-height: 1.7; color: #2b2422;
  background-color: #faf6f1;
  display: flex; flex-direction: column; min-height: 100vh;
}
main { flex: 1 0 auto; }

h1, h2, h3, h4, h5, h6 { font-family: 'Playfair Display', sans-serif; color: #7a1f2b; font-weight: 700; line-height: 1.25; }
h1, .page-title { font-size: 38px; font-weight: 700; margin: .4em 0 .5em; }
h2, .block-heading { font-size: 28px; font-weight: 600; }
h3 { font-size: 21px; font-weight: 600; }
.section { padding: 40px 0; }

/* ── Header / nav ───────────────────────────────────── */
.site-header { background-color: #ffffff; border-bottom: 3px solid #7a1f2b; }
.title-bar { background-color: #7a1f2b; }
.title-bar-title .brand-link { color: #fff; font-family: 'Playfair Display', sans-serif; font-weight: 700; }
.top-bar.site-nav { background-color: #7a1f2b; padding: .5rem 1rem; }
.top-bar.site-nav .brand-text .brand-link { color: #fff; font-family: 'Playfair Display', sans-serif; font-weight: 700; font-size: 1.3rem; }
.top-bar.site-nav .menu { background: transparent; }
.top-bar.site-nav .menu > li > a { color: #fff; font-family: 'Source Sans 3', sans-serif; font-weight: 600; }
.top-bar.site-nav .menu > li > a:hover { color: #f3e9d6; }
.top-bar.site-nav .submenu { background: #fff; border: 1px solid var(--border); min-width: 260px; }
.top-bar.site-nav .submenu li a { color: #2b2422; }
.top-bar.site-nav .submenu li a:hover { background: #faf6f1; color: #7a1f2b; }

/* ── Hero ───────────────────────────────────────────── */
.hero { background: linear-gradient(135deg, #7a1f2b 0%, #561520 100%); color: #fff; padding: 60px 0 66px; text-align: center; }
.hero-title { color: #fff; font-size: 40px; }
.hero-lead { color: #efe2cf; font-size: 1.2rem; max-width: 720px; margin: 0 auto 1.4em; }
.hero-btn-primary { background-color: #c19a4b; color: #fff; font-weight: 700; border-radius: 26px; padding: .9em 2em; }
.hero-btn-primary:hover { background-color: #a8823f; color: #fff; }

/* ── Cards / content ────────────────────────────────── */
.category-grid { margin: 1rem 0 2rem; }
.card, .category-card, .listing-card, .default-card { background: #fff; border: 1px solid var(--border); border-radius: 10px; border-top: 3px solid #c19a4b; overflow: hidden; }
.card-title a, .card-section h5 a { color: #7a1f2b; }
.card-minimal { background: #fff; border-left: 3px solid #c19a4b; border-radius: 8px; padding: .9em 1.2em; }
.read-more-btn { background-color: #c19a4b; color: #fff; font-weight: 700; }
.read-more-btn:hover { background-color: #a8823f; }

.site-prose { color: #2b2422; }
.site-prose p, .block-paragraph { margin: 0 0 1.1em; }
.block-image, .article-main-image { max-width: 100%; height: auto; border-radius: 8px; margin: 1.1em 0; }
@media (min-width: 64em) { .article-main-image { float: right; max-width: 38%; margin: .2em 0 1em 1.6em; } }
.article-summary { border-left: 4px solid #c19a4b; background: #f3e9d6; padding: 1em 1.3em; border-radius: 0 8px 8px 0; }
.article-dates { color: #6e6660; font-size: .9rem; }
.block-quote { border-left: 4px solid #c19a4b; padding: .3em 0 .3em 1.3em; color: #6e6660; font-style: italic; font-size: 1.1rem; }
.block-list { margin-left: 1.3em; } .block-list li { list-style: disc; margin-bottom: .4em; }
.block-table { margin: 1.4em 0; }
.block-list-item { padding: 1em 0; border-bottom: 1px solid var(--border); }
.list-item-title-wrap a, .list-item-title a { font-weight: 700; color: #7a1f2b; }

/* content body links — scoped, visible */
.site-prose a, .block-paragraph a, .block-list a, .list-item-title-wrap a {
  color: #7a1f2b; text-decoration: underline; text-decoration-color: #c19a4b;
}
.site-prose a:hover, .block-paragraph a:hover { color: #561520; }

/* ── Breadcrumbs ────────────────────────────────────── */
.breadcrumb-bar { background-color: #fff; border-bottom: 1px solid var(--border); padding: .6rem 0; }
.breadcrumbs a { color: #7a1f2b; }

/* ── ToC ────────────────────────────────────────────── */
.toc-box { background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 1em 1.2em; margin-bottom: 1.4em; }
.toc-box h6 { color: #7a1f2b; margin-top: 0; }
.toc-box a { color: #2b2422; }
.toc-level-3 { padding-left: 1em; }

/* ── Footer ─────────────────────────────────────────── */
.site-footer { background-color: #561520; color: #e9d9c4; padding: 32px 0 0; margin-top: 2rem; font-family: 'Source Sans 3', sans-serif; }
.site-footer .footer-title { color: #fff; font-family: 'Playfair Display', sans-serif; }
.site-footer a { color: #e9d9c4; }
.site-footer a:hover { color: #f3e9d6; }
.footer-links { list-style: none; margin-left: 0; column-count: 2; }
.footer-copyright { background: rgba(0,0,0,.22); padding: .9em 0; margin-top: 1.4rem; }
@media (max-width: 640px) { .footer-links { column-count: 1; } }
