/* ====================================================================
   Components — reusable patterns (pull quotes, cards, SVG backgrounds)
   ==================================================================== */

/* ---------- Hairline rule (decorative, sage or subtle) ---------- */
.rule {
  height: 1px;
  background: var(--color-border);
  border: 0;
  margin: var(--space-xl) auto;
  max-width: 120px;
}
.rule-accent {
  background: var(--color-accent);
  opacity: 0.5;
}

/* ---------- Eyebrow labels ---------- */
.eyebrow,
.eyebrow-sm {
  display: inline-block;
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-text-subtle);
}
.eyebrow { font-size: var(--fs-xs); }
.eyebrow-sm { font-size: var(--fs-2xs); }

/* ---------- SVG background patterns for category heroes ---------- */
/* Use as: class="pattern pattern-dots" with category color var override */
.pattern {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.08;
  z-index: 0;
}
.pattern-dots {
  background-image: radial-gradient(var(--pattern-color, var(--color-accent)) 1.5px, transparent 1.5px);
  background-size: 24px 24px;
}
.pattern-diagonal {
  background-image: repeating-linear-gradient(
    135deg,
    var(--pattern-color, var(--color-accent)),
    var(--pattern-color, var(--color-accent)) 1px,
    transparent 1px,
    transparent 14px
  );
}
.pattern-grid {
  background-image:
    linear-gradient(var(--pattern-color, var(--color-accent)) 1px, transparent 1px),
    linear-gradient(90deg, var(--pattern-color, var(--color-accent)) 1px, transparent 1px);
  background-size: 40px 40px;
}
.pattern-leaves {
  /* Botanical dots in a scattered pattern (pseudo-leaves via varied radial) */
  background-image:
    radial-gradient(var(--pattern-color, var(--color-accent)) 2px, transparent 2px),
    radial-gradient(var(--pattern-color, var(--color-accent)) 1px, transparent 1px);
  background-size: 48px 48px, 32px 32px;
  background-position: 0 0, 16px 16px;
}

/* ---------- Pull quote (inside article body) ---------- */
.article-body .pull-quote,
.pull-quote {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 30px);
  font-style: italic;
  line-height: 1.4;
  color: var(--color-text);
  border-left: 3px solid var(--color-accent);
  padding-left: var(--space-xl);
  margin: var(--space-2xl) calc(-1 * var(--space-xl)) var(--space-2xl) calc(-1 * var(--space-xl));
  max-width: none;
  font-weight: 500;
}
@media (max-width: 720px) {
  .article-body .pull-quote,
  .pull-quote {
    margin-inline: 0;
    padding-left: var(--space-lg);
    font-size: var(--fs-lg);
  }
}

/* ---------- Drop cap (first-letter on first paragraph) ---------- */
.article-body > p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 5.5em;
  float: left;
  line-height: 0.85;
  padding-top: 0.1em;
  padding-right: 0.1em;
  padding-bottom: 0;
  color: var(--color-accent-ink);
}
@media (max-width: 640px) {
  .article-body > p:first-of-type::first-letter {
    font-size: 4em;
  }
}

/* ---------- Custom list markers (sage dots) ---------- */
.article-body ul {
  list-style: none;
  padding-left: 0;
}
.article-body ul > li {
  position: relative;
  padding-left: 28px;
  margin-bottom: var(--space-sm);
}
.article-body ul > li::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 0.7em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
}
.article-body ol {
  list-style: none;
  padding-left: 0;
  counter-reset: acli;
}
.article-body ol > li {
  position: relative;
  padding-left: 36px;
  margin-bottom: var(--space-sm);
  counter-increment: acli;
}
.article-body ol > li::before {
  content: counter(acli) ".";
  position: absolute;
  left: 0;
  top: 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--color-accent);
  font-size: 1em;
  min-width: 28px;
}

/* ---------- Featured post-card variant (category grid first item) ---------- */
.post-card-featured {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: var(--space-2xl);
  align-items: center;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  padding: 0;
}
.post-card-featured:hover {
  transform: none;
  box-shadow: none;
}
.post-card-featured .post-card-image-link {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.post-card-featured .post-card-image {
  aspect-ratio: 4 / 3;
}
.post-card-featured .post-card-body {
  padding: 0;
  gap: var(--space-md);
}
.post-card-featured .post-card-title {
  font-size: var(--fs-2xl);
  line-height: 1.15;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.post-card-featured .post-card-excerpt {
  font-size: var(--fs-base);
  line-height: 1.6;
  max-width: 520px;
}
@media (max-width: 820px) {
  .post-card-featured {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
  .post-card-featured .post-card-title {
    font-size: var(--fs-xl);
  }
}

/* ---------- "Latest" horizontal rail ---------- */
.latest-rail {
  padding: var(--section-y-sm) 0;
  background: var(--color-bg);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.latest-rail-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--space-xl);
  gap: var(--space-md);
}
.latest-rail-head h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
  margin: 0;
}
.latest-rail-track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: var(--space-lg);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: var(--space-sm);
}
.latest-rail-track > * { scroll-snap-align: start; }
.latest-rail .post-card {
  box-shadow: none;
  background: transparent;
  border-radius: 0;
}
.latest-rail .post-card:hover {
  transform: none;
  box-shadow: none;
}
.latest-rail .post-card-image {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.latest-rail .post-card-body {
  padding: var(--space-sm) 0 0;
  gap: var(--space-xs);
}
.latest-rail .post-card-title {
  font-size: var(--fs-base);
  line-height: 1.3;
}
.latest-rail .post-card-excerpt {
  display: none;
}

/* ---------- Inline category icon (tiny SVG-style via CSS box) ---------- */
.cat-icon {
  display: inline-block;
  width: 18px;
  height: 18px;
  vertical-align: -3px;
  margin-right: 6px;
}

/* ---------- Prose helpers ---------- */
.prose-intro {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-lg);
  line-height: 1.55;
  color: var(--color-text-muted);
  max-width: 600px;
  margin: 0 auto;
}
