@charset "UTF-8";
/* ============================================================
   Sarah Fremont — composition styles
   Built on Camp Frémont design system v1 tokens
   (assets/colors_and_type.css). Frank + Larsson + Konig.
   ============================================================ */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
}

img { display: block; width: 100%; max-width: 100%; height: auto; }

[id] { scroll-margin-top: 100px; }

.skip-link {
  position: absolute;
  top: -100px;
  left: var(--space-4);
  z-index: 90;
  padding: 10px 14px;
  background: var(--bone);
  border: 1px solid var(--brass);
  border-radius: var(--radius-sm);
  color: var(--ink);
  font-family: var(--font-label);
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
}
.skip-link:focus { top: var(--space-4); }

/* ---------- App shell -------------------------------------- */
.site-shell {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

/* ---------- Top nav / lockup ------------------------------- */
.site-header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-5) 0 var(--space-4);
  border-bottom: 1px solid var(--brass);
}

.site-header__brand {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  text-align: center;
  text-decoration: none;
  color: var(--ink);
}
.site-header__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  letter-spacing: 0.01em;
  line-height: 1;
  color: var(--ink);
}
.site-header__title em { font-style: italic; color: var(--moss); }
.site-header__sub {
  font-family: var(--font-label);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.site-header__row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--ink-quiet);
}

.site-nav {
  grid-column: 2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-5);
}
.site-nav a {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--ink);
  text-decoration: none;
  padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: color var(--dur-base) var(--ease-leaf),
              border-color var(--dur-base) var(--ease-leaf);
}
.site-nav a:hover,
.site-nav a:focus-visible { color: var(--moss-deep); border-bottom-color: var(--brass); }
.site-nav a.is-active { color: var(--moss-deep); border-bottom-color: var(--geranium); }

.site-header__icons {
  grid-column: 3;
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  color: var(--brass);
}
.site-header__icons button,
.site-header__icons a {
  background: none; border: 0; cursor: pointer;
  color: inherit; padding: 6px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background var(--dur-base) var(--ease-leaf);
}
.site-header__icons button:hover,
.site-header__icons a:hover { background: rgba(167,138,78,0.12); color: var(--moss-deep); }
.site-header__icons svg { width: 20px; height: 20px; display: block; }

/* ---------- Section subnav (italic categories) ------------- */
.section-nav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-7);
  padding: var(--space-4) 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink-soft);
}
.section-nav a {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color var(--dur-base) var(--ease-leaf),
              border-color var(--dur-base) var(--ease-leaf);
}
.section-nav a:hover,
.section-nav a:focus-visible { color: var(--geranium); border-bottom-color: var(--brass); }

/* ---------- Page wrapper ----------------------------------- */
.page { padding: var(--space-5) 0 var(--space-9); }
.section { padding: var(--space-5) 0; }

/* ---------- Hero (home) ------------------------------------ */
.hero {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--space-8);
  padding: var(--space-9) 0 var(--space-8);
  align-items: center;
}
.hero__eyebrow { margin-bottom: var(--space-4); }
.hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.6rem, 4.6vw, 4.4rem);
  line-height: 1.02;
  letter-spacing: -0.01em;
  margin: 0 0 var(--space-5);
  text-wrap: balance;
}
.hero__title em { font-style: italic; color: var(--moss); }
.hero__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.4rem;
  line-height: 1.45;
  color: var(--fg-2);
  margin: 0 0 var(--space-6);
  max-width: 30em;
}
.hero__byline {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--fg-3);
  margin-bottom: var(--space-6);
}
.hero__byline .hand {
  font-family: var(--font-hand);
  font-size: 2rem;
  color: var(--moss);
  vertical-align: -8px;
  margin-right: 8px;
}
.hero__figure {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-lift);
}
.hero__figure img {
  aspect-ratio: 4 / 5;
  width: 100%;
  object-fit: cover;
}
.hero__figure::after {
  content: ''; position: absolute; inset: 12px;
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: 4px;
  pointer-events: none;
}
.hero__caption {
  font-family: var(--font-hand);
  font-size: 1.6rem;
  color: var(--brass);
  margin-top: var(--space-3);
  text-align: right;
}

/* ---------- Section heading (brass-ruled) ------------------ */
.section-head {
  display: flex; align-items: center; gap: var(--space-4);
  padding-top: var(--space-7);
  padding-bottom: var(--space-5);
}
.section-head::before,
.section-head::after {
  content: ''; flex: 1; height: 1px;
  background: var(--brass); opacity: 0.5;
}
.section-head__title {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--ink);
  white-space: nowrap;
}

