@import "./tokens.css";

/* ────────────────────────────────────────────────────────────────
   ECCLESIA v2 — editorial stylesheet
   Hi-fi implementation of chls-all-new (Direction A · The Parish)
   Sans body (system stack) + Cormorant Garamond for display.
   Uppercase + letter-spacing for all labels; no small-caps.
   ──────────────────────────────────────────────────────────────── */

@layer reset {
  *, *::before, *::after { box-sizing: border-box; }
  html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
  body {
    margin: 0;
    background: #e8e1d2;
    color: var(--ink-soft);
    font-family: var(--sans);
    font-size: var(--size-body);
    line-height: 1.55;
    letter-spacing: -0.005em;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    min-block-size: 100dvh;
  }
  .frame {
    max-inline-size: 90rem;         /* 1440 px */
    margin-inline: auto;
    background: var(--bg);
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 0 80px rgba(28, 26, 23, 0.04);
  }
  main { flex: 1; }
  img, picture, svg, video { display: block; max-inline-size: 100%; block-size: auto; }
  a { color: var(--burgundy); text-decoration: none; transition: color 150ms ease; }
  a:hover { color: var(--burgundy-d); }
  a.u, .link-u { text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
  button, input, select { font: inherit; color: inherit; }
  button { cursor: pointer; }
  hr { border: 0; }
  ol, ul { margin: 0; padding: 0; list-style: none; }
  dl, dd, dt, p, h1, h2, h3, h4, figure, blockquote { margin: 0; }
  :focus-visible { outline: 2px solid var(--burgundy); outline-offset: 2px; }

  .visually-hidden { clip: rect(0 0 0 0); clip-path: inset(50%); block-size: 1px; inline-size: 1px; overflow: hidden; position: absolute; white-space: nowrap; }
  .skip-link { position: absolute; inset-inline-start: -9999px; padding: 8px 12px; background: var(--ink); color: var(--paper); }
  .skip-link:focus { inset-inline-start: 8px; inset-block-start: 8px; z-index: 100; }
}

@layer typography {
  .serif, .pa-serif-d { font-family: var(--serif); font-feature-settings: "kern", "liga", "dlig"; }
  .sans { font-family: var(--sans); }

  h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; color: var(--ink); text-wrap: balance; }
  h1 { font-size: var(--h1-page); line-height: 1.02; letter-spacing: -0.02em; }
  h2 { font-size: var(--h2);      line-height: 1.02; letter-spacing: -0.015em; }
  h3 { font-size: var(--h3);      line-height: 1.1;  letter-spacing: -0.015em; }
  h4 { font-size: var(--h4);      line-height: 1.1;  letter-spacing: -0.01em;  }
  h1 em, h2 em, h3 em, h4 em { font-style: italic; font-weight: 500; }

  em { font-style: italic; }

  .label, .eyebrow {
    font-family: var(--sans);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-weight: 600;
    font-size: var(--size-label);
    color: var(--ink-soft);
    display: inline-block;
  }
  .eyebrow { letter-spacing: 0.16em; font-weight: 700; }
  .label--accent, .eyebrow--accent { color: var(--burgundy); }
  .label--mute,   .eyebrow--mute   { color: var(--ink-mute); }
  .label--ink,    .eyebrow--ink    { color: var(--ink); }
  .label--gold                     { color: var(--gold); }

  .num {
    font-family: var(--sans);
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: 700;
    font-size: 0.75rem;
    color: var(--burgundy);
  }

  .rule       { display: block; block-size: 1px; background: var(--rule);      margin: 0.625rem 0 0.875rem; border: 0; }
  .rule--soft { background: var(--rule-soft); }
  .rule--double { block-size: 3px; background:
      linear-gradient(var(--rule) 1px, transparent 1px 2px, var(--rule) 2px 3px); }

  .dropcap {
    float: inline-start;
    font-family: var(--serif);
    font-weight: 500;
    font-size: 4.5rem;    /* 72 px */
    line-height: 0.8;
    margin-inline-end: 0.5rem;
    margin-block-start: 0.25rem;
    color: var(--burgundy);
  }

  .italic-serif { font-family: var(--serif); font-style: italic; }
}

/* ───────────────────────────────────────────────
   MASTHEAD (global nav on every page)
   ─────────────────────────────────────────────── */
@layer layout {
  .mast {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.375rem var(--pad-x);
    background: var(--paper);
    border-block-end: 1px solid var(--rule);
  }
  .mast__brand {
    display: flex;
    align-items: center;
    gap: 1.125rem;
    text-decoration: none;
    color: var(--ink);
  }
  .mast__wordmark {
    font-family: var(--serif);
    font-size: 1.625rem;      /* 26 px */
    font-weight: 600;
    line-height: 1;
    letter-spacing: -0.01em;
  }
  .mast__tick { inline-size: 28px; block-size: 1px; background: var(--rule); }
  .mast__sub {
    font-family: var(--sans);
    font-size: 0.8125rem;
    color: var(--ink-soft);
    font-weight: 500;
  }
  .mast__nav {
    display: flex;
    align-items: center;
    gap: 1.75rem;
  }
  .mast__nav a {
    font-family: var(--sans);
    font-size: 0.875rem;
    color: var(--ink);
    font-weight: 500;
  }
  .mast__nav a.is-active { color: var(--burgundy); font-weight: 600; }
  .mast__nav a:hover { color: var(--burgundy); }
  .mast__search {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid var(--rule);
    background: var(--bg);
    padding: 0.5rem 0.875rem;
    min-inline-size: 12rem;
  }
  .mast__search input {
    border: 0;
    background: transparent;
    outline: none;
    font: 500 0.8125rem/1 var(--sans);
    color: var(--ink);
    inline-size: 100%;
  }
  .mast__search input::placeholder { color: var(--ink-mute); font-weight: 500; }

  /* ───────────── FOOTER ───────────── */
  .foot {
    margin-block-start: auto;
    background: var(--paper);
    border-block-start: 1px solid var(--rule);
    padding: 1.125rem var(--pad-x);
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-family: var(--sans);
    font-size: 0.75rem;
    color: var(--ink-mute);
    font-weight: 500;
  }
  .foot em { font-family: var(--serif); font-style: italic; }
}

/* ───────────────────────────────────────────────
   HOME
   ─────────────────────────────────────────────── */
