/* ── Section kicker ────────────────────────────────────── */
.section-kicker {
  margin-bottom: 0.65rem;
  display: inline-flex;
  align-items: center;
  gap: 0.55em;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  font-weight: 800;
  color: color-mix(in srgb, var(--jrm-color-primary-strong) 88%, #6b4d00 12%);
}

.section-kicker--hero {
  color: color-mix(in srgb, var(--jrm-color-primary) 90%, #fff 10%);
}

/* Decorative leading rule on light bg */
.section-kicker::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 2px;
  background: currentColor;
  border-radius: 1px;
  flex-shrink: 0;
}

/* No decorative rule on hero kickers — they have enough visual weight */
.section-kicker--hero::before {
  display: none;
}

/* ── Section title ─────────────────────────────────────── */
.section-title {
  margin-bottom: 1.35rem;
  font-size: clamp(1.9rem, 3.4vw, 2.6rem);
}

/* ── Context header ────────────────────────────────────── */
.page-header,
.jrm-context-header {
  margin-bottom: clamp(1.1rem, 2.6vw, 1.8rem);
}

.jrm-context-header {
  display: grid;
  gap: var(--jrm-space-1);
  max-width: 72ch;
}

.jrm-context-header p:last-child,
.jrm-context-header h1:last-child,
.jrm-context-header h2:last-child {
  margin-bottom: 0;
}

.archive-description {
  color: var(--jrm-color-muted);
}

/* ── Lists ─────────────────────────────────────────────── */
.jrm-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.6rem;
}

.jrm-list--meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.jrm-list--meta > li {
  margin: 0;
  font-size: 0.82rem;
  border-radius: var(--jrm-radius-pill);
  padding: 0.26rem 0.6rem;
  border: 1px solid var(--jrm-color-border-strong);
  color: var(--jrm-color-muted);
  background: color-mix(in srgb, var(--jrm-color-surface-alt) 64%, #fff 36%);
}

.jrm-list--lined > li {
  padding: 0.55rem 0.1rem;
  border-bottom: 1px solid var(--jrm-color-border);
}

.jrm-list--lined > li:last-child {
  border-bottom: 0;
}

.jrm-list--bullet > li {
  position: relative;
  padding-left: 1rem;
  color: var(--jrm-color-muted);
}

.jrm-list--bullet > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62rem;
  width: 6px;
  height: 6px;
  border-radius: var(--jrm-radius-pill);
  background: var(--jrm-color-primary-strong);
}

/* ── Card base ─────────────────────────────────────────── */
.jrm-card,
.jrm-page-card,
.jrm-feature-item,
.jrm-hub-card,
.jrm-single,
.post-card,
.post-single,
.page-content,
.empty-state-card,
.jrm-form-shell {
  background: var(--jrm-color-surface-elevated);
  border: 1px solid var(--jrm-color-border);
  border-radius: var(--jrm-radius-card);
  box-shadow: var(--jrm-shadow-card);
  padding: clamp(1rem, 2.5vw, 1.5rem);
}

.jrm-standard-card {
  background: var(--jrm-color-surface-elevated);
  border: 1px solid var(--jrm-color-border);
  border-radius: var(--jrm-radius-card);
  box-shadow: var(--jrm-shadow-card);
  padding: 0;
  overflow: hidden;
}

/* ── Card interactions ─────────────────────────────────── */
.jrm-card--interactive,
.jrm-standard-card,
.jrm-hub-card,
.jrm-feature-item,
.jrm-list-card {
  transition:
    transform var(--jrm-transition-base),
    box-shadow var(--jrm-transition-base),
    border-color var(--jrm-transition-base);
}