/* ---------- Post grid (home & category) -------------------- */
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  padding-bottom: var(--space-8);
}
.post-card {
  background: var(--bone);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  cursor: pointer;
  display: flex; flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform var(--dur-base) var(--ease-leaf),
              box-shadow var(--dur-base) var(--ease-leaf);
}
.post-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lift);
}
.post-card__image {
  height: 220px;
  border-bottom: 1px solid var(--brass);
  background-size: cover;
  background-position: center;
  background-color: var(--linen);
}
.post-card__body {
  padding: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-2);
  flex: 1;
}
.post-card__category {
  font: 500 0.7rem/1 var(--font-label);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.post-card__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.55rem;
  line-height: 1.15;
  color: var(--ink);
  margin: 0;
}
.post-card__title a { color: inherit; text-decoration: none; }
.post-card__title a:hover { color: var(--geranium); text-decoration: none; }
.post-card__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--fg-2);
  margin: 0;
  line-height: 1.45;
}
.post-card__meta {
  margin-top: auto;
  padding-top: var(--space-3);
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--fg-3);
  display: flex; align-items: center; gap: var(--space-2);
  font-variant-numeric: tabular-nums;
}
.post-card__meta .dot {
  width: 3px; height: 3px; border-radius: 50%;
  background: var(--ink-quiet);
}

/* ---------- Subscribe block (Frank vine pattern) ----------- */
.subscribe {
  position: relative;
  background: var(--parchment-deep);
  border-radius: var(--radius-lg);
  padding: var(--space-7) var(--space-7);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-7);
  align-items: center;
  margin: var(--space-8) 0;
  box-shadow: var(--shadow-inset);
  overflow: hidden;
}
.subscribe::before {
  content: '';
  position: absolute; inset: 0;
  background-image: url('pattern-frank-vine.svg');
  background-size: 160px;
  opacity: 0.08;
  pointer-events: none;
}
.subscribe > * { position: relative; z-index: 1; }
.subscribe__eyebrow { margin-bottom: var(--space-3); }
.subscribe__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  line-height: 1.1;
  margin: 0 0 var(--space-3);
}
.subscribe__title em { font-style: italic; color: var(--moss); }
.subscribe__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--fg-2);
  margin: 0;
  line-height: 1.45;
}
.subscribe__form { display: flex; flex-direction: column; gap: var(--space-3); }
.subscribe__row { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.subscribe__input {
  flex: 1; min-width: 220px;
  font-family: var(--font-body);
  font-size: 1rem;
  background: var(--bone);
  border: 1px solid var(--ink-quiet);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  color: var(--ink);
  transition: border-color var(--dur-base) var(--ease-leaf),
              box-shadow var(--dur-base) var(--ease-leaf);
}
.subscribe__input::placeholder { color: var(--ink-faint); font-style: italic; }
.subscribe__input:focus {
  outline: none;
  border-color: var(--brass);
  box-shadow: 0 0 0 3px rgba(167,138,78,0.2);
}
.subscribe__hint {
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--fg-3);
  font-style: italic;
}

/* ---------- Footer ----------------------------------------- */
.footer {
  border-top: 1px solid var(--brass);
  padding: var(--space-7) 0 var(--space-8);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-6);
}
.footer__brand {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--fg-2);
}
.footer__brand .name {
  font-style: normal;
  color: var(--ink);
  font-size: 1.3rem;
  display: block;
  margin-bottom: 6px;
}
.footer__brand .parent {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-label);
  font-style: normal;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.footer__col h4 {
  font: 500 0.7rem/1 var(--font-label);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin: 0 0 var(--space-3);
}
.footer__col ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--space-2);
}
.footer__col li a {
  font-family: var(--font-body); font-size: 0.95rem;
  color: var(--ink); text-decoration: none; cursor: pointer;
}
.footer__col li a:hover { color: var(--geranium); }
.footer__colophon {
  grid-column: 1 / -1;
  padding-top: var(--space-5);
  border-top: 1px solid var(--rule);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--fg-3);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3);
}