@layer components {
  .home { max-inline-size: var(--page-max); margin-inline: auto; }

  /* 1. Masthead section (page-scoped, below global nav) */
  .home__masthead {
    padding: 3.5rem var(--pad-x) 3rem;
    border-block-end: 1px solid var(--rule);
    position: relative;
  }
  .home__meta {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-block-end: 2rem;
    gap: 2rem;
  }
  .home__stats { display: flex; align-items: center; gap: 0.75rem; margin-block-start: 0.5rem; }
  .home__stats .dot { inline-size: 4px; block-size: 4px; background: var(--burgundy); border-radius: 50%; }
  .home__epigraph .italic-serif { font-size: 0.875rem; color: var(--ink-mute); }
  .home__epigraph .cite { font-family: var(--sans); font-size: 0.6875rem; color: var(--ink-mute); margin-block-start: 0.25rem; display: block; }

  .home__h1 {
    font-size: var(--h1-hero);
    line-height: 0.92;
    letter-spacing: -0.02em;
    margin: 0 0 0.5rem;
    font-weight: 500;
  }

  .home__intro {
    display: grid;
    grid-template-columns: 1fr 1px 16.25rem;
    gap: 3rem;
    margin-block-start: 2.5rem;
    max-inline-size: 56rem;
    align-items: start;
  }
  .home__intro-rule { background: var(--rule); inline-size: 1px; block-size: 100%; }
  .home__intro-body {
    font-family: var(--sans);
    font-size: var(--size-body-lg);
    line-height: 1.55;
    color: var(--ink-soft);
    max-inline-size: 40rem;
  }
  .home__intro-howto ol {
    list-style: decimal inside;
    font-size: 0.875rem;
    line-height: 1.65;
    color: var(--ink-soft);
    margin-block-start: 0.625rem;
  }
  .home__intro-howto li::marker { color: var(--burgundy); font-weight: 600; }

  .home__search {
    margin-block-start: 3rem;
    display: grid;
    grid-template-columns: 1fr 17.5rem auto;
    max-inline-size: 57.5rem;
    background: var(--paper);
    border: 1px solid var(--ink);
    padding: 4px;
  }
  .home__search > * { padding: 1rem 1.375rem; }
  .home__search-seek, .home__search-near {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.75rem;
    align-items: center;
    background: var(--paper);
  }
  .home__search-near { border-inline-start: 1px solid var(--rule); }
  .home__search .icon { grid-row: 1 / 3; }
  .home__search-seek label, .home__search-near label { grid-row: 1; }
  .home__search-seek input, .home__search-near input {
    grid-row: 2; grid-column: 2;
    border: 0; background: transparent; outline: none;
    font: 500 1rem/1.3 var(--sans); color: var(--ink);
  }
  .home__search-seek input::placeholder, .home__search-near input::placeholder { color: var(--ink-mute); font-style: italic; font-weight: 400; }
  .home__search-submit {
    background: var(--burgundy); color: var(--paper); border: 0;
    text-transform: uppercase; letter-spacing: 0.18em; font-weight: 600;
    font-size: 0.8125rem; padding: 0 2.25rem; transition: background 150ms ease;
  }
  .home__search-submit:hover { background: var(--burgundy-d); }

  .home__popular { margin-block-start: 0.875rem; display: flex; align-items: center; gap: 1.125rem; flex-wrap: wrap; }
  .home__popular a {
    font-family: var(--sans);
    font-size: 0.8125rem;
    font-style: italic;
    color: var(--burgundy);
    text-decoration: underline;
    text-underline-offset: 3px;
  }

  /* 2. Featured ─── “This season, we commend —” */
  .sect { padding: 3rem var(--pad-x); border-block-end: 1px solid var(--rule); }
  .sect--paper { background: var(--paper); }
  .sect__head {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 1.5rem; margin-block-end: 1.5rem; flex-wrap: wrap;
  }
  .sect__title-grp { display: flex; align-items: baseline; gap: 0.875rem; }
  .sect__roman {
    font-family: var(--serif); font-style: italic;
    font-size: 0.875rem; color: var(--burgundy);
  }
  .sect__h2 { font-size: var(--h2); font-weight: 500; letter-spacing: -0.015em; }
  .sect__meta { font: italic 0.8125rem/1.5 var(--sans); color: var(--ink-mute); }

  .featured-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 2.25rem; }
  .featured__lead-card { display: block; color: inherit; }
  .featured__lead-fig {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
  }
  .featured__lead-fig img, .featured__lead-fig svg {
    inline-size: 100%; block-size: 100%; object-fit: cover;
    filter: sepia(0.18) saturate(0.82);
  }
  .featured__lead-fig svg { filter: none; }
  .featured__lead-tag {
    position: absolute; inset-block-start: 1rem; inset-inline-start: 1rem;
    background: var(--paper); border: 1px solid var(--ink);
    padding: 0.375rem 0.625rem;
  }
  .featured__lead-body { margin-block-start: 1.125rem; }
  .featured__lead-h3 {
    font-size: 3rem; line-height: 1.0; font-weight: 500;
    letter-spacing: -0.015em; margin-block: 0.375rem 0.625rem;
    transition: color 150ms ease;
  }
  .featured__lead-card:hover .featured__lead-h3 { color: var(--burgundy); }
  .featured__lead-p { font-family: var(--sans); font-size: 1rem; line-height: 1.55; color: var(--ink-soft); }
  .featured__side { display: flex; flex-direction: column; gap: 1.75rem; }
  .featured__side-row {
    display: grid; grid-template-columns: 140px 1fr; gap: 1.125rem;
    padding-block-end: 1.375rem; border-block-end: 1px solid var(--rule);
  }
  .featured__side-row:last-child { border-block-end: 0; padding-block-end: 0; }
  .featured__side-fig { aspect-ratio: 1/1; overflow: hidden; }
  .featured__side-fig img, .featured__side-fig svg { inline-size:100%; block-size:100%; object-fit: cover; filter: sepia(0.18) saturate(0.82); }
  .featured__side-fig svg { filter: none; }
  .featured__side-title {
    font-size: 1.5rem; line-height: 1.1; font-weight: 500;
    letter-spacing: -0.015em; margin-block: 0.25rem 0.375rem;
    transition: color 150ms ease;
  }
  .featured__side-row:hover .featured__side-title { color: var(--burgundy); }
  .featured__side-meta { font: italic 0.75rem/1.4 var(--sans); color: var(--ink-mute); margin-block-end: 0.375rem; }
  .featured__side-blurb { font-size: 0.84375rem; line-height: 1.5; color: var(--ink-soft); }

  /* 3. Traditions */
  .trad-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    border-block-start: 1px solid var(--rule);
    border-inline-start: 1px solid var(--rule);
  }
  .trad-tile {
    border-block-end: 1px solid var(--rule);
    border-inline-end: 1px solid var(--rule);
    min-block-size: 8.75rem;
    position: relative;
  }
  .trad-tile a {
    display: block; padding: 1.375rem 1.25rem 3rem; block-size: 100%;
    color: inherit; transition: background 150ms ease;
  }
  .trad-tile a:hover { background: var(--bg); }
  .trad-tile__name {
    font-family: var(--serif); font-weight: 500;
    font-size: 1.5rem; line-height: 1.05;
    margin-block: 0.5rem 0.25rem; letter-spacing: -0.015em;
    transition: color 150ms ease;
  }
  .trad-tile a:hover .trad-tile__name { color: var(--burgundy); }
  .trad-tile__count { font-family: var(--sans); font-size: 0.8125rem; font-style: italic; color: var(--ink-mute); }
  .trad-tile__arrow { position: absolute; inset-inline-end: 1rem; inset-block-end: 1rem; color: var(--ink-mute); transition: transform 150ms ease, color 150ms ease; }
  .trad-tile a:hover .trad-tile__arrow { transform: translateX(3px); color: var(--burgundy); }

  /* 4. Places (cities + editors' letter) */
  .places-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
  .city-ledger li { border-block-end: 1px solid var(--rule-soft); }
  .city-ledger a {
    display: grid; grid-template-columns: 1fr auto auto auto;
    align-items: baseline; gap: 0.75rem; padding-block: 0.875rem;
    color: inherit;
  }
  .city-ledger a:hover { color: var(--burgundy); }
  .city-ledger__city {
    font-family: var(--serif); font-weight: 500;
    font-size: 1.5rem; line-height: 1.1; color: var(--ink);
    letter-spacing: -0.015em;
  }
  .city-ledger__st { font: italic 0.75rem/1 var(--sans); color: var(--ink-mute); }
  .city-ledger__n  { font: 0.8125rem/1 var(--sans); color: var(--ink-mute); font-style: italic; }
  .city-ledger__arrow { color: var(--ink-mute); transition: transform 150ms ease; }
  .city-ledger a:hover .city-ledger__arrow { transform: translateX(3px); color: var(--burgundy); }

  .editor-letter {
    background: var(--ink); color: #f1e8d6;
    padding: 2rem 2.25rem;
  }
  .editor-letter__q {
    font-family: var(--serif); font-style: italic;
    font-size: 1.5rem; line-height: 1.4; color: #f1e8d6;
    text-wrap: balance;
  }
  .editor-letter__sign {
    margin-block-start: 1.25rem;
    text-transform: uppercase; letter-spacing: 0.18em;
    font-size: 0.6875rem; color: var(--gold);
    font-weight: 600; font-family: var(--sans); font-style: normal;
  }
}

/* ───────────────────────────────────────────────
   PARISH DETAIL
   ─────────────────────────────────────────────── */
