/* CHAPTERS, whisper, footer, toast. Split from styles.css. */

.chapter {
  margin: 80px auto 0;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 900ms cubic-bezier(0.2, 0.7, 0.2, 1), transform 900ms cubic-bezier(0.2, 0.7, 0.2, 1);
}
.chapter.is-in {
  opacity: 1;
  transform: translateY(0);
}

.chapter-head {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 28px;
  padding: 0 4px;
}
.chapter-num {
  font-family: 'Cinzel', serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--accent-warm);
  letter-spacing: 0.12em;
  min-width: 18px;
  text-align: center;
}
.chapter-title {
  font-family: 'Cinzel', serif;
  font-weight: 400;
  font-size: clamp(28px, 5vw, 42px);
  letter-spacing: 0.18em;
  color: var(--text);
  text-transform: lowercase;
  line-height: 1;
}
.chapter-kicker {
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--text-faint);
  text-transform: lowercase;
  font-style: italic;
  margin-left: 2px;
}

/* ───── card title badges (SOON / access) ──────────────── */
.badge-soon {
  display: inline-block;
  margin-left: 10px;
  padding: 2px 7px;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 0.28em;
  text-indent: 0.28em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--bg-deep);
  background: var(--accent-warm);
  border-radius: 3px;
  vertical-align: 2px;
}
.badge-access {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 7px;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 0.24em;
  text-indent: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  color: rgba(220, 232, 245, 0.92);
  background: rgba(95, 180, 196, 0.20);
  border: 1px solid rgba(95, 180, 196, 0.55);
  border-radius: 3px;
  vertical-align: 2px;
}

/* ───── soon-toast (coming cards) ──────────────────────── */
.soon-toast {
  position: fixed;
  transform: translate(-50%, -100%);
  background: rgba(8, 12, 18, 0.94);
  border: 1px solid var(--accent-warm);
  color: var(--accent-warm);
  padding: 6px 14px;
  font-family: 'Cinzel', serif;
  font-size: 11px;
  letter-spacing: 0.32em;
  text-indent: 0.32em;
  text-transform: lowercase;
  border-radius: 4px;
  z-index: 100;
  pointer-events: none;
  box-shadow: 0 10px 28px rgba(0,0,0,0.55), 0 0 16px rgba(196, 69, 54, 0.35);
  animation: soon-pop 1.7s ease-out forwards;
}
@keyframes soon-pop {
  0%   { opacity: 0; transform: translate(-50%, -90%); }
  18%  { opacity: 1; transform: translate(-50%, -120%); }
  82%  { opacity: 1; transform: translate(-50%, -120%); }
  100% { opacity: 0; transform: translate(-50%, -140%); }
}

/* ───── WHISPER (family note) ──────────────────────────── */
.whisper {
  max-width: 460px;
  margin: 100px auto 0;
  text-align: center;
  font-family: 'Cinzel', serif;
  font-size: 12px;
  letter-spacing: 0.22em;
  line-height: 2.2;
  color: var(--text-faint);
  font-style: italic;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 900ms ease, transform 900ms ease;
}
.whisper.is-in { opacity: 0.82; transform: translateY(0); }
.whisper span { display: block; }

/* ───── FOOTER ─────────────────────────────────────────── */
footer {
  margin-top: 80px;
  padding-bottom: 48px;
  text-align: center;
  font-family: 'Cinzel', serif;
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: 0.42em;
  text-indent: 0.42em;
}
footer .year::before { content: '·'; margin-right: 14px; color: var(--accent-warm); }
footer .year::after  { content: '·'; margin-left:  14px; color: var(--accent-warm); }

/* ───── SMALL SCREEN POLISH ────────────────────────────── */
@media (max-width: 540px) {
  .chapter { margin-top: 56px; }
  .chapter-head { margin-bottom: 20px; gap: 10px; flex-wrap: wrap; }
  .chapter-kicker { width: 100%; margin-left: 32px; }
}