/* ---------- About page ------------------------------------- */
.about {
  padding: var(--space-7) 0 var(--space-9);
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: var(--space-8);
  align-items: center;
}
.about__portrait {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: linear-gradient(160deg, #E4D8BE, #C99A53 50%, #5A4F40);
}
.about__portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
.about h1 { margin-bottom: var(--space-4); }
.about p { font-size: 1.1rem; }
.about__signoff {
  font-family: var(--font-hand);
  color: var(--moss);
  font-size: 2.8rem;
  line-height: 1;
  margin: var(--space-5) 0 0;
}

/* ---------- Generic page intro ----------------------------- */
.page-intro {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-7);
  padding: var(--space-7) 0 var(--space-5);
  align-items: start;
}
.page-intro--single { grid-template-columns: 1fr; }
.page-intro .breadcrumbs {
  font-family: var(--font-label);
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--space-3);
}
.page-intro .breadcrumbs a { color: inherit; }
.page-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 4.2vw, 3.8rem);
  line-height: 1.05;
  margin: var(--space-2) 0 var(--space-4);
  letter-spacing: -0.005em;
  text-wrap: balance;
}

/* ---------- Eyebrow / section tag -------------------------- */
.section-tag {
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin: 0 0 var(--space-2);
}

.section-intro {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.5;
  color: var(--fg-2);
  margin: 0;
}

.meta {
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* ---------- Buttons (legacy class names → new tokens) ------ */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 10px 22px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--brass);
  background: var(--moss);
  color: var(--bone);
  cursor: pointer;
  text-decoration: none;
  line-height: 1.2;
  transition:
    background var(--dur-base) var(--ease-leaf),
    color var(--dur-base) var(--ease-leaf),
    box-shadow var(--dur-base) var(--ease-leaf),
    border-color var(--dur-base) var(--ease-leaf);
}
.button:hover { background: var(--moss-deep); }
.button:focus-visible {
  outline: 2px solid var(--brass);
  outline-offset: 3px;
}
.button:active { box-shadow: inset 0 1px 2px rgba(42,38,32,0.18); }

.button--light {
  background: var(--bone);
  color: var(--ink);
  border-color: var(--brass);
}
.button--light:hover { background: var(--parchment-deep); color: var(--moss-deep); }

.button--ghost {
  background: transparent;
  color: var(--moss-deep);
  border-color: transparent;
  padding: 8px 4px;
}
.button--ghost:hover { color: var(--geranium); background: transparent; }

.button--small { font-size: 0.85rem; padding: 8px 16px; }

.cta-row {
  display: flex; flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}

/* ---------- Forms (text input / select / field) ------------ */
.field { display: flex; flex-direction: column; gap: 6px; }
.field > span {
  font-family: var(--font-label);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.text-input,
.select-input {
  font-family: var(--font-body);
  font-size: 1rem;
  background: var(--bone);
  border: 1px solid var(--ink-quiet);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  color: var(--ink);
  transition: border-color var(--dur-base) var(--ease-leaf),
              box-shadow var(--dur-base) var(--ease-leaf);
}
.text-input::placeholder { color: var(--ink-faint); font-style: italic; }
.text-input:focus,
.select-input:focus {
  outline: none;
  border-color: var(--brass);
  box-shadow: 0 0 0 3px rgba(167,138,78,0.2);
}

/* ---------- Archive: slim toolbar (light search) ----------- */
.archive-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) auto;
  gap: var(--space-4);
  align-items: stretch;
  padding: var(--space-4) 0;
  border-top: 1px solid var(--ink-quiet);
  border-bottom: 1px solid var(--ink-quiet);
  margin-bottom: var(--space-3);
}
.archive-toolbar__search {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 8px 14px;
  background: var(--bone);
  border: 1px solid var(--ink-quiet);
  border-radius: var(--radius-sm);
  transition: border-color var(--dur-base) var(--ease-leaf),
              box-shadow var(--dur-base) var(--ease-leaf);
}
.archive-toolbar__search:focus-within {
  border-color: var(--brass);
  box-shadow: 0 0 0 3px rgba(167,138,78,0.2);
}
.archive-toolbar__icon { color: var(--brass); flex-shrink: 0; }
.archive-toolbar__search input {
  flex: 1;
  border: 0;
  background: transparent;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--ink);
  outline: none;
  padding: 4px 0;
  min-width: 0;
}
.archive-toolbar__search input::placeholder { color: var(--ink-faint); }