@layer components {
  .parish { max-inline-size: var(--page-max); margin-inline: auto; }

  .breadcrumb {
    padding: 1.5rem var(--pad-x) 0;
    font: 500 0.8125rem/1.5 var(--sans);
    color: var(--ink-soft);
  }
  .breadcrumb ol { display: flex; flex-wrap: wrap; gap: 0 0.625rem; align-items: baseline; }
  .breadcrumb li { display: inline-flex; align-items: baseline; gap: 0.625rem; }
  .breadcrumb li + li::before { content: "›"; color: var(--ink-mute); }
  .breadcrumb a { color: var(--ink-soft); }
  .breadcrumb a:hover { color: var(--burgundy); }
  .breadcrumb [aria-current="page"] { color: var(--ink); font-weight: 600; }

  /* Hero — full-bleed photo + overlay */
  .parish__hero {
    position: relative;
    margin-block-start: 1.25rem;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-block: 1px solid var(--rule);
  }
  .parish__hero > img, .parish__hero > svg {
    inline-size: 100%; block-size: 100%; object-fit: cover;
    filter: sepia(0.18) saturate(0.82);
  }
  .parish__hero > svg { filter: none; }
  .parish__hero-overlay {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 2.5rem var(--pad-x);
    background: linear-gradient(180deg, transparent 40%, rgba(28,26,23,0.25) 70%, rgba(28,26,23,0.75) 100%);
    color: #f1e8d6;
  }
  .parish__hero-eyebrow { color: var(--gold); margin-block-end: 0.75rem; }
  .parish__hero-title {
    font-family: var(--serif); font-weight: 500;
    font-size: clamp(3rem, 5vw + 1rem, 6rem);
    line-height: 1.02; letter-spacing: -0.02em;
    color: #faf6ec; text-wrap: balance;
    max-inline-size: 40rem;
  }
  .parish__hero-title em { font-style: italic; font-weight: 500; }
  .parish__hero-addr {
    margin-block-start: 0.875rem;
    font: 500 1rem/1.4 var(--sans);
    color: #f1e8d6;
    opacity: 0.85;
    display: inline-flex; align-items: center; gap: 0.5rem;
  }

  /* Sticky CTA bar */
  .parish__cta {
    position: sticky; top: 0; z-index: 20;
    background: var(--paper); border-block-end: 1px solid var(--rule);
    padding: 0.875rem var(--pad-x);
    display: flex; flex-wrap: wrap; gap: 0.625rem;
    justify-content: space-between; align-items: center;
  }
  .parish__cta-left { display: inline-flex; gap: 0.625rem; flex-wrap: wrap; align-items: center; }
  .parish__cta-meta { font: 500 0.8125rem/1 var(--sans); color: var(--ink-mute); }

  .btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.625rem 1.25rem;
    font-family: var(--sans);
    font-size: 0.8125rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.14em;
    border: 1px solid transparent; text-decoration: none;
    transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
  }
  .btn--burgundy { background: var(--burgundy); color: var(--paper); border-color: var(--burgundy); }
  .btn--burgundy:hover { background: var(--burgundy-d); border-color: var(--burgundy-d); color: var(--paper); }
  .btn--outline  { background: transparent; color: var(--ink); border-color: var(--ink); }
  .btn--outline:hover { background: var(--ink); color: var(--paper); }
  .btn--ghost    { background: transparent; color: var(--ink-soft); border-color: var(--rule); }
  .btn--ghost:hover { border-color: var(--ink); color: var(--ink); }

  /* Body — 2-col editorial */
  .parish__body {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 3.5rem;
    padding: 3rem var(--pad-x);
    border-block-end: 1px solid var(--rule);
  }
  /* Parish-page H2: editorial section labels, not article headlines.
     Small uppercase sans, plenty of air above. Applies across both parish__main
     and the cross-church sect blocks (Other churches / Nearest / Similar). */
  .parish .parish__main h2,
  .parish > .sect .sect__h2 {
    font: 600 0.75rem/1.25 var(--sans);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--burgundy);
    margin-block-start: 3.5rem;
    margin-block-end: 0.875rem;
    padding-block-start: 1.75rem;
    border-block-start: 1px solid var(--rule);
  }
  .parish .parish__main h2:first-of-type {
    margin-block-start: 0;
    padding-block-start: 0;
    border-block-start: 0;
  }
  /* Cross-church sect blocks use sect__head wrapper — its own padding already
     separates them; drop our border-top when the block is the first in its row. */
  .parish > .sect { padding-block-start: 2rem; padding-block-end: 2rem; }
  .parish > .sect + .sect { padding-block-start: 0; }
  .parish > .sect .sect__head { margin-block-end: 1.25rem; }
  /* The existing <hr class="rule"> right after each h2 is now redundant —
     our border-top replaces it. Hide on parish pages only. */
  .parish h2 + hr.rule { display: none; }
  .parish__main h3 { font: 500 1.25rem/1.3 var(--serif); margin-block: 0.25rem 0.5rem; }
  .parish__lede {
    font-size: 1.1875rem; line-height: 1.6; color: var(--ink);
    text-wrap: pretty;
  }
  .parish__main p { font-size: 1rem; line-height: 1.6; color: var(--ink-soft); margin-block-start: 1rem; }

  .parish__schedule {
    border: 1px solid var(--rule);
    margin-block-start: 1.25rem;
    display: grid; grid-template-columns: 9rem 1fr;
  }
  .parish__schedule dt, .parish__schedule dd {
    padding: 0.875rem 1.125rem;
    border-block-end: 1px solid var(--rule-soft);
  }
  .parish__schedule > dt:last-of-type, .parish__schedule > dd:last-of-type { border-block-end: 0; }
  .parish__schedule dt {
    font-family: var(--serif); font-style: italic;
    font-size: 1.25rem; font-weight: 500; color: var(--ink);
  }
  .parish__schedule dd { font-family: var(--sans); font-size: 0.875rem; color: var(--ink); }

  .parish__sidebar { align-self: start; }
  .parish__sidebar > * + * { margin-block-start: 1.75rem; }
  .parish__sidebar h3 {
    font-family: var(--sans); text-transform: uppercase; letter-spacing: 0.14em;
    font-size: 0.6875rem; font-weight: 700; color: var(--ink-soft);
  }
  .kv { display: grid; grid-template-columns: 7.5rem 1fr; gap: 0.5rem 1rem; }
  .kv dt { font: 600 0.75rem/1.4 var(--sans); color: var(--ink-mute); padding-block: 0.5rem 0; }
  .kv dd { font: 500 0.875rem/1.5 var(--sans); color: var(--ink); padding-block: 0.5rem 0; border-block-end: 1px solid var(--rule-soft); }
  .kv > dd:last-of-type { border-block-end: 0; }

  .contact { display: flex; flex-direction: column; gap: 0.625rem; font-size: 0.875rem; }
  .contact li { display: flex; align-items: center; gap: 0.625rem; color: var(--ink); }
  .contact .icon { color: var(--burgundy); flex: 0 0 auto; }

  /* Similar parishes */
  .similar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
  .similar a { display: block; color: inherit; }
  .similar__card-fig { aspect-ratio: 4/3; overflow: hidden; background: var(--rule-soft); margin-block-end: 0.875rem; }
  .similar__card-fig svg { inline-size: 100%; block-size: 100%; }
  .similar__card-title {
    font-family: var(--serif); font-weight: 500;
    font-size: 1.375rem; line-height: 1.15; letter-spacing: -0.01em;
    margin-block: 0.375rem 0.25rem;
    transition: color 150ms ease;
  }
  .similar a:hover .similar__card-title { color: var(--burgundy); }
  .similar__card-meta { font: italic 0.75rem/1.4 var(--sans); color: var(--ink-mute); }
}

/* ───────────────────────────────────────────────
   CATEGORY / TRADITION INDEX
   ─────────────────────────────────────────────── */
@layer components {
  .cat { max-inline-size: var(--page-max); margin-inline: auto; }
  .cat__hero {
    padding: 2.25rem var(--pad-x) 2rem;
    border-block-end: 1px solid var(--rule);
  }
  .cat__h1 {
    font-size: var(--h1-page);
    line-height: 1.0; letter-spacing: -0.02em;
    margin-block: 0.625rem 1rem;
  }
  .cat__h1 em { font-style: italic; font-weight: 500; }
  .cat__lede { font: 1rem/1.55 var(--sans); color: var(--ink-soft); max-inline-size: 44rem; }
  .cat__stats {
    display: flex; gap: 2.5rem; flex-wrap: wrap;
    margin-block-start: 1.75rem;
    padding-block-start: 1rem;
    border-block-start: 1px solid var(--rule);
  }
  .cat__stats > div { display: flex; flex-direction: column; gap: 0.25rem; }
  .cat__stats dt { font: 600 0.6875rem/1 var(--sans); letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); }
  .cat__stats dd { font: 600 1.625rem/1 var(--sans); color: var(--ink); letter-spacing: -0.01em; }

  .cat__filters {
    display: flex; gap: 1rem; align-items: center;
    padding: 1rem var(--pad-x);
    border-block-end: 1px solid var(--rule);
    background: var(--paper);
    flex-wrap: wrap; justify-content: space-between;
  }
  .filter-pill {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.5rem 0.875rem;
    border: 1px solid var(--rule); background: var(--bg);
    font-size: 0.8125rem;
  }
  .filter-pill select {
    border: 0; background: transparent; outline: none;
    font: 500 0.8125rem/1 var(--sans); color: var(--ink);
  }

  .alphabet {
    display: flex; flex-wrap: wrap; justify-content: space-between; gap: 0.5rem 1rem;
    padding: 1rem var(--pad-x);
    border-block-end: 1px solid var(--rule);
    font-family: var(--serif); font-style: italic; font-size: 1rem;
  }
  .alphabet a { color: var(--ink-mute); text-decoration: none; }
  .alphabet a:hover { color: var(--ink); }
  .alphabet a.is-active { color: var(--burgundy); font-weight: 600; }
  .alphabet span { color: var(--rule); }

  .ledger { padding: 1.5rem var(--pad-x); border-block-end: 1px solid var(--rule); }
  .ledger__row {
    display: grid;
    grid-template-columns: 120px 3rem 1fr auto;
    gap: 1.5rem;
    align-items: start;
    padding: 1.375rem 0;
    border-block-end: 1px solid var(--rule);
  }
  .ledger__row:last-of-type { border-block-end: 0; }
  .ledger__fig {
    aspect-ratio: 3 / 4; overflow: hidden; background: var(--rule-soft);
  }
  .ledger__fig img, .ledger__fig svg { inline-size: 100%; block-size: 100%; object-fit: cover; filter: sepia(0.18) saturate(0.82); }
  .ledger__fig svg { filter: none; }
  .ledger__num { padding-block-start: 0.35rem; }
  .ledger__body { display: flex; flex-direction: column; gap: 0.5rem; }
  .ledger__title {
    font-family: var(--serif); font-weight: 500;
    font-size: 1.625rem; line-height: 1.15; letter-spacing: -0.015em;
    color: var(--ink); transition: color 150ms ease;
  }
  .ledger__row:hover .ledger__title { color: var(--burgundy); }
  .ledger__meta { font: italic 0.8125rem/1.4 var(--sans); color: var(--ink-mute); }
  .ledger__blurb { font-size: 0.9375rem; line-height: 1.55; color: var(--ink-soft); }
  .ledger__read {
    font-family: var(--sans); font-weight: 700; font-size: 0.75rem;
    text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy);
    padding-block-start: 0.35rem; align-self: start;
  }

  .pagination {
    display: flex; justify-content: center; align-items: baseline; gap: 1rem;
    padding: 1.5rem var(--pad-x) 2.5rem;
    font-family: var(--sans); font-size: 0.875rem; font-weight: 500;
  }
  .pagination a, .pagination span { color: var(--ink-mute); }
  .pagination a:hover { color: var(--burgundy); }
  .pagination .is-current { color: var(--burgundy); font-weight: 700; }
}

/* ───────────────────────────────────────────────
   RESPONSIVE
   ─────────────────────────────────────────────── */
