:root {
  --ac-text: #222;
  --ac-muted: #666;
  --ac-max: 760px; /* bookish reading width */
}

/* Base */
body {
  color: var(--ac-text);
  font-family: 'Libre Baskerville', serif;
  font-size: 16px;
  line-height: 1.75;
  margin: 0;
}

/* Content width */
.homepage .content,
.content {
  max-width: var(--ac-max);
  margin-left: auto;
  margin-right: auto;
}

/* =========================
   HEADER (Dark band)
   ========================= */
.site-header {
  background-color: #111; /* dark charcoal */
  color: #fff;
  border-bottom: none;
}

.site-header .content {
  background: transparent;
  padding: 1.25rem 0;
}

.site-header a {
  color: #fff;
}

.site-header a:hover {
  text-decoration: underline;
}

/* Navigation spacing */
.site-header .nav,
.site-footer .nav {
  gap: 1rem;
}

/* =========================
   TYPOGRAPHY
   ========================= */
h1, h2, h3 {
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.01em;
}

h1 {
  font-size: 2.25rem;
}

h2 {
  font-size: 1.5rem;
  margin-top: 3rem;
}

h3 {
  font-size: 1.15rem;
  margin-top: 1.5rem;
}

.content p {
  margin-bottom: 1.25rem;
  font-size: 1.05rem;
  line-height: 1.75;
  max-width: 70ch;
}

/* =========================
   SECTION RHYTHM
   ========================= */
/* Gentle vertical breathing room without visual dividers */
.content > * + * {
  margin-top: 2rem;
}

/* =========================
   ANCHOR SCROLL OFFSET
   ========================= */
html {
  scroll-behavior: smooth;
}

:target {
  scroll-margin-top: 96px;
}

/* =========================
   UPCOMING ART IMAGE
   ========================= */
.upcoming-art {
  max-width: 680px;
  margin: 2rem auto;
}

.upcoming-art img {
  width: 100%;
  height: auto;
}

/* =========================
   FOOTER (quiet)
   ========================= */
.site-footer {
  margin-top: 4rem;
}

.site-footer a {
  color: inherit;
}

.site-footer a:hover {
  text-decoration: underline;
}

#updates + p {
  font-style: italic;
}