.archive-toolbar__filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}
.archive-toolbar__select {
  font-family: var(--font-body);
  font-size: 0.9rem;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ink-quiet);
  color: var(--ink);
  padding: 6px 22px 6px 6px;
  cursor: pointer;
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23A78A4E' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9 L 12 15 L 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 4px center;
  background-size: 14px;
  transition: border-color var(--dur-base) var(--ease-leaf),
              color var(--dur-base) var(--ease-leaf);
}
.archive-toolbar__select:hover { border-bottom-color: var(--brass); color: var(--moss-deep); }
.archive-toolbar__select:focus { outline: none; border-bottom-color: var(--brass); }
.archive-toolbar__clear {
  background: none;
  border: 0;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-style: italic;
  color: var(--ink-faint);
  cursor: pointer;
  padding: 4px 8px;
  transition: color var(--dur-base) var(--ease-leaf);
}
.archive-toolbar__clear:hover { color: var(--geranium); }

.archive-popular {
  margin: 0 0 var(--space-3);
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink-faint);
  line-height: 1.8;
}
.archive-popular__label {
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-right: var(--space-2);
}
.archive-popular__term {
  background: none;
  border: 0;
  font: inherit;
  color: var(--moss-deep);
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-decoration-thickness: 0.5px;
  text-decoration-color: var(--ink-quiet);
  text-underline-offset: 0.18em;
  transition: color var(--dur-base) var(--ease-leaf),
              text-decoration-color var(--dur-base) var(--ease-leaf);
}
.archive-popular__term:hover {
  color: var(--geranium);
  text-decoration-color: currentColor;
}

.archive-summary {
  margin: 0 0 var(--space-5);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--fg-2);
}

.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ---------- Library / archive panel (legacy classes) ------- */
.library-stack { display: grid; gap: var(--space-6); }
.library-panel {
  background: var(--bone);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card), var(--shadow-inset);
  padding: var(--space-6);
}
.library-search-panel { display: grid; gap: var(--space-4); }
.library-search-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 2.2vw, 2.1rem);
  margin: 0;
  line-height: 1.15;
}
.search-handoff__row,
.article-search-row {
  display: flex; gap: var(--space-3); flex-wrap: wrap;
}
.search-handoff__row .text-input,
.article-search-row .text-input { flex: 1; min-width: 220px; }

.search-suggestions { display: grid; gap: var(--space-2); }
.search-suggestions__label {
  font-family: var(--font-label);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 0;
}
.filter-chip-row {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
}
.pill {
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  background: var(--parchment-deep);
  color: var(--ink);
  border: 1px solid var(--brass);
  padding: 6px 12px;
  border-radius: var(--radius-xs);
  cursor: pointer;
  transition: background var(--dur-base) var(--ease-leaf),
              color var(--dur-base) var(--ease-leaf);
}
.pill:hover { background: var(--brass); color: var(--bone); }
.pill[aria-pressed="true"] {
  background: var(--moss); color: var(--bone); border-color: var(--moss);
}

.library-filter-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  gap: var(--space-4);
  align-items: end;
}
.library-actions { display: flex; align-items: end; }

.result-summary {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--fg-2);
  margin: 0 0 var(--space-4);
}

.empty-state {
  padding: var(--space-5);
  border: 1px dashed var(--brass);
  border-radius: var(--radius-md);
  background: var(--parchment-deep);
}

/* ---------- Journal cards (archive list) ------------------- */
.journal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-5);
}
.journal-card {
  background: var(--parchment-deep);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  display: flex; flex-direction: column;
  cursor: pointer;
  transition: transform var(--dur-base) var(--ease-leaf),
              box-shadow var(--dur-base) var(--ease-leaf);
}
.journal-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lift);
}
.journal-card__media {
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-bottom: 1px solid var(--brass);
}
.journal-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--dur-leisurely) var(--ease-leaf);
}
.journal-card:hover .journal-card__media img { transform: scale(1.03); }
.journal-card__content {
  padding: var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-2);
  flex: 1;
}
.journal-card__header {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-3);
}
.journal-card__topic {
  font-family: var(--font-label);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--moss-deep);
}
.journal-card h3 {
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 400;
  font-size: 1.45rem;
  line-height: 1.18;
  margin: 0;
  color: var(--ink);
}
.journal-card__title-link {
  color: inherit;
  text-decoration: none;
}
.journal-card__title-link:hover { color: var(--geranium); }
.journal-card p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1rem;
  color: var(--fg-2);
  margin: 0;
  line-height: 1.45;
}
.journal-card__actions {
  margin-top: auto;
  padding-top: var(--space-3);
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-3);
}
.journal-card__link {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: var(--moss-deep);
  text-decoration: none;
  border-bottom: 1px solid var(--brass);
  padding-bottom: 1px;
}
.journal-card__link:hover { color: var(--geranium); border-bottom-color: currentColor; }