@layer responsive {
  @media (max-width: 1023.98px) {
    .home__intro  { grid-template-columns: 1fr; }
    .home__intro-rule { display: none; }
    .featured-grid { grid-template-columns: 1fr; }
    .featured__lead-h3 { font-size: 2.25rem; }
    .trad-grid    { grid-template-columns: repeat(3, 1fr); }
    .places-grid  { grid-template-columns: 1fr; }
    .parish__body { grid-template-columns: 1fr; gap: 2rem; }
    .parish__hero { aspect-ratio: 4 / 3; }
    .parish__hero-title { font-size: clamp(2.25rem, 6vw, 3.75rem); }
    .similar      { grid-template-columns: repeat(2, 1fr); }
    .ledger__row  { grid-template-columns: 90px 2.5rem 1fr; }
    .ledger__read { grid-column: 1 / -1; justify-self: start; padding-block-start: 0; }
  }
  @media (max-width: 767.98px) {
    .mast { flex-direction: column; align-items: flex-start; gap: 0.625rem; padding-block: 0.875rem; }
    .mast__nav { gap: 1rem; flex-wrap: wrap; }
    .mast__search { display: none; }
    .home__meta { flex-direction: column; gap: 1rem; }
    .home__epigraph { text-align: start; }
    .home__search { grid-template-columns: 1fr; padding: 0; border-width: 1px; }
    .home__search-seek, .home__search-near { border-inline-start: 0; border-block-end: 1px solid var(--rule); }
    .home__search-submit { padding-block: 0.875rem; }
    .trad-grid   { grid-template-columns: repeat(2, 1fr); }
    /* !important needed because the blade sets grid-template-columns inline
       with a dynamic column count (up to 5) to hide empty slots on desktop. */
    .similar     { grid-template-columns: 1fr 1fr !important; gap: 1rem; }
    .parish__hero { aspect-ratio: 1 / 1; }
    .parish__hero-overlay { padding: 1.25rem; }
    .parish__cta { padding: 0.625rem 1rem; flex-wrap: wrap; }
    .parish__cta-left { flex-wrap: wrap; gap: 0.5rem; }
    .cat__stats { gap: 1.25rem; }
    .ledger__row { grid-template-columns: 80px 1fr; }
    .ledger__num { display: none; }
    .foot { flex-direction: column; text-align: start; gap: 0.375rem; }
    .pm-poi-grid { grid-template-columns: 1fr 1fr; gap: 1.25rem 1rem; }
    .pm-poi-grid > div:nth-child(3):last-child { grid-column: 1 / -1; }
    /* Parish body: stack main + sidebar vertically on mobile. */
    .parish__body { grid-template-columns: 1fr !important; gap: 1rem; }
    .parish__hero-title { font-size: clamp(1.75rem, 7vw, 2.5rem); }
    .parish__summary { font-size: 0.9375rem; }
    .parish__stars .star { width: 16px; height: 16px; }
    .parish__pulse { gap: 0.5rem 1rem; padding: 0.75rem var(--pad-x); }
    .parish__gallery { grid-template-columns: 1fr 1fr; }
    .parish__trivia, .parish__stats-row { grid-template-columns: 1fr 1fr; }
    .parish__sunday { grid-template-columns: 1fr; }
    .parish__faq dt { font-size: 0.875rem; }
    .parish__staff { grid-template-columns: 1fr; }
    .parish__wiki { grid-template-columns: 1fr; }
    .parish__timeline li { grid-template-columns: 70px 1fr; }
    .parish__yt-grid { grid-template-columns: 1fr 1fr; }
    .parish__yt-head { flex-direction: column; align-items: stretch; }
    .parish__siblings { grid-template-columns: 1fr !important; }
    .parish__sacraments { grid-template-columns: 1fr !important; }
    .breadcrumb ol { flex-wrap: wrap; gap: 0.25rem 0.5rem; font-size: 0.75rem; }
    /* Flush breadcrumb → hero on phones (no empty beige band). */
    .parish__hero { margin-block-start: 0 !important; }
    .parish .breadcrumb {
      padding: 0.625rem var(--pad-x) 0.5rem;
      line-height: 1.35;
    }
    .parish .breadcrumb ol { gap: 0 0.375rem; }
  }

  /* State / City / Denomination pages (layouts.minimal wrapper = .pa).
     These templates were hand-tuned for desktop with inline 56 px padding +
     fixed-pixel grid tracks. Override on narrow screens so they don't break. */
  @media (max-width: 767.98px) {
    .pa [style*="56px"] {
      padding-inline: 1.125rem !important;
    }
    .pa [style*="70px 56px"],
    .pa [style*="64px 56px"],
    .pa [style*="padding: 48px 56px"] {
      padding-block: 1.75rem !important;
    }
    .pa [style*="padding: 22px 56px"] {
      padding-block: 0.875rem !important;
    }
    /* Collapse every multi-column grid to single column on phones. */
    .pa [style*="grid-template-columns: 1fr 500px"],
    .pa [style*="grid-template-columns: 220px 1fr"],
    .pa [style*="grid-template-columns: repeat(5, 1fr)"],
    .pa [style*="grid-template-columns: repeat(4, 1fr)"],
    .pa [style*="grid-template-columns: repeat(3, 1fr)"],
    .pa [style*="grid-template-columns: 1fr 1fr 1fr"],
    .pa [style*="grid-template-columns: 50px 1fr 100px 260px 100px"],
    .pa [style*="grid-template-columns: 1fr 120px 120px"] {
      grid-template-columns: 1fr !important;
      gap: 0.75rem !important;
    }
    .pa [style*="gap: 80px"],
    .pa [style*="gap: 64px"],
    .pa [style*="gap: 48px"],
    .pa [style*="gap: 32px"] {
      gap: 1.5rem !important;
    }
    /* Huge state hero type → sane mobile size */
    .pa [style*="font-size: 124px"] { font-size: clamp(2.5rem, 12vw, 4rem) !important; }
    .pa [style*="font-size: 96px"]  { font-size: clamp(2rem, 10vw, 3.5rem) !important; }
    .pa [style*="font-size: 72px"]  { font-size: clamp(1.75rem, 8vw, 2.75rem) !important; }
    .pa [style*="font-size: 56px"]  { font-size: clamp(1.5rem, 7vw, 2.25rem) !important; }
    /* Header mastheads — flex column + hide search bar like in the app layout */
    .pa [style*="display: flex"][style*="justify-content: space-between"] {
      flex-wrap: wrap; gap: 0.75rem;
    }
    /* Hide the in-header inline search input that doesn't fit on mobile */
    .pa form[role="search"] { display: none !important; }
    /* Reasonable body min-width so long city names don't overflow into a line */
    .pa * { min-inline-size: 0; }
  }
}

/* Parish — nearby POIs under the Leaflet map.
   Desktop: 2 columns (cards are ~50% wider than the old 3-col layout).
   The 3rd card wraps to a new row and spans both columns.
   Mobile: 2 cols side-by-side (overridden inside the mobile media query above). */
.pm-poi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem 2.25rem;
  margin: 1.375rem 0 0.25rem;
}
.pm-poi-grid > div:nth-child(3):last-child { grid-column: 1 / -1; }

/* ── Parish page — demo-tier enrichment blocks ────────────────────── */

/* Hero photograph from Wikimedia Commons; sits behind the overlay text. */
.parish__hero-photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.55) contrast(1.05);
  z-index: 0;
}
/* parish__hero already has position:relative in its block above; we only
   need the photo to slot behind existing overlay, not reposition the overlay. */

/* Pulse strip under the CTA: stars + open-now. */
.parish__pulse {
  display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 2rem;
  padding: 0.875rem 0;
  border-bottom: 1px solid var(--rule);
  font: 500 0.875rem/1.3 var(--sans);
}
.parish__stars { display: inline-flex; align-items: center; gap: 0.625rem; }
.parish__stars .stars { display: inline-flex; gap: 2px; }
.parish__stars .star { width: 18px; height: 18px; }
.parish__stars .star--full  { fill: var(--burgundy); }
.parish__stars .star--empty { fill: var(--rule); }
.parish__stars-num strong { font-size: 1.125rem; color: var(--ink); }
.parish__stars-num span  { color: var(--ink-mute); margin-left: 4px; }