.jrm-card--interactive:hover,
.jrm-card--interactive:focus-within,
.jrm-standard-card:hover,
.jrm-standard-card:focus-within,
.jrm-hub-card:hover,
.jrm-hub-card:focus-within,
.jrm-feature-item:hover,
.jrm-feature-item:focus-within,
.jrm-list-card:hover,
.jrm-list-card:focus-within {
  transform: translateY(-3px);
  box-shadow: var(--jrm-shadow-card-hover);
  border-color: color-mix(in srgb, var(--jrm-color-primary-strong) 38%, #fff 62%);
}

/* ── Card media ────────────────────────────────────────── */
.jrm-card__media,
.jrm-standard-card__media {
  display: block;
  aspect-ratio: 16 / 10;
  background: linear-gradient(130deg, #ecebe6, #dae1eb);
  overflow: hidden;
  position: relative;
  /* border-radius intentionally omitted — parent overflow:hidden handles clipping */
}

.jrm-card__media img,
.jrm-standard-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jrm-card__placeholder,
.jrm-standard-card__placeholder {
  display: block;
  width: 100%;
  height: 100%;
  background:
    linear-gradient(120deg, rgba(244, 197, 66, 0.24), rgba(14, 42, 71, 0.22)),
    radial-gradient(circle at 70% 20%, rgba(255, 255, 255, 0.6), transparent 32%);
}

/* ── Card badge ────────────────────────────────────────── */
.jrm-card__badge,
.jrm-standard-card__badge {
  position: absolute;
  left: 0.62rem;
  top: 0.62rem;
  z-index: 2;
  font-size: 0.74rem;
  font-weight: 700;
  padding: 0.32rem 0.55rem;
  border-radius: var(--jrm-radius-pill);
  color: #fff;
  background: rgba(10, 23, 40, 0.82);
  backdrop-filter: blur(4px);
}

/* ── Card body ─────────────────────────────────────────── */
.jrm-card__body,
.jrm-standard-card__body {
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex: 1;
}

.jrm-card__title,
.jrm-standard-card__title {
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.15;
  font-weight: 700;
}

.jrm-card__title a,
.jrm-standard-card__title a {
  text-decoration: none;
}

.jrm-card__meta,
.jrm-card__date,
.jrm-standard-card__meta,
.jrm-standard-card__date,
.post-card__meta,
.post-single__meta {
  margin: 0;
  font-size: 0.82rem;
  color: var(--jrm-color-muted-light);
}

.jrm-card__date,
.jrm-standard-card__date {
  color: color-mix(in srgb, var(--jrm-color-primary-strong) 88%, #0d1c2f 12%);
  font-weight: 700;
}

.jrm-card__text,
.jrm-standard-card__text {
  margin: 0;
  color: var(--jrm-color-muted);
}

/* ── Card actions ──────────────────────────────────────── */
.jrm-action-row,
.jrm-card__actions,
.jrm-standard-card__actions,
.jrm-single__actions {
  margin-top: auto;
  padding-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

/* ── Post cards ────────────────────────────────────────── */
.post-card h2,
.post-single h1,
.page-content h1 {
  margin-top: 0.1rem;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
}

.jrm-single__title {
  margin-bottom: 0.5rem;
}

/* ── Meta pills ────────────────────────────────────────── */
.jrm-meta-list,
.jrm-single__meta-list {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.jrm-meta-list > li,
.jrm-single__meta-list li {
  margin: 0;
  font-size: 0.82rem;
  border-radius: var(--jrm-radius-pill);
  padding: 0.26rem 0.6rem;
  border: 1px solid var(--jrm-color-border-strong);
  color: var(--jrm-color-muted);
  background: color-mix(in srgb, var(--jrm-color-surface-alt) 64%, #fff 36%);
}

.jrm-single__summary {
  color: var(--jrm-color-muted-dark);
  font-size: 1rem;
  margin-bottom: 1rem;
}

.entry-content > * + * {
  margin-top: 0.95rem;
}

.entry-content > :last-child {
  margin-bottom: 0;
}

.entry-media {
  margin-bottom: 1.2rem;
  border-radius: var(--jrm-radius-card);
  overflow: hidden;
}

/* ── Pagination ────────────────────────────────────────── */
.jrm-pagination {
  margin-top: 1.45rem;
}

.jrm-pagination .nav-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.jrm-pagination .page-numbers {
  min-width: 40px;
  min-height: 40px;
  border-radius: var(--jrm-radius-sm);
  border: 1px solid var(--jrm-color-border-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.66rem;
  text-decoration: none;
  font-weight: 700;
  font-size: 0.86rem;
  transition: background var(--jrm-transition-base), border-color var(--jrm-transition-base);
}

.jrm-pagination .page-numbers:hover {
  border-color: color-mix(in srgb, var(--jrm-color-primary-strong) 42%, #fff 58%);
  background: color-mix(in srgb, var(--jrm-color-primary) 12%, #fff 88%);
}

.jrm-pagination .page-numbers.current {
  color: #111;
  border-color: color-mix(in srgb, var(--jrm-color-primary-strong) 42%, #fff 58%);
  background: color-mix(in srgb, var(--jrm-color-primary) 90%, #fff 10%);
}

/* ── Back link ─────────────────────────────────────────── */
.jrm-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.85rem;
  font-size: 0.82rem;
  font-weight: 700;
  text-decoration: none;
  color: color-mix(in srgb, var(--jrm-color-secondary) 82%, #111 18%);
  transition: gap var(--jrm-transition-base);
}

.jrm-back-link::before {
  content: "\2190";
  font-size: 0.9rem;
}

.jrm-back-link:hover {
  gap: 0.2rem;
}

/* ── Buttons ───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-height: 44px;
  border: 0;
  border-radius: var(--jrm-radius-button);
  padding: 0.74rem 1.22rem;
  font-family: var(--jrm-font-heading);
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition:
    transform var(--jrm-transition-base),
    box-shadow var(--jrm-transition-base),
    background-color var(--jrm-transition-base);
}

.btn:hover,
.btn:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(10, 21, 35, 0.18);
}

.btn--sm {
  min-height: 38px;
  font-size: 0.78rem;
  padding: 0.58rem 0.95rem;
}

/* Primary — gold with shimmer sweep */
.btn--primary {
  background: var(--jrm-color-primary);
  color: #111;
}

.btn--primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    transparent 30%,
    rgba(255, 255, 255, 0.38) 50%,
    transparent 70%
  );
  transform: translateX(-110%);
  transition: transform 0.52s ease;
}

.btn--primary:hover::after,
.btn--primary:focus-visible::after {
  transform: translateX(110%);
}

.btn--primary:hover,
.btn--primary:focus-visible {
  box-shadow: var(--jrm-shadow-glow-strong);
}

/* Dark */
.btn--dark {
  background: var(--jrm-color-secondary);
  color: #fff;
}

.btn--dark:hover,
.btn--dark:focus-visible {
  background: color-mix(in srgb, var(--jrm-color-secondary) 86%, #fff 14%);
}

/* Outline */
.btn--outline {
  border: 1px solid color-mix(in srgb, var(--jrm-color-secondary) 25%, #fff 75%);
  color: var(--jrm-color-secondary);
  background: var(--jrm-color-surface);
  transition:
    transform var(--jrm-transition-base),
    box-shadow var(--jrm-transition-base),
    border-color var(--jrm-transition-base),
    background var(--jrm-transition-base);
}

.btn--outline:hover,
.btn--outline:focus-visible {
  border-color: color-mix(in srgb, var(--jrm-color-secondary) 50%, #fff 50%);
  background: color-mix(in srgb, var(--jrm-color-secondary) 4%, #fff 96%);
}

/* Ghost (on dark backgrounds) */
.btn--ghost {
  border: 1px solid rgba(255, 255, 255, 0.38);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  transition:
    transform var(--jrm-transition-base),
    box-shadow var(--jrm-transition-base),
    background var(--jrm-transition-base),
    border-color var(--jrm-transition-base);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.6);
}

.btn--full {
  width: 100%;
  justify-content: center;
}

/* ── Donate cards ──────────────────────────────────────── */
.jrm-donate-cards {
  margin: 2rem 0;
}

.jrm-donate-cards__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.jrm-donate-card {
  background: var(--jrm-color-surface-alt);
  border-radius: var(--jrm-radius-card);
  padding: 1.2rem;
}

.jrm-bank-transfer {
  margin-top: 1rem;
  background: var(--jrm-color-surface);
  border: 1px solid var(--jrm-color-border);
  border-radius: var(--jrm-radius-card);
  padding: 1rem;
}

/* ── List grid / list card ─────────────────────────────── */
.jrm-list-grid {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.jrm-list-card {
  padding: 0.9rem 1rem;
  border-radius: var(--jrm-radius-card);
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--jrm-color-secondary) 9%, #fff 91%);
}

.jrm-list-card__meta {
  margin-bottom: 0;
  font-size: 0.82rem;
  color: var(--jrm-color-muted-light);
}

/* ── Report list ───────────────────────────────────────── */
.jrm-report-list {
  padding: 0;
  list-style: none;
  margin: 1rem 0;
  display: grid;
  gap: 0.7rem;
}

.jrm-report-list li a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.5rem 0.75rem;
  border-radius: var(--jrm-radius-button);
  border: 1px solid var(--jrm-color-border);
  text-decoration: none;
  transition: border-color var(--jrm-transition-base), background var(--jrm-transition-base);
}

.jrm-report-list li a:hover {
  border-color: color-mix(in srgb, var(--jrm-color-primary-strong) 35%, #fff 65%);
  background: color-mix(in srgb, var(--jrm-color-primary) 6%, #fff 94%);
}

/* ── Sermon player ─────────────────────────────────────── */
.sermon-single .sermon-meta {
  display: grid;
  gap: 0.42rem;
  padding: 0;
  margin: 0 0 1rem;
  list-style: none;
}

.sermon-player {
  margin-bottom: 1rem;
}

.sermon-description {
  font-size: 1.01rem;
  font-weight: 500;
  margin-bottom: 1rem;
  color: var(--jrm-color-muted-dark);
}

/* ── Responsive ────────────────────────────────────────── */
@media (max-width: 980px) {
  .jrm-donate-cards__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .jrm-meta-list,
  .jrm-single__meta-list {
    flex-direction: column;
    align-items: flex-start;
  }

  .jrm-action-row,
  .jrm-card__actions,
  .jrm-standard-card__actions,
  .jrm-single__actions {
    display: grid;
    gap: 0.55rem;
  }

  .jrm-action-row .btn,
  .jrm-card__actions .btn,
  .jrm-standard-card__actions .btn,
  .jrm-single__actions .btn {
    width: 100%;
  }

  .jrm-donate-cards__grid {
    grid-template-columns: 1fr;
  }
}