.tag-row {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
}
.tag {
  font-family: var(--font-label);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  background: var(--bone);
  border: 1px solid var(--ink-quiet);
  border-radius: var(--radius-xs);
  padding: 4px 8px;
}

/* ---------- Article (post detail) -------------------------- */
.article-shell { padding-top: var(--space-7); }
.article-shell .breadcrumbs { margin-bottom: var(--space-3); }
.article-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 4.6vw, 3.8rem);
  line-height: 1.04;
  letter-spacing: -0.005em;
  margin: 0 0 var(--space-4);
  text-wrap: balance;
}
.article-standfirst {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.2rem, 1.6vw, 1.5rem);
  line-height: 1.45;
  color: var(--fg-2);
  margin: 0;
}

.article-meta-card {
  background: var(--parchment-deep);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow: var(--shadow-inset);
  display: grid; gap: var(--space-3);
}
.article-meta-card .detail-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--fg-2);
}

.detail-list { list-style: none; padding: 0; margin: 0; }

.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: var(--space-7);
  align-items: start;
}

.article-main { padding: var(--space-7); }
.article-body { display: grid; gap: var(--space-4); }
.article-body p {
  font-family: var(--font-body);
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--ink);
  margin: 0;
}
.article-body p + p { margin-top: 0; }
.article-body > p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 4.6rem;
  line-height: 0.85;
  float: left;
  margin: 4px 12px 0 0;
  color: var(--geranium);
}
.article-body h2,
.article-body h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-style: italic;
  margin: var(--space-5) 0 var(--space-2);
  color: var(--ink);
}
.article-body h2 { font-size: 1.9rem; font-style: normal; font-weight: 400; }
.article-body h3 { font-size: 1.5rem; }
.article-body blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.4;
  color: var(--ink);
  border-left: 1px solid var(--brass);
  padding: var(--space-2) 0 var(--space-2) var(--space-5);
  margin: var(--space-5) 0;
}
.article-list {
  list-style: none; padding-left: 0; margin: 0;
  display: grid; gap: var(--space-3);
  counter-reset: article-list;
}
.article-list li {
  font-family: var(--font-body);
  font-size: 1.1rem;
  line-height: 1.6;
  padding-left: 2.2rem;
  position: relative;
  counter-increment: article-list;
}
.article-list li::before {
  content: counter(article-list) ".";
  position: absolute;
  left: 0; top: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--moss-deep);
  font-feature-settings: "onum";
}

.article-media {
  margin: var(--space-5) 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.article-media--hero {
  margin: var(--space-3) 0 var(--space-6);
}
.article-media--inline { margin: var(--space-5) 0; }
.article-media img {
  width: 100%; height: auto; display: block;
}
.article-media figcaption {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--fg-3);
  text-align: center;
  padding: var(--space-3) var(--space-4);
  background: var(--bone);
  border-top: 1px solid var(--brass);
}
.article-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
  margin: var(--space-6) 0;
}
.article-gallery .article-media { margin: 0; }

.article-body::after {
  content: "\2766 \00a0 \2042 \00a0 \2766";
  display: block;
  text-align: center;
  color: var(--brass);
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: 0.4em;
  margin: var(--space-6) 0 var(--space-4);
}

.article-signoff {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--fg-2);
  text-align: right;
  margin: 0;
}
.article-signoff .hand {
  font-family: var(--font-hand);
  color: var(--moss);
  font-size: 2.4rem;
  vertical-align: -12px;
  margin-left: 6px;
}

.article-sidebar { display: grid; gap: var(--space-5); position: sticky; top: var(--space-5); }
.article-sidebar .library-panel { padding: var(--space-5); }
.story-list { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-3); }
.story-list li {
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--ink-quiet);
}
.story-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.story-list a {
  font-family: var(--font-display);
  font-size: 1.15rem;
  line-height: 1.2;
  color: var(--ink);
  text-decoration: none;
  display: block;
  margin-bottom: 4px;
}
.story-list a:hover { color: var(--geranium); }
.story-list span {
  font-family: var(--font-label);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  display: block;
}