.parish__open { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--ink-soft); }
.parish__open .dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--ink-mute);
}
.parish__open.is-open .dot   { background: #3c8a3c; }
.parish__open.is-closed .dot { background: #b94646; }

/* Unclaimed banner — prominent but editorial. */
.parish__unclaimed {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: 1rem 1.5rem;
  background: #fdf6e7;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 0.875rem 1.25rem;
  font: 500 0.875rem/1.45 var(--sans);
  color: var(--ink);
}
.parish__unclaimed strong { color: var(--burgundy); }
.btn--small { padding: 0.5rem 0.875rem; font-size: 0.8125rem; }

/* Wikipedia card — title + extract + thumb on the right. */
.parish__wiki {
  display: grid;
  grid-template-columns: 1fr 180px;
  gap: 1.5rem;
  margin: 1.5rem 0 2rem;
  padding: 1.125rem 1.25rem;
  background: var(--paper);
  border-left: 3px solid var(--burgundy);
}
.parish__wiki-thumb img {
  width: 100%; height: auto;
  display: block;
  border: 1px solid var(--rule);
}
@media (max-width: 767.98px) {
  .parish__wiki { grid-template-columns: 1fr; }
  .parish__wiki-thumb { max-width: 220px; }
}

/* Timeline — compact editorial dot-line. */
.parish__timeline {
  list-style: none; padding: 0; margin: 1rem 0 2rem;
  display: grid; gap: 0.5rem;
}
.parish__timeline li {
  display: grid; grid-template-columns: 90px 1fr;
  align-items: baseline;
  padding: 0.375rem 0;
  border-bottom: 1px dashed var(--rule);
  font: 500 0.9375rem/1.4 var(--sans);
}
.parish__timeline-date {
  font: 600 0.8125rem/1 var(--sans);
  letter-spacing: 0.06em;
  color: var(--burgundy);
}

/* Census neighborhood stats row. */
.parish__stats-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
  gap: 1rem 1.5rem;
  margin: 1rem 0 0.25rem;
}
.parish__stats-row > div {
  padding: 0.75rem 1rem;
  border: 1px solid var(--rule);
  background: var(--paper);
  display: flex; flex-direction: column; gap: 0.375rem;
}
.parish__stat-num {
  font: 600 1.5rem/1.05 var(--sans);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.parish__stat-label {
  font: 500 0.75rem/1.2 var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
}

/* Commons photo gallery. */
.parish__gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0.75rem;
  margin: 1rem 0 0.25rem;
}
.parish__gallery figure { margin: 0; }
.parish__gallery img {
  width: 100%; aspect-ratio: 4/3;
  object-fit: cover; display: block;
  border: 1px solid var(--rule);
  transition: transform 0.2s;
}
.parish__gallery a:hover img { transform: scale(1.02); }
.parish__gallery figcaption {
  font: 500 0.75rem/1.35 var(--sans);
  color: var(--ink-mute);
  margin-top: 0.375rem;
  display: flex; gap: 0.375rem; flex-wrap: wrap;
}
.parish__gallery figcaption em { font-style: italic; color: var(--ink-soft); }

/* Sidebar "By the numbers" stats. */
.parish__sidestats {
  display: grid; gap: 0.5rem;
}
.parish__sidestats > div {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0.375rem 0; border-bottom: 1px solid var(--rule);
}
.parish__sidestats span {
  font: 600 1.125rem/1 var(--sans); color: var(--burgundy);
  font-variant-numeric: tabular-nums;
}
.parish__sidestats em {
  font: 500 0.8125rem/1.3 var(--sans); color: var(--ink-mute);
}

/* Copy-to-clipboard button — inline, subtle. */
.parish__copy {
  display: inline-block;
  margin-inline-start: 0.5rem;
  padding: 2px 6px;
  font: 500 0.6875rem/1 var(--sans);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: transparent;
  color: var(--ink-mute);
  border: 1px solid var(--rule);
  border-radius: 3px;
  cursor: pointer;
}
.parish__copy:hover { color: var(--burgundy); border-color: var(--burgundy); }
.parish__copy--hero {
  color: rgba(255,255,255,0.75);
  border-color: rgba(255,255,255,0.35);
}
.parish__copy--hero:hover {
  color: #fff; border-color: #fff;
}

/* Liturgy-of-the-day strip (Catholic / Anglican / Orthodox parishes only). */
.parish__liturgy {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.75rem 1.25rem;
  background: var(--paper);
  border-block: 1px solid var(--rule);
  font: 500 0.875rem/1.35 var(--sans);
}
.parish__liturgy-mark {
  width: 10px; height: 40px; border-radius: 2px; flex: 0 0 auto;
}

/* YouTube block. */
.parish__yt {
  margin: 1.5rem 0 2rem;
  padding: 1rem 1.25rem;
  background: var(--paper);
  border-left: 3px solid #c4302b;
}
.parish__yt-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 1rem; margin-bottom: 0.75rem;
}
.parish__yt-live {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0.875rem;
  background: #c4302b; color: #fff;
  font: 700 0.75rem/1 var(--sans); letter-spacing: 0.14em;
  text-transform: uppercase; text-decoration: none;
  border-radius: 3px;
}
.parish__yt-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #fff;
  animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse { 50% { opacity: 0.35; } }
.parish__yt-live-embed {
  position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden;
  border: 1px solid var(--rule); background: #000;
}
.parish__yt-live-embed iframe {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
}
.parish__yt-list { list-style: none; padding: 0; margin: 8px 0 0; font: 500 0.875rem/1.55 var(--sans); }
.parish__yt-list li { padding: 4px 0; border-bottom: 1px solid var(--rule); }
.parish__yt-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.75rem; margin-top: 0.5rem;
}
.parish__yt-grid a {
  display: flex; flex-direction: column; gap: 0.375rem;
  font: 500 0.8125rem/1.35 var(--sans); color: var(--ink);
  text-decoration: none;
}
.parish__yt-grid a:hover { color: var(--burgundy); }
.parish__yt-grid img {
  width: 100%; aspect-ratio: 16/9; object-fit: cover;
  border: 1px solid var(--rule); display: block;
}

/* Patron-saint panel. */
.parish__saint {
  padding: 1rem 1.25rem;
  background: var(--paper);
  border-left: 3px solid var(--gold);
  margin: 0.5rem 0 2rem;
}
.parish__saint-name {
  font: 600 1.125rem/1.3 var(--sans);
  color: var(--burgundy);
  letter-spacing: -0.01em;
}

/* "Find a Mass right now" banner — sits above the rating strip. */
.parish__next {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.625rem 1.25rem;
  background: #111; color: #faf6ec;
  font: 600 0.875rem/1.3 var(--sans); letter-spacing: -0.005em;
}
.parish__next-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #888;
}
.parish__next.is-open  .parish__next-dot { background: #3cc05f; animation: pulse 1.6s ease-in-out infinite; }
.parish__next.is-soon  .parish__next-dot { background: var(--gold); }
.parish__next.is-later .parish__next-dot { background: #888; }

/* Sacraments list. */
.parish__sacraments {
  list-style: none; padding: 0; margin: 0.75rem 0 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
  gap: 0.25rem 1.5rem;
}
.parish__sacraments li {
  padding: 0.5rem 0; border-bottom: 1px dashed var(--rule);
  font: 500 0.9375rem/1.4 var(--sans);
  position: relative; padding-inline-start: 1.25rem;
}
.parish__sacraments li::before {
  content: '†'; position: absolute; inset-inline-start: 0; top: 0.5rem;
  color: var(--burgundy); font: 500 1rem/1 var(--serif);
}

/* Sibling / cohort lists (arch / diocese / founded cohort). */
.parish__siblings {
  list-style: none; padding: 0; margin: 0.75rem 0 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
  gap: 0;
}
.parish__siblings li { border-bottom: 1px solid var(--rule); }
.parish__siblings a {
  display: block; padding: 0.875rem 1rem;
  text-decoration: none; color: var(--ink);
  transition: background 0.15s;
}
.parish__siblings a:hover { background: var(--paper); }
.parish__siblings strong { font: 600 0.9375rem/1.3 var(--sans); display: block; letter-spacing: -0.005em; }
.parish__siblings em {
  display: block; font: italic 500 0.8125rem/1.3 var(--sans);
  color: var(--ink-mute); margin-top: 2px;
}

/* Sunday plan — 4-cell grid of composite signals. */
.parish__sunday {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.5rem 1rem; margin-top: 0.75rem;
}
.parish__sunday-cell {
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--rule); background: var(--paper);
  display: flex; flex-direction: column; gap: 0.25rem;
}
.parish__sunday-cell strong {
  font: 600 0.9375rem/1.3 var(--sans);
  color: var(--ink);
}

/* Cornerstone "by the numbers" trivia. */
.parish__trivia {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: 0.75rem; margin-top: 0.75rem;
}
.parish__trivia > div {
  padding: 1rem 1.125rem;
  background: var(--paper); border: 1px solid var(--rule);
}
.parish__trivia-value {
  display: block;
  font: 600 1.375rem/1.1 var(--sans);
  color: var(--burgundy);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.parish__trivia-label {
  display: block; margin-top: 0.375rem;
  font: 500 0.75rem/1.3 var(--sans); color: var(--ink-mute);
  text-transform: uppercase; letter-spacing: 0.1em;
}

/* Denomination-show toolbar helpers (inline flex containers). */
.cat__filter-row { display: inline-flex; gap: 0.75rem; align-items: center; flex-wrap: wrap; }
.cat__filter-meta { display: inline-flex; gap: 1rem; align-items: baseline; }
.filter-pill--active { background: var(--paper); }

/* City-page specific layout (reuses .st-bar, .st-meta, .st-foot). */
.ci-hero {
  padding: 3rem var(--pad-x) 2.5rem;
  border-bottom: 1px solid var(--rule);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 3.5rem; align-items: start;
}
.ci-hero__eyebrow { font: 700 0.75rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.ci-hero__h1 {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(2.5rem, 7vw, 6.5rem);
  line-height: 0.92; letter-spacing: -0.03em;
  margin: 0.75rem 0 1rem;
}
.ci-hero__lede { font: 500 1.0625rem/1.55 var(--sans); color: var(--ink-soft); margin: 0; max-width: 36rem; }
.ci-hero__stats { margin-top: 1.75rem; display: flex; gap: 2rem; flex-wrap: wrap; }
.ci-hero__stat  { min-inline-size: 5rem; }
.ci-hero__stat-num { font: 600 1.875rem/1 var(--sans); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; color: var(--ink); }
.ci-hero__stat-label { font: 600 0.625rem/1.35 var(--sans); text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-soft); display: block; margin-top: 0.375rem; }
.ci-hero__map { border: 1px solid var(--rule); background: var(--paper); aspect-ratio: 4/3; overflow: hidden; }

.ci-filters {
  padding: 1rem var(--pad-x);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  display: flex; gap: 0.625rem; align-items: center; flex-wrap: wrap;
}
.ci-filters__pill-primary {
  background: var(--ink); color: var(--paper);
  padding: 0.625rem 0.875rem;
  display: inline-flex; align-items: center; gap: 0.5rem;
  font: 600 0.8125rem/1 var(--sans);
  text-transform: uppercase; letter-spacing: 0.18em;
}
.ci-filters__pill {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border: 1px solid var(--rule); background: var(--bg);
  padding: 0.625rem 0.75rem;
}
.ci-filters__pill-label { font: 600 0.625rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-mute); }
.ci-filters__pill-value { font: 600 0.8125rem/1 var(--sans); color: var(--ink); }
.ci-filters__view-group {
  margin-left: auto; display: inline-flex; gap: 0.25rem;
  border: 1px solid var(--rule); padding: 3px; background: var(--bg);
}
.ci-filters__view-tab {
  padding: 0.4375rem 0.875rem;
  background: transparent; color: var(--ink-soft);
  font: 600 0.75rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.18em;
}
.ci-filters__view-tab.is-active { background: var(--ink); color: var(--paper); }

.ci-split {
  padding: 3.5rem var(--pad-x);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 45rem);
  gap: 3.5rem;
  border-bottom: 1px solid var(--rule);
}
.ci-trad a {
  display: block; padding: 1.25rem 0; border-bottom: 1px solid var(--rule-soft);
  text-decoration: none; color: inherit;
}
.ci-trad a:last-child { border-bottom: 0; }
.ci-trad__row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.375rem; }
.ci-trad__name { font: 500 1.375rem/1.2 var(--serif); margin: 0; }
.ci-trad__n    { font: 500 0.8125rem/1 var(--sans); color: var(--ink-mute); font-variant-numeric: tabular-nums; }
.ci-trad__note { font: 500 0.875rem/1.55 var(--sans); color: var(--ink-soft); margin: 0; }
.ci-trad__cta  { display: inline-block; margin-top: 0.5rem; font: 700 0.75rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }

