:root {
  color-scheme: light;
  --ink: #18242b;
  --muted: #5b6a70;
  --paper: #edf1ed;
  --accent: #bd5a3a;
  --line: #ccd5d1;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 70% 0%, #d8e6e4 0, transparent 34rem),
    var(--paper);
  font: 17px/1.65 Georgia, "Times New Roman", serif;
}

a { color: inherit; text-underline-offset: .2em; }

.site-header, main, footer {
  width: min(1080px, calc(100% - 2.5rem));
  margin-inline: auto;
}

.site-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.4rem 0;
  border-bottom: 1px solid var(--line);
}

.brand {
  font: 700 1rem/1.2 system-ui, sans-serif;
  letter-spacing: .08em;
  text-decoration: none;
  text-transform: uppercase;
}

nav { display: flex; gap: 1.25rem; font: .9rem/1.2 system-ui, sans-serif; }
nav a { text-decoration: none; }
nav a:hover, nav a[aria-current="page"] { color: var(--accent); }

.hero { padding: 7rem 0 4rem; }
.hero h1, .narrow h1 {
  max-width: 850px;
  margin: .3rem 0 1.2rem;
  font-size: clamp(2.6rem, 7vw, 6.4rem);
  font-weight: 500;
  line-height: .98;
  letter-spacing: -.045em;
}

.lede { max-width: 680px; color: var(--muted); font-size: 1.2rem; }
.eyebrow, time { color: var(--accent); font: 700 .76rem/1.2 system-ui, sans-serif; letter-spacing: .12em; text-transform: uppercase; }

.brewline {
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 4%;
  height: 130px;
  margin-top: 4rem;
  border-bottom: 5px solid var(--ink);
}

.brewline span {
  width: 11%;
  height: 48%;
  border: 5px solid var(--ink);
  border-top: 0;
  border-radius: 0 0 2rem 2rem;
  opacity: .86;
}
.brewline span:nth-child(2),
.brewline span:nth-child(5) { height: 66%; }
.brewline span:nth-child(3) { height: 38%; }
.brewline span:nth-child(4) { height: 78%; }

.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  padding: 3rem 0 6rem;
  border-top: 1px solid var(--line);
}

article h2, .narrow h2 { font-size: 1.45rem; line-height: 1.2; }
article p, .narrow p { color: var(--muted); }
.narrow { max-width: 760px; padding: 7rem 0; }
.narrow h1 { font-size: clamp(2.8rem, 7vw, 5.2rem); }
hr { margin: 3rem 0; border: 0; border-top: 1px solid var(--line); }
footer { padding: 2rem 0 4rem; border-top: 1px solid var(--line); color: var(--muted); font-size: .9rem; }
.error-page { min-height: 70vh; }
.button { display: inline-block; padding: .7rem 1rem; background: var(--ink); color: white; text-decoration: none; font: .9rem system-ui, sans-serif; }

@media (max-width: 720px) {
  .site-header { align-items: flex-start; gap: 1rem; }
  nav { flex-direction: column; gap: .4rem; text-align: right; }
  .hero { padding-top: 4rem; }
  .grid { grid-template-columns: 1fr; }
}