/* ---------- "From the archive" featured collection grid ---- */
.collection-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}
.collection-card {
  background: var(--parchment-deep);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card), var(--shadow-inset);
  padding: var(--space-5);
  display: grid; gap: var(--space-3);
}
.collection-card h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: normal;
  font-size: 1.55rem;
  line-height: 1.2;
  margin: 0;
}
.collection-card p {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--fg-2);
  margin: 0;
}

/* ---------- Home: "Now" strip + rail brief ---------------- */
.now-strip {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4) var(--space-5);
  background: var(--parchment-deep);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-inset);
  margin-top: var(--space-5);
}
.now-strip__tag {
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--moss-deep);
}
.now-strip__text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--fg-2);
  margin: 0;
}

/* ---------- Meet Sarah inset (home) ------------------------ */
.meet-sarah {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: var(--space-8);
  align-items: center;
  padding: var(--space-8) 0;
  border-top: 1px solid var(--ink-quiet);
  border-bottom: 1px solid var(--ink-quiet);
  margin: var(--space-7) 0;
}
.meet-sarah__portrait {
  margin: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  aspect-ratio: 4 / 5;
  background: var(--linen);
}
.meet-sarah__portrait img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.meet-sarah__body { display: grid; gap: var(--space-3); }
.meet-sarah__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(2rem, 3.6vw, 3rem);
  line-height: 1.05;
  margin: var(--space-2) 0 0;
  letter-spacing: -0.005em;
}
.meet-sarah__lede {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.15rem, 1.5vw, 1.4rem);
  line-height: 1.5;
  color: var(--fg-2);
  margin: 0;
  max-width: 32em;
}
.meet-sarah__roles {
  display: flex; flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
  margin: var(--space-2) 0 0;
  font-family: var(--font-label);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.meet-sarah__roles span {
  display: inline-flex; align-items: center;
}
.meet-sarah__roles span + span::before {
  content: "\00b7";
  margin-right: var(--space-3);
  color: var(--ink-quiet);
}
.meet-sarah__sign {
  font-family: var(--font-hand);
  color: var(--moss);
  font-size: 2.6rem;
  line-height: 1;
  margin: var(--space-3) 0 0;
}
.meet-sarah__sign .hand { font-family: var(--font-hand); }

/* ---------- Search overlay (added) ------------------------- */
.search-overlay {
  position: fixed; inset: 0;
  background: rgba(42, 38, 32, 0.55);
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 14vh;
  z-index: 50;
  animation: fadeIn 220ms var(--ease-leaf);
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.search-panel {
  width: min(640px, 92vw);
  background: var(--bone);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6) var(--space-6);
  box-shadow: var(--shadow-lift);
}
.search-panel__row {
  display: flex; gap: var(--space-3); align-items: center;
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--brass);
}
.search-panel__row svg { width: 22px; height: 22px; color: var(--brass); }
.search-panel__row input {
  flex: 1; border: 0; background: transparent;
  font-family: var(--font-display); font-style: italic;
  font-size: 1.6rem; color: var(--ink);
  outline: none;
}
.search-panel__row input::placeholder { color: var(--ink-faint); }
.search-panel__row button {
  background: none; border: 0; cursor: pointer;
  color: var(--ink-faint);
  display: inline-flex;
}
.search-panel__hits {
  padding-top: var(--space-4);
  display: flex; flex-direction: column; gap: var(--space-3);
  max-height: 56vh; overflow-y: auto;
}
.search-hit {
  display: flex; flex-direction: column; gap: 4px;
  padding: var(--space-2) 0;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.search-hit:hover .search-hit__title { color: var(--geranium); }
.search-hit__cat {
  font: 500 0.62rem/1 var(--font-label);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.search-hit__title {
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--ink);
  transition: color var(--dur-base) var(--ease-leaf);
}

/* ---------- Toast ----------------------------------------- */
.toast {
  position: fixed; left: 50%; bottom: 32px;
  transform: translateX(-50%);
  background: var(--moss-deep); color: var(--bone);
  padding: 14px 22px; border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-style: italic; font-size: 1.1rem;
  box-shadow: var(--shadow-lift);
  z-index: 60;
  animation: rise 280ms var(--ease-leaf);
}
@keyframes rise {
  from { opacity: 0; transform: translate(-50%, 12px); }
  to { opacity: 1; transform: translate(-50%, 0); }
}

/* ============================================================
   COLOUR ACCENTS — Frank's botanical brights, deployed by
   meaning (collection + season), never as a flood.
   ============================================================ */

/* --- Per-collection accent on archive card topic labels --- */
.journal-card[data-topic="houseplants"] .journal-card__topic   { color: var(--moss-deep); }
.journal-card[data-topic="kitchen-garden"] .journal-card__topic { color: var(--fern); }
.journal-card[data-topic="seasonal-crafts"] .journal-card__topic { color: var(--geranium); }
.journal-card[data-topic="garden-design"] .journal-card__topic  { color: var(--plum); }
.journal-card[data-topic="plant-history"] .journal-card__topic  { color: var(--delft); }
.journal-card[data-topic="pollinators"] .journal-card__topic    { color: var(--ochre); }

/* A hairline of the same accent under each card image */
.journal-card[data-topic="houseplants"] .journal-card__media   { border-bottom-color: var(--moss-deep); }
.journal-card[data-topic="kitchen-garden"] .journal-card__media { border-bottom-color: var(--fern); }
.journal-card[data-topic="seasonal-crafts"] .journal-card__media { border-bottom-color: var(--geranium); }
.journal-card[data-topic="garden-design"] .journal-card__media  { border-bottom-color: var(--plum); }
.journal-card[data-topic="plant-history"] .journal-card__media  { border-bottom-color: var(--delft); }
.journal-card[data-topic="pollinators"] .journal-card__media    { border-bottom-color: var(--ochre); }

/* --- Season tag tint (first tag is always the season) ----- */
.journal-card .tag:first-child {
  color: var(--ink);
  background: var(--bone);
}
.journal-card[data-season="spring"] .tag:first-child {
  color: var(--fern); border-color: var(--fern);
  background: rgba(107, 142, 78, 0.10);
}
.journal-card[data-season="summer"] .tag:first-child {
  color: var(--geranium); border-color: var(--geranium);
  background: rgba(194, 91, 83, 0.10);
}
.journal-card[data-season="fall"] .tag:first-child {
  color: #9A6F38; border-color: var(--ochre);
  background: rgba(201, 154, 83, 0.14);
}
.journal-card[data-season="winter"] .tag:first-child {
  color: var(--delft); border-color: var(--delft);
  background: rgba(74, 103, 131, 0.10);
}
.journal-card[data-season="late winter"] .tag:first-child {
  color: var(--delft); border-color: var(--sky);
  background: rgba(138, 168, 184, 0.12);
}

/* --- Home recent-entries: rotate category colour ---------- */
.grid .post-card:nth-child(6n+1) .post-card__category { color: var(--moss-deep); }
.grid .post-card:nth-child(6n+2) .post-card__category { color: var(--geranium); }
.grid .post-card:nth-child(6n+3) .post-card__category { color: var(--plum); }
.grid .post-card:nth-child(6n+4) .post-card__category { color: var(--delft); }
.grid .post-card:nth-child(6n+5) .post-card__category { color: var(--fern); }
.grid .post-card:nth-child(6n+6) .post-card__category { color: var(--ochre); }

/* --- Collection cards: a quiet coloured eyebrow ----------- */
.collection-grid .collection-card:nth-child(3n+1) .eyebrow { color: var(--moss-deep); }
.collection-grid .collection-card:nth-child(3n+2) .eyebrow { color: var(--geranium); }
.collection-grid .collection-card:nth-child(3n+3) .eyebrow { color: var(--delft); }

/* --- Post page: theme the WHOLE page to its collection ----
   One accent variable per collection, set on the page
   container, then applied consistently to every eyebrow,
   the breadcrumb, and accent rules across the article.    */
.page[data-topic="houseplants"]    { --topic-accent: var(--moss-deep); }
.page[data-topic="kitchen-garden"] { --topic-accent: var(--fern); }
.page[data-topic="seasonal-crafts"] { --topic-accent: var(--geranium); }
.page[data-topic="garden-design"]  { --topic-accent: var(--plum); }
.page[data-topic="plant-history"]  { --topic-accent: var(--delft); }
.page[data-topic="pollinators"]    { --topic-accent: var(--ochre); }

/* Every eyebrow on a themed page picks up the collection colour */
.page[data-topic] .eyebrow { color: var(--topic-accent); }

/* Coordinate the rest of the article furniture to it */
.page[data-topic] .breadcrumbs a:hover { color: var(--topic-accent); }
.page[data-topic] .article-meta-card { box-shadow: inset 0 0 0 1px var(--topic-accent); }
.page[data-topic] .article-meta-card .tag {
  border-color: var(--topic-accent);
  color: var(--topic-accent);
}
.page[data-topic] .journal-card__media,
.page[data-topic] .article-media--hero { border-bottom: 1px solid var(--topic-accent); }
.page[data-topic] .story-list a:hover { color: var(--topic-accent); }
.page[data-topic] .article-body > p:first-of-type::first-letter { color: var(--topic-accent); }
.page[data-topic] .article-list li::before { color: var(--topic-accent); }
.page[data-topic] .article-body blockquote { border-left-color: var(--topic-accent); }

/* Season also reads in its own colour inside Filed in the Archive */
.page[data-season="spring"]      { --season-accent: var(--fern); }
.page[data-season="summer"]      { --season-accent: var(--geranium); }
.page[data-season="fall"]        { --season-accent: var(--ochre); }
.page[data-season="winter"]      { --season-accent: var(--delft); }
.page[data-season="late winter"] { --season-accent: var(--sky); }
.page[data-season] .detail-list__season {
  color: var(--season-accent);
  font-weight: 600;
}
.page[data-season] .article-meta-card .tag:first-child {
  color: var(--season-accent);
  border-color: var(--season-accent);
}

/* --- Now strip becomes an ochre ribbon -------------------- */
.now-strip {
  border-left: 3px solid var(--ochre);
  background: rgba(232, 185, 138, 0.14);
}
.now-strip__tag { color: #9A6F38; }

/* --- Warm article flourishes ------------------------------ */
.article-list li::before { color: var(--geranium); }
.article-body blockquote { border-left-color: var(--geranium); }

/* --- Meet Sarah: a warm eyebrow --------------------------- */
.meet-sarah .eyebrow { color: var(--geranium); }
.subscribe__eyebrow { color: var(--geranium); }

/* ---------- Reveal (entrance) ----------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity var(--dur-leisurely) var(--ease-leaf),
              transform var(--dur-leisurely) var(--ease-leaf);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* ---------- Side note (used in page-intro asides) --------- */
.side-note {
  background: var(--parchment-deep);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow: var(--shadow-inset);
  display: grid; gap: var(--space-3);
}
.side-note .section-tag { color: var(--moss-deep); }
.side-note p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--fg-2);
  margin: 0;
}