.ci-notable a {
  display: grid;
  grid-template-columns: 7.5rem 3rem minmax(0, 1fr) auto;
  gap: 1.25rem; padding: 1.25rem 0;
  border-bottom: 1px solid var(--rule-soft);
  text-decoration: none; color: inherit;
  align-items: start;
}
.ci-notable a:last-child { border-bottom: 0; }
.ci-notable__fig { aspect-ratio: 3/4; overflow: hidden; }
.ci-notable__num { font: 700 0.6875rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); padding-top: 0.375rem; }
.ci-notable__name { font: 500 1.375rem/1.15 var(--serif); margin: 0 0 0.25rem; letter-spacing: -0.01em; }
.ci-notable__meta { font: 500 0.8125rem/1.3 var(--sans); color: var(--ink-soft); margin-bottom: 0.5rem; }
.ci-notable__blurb { font: 500 0.84375rem/1.5 var(--sans); color: var(--ink-soft); margin: 0; }
.ci-notable__cta { font: 700 0.75rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); padding-top: 0.375rem; }

.ci-pick {
  padding: 3.5rem var(--pad-x);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 3rem;
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
}
.ci-pick__eyebrow { font: 700 0.75rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.ci-pick__h2 { font: 500 2rem/1.15 var(--serif); margin: 0.625rem 0 0.75rem; letter-spacing: -0.015em; }
.ci-pick__body { font: 500 1rem/1.65 var(--sans); color: var(--ink-soft); margin: 0; }
.ci-nearby__label { font: 700 0.75rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-soft); }
.ci-nearby__grid { margin-top: 0.75rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.625rem; }
.ci-nearby__cell {
  border: 1px solid var(--rule); padding: 0.75rem 0.875rem;
  background: var(--bg); text-decoration: none; color: inherit; display: block;
}
.ci-nearby__name { font: 500 1.125rem/1.2 var(--serif); }
.ci-nearby__n { font: 500 0.75rem/1.3 var(--sans); color: var(--ink-soft); margin-top: 0.125rem; }

@media (max-width: 1023.98px) {
  .ci-hero { grid-template-columns: minmax(0, 1fr); gap: 2rem; }
  .ci-split { grid-template-columns: minmax(0, 1fr); gap: 2rem; }
  .ci-pick { grid-template-columns: minmax(0, 1fr); gap: 2rem; }
}
@media (max-width: 639.98px) {
  .ci-hero { padding: 2rem var(--pad-x) 1.75rem; }
  .ci-split { padding: 2rem var(--pad-x); }
  .ci-pick { padding: 2rem var(--pad-x); }
  .ci-hero__stats { gap: 1.5rem; }
  .ci-filters { padding: 0.75rem var(--pad-x); }
  .ci-filters__view-group { margin-left: 0; width: 100%; overflow: auto; }
  .ci-notable a { grid-template-columns: 5rem 1fr; gap: 0.875rem; }
  .ci-notable a > :nth-child(2) { display: none; }
  .ci-notable a > :nth-child(4) { display: none; }
  .ci-nearby__grid { grid-template-columns: 1fr; }
}

/* ── State / City / Denomination index pages ─────────────────────────
   Shared editorial layout. Serif ONLY on h1/h2/h3. Numbers are sans. */
.st-chrome { min-height: 100vh; background: var(--bg); }
.st-bar {
  padding: 1rem var(--pad-x);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  flex-wrap: wrap;
}
.st-brand { display: flex; align-items: center; gap: 1.125rem; text-decoration: none; color: var(--ink); }
.st-brand__word { font-family: var(--serif); font-size: 1.625rem; font-weight: 600; letter-spacing: -0.01em; line-height: 1; }
.st-brand__tick { width: 28px; height: 1px; background: var(--rule); }
.st-brand__sub  { font: 500 0.8125rem/1.2 var(--sans); color: var(--ink-soft); }
.st-nav { display: flex; align-items: center; gap: 1.75rem; flex-wrap: wrap; }
.st-nav a { font: 500 0.875rem/1 var(--sans); color: var(--ink); }
.st-nav a.is-active { color: var(--burgundy); font-weight: 600; }
.st-nav a:hover { color: var(--burgundy); }
.st-nav__search { display: inline-flex; align-items: center; gap: 0.5rem; border: 1px solid var(--rule); background: var(--bg); padding: 0.5rem 0.875rem; }
.st-nav__search input { border: 0; background: transparent; outline: none; font: 500 0.8125rem/1 var(--sans); color: var(--ink); min-width: 8rem; }

.st-meta {
  padding: 1.25rem var(--pad-x) 1rem;
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; flex-wrap: wrap;
  font: 500 0.8125rem/1.35 var(--sans); color: var(--ink-soft);
}
.st-crumb { display: inline-flex; align-items: baseline; gap: 0.625rem; flex-wrap: wrap; }
.st-crumb a { color: var(--ink-soft); }
.st-crumb a:hover { color: var(--burgundy); }
.st-crumb__sep { color: var(--ink-mute); }
.st-crumb__here { color: var(--ink); font-weight: 600; }
.st-meta__labels { display: inline-flex; gap: 1.125rem; flex-wrap: wrap; }
.st-meta__labels > span {
  font: 600 0.6875rem/1.2 var(--sans);
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-soft);
}

/* Hero */
.st-hero {
  padding: 3.5rem var(--pad-x) 3rem;
  border-bottom: 1px solid var(--rule);
}
.st-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 28rem);
  gap: 3rem; align-items: end;
}
.st-hero__eyebrow { font: 700 0.75rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-hero__h1 {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(3rem, 8vw, 7.75rem);
  line-height: 0.9; letter-spacing: -0.03em;
  margin: 1rem 0 0.875rem; color: var(--ink);
}
.st-hero__motto { display: flex; align-items: center; gap: 0.875rem; margin-bottom: 1.75rem; }
.st-hero__motto::before { content: ''; width: 40px; height: 1px; background: var(--rule); }
.st-hero__motto em { font-style: italic; font: 500 italic 1.25rem/1.4 var(--sans); color: var(--burgundy); }
.st-hero__lede { font: 500 1.125rem/1.55 var(--sans); color: var(--ink-soft); margin: 0; max-width: 38rem; }

/* Stats strip */
.st-stats {
  padding: 2.25rem var(--pad-x);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
}
.st-stats__grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1.5rem 2rem;
}
.st-stat { padding-left: 1.5rem; border-left: 1px solid var(--rule); }
.st-stat:first-child { padding-left: 0; border-left: 0; }
.st-stat__num {
  font: 600 2.125rem/1 var(--sans);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em; color: var(--ink);
}
.st-stat__label {
  font: 600 0.6875rem/1.35 var(--sans);
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-soft);
  display: block; margin-top: 0.5rem;
}

/* Body grid with sticky TOC */
.st-body {
  padding: 3.5rem var(--pad-x);
  display: grid;
  grid-template-columns: 14rem minmax(0, 1fr);
  gap: 3.5rem;
  border-bottom: 1px solid var(--rule);
}
.st-toc { align-self: start; position: sticky; top: 1.25rem; }
.st-toc__kicker { font: 700 0.6875rem/1.2 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-soft); }
.st-toc__rule { height: 1px; background: var(--rule); margin: 0.75rem 0 0.5rem; }
.st-toc__link { display: grid; grid-template-columns: 1.875rem 1fr; align-items: baseline; padding: 0.625rem 0; border-bottom: 1px solid var(--rule-soft); text-decoration: none; }
.st-toc__link:last-child { border-bottom: 0; }
.st-toc__num  { font: 700 0.8125rem/1 var(--serif); color: var(--burgundy); }
.st-toc__name { font: 500 0.875rem/1.3 var(--sans); color: var(--ink-soft); }
.st-toc__link.is-current .st-toc__name { color: var(--ink); font-weight: 700; }

/* Sections inside the main column */
.st-sec { margin-bottom: 4rem; }
.st-sec:last-child { margin-bottom: 0; }
.st-sec__head { display: flex; align-items: baseline; gap: 0.875rem; margin-bottom: 1.375rem; flex-wrap: wrap; }
.st-sec__num  { font: 700 0.75rem/1.3 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-sec__h2   { font: 500 2rem/1.15 var(--serif); margin: 0; letter-spacing: -0.015em; color: var(--ink); }
.st-sec__meta { font: 500 0.875rem/1.3 var(--sans); color: var(--ink-mute); margin-left: auto; }
.st-sec__body { font: 500 1rem/1.65 var(--sans); color: var(--ink); }
.st-sec__body p { margin: 0 0 1rem; }
.st-sec__body p:last-child { margin-bottom: 0; }
.st-sec__body--2col { column-count: 2; column-gap: 2.5rem; }

/* Denomination table */
.st-denoms { border: 1px solid var(--rule); background: var(--paper); }
.st-denoms a {
  display: grid;
  grid-template-columns: 3rem minmax(0, 1fr) 5rem minmax(0, 14rem) 4.5rem;
  align-items: center; gap: 1rem;
  padding: 0.875rem 1.125rem;
  border-bottom: 1px solid var(--rule-soft);
  text-decoration: none; color: inherit;
}
.st-denoms a:last-child { border-bottom: 0; }
.st-denoms a:hover { background: var(--bg); }
.st-denoms__num  { font: 700 0.6875rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-denoms__name { font: 500 1.0625rem/1.2 var(--serif); color: var(--ink); }
.st-denoms__count { font: 600 0.9375rem/1 var(--sans); color: var(--ink); text-align: right; font-variant-numeric: tabular-nums; }
.st-denoms__bar { height: 6px; background: var(--rule-soft); position: relative; }
.st-denoms__bar-fill { position: absolute; inset: 0 auto 0 0; background: var(--burgundy); }
.st-denoms__pct { font: 500 0.8125rem/1 var(--sans); color: var(--ink-soft); text-align: right; font-variant-numeric: tabular-nums; }

/* City cards + simple table */
.st-feat-cities { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.5rem; margin-bottom: 1.5rem; }
.st-feat-city { border: 1px solid var(--rule); padding: 1.375rem 1.375rem 1.25rem; background: var(--paper); text-decoration: none; color: inherit; }
.st-feat-city:hover { background: var(--bg); }
.st-feat-city__top { display: flex; justify-content: space-between; align-items: baseline; }
.st-feat-city__eyebrow { font: 700 0.6875rem/1.2 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-feat-city__count { font: 500 0.75rem/1.2 var(--sans); color: var(--ink-mute); font-variant-numeric: tabular-nums; }
.st-feat-city__name { font: 500 1.625rem/1.1 var(--serif); margin: 0.625rem 0; letter-spacing: -0.01em; }
.st-feat-city__lede { font: 500 0.9375rem/1.55 var(--sans); color: var(--ink-soft); margin: 0 0 0.875rem; }
.st-feat-city__cta  { font: 700 0.75rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }

.st-city-table { border: 1px solid var(--rule); background: var(--bg); }
.st-city-table__head, .st-city-table__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 7rem 6rem;
  gap: 1rem; padding: 0.75rem 1.25rem;
  border-bottom: 1px solid var(--rule-soft);
  align-items: baseline;
}
.st-city-table__head { background: var(--paper); border-bottom: 1px solid var(--rule); }
.st-city-table__row { text-decoration: none; color: inherit; }
.st-city-table__row:hover { background: var(--paper); }
.st-city-table__row:last-child { border-bottom: 0; }
.st-city-table__head span { font: 600 0.625rem/1.2 var(--sans); text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-mute); }
.st-city-table__name { font: 500 1.0625rem/1.2 var(--serif); }
.st-city-table__n    { font: 500 0.875rem/1 var(--sans); color: var(--ink-soft); text-align: right; font-variant-numeric: tabular-nums; }
.st-city-table__cta  { font: 700 0.75rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); text-align: right; }

.st-more { padding: 1.25rem 0 0; text-align: center; }
.st-more a { font: 700 0.8125rem/1 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); text-decoration: none; }