/* ---------- Footer panel (legacy class for home) ---------- */
.footer-panel {
  border-top: 1px solid var(--brass);
  padding: var(--space-8) 0 0;
  margin-top: var(--space-8);
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) auto;
  gap: var(--space-6);
  align-items: end;
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--rule);
}
.footer-grid h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.6rem, 2vw, 2rem);
  margin: var(--space-2) 0;
  text-wrap: balance;
}
.footer-grid p {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--fg-2);
  margin: 0;
}
.footer-note {
  padding: var(--space-4) 0 var(--space-7);
  font-family: var(--font-label);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: center;
}

/* ---------- Responsive (≥ 720px is the design baseline) --- */
@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; padding: var(--space-7) 0; }
  .grid { grid-template-columns: repeat(2, 1fr); }
  .collection-grid { grid-template-columns: 1fr; }
  .article-layout { grid-template-columns: 1fr; }
  .article-sidebar { position: static; }
  .about { grid-template-columns: 1fr; }
  .meet-sarah { grid-template-columns: 1fr; gap: var(--space-5); padding: var(--space-6) 0; }
  .footer { grid-template-columns: 1fr 1fr; }
  .library-filter-row { grid-template-columns: 1fr 1fr; }
  .page-intro { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .site-shell { padding: 0 var(--space-4); }
  .site-header { grid-template-columns: 1fr; }
  .site-header__row { grid-template-columns: 1fr; gap: var(--space-3); }
  .site-nav { grid-column: 1; }
  .site-header__icons { grid-column: 1; justify-content: center; }
  .grid { grid-template-columns: 1fr; }
  .journal-grid { grid-template-columns: 1fr; }
  .subscribe { grid-template-columns: 1fr; padding: var(--space-5); }
  .footer { grid-template-columns: 1fr; }
  .library-filter-row { grid-template-columns: 1fr; }
  .article-main { padding: var(--space-5); }
}