/* Featured parishes */
.st-featured { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.5rem; }
.st-featured a { display: block; color: inherit; text-decoration: none; }
.st-featured__fig { aspect-ratio: 3/4; overflow: hidden; background: var(--rule-soft); }
.st-featured__body { margin-top: 0.875rem; }
.st-featured__eyebrow { font: 700 0.6875rem/1.2 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-featured__name { font: 500 1.5rem/1.1 var(--serif); margin: 0.375rem 0; letter-spacing: -0.005em; }
.st-featured__loc  { font: 500 0.8125rem/1.2 var(--sans); color: var(--ink-soft); }

/* FAQ */
.st-faq details {
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 1.375rem 0;
}
.st-faq details + details { border-top: 0; }
.st-faq summary {
  list-style: none; cursor: pointer;
  display: grid; grid-template-columns: 3.75rem 1fr 2.5rem;
  gap: 1rem; align-items: start;
}
.st-faq summary::-webkit-details-marker { display: none; }
.st-faq__num { font: 700 0.75rem/1.4 var(--sans); text-transform: uppercase; letter-spacing: 0.16em; color: var(--burgundy); }
.st-faq__q   { font: 500 1.375rem/1.3 var(--serif); margin: 0 0 0.625rem; letter-spacing: -0.005em; }
.st-faq__a   { font: 500 0.9375rem/1.6 var(--sans); color: var(--ink-soft); margin: 0; }
.st-faq__toggle { font: 500 1.5rem/1 var(--sans); color: var(--ink-mute); text-align: right; }
.st-faq details[open] .st-faq__toggle::before { content: '−'; }
.st-faq details:not([open]) .st-faq__toggle::before { content: '+'; }

/* Footer mini */
.st-foot {
  padding: 1.125rem var(--pad-x);
  border-top: 1px solid var(--rule);
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; flex-wrap: wrap;
  background: var(--paper);
  font: 500 0.75rem/1.35 var(--sans); color: var(--ink-mute);
}
.st-foot em { font-style: italic; }

/* Responsive */
@media (max-width: 1023.98px) {
  .st-body { grid-template-columns: minmax(0, 1fr); gap: 2rem; }
  .st-toc { position: static; }
  .st-hero__grid { grid-template-columns: minmax(0, 1fr); }
  .st-stats__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.5rem; }
  .st-stats__grid .st-stat:nth-child(4) { padding-left: 0; border-left: 0; }
  .st-denoms a { grid-template-columns: 3rem minmax(0, 1fr) 4.5rem; gap: 0.75rem; }
  .st-denoms a > :nth-child(4), .st-denoms a > :nth-child(5) { display: none; }
  .st-feat-cities { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .st-featured { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 639.98px) {
  .st-stats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .st-stats__grid .st-stat:nth-child(3) { padding-left: 0; border-left: 0; }
  .st-feat-cities, .st-featured { grid-template-columns: minmax(0, 1fr); }
  .st-hero__h1 { font-size: clamp(2.25rem, 12vw, 4rem); }
  .st-nav__search { display: none; }
  .st-body { padding: 2rem var(--pad-x); }
  .st-hero { padding: 2.25rem var(--pad-x) 2rem; }
  .st-stats { padding: 1.75rem var(--pad-x); }
  .st-sec__head { gap: 0.5rem 0.875rem; }
  .st-sec__h2 { font-size: 1.625rem; }
  .st-sec__meta { margin-left: 0; width: 100%; }
  .st-sec__body--2col { column-count: 1; }
  .st-city-table__head, .st-city-table__row { grid-template-columns: minmax(0, 1fr) 4.5rem; gap: 0.75rem; padding: 0.625rem 1rem; }
  .st-city-table__row > :nth-child(3), .st-city-table__head > :nth-child(3) { display: none; }
}

/* Home: "Use my location" subtle link UNDER the search box, not inside it.
   Search-box grid stays untouched; geolocation is a quiet affordance that
   appears on a new row aligned right. */
.home__search-meta {
  max-inline-size: 57.5rem;
  display: flex; align-items: center; justify-content: flex-end;
  gap: 0.75rem;
  margin: 0.625rem 0 0;
  min-block-size: 1.25rem;
  font: 500 0.8125rem/1.3 var(--sans);
}
.home__locate-link {
  display: inline-flex; align-items: center; gap: 0.375rem;
  padding: 0; border: 0; background: transparent;
  color: var(--ink-mute);
  font: 500 0.75rem/1 var(--sans);
  text-transform: uppercase; letter-spacing: 0.12em;
  cursor: pointer;
}
.home__locate-link:hover:not(:disabled) { color: var(--burgundy); }
.home__locate-link:disabled { opacity: 0.5; cursor: default; }
.home__locate-link svg { flex: 0 0 auto; }
.home__locate-status {
  font: italic 500 0.75rem/1.3 var(--sans); color: var(--ink-mute);
  flex: 1 1 auto; text-align: end;
}

/* Dense section-opener ("AI inverted pyramid"). Plain sans, slightly larger,
   stated-up-front so an LLM can extract it as a grounded claim. */
.parish__summary {
  font: 500 1rem/1.6 var(--sans);
  color: var(--ink);
  margin: 0.625rem 0 1rem;
}
.parish__summary--compact {
  font: 500 0.9375rem/1.55 var(--sans);
  color: var(--ink-soft);
}

/* What to expect — denomination primer. */
.parish__expect {
  list-style: none; padding: 0; margin: 0.5rem 0 1rem;
}
.parish__expect li {
  position: relative; padding: 4px 0 4px 1.25rem;
  font: 500 0.9375rem/1.5 var(--sans);
  border-bottom: 1px dashed var(--rule);
}
.parish__expect li::before {
  content: '§';
  position: absolute; left: 0; top: 5px;
  color: var(--burgundy); font: 500 0.875rem/1 var(--sans);
}

/* Quiet-time-to-visit banner. */
.parish__quiet {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.75rem 1rem;
  margin: 1.125rem 0 1.5rem;
  background: var(--paper);
  border-left: 3px solid var(--gold);
  font: 500 0.9375rem/1.4 var(--sans);
  color: var(--ink);
}
.parish__quiet svg { flex: 0 0 auto; color: var(--burgundy); }

/* FAQ. */
.parish__faq { margin: 0.5rem 0 2rem; }
.parish__faq dt {
  font: 600 0.9375rem/1.4 var(--sans);
  color: var(--ink);
  letter-spacing: -0.005em;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--rule);
}
.parish__faq dt:first-child { border-top: 0; padding-top: 0; margin-top: 0; }
.parish__faq dd {
  font: 500 0.9375rem/1.55 var(--sans);
  color: var(--ink-soft);
  margin: 0.375rem 0 0;
}

/* Owner-supplied announcement banner. */
.parish__announce {
  display: flex; align-items: flex-start; gap: 0.875rem;
  padding: 0.875rem 1.25rem;
  background: #fff3d6;
  border-top: 2px solid var(--burgundy);
  border-bottom: 1px solid var(--rule);
}
.parish__announce-mark {
  width: 4px; align-self: stretch; background: var(--burgundy); border-radius: 2px;
}
.parish__announce-body { flex: 1; font: 500 0.875rem/1.45 var(--sans); color: var(--ink); }
.parish__announce-body p { margin: 4px 0 0; color: var(--ink-soft); }
.parish__announce-headline { color: var(--burgundy); display: block; font-size: 0.9375rem; }

/* Owner: first-visit note. */
.parish__firstvisit {
  padding: 1rem 1.25rem;
  background: var(--paper);
  border-left: 3px solid var(--gold);
  font: 500 1rem/1.55 var(--sans);
  color: var(--ink);
}

/* Owner: staff list. */
.parish__staff {
  list-style: none; padding: 0; margin: 0.5rem 0 2rem;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
  gap: 1rem;
}
.parish__staff li {
  display: flex; gap: 0.875rem; padding: 0.875rem;
  background: var(--paper); border: 1px solid var(--rule);
}
.parish__staff img {
  width: 64px; height: 64px; object-fit: cover; border-radius: 50%;
  border: 1px solid var(--rule); flex: 0 0 auto;
}
.parish__staff strong { font: 600 0.9375rem/1.25 var(--sans); color: var(--ink); letter-spacing: -0.005em; }
.parish__staff em {
  display: block;
  font: italic 500 0.8125rem/1.2 var(--sans); color: var(--burgundy);
  margin-top: 2px;
}
.parish__staff p {
  font: 500 0.8125rem/1.4 var(--sans); color: var(--ink-soft); margin: 6px 0 0;
}

/* Owner: donate panel in sidebar. */
.parish__donate {
  margin-top: 1.75rem; padding: 18px 20px;
  border-left: 3px solid var(--gold);
  background: var(--paper);
}

/* ── Home: livestreaming + streaming-capable grids ───────────────── */
.live-grid, .capable-grid {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
}
.live-card {
  display: block; text-decoration: none; color: var(--ink);
  background: var(--paper); border: 1px solid var(--rule);
  transition: transform 0.15s;
}
.live-card:hover { transform: translateY(-2px); }
.live-card figure {
  position: relative; margin: 0; aspect-ratio: 16/9; overflow: hidden;
  background: #000;
}
.live-card figure img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.live-card__badge {
  position: absolute; top: 8px; left: 8px;
  background: #c4302b; color: #fff;
  padding: 3px 8px; font: 700 0.6875rem/1 var(--sans);
  letter-spacing: 0.14em; border-radius: 3px;
}
.live-card__body { padding: 0.75rem 1rem; }
.live-card__body strong {
  font: 600 0.9375rem/1.3 var(--sans); display: block; color: var(--ink);
  letter-spacing: -0.01em;
}
.live-card__body em {
  display: block; font: italic 500 0.8125rem/1.2 var(--sans);
  color: var(--ink-mute); margin: 2px 0 6px;
}
.live-card__body p {
  font: 500 0.8125rem/1.4 var(--sans); color: var(--ink-soft); margin: 0;
}

.capable-grid li { border-bottom: 1px solid var(--rule); }
.capable-grid a {
  display: block; padding: 0.875rem 1rem; text-decoration: none; color: var(--ink);
  transition: background 0.15s;
}
.capable-grid a:hover { background: var(--paper); }
.capable-grid strong { font: 600 0.9375rem/1.25 var(--sans); display: block; letter-spacing: -0.005em; }
.capable-grid em {
  display: block; font: 500 0.8125rem/1.3 var(--sans);
  color: var(--ink-mute); margin: 3px 0;
}
.capable-subs {
  font: 500 0.75rem/1.2 var(--sans); text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--burgundy);
}

/* ── Facet index pages (/finding/<slug>) ─────────────────────────── */
.facet { padding: 2rem var(--pad-x); max-width: 90rem; margin: 0 auto; }
.facet__hero { margin: 1rem 0 2.5rem; border-bottom: 1px solid var(--rule); padding-bottom: 1.5rem; }
.facet__title {
  font: 500 clamp(2.5rem, 6vw, 4rem)/1 var(--serif);
  letter-spacing: -0.02em;
  margin: 0.75rem 0 1rem;
  color: var(--ink);
}
.facet__lede { font: 500 1.125rem/1.55 var(--sans); color: var(--ink-soft); max-width: 42rem; margin: 0; }
.facet__list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(20rem, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule);
}
.facet__item { border-bottom: 1px solid var(--rule); border-right: 1px solid var(--rule); }
.facet__item a {
  display: block; padding: 1.125rem 1.25rem;
  text-decoration: none; color: var(--ink);
  transition: background 0.15s;
}
.facet__item a:hover { background: var(--paper); }
.facet__item-head {
  display: flex; align-items: center; justify-content: space-between; gap: 0.75rem;
  margin-bottom: 0.375rem;
}
.facet__item-name { font: 600 0.9375rem/1.35 var(--sans); margin: 0; letter-spacing: -0.005em; }
.facet__item-meta {
  font: 500 0.8125rem/1.4 var(--sans); color: var(--ink-mute); margin: 0;
}
.facet__live {
  display: inline-flex; align-items: center; padding: 2px 8px;
  background: #c4302b; color: #fff; border-radius: 3px;
  font: 700 0.6875rem/1 var(--sans); letter-spacing: 0.14em;
}
.facet__empty { padding: 3rem 0; color: var(--ink-mute); }
.facet__note { font: italic 0.8125rem/1.4 var(--sans); color: var(--ink-mute); margin: 1.5rem 0 0; }

/* Sidebar: Sunday weather forecast. */
.parish__weather { margin-top: 1rem; }
.parish__weather-row {
  display: flex; align-items: center; gap: 0.625rem;
  padding: 0.5rem 0; border-bottom: 1px dashed var(--rule);
}
.parish__weather-row img {
  width: 48px; height: 48px; flex: 0 0 auto;
  border: 1px solid var(--rule); background: var(--paper);
}
.parish__weather-period {
  font: 500 0.8125rem/1.3 var(--sans); color: var(--ink-soft);
}
.parish__weather-temp {
  font: 600 1.125rem/1 var(--sans); color: var(--burgundy);
  font-variant-numeric: tabular-nums; margin-top: 2px;
}
.parish__weather-src {
  font: italic 0.75rem/1.3 var(--sans); color: var(--ink-mute);
  margin: 6px 0 0;
}

/* Sidebar: architecture & history card. */
.parish__arch { margin-top: 1rem; }
.parish__arch-src {
  font: italic 0.75rem/1.3 var(--sans); color: var(--ink-mute);
  margin: 8px 0 0;
}

/* Language chips in sidebar dl. */
.parish__lang {
  display: inline-block;
  padding: 2px 8px;
  margin: 0 4px 3px 0;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 3px;
  font: 500 0.75rem/1.2 var(--sans);
  color: var(--ink-soft);
}
