@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --paper: #f2ebdc;
  --paper-dim: #e7dfca;
  --ink: #1a1410;
  --ink-soft: #3a2f24;
  --ink-muted: #6b5d4a;
  --ink-faint: #9c8e77;
  --rule: #c9bea3;
  --rule-soft: #dbd1b8;
  --accent: #8b1a1a;
  --accent-soft: #c2786b;
  --font-display: 'Cormorant Garamond', 'Palatino Linotype', Palatino, Georgia, serif;
  --font-serif: 'Cormorant Garamond', 'Iowan Old Style', 'Palatino Linotype', Palatino, Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-serif);
  font-size: 20px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern", "liga", "calt";
}

body {
  background: var(--paper);
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
p { margin: 0 0 1em; }

/* ============ NAV ============ */

.codex-nav {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 22px clamp(18px, 4vw, 36px);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  font-family: var(--font-sans);
  position: sticky;
  top: 0;
  z-index: 10;
}

.codex-nav-brand {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 20px;
  letter-spacing: 0.01em;
  color: var(--ink);
}

.codex-nav-links {
  display: flex;
  gap: 22px;
  align-items: baseline;
}

.codex-nav-links a {
  color: var(--ink-muted);
  font-size: 13px;
  letter-spacing: 0.02em;
  transition: color 140ms ease;
}

.codex-nav-links a:hover { color: var(--ink); }

.codex-nav-counter {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.06em;
}

/* ============ LAYOUT ============ */

.codex-wrap {
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(48px, 8vh, 80px) clamp(20px, 5vw, 32px) 120px;
}

.codex-page {
  max-width: 640px;
  margin: 0 auto;
  padding: clamp(48px, 8vh, 80px) clamp(20px, 5vw, 32px) 120px;
}

.codex-eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 0 0 36px;
}

.codex-hero-head {
  margin-bottom: 40px;
}

.codex-hero-head h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(30px, 3.8vw, 40px);
  line-height: 1.15;
  color: var(--ink);
  letter-spacing: 0;
}

.codex-hero-head .tagline {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--ink-muted);
  font-size: 16px;
  margin-top: 8px;
}

/* ============ CATALOGUE CARD ============ */

@import url('https://fonts.googleapis.com/css2?family=UnifrakturCook:wght@700&family=Special+Elite&family=Cormorant+Unicase:wght@400;500;600&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&display=swap');

.catalog-card {
  --card-paper: var(--paper);
  --card-ink: var(--ink-soft);
  --card-accent: var(--accent);
  --card-title-weight: 400;
  --card-remarks-weight: 500;
  --card-grain-intensity: 0;
  --card-foxing: 0;
  --card-vignette: 0;

  max-width: 62ch;
  margin: 0 auto;
  padding: clamp(28px, 4vw, 48px) clamp(20px, 3.6vw, 40px);
  background: var(--card-paper);
  color: var(--card-ink);
  position: relative;
  border-radius: 2px;
  transition: background 300ms ease, color 300ms ease;
}

/* vignette overlay — edge darkening */
.catalog-card::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background: radial-gradient(ellipse at 50% 50%, transparent 50%, rgba(20, 15, 10, calc(var(--card-vignette) * 0.8)) 100%);
  opacity: calc(var(--card-vignette) * 5);
  mix-blend-mode: multiply;
}

/* grain overlay */
.catalog-card[data-grain="paper"],
.catalog-card[data-grain="linen"],
.catalog-card[data-grain="canvas"] {
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.4)) 2px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.4)) 3px),
    repeating-linear-gradient(90deg, transparent, transparent 2px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.3)) 2px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.3)) 3px);
  background-size: 3px 3px, 3px 3px;
  background-blend-mode: multiply;
  background-color: var(--card-paper);
}

.catalog-card[data-grain="vellum"] {
  background:
    radial-gradient(ellipse at 30% 30%, rgba(230,200,140,calc(var(--card-grain-intensity) * 0.4)) 0%, transparent 40%),
    radial-gradient(ellipse at 70% 70%, rgba(180,150,100,calc(var(--card-grain-intensity) * 0.3)) 0%, transparent 50%),
    var(--card-paper);
}

.catalog-card[data-grain="parchment"] {
  background:
    radial-gradient(ellipse at 20% 20%, rgba(160,130,80,calc(var(--card-grain-intensity) * 0.3)) 0%, transparent 35%),
    radial-gradient(ellipse at 80% 60%, rgba(120,90,50,calc(var(--card-grain-intensity) * 0.3)) 0%, transparent 40%),
    var(--card-paper);
}

.catalog-card[data-grain="silk"] {
  background:
    repeating-linear-gradient(45deg, transparent, transparent 4px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.15)) 4px, rgba(0,0,0,calc(var(--card-grain-intensity) * 0.15)) 5px),
    var(--card-paper);
}

/* foxing — small age-spots */
.catalog-card::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background-image:
    radial-gradient(circle at 12% 24%, rgba(120,70,40,0.5) 0px, transparent 3px),
    radial-gradient(circle at 78% 18%, rgba(140,80,45,0.4) 0px, transparent 2px),
    radial-gradient(circle at 34% 67%, rgba(110,60,30,0.4) 0px, transparent 3px),
    radial-gradient(circle at 88% 82%, rgba(130,75,35,0.5) 0px, transparent 2px),
    radial-gradient(circle at 56% 38%, rgba(125,70,35,0.4) 0px, transparent 2px),
    radial-gradient(circle at 22% 88%, rgba(135,85,45,0.3) 0px, transparent 3px);
  opacity: calc(var(--card-foxing) * 2);
  mix-blend-mode: multiply;
}

/* borders */
.catalog-card[data-card-border="hairline"] {
  outline: 1px solid var(--card-ink);
  outline-offset: -12px;
}
.catalog-card[data-card-border="double-rule"] {
  outline: 1px solid var(--card-ink);
  outline-offset: -10px;
  box-shadow: inset 0 0 0 4px var(--card-paper), inset 0 0 0 5px var(--card-ink);
}
.catalog-card[data-card-border="dashed"] {
  outline: 1px dashed var(--card-ink);
  outline-offset: -12px;
}
.catalog-card[data-card-border="dotted"] {
  outline: 1px dotted var(--card-ink);
  outline-offset: -12px;
}
.catalog-card[data-card-border="ornate-corners"] {
  outline: none;
}
.catalog-card[data-card-border="ornate-corners"] .card-top::before,
.catalog-card[data-card-border="ornate-corners"] .card-top::after {
  content: '✦';
  color: var(--card-accent);
  font-size: 10px;
  position: absolute;
}
.catalog-card[data-card-border="ornate-corners"] .card-top::before { top: 8px; left: 8px; }
.catalog-card[data-card-border="ornate-corners"] .card-top::after { top: 8px; right: 8px; }

.card-top { position: relative; }

.card-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 18px;
}

.card-num {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--card-accent);
  letter-spacing: 0.08em;
}

.card-dots {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--card-accent);
  letter-spacing: 0.1em;
}

.card-item {
  font-family: var(--font-display);
  font-weight: var(--card-title-weight);
  font-style: italic;
  font-size: clamp(26px, 3vw, 34px);
  line-height: 1.22;
  color: var(--card-ink);
  margin: 0 0 32px;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
}

/* title display-font variants */
.catalog-card[data-display-font="didone"] .card-item {
  font-family: 'Playfair Display', 'Didot', 'Bodoni', Georgia, serif;
}
.catalog-card[data-display-font="blackletter"] .card-item {
  font-family: 'UnifrakturCook', 'Fraktur', serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(28px, 3.2vw, 38px);
}
.catalog-card[data-display-font="typewriter"] .card-item {
  font-family: 'Special Elite', 'Courier New', monospace;
  font-style: normal;
  font-weight: 400;
  font-size: clamp(22px, 2.6vw, 28px);
  letter-spacing: 0.01em;
}
.catalog-card[data-display-font="engraved"] .card-item {
  font-family: 'Cormorant Unicase', 'Cormorant Garamond', serif;
  font-style: normal;
  letter-spacing: 0.04em;
}
.catalog-card[data-display-font="uncial"] .card-item {
  font-family: 'Cormorant Garamond', serif;
  font-style: normal;
  letter-spacing: 0.02em;
}

/* title treatment */
.catalog-card[data-title-treatment="roman"] .card-item { font-style: normal; }
.catalog-card[data-title-treatment="smallcaps"] .card-item {
  font-style: normal;
  font-variant-caps: small-caps;
  letter-spacing: 0.06em;
}
.catalog-card[data-title-treatment="allcaps"] .card-item {
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: clamp(22px, 2.6vw, 28px);
}
.catalog-card[data-title-treatment="italic-smallcaps"] .card-item {
  font-variant-caps: small-caps;
  letter-spacing: 0.05em;
}

.card-meta {
  margin: 0 0 36px;
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 4px 18px;
  font-family: var(--font-serif);
  font-size: 15px;
  line-height: 1.5;
  color: var(--card-ink);
  padding-bottom: 18px;
  position: relative;
  z-index: 1;
}

.card-meta dt {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--card-accent);
  padding-top: 5px;
  opacity: 0.85;
}

.card-meta dd {
  margin: 0;
  font-style: italic;
  opacity: 0.88;
}

/* divider style */
.catalog-card[data-divider="solid-rule"] .card-meta { border-bottom: 1px solid color-mix(in srgb, var(--card-ink) 22%, transparent); }
.catalog-card[data-divider="dotted"] .card-meta { border-bottom: 1px dotted color-mix(in srgb, var(--card-ink) 35%, transparent); }
.catalog-card[data-divider="double-rule"] .card-meta {
  border-bottom: 3px double color-mix(in srgb, var(--card-ink) 28%, transparent);
  padding-bottom: 22px;
}
.catalog-card[data-divider="fleuron"] .card-meta {
  border-bottom: none;
  padding-bottom: 36px;
  position: relative;
}
.catalog-card[data-divider="fleuron"] .card-meta::after {
  content: '❦';
  position: absolute;
  left: 50%;
  bottom: 6px;
  transform: translateX(-50%);
  color: var(--card-accent);
  font-size: 16px;
}
.catalog-card[data-divider="asterism"] .card-meta {
  border-bottom: none;
  padding-bottom: 40px;
  position: relative;
}
.catalog-card[data-divider="asterism"] .card-meta::after {
  content: '✦  ✦  ✦';
  position: absolute;
  left: 50%;
  bottom: 6px;
  transform: translateX(-50%);
  color: var(--card-accent);
  font-size: 12px;
  letter-spacing: 0.3em;
}
.catalog-card[data-divider="none"] .card-meta { border-bottom: none; padding-bottom: 12px; }

.card-remarks-label {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--card-accent);
  margin-bottom: 14px;
  opacity: 0.85;
  position: relative;
  z-index: 1;
}

.card-remarks {
  font-family: var(--font-serif);
  font-weight: var(--card-remarks-weight);
  font-size: 19px;
  line-height: 1.7;
  color: var(--card-ink);
  position: relative;
  z-index: 1;
}

.card-remarks p { margin: 0 0 1em; }
.card-remarks p:last-child { margin-bottom: 0; }

/* drop cap */
.catalog-card[data-drop-cap="1"] .card-remarks p:first-child::first-letter {
  font-family: var(--font-display);
  font-size: 3.4em;
  float: left;
  line-height: 0.9;
  padding: 0.08em 0.08em 0 0;
  color: var(--card-accent);
  font-weight: 600;
  font-style: italic;
}

.catalog-card[data-display-font="blackletter"][data-drop-cap="1"] .card-remarks p:first-child::first-letter {
  font-family: 'UnifrakturCook', 'Fraktur', serif;
  font-style: normal;
}

/* footer ornament */
.card-footer-ornament {
  margin-top: 30px;
  text-align: center;
  color: var(--card-accent);
  font-family: var(--font-display);
  font-size: 16px;
  letter-spacing: 0.3em;
  opacity: 0.7;
}

/* margin marks */
.catalog-card[data-margin-marks="ditto-marks"]::before {
  background-image:
    radial-gradient(circle at 4% 30%, rgba(0,0,0,0.18) 0px, transparent 1px),
    radial-gradient(circle at 4% 40%, rgba(0,0,0,0.18) 0px, transparent 1px),
    radial-gradient(circle at 4% 60%, rgba(0,0,0,0.18) 0px, transparent 1px);
  opacity: 1;
}
.catalog-card[data-margin-marks="tick-marks"] { border-left: 1px solid color-mix(in srgb, var(--card-accent) 30%, transparent); }
.catalog-card[data-margin-marks="stamp-impression"] {
  background-image: radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--card-accent) 18%, transparent) 0px, color-mix(in srgb, var(--card-accent) 18%, transparent) 28px, transparent 30px);
}

.card-refs {
  margin-top: 44px;
  padding-top: 18px;
  border-top: 1px dotted color-mix(in srgb, var(--card-ink) 22%, transparent);
  font-family: var(--font-serif);
  font-size: 14px;
  font-style: italic;
  color: var(--card-ink);
  line-height: 1.8;
  opacity: 0.8;
  position: relative;
  z-index: 1;
}

.card-refs-label {
  font-style: normal;
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-right: 10px;
}

.ref-chip {
  display: inline;
  color: var(--ink-soft);
  border-bottom: 1px dashed var(--ink-faint);
  padding: 0;
  margin-right: 14px;
  transition: border-color 140ms ease, color 140ms ease;
}

.ref-chip:hover { color: var(--ink); border-bottom-color: var(--ink-soft); }

.ref-chip .n {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-faint);
  font-style: normal;
  margin-right: 4px;
}

.card-tags {
  margin-top: 26px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 14px;
}

.card-tags a {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--ink-faint);
  transition: color 140ms ease;
}

.card-tags a:hover { color: var(--ink); }

/* ============ PREV/NEXT ============ */

.prev-next {
  display: flex;
  gap: 18px;
  align-items: baseline;
  margin-top: 56px;
  padding-top: 22px;
  border-top: 1px solid var(--rule);
  font-family: var(--font-sans);
  font-size: 13px;
}

.prev-next a {
  color: var(--ink-muted);
  transition: color 140ms ease;
}

.prev-next a:hover { color: var(--ink); }
.prev-next .sep { color: var(--ink-faint); }

/* ============ WALL (recent list) ============ */

.wall {
  display: block;
  margin-top: 56px;
  border-top: 1px solid var(--rule);
}

.wall-card {
  display: block;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule-soft);
  color: inherit;
  transition: background 140ms ease;
}

.wall-card:hover { background: var(--paper-dim); margin-inline: -16px; padding-inline: 16px; }

.wall-card .n {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.wall-card .t {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 20px;
  line-height: 1.22;
  color: var(--ink);
}

.wall-card .meta {
  display: none;
}

/* ============ PAGES: about, subscribe, etc ============ */

.codex-page h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(32px, 4.2vw, 44px);
  line-height: 1.12;
  color: var(--ink);
  margin: 0 0 32px;
}

.codex-page h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 24px;
  color: var(--ink);
  margin: 48px 0 14px;
  letter-spacing: 0;
}

.codex-page h2::before {
  content: "✦ ";
  color: var(--accent);
  font-style: normal;
  font-size: 16px;
  vertical-align: 1px;
  margin-right: 4px;
}

.codex-page .ornament {
  text-align: center;
  color: var(--accent-soft);
  font-size: 18px;
  letter-spacing: 1em;
  margin: 2em 0 2em 1em;
  max-width: none;
}

.codex-page .signoff {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--ink-muted);
  font-size: 18px;
  text-align: center;
  margin-top: 1em;
}

.codex-page p {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.68;
  color: var(--ink-soft);
  max-width: 62ch;
  margin: 0 0 1em;
}

.codex-page a {
  color: var(--accent);
  border-bottom: 1px solid var(--rule);
  transition: border-color 140ms ease;
}

.codex-page a:hover { border-bottom-color: var(--accent); }

.codex-page .mono {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--ink-soft);
  background: var(--paper-dim);
  padding: 1px 6px;
  border-radius: 2px;
  border: none;
}

.codex-page pre {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.65;
  background: var(--paper-dim);
  padding: 18px 20px;
  border-radius: 3px;
  overflow-x: auto;
  color: var(--ink-soft);
  margin: 1em 0;
}

.codex-page pre.mono { background: var(--paper-dim); }

/* ============ ATLAS / TAGS / SHOP ============ */

.cluster-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0;
  margin-top: 28px;
  border-top: 1px solid var(--rule);
}

.cluster-card {
  padding: 18px 16px;
  border-bottom: 1px solid var(--rule-soft);
  border-right: 1px solid var(--rule-soft);
  color: inherit;
  transition: background 140ms ease;
}

.cluster-card:hover { background: var(--paper-dim); }

.cluster-card .name {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 20px;
  color: var(--ink);
  margin-bottom: 4px;
}

.cluster-card .count {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}

.tag-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
  margin-top: 28px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  line-height: 1.8;
}

.tag-grid a {
  color: var(--ink-muted);
  border-bottom: none;
  transition: color 140ms ease;
}

.tag-grid a:hover { color: var(--ink); }
.tag-grid .size {
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 11px;
  color: var(--ink-faint);
  margin-left: 3px;
}

.shop-grid {
  display: block;
  margin-top: 28px;
  border-top: 1px solid var(--rule);
}

.shop-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule-soft);
}

.shop-card .kind {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

.shop-card .name {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
}

.shop-card .desc {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-muted);
}

.shop-card .buy {
  align-self: flex-start;
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 6px;
  padding: 0;
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: 14px;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 2px;
  transition: border-color 140ms ease;
}

.shop-card .buy:hover { border-bottom-color: var(--accent); }
.shop-card .price { font-family: var(--font-mono); color: var(--ink-muted); }

/* ============ NEWSLETTER ============ */

.newsletter {
  margin-top: 48px;
  padding: 28px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  max-width: 62ch;
}

.newsletter h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  margin: 0 0 8px;
}

.newsletter p {
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0 0 16px;
}

.newsletter form {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.newsletter input[type=email] {
  flex: 1;
  padding: 10px 14px;
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 2px;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 14px;
}

.newsletter input[type=email]:focus {
  outline: none;
  border-color: var(--ink-muted);
}

.newsletter button {
  padding: 10px 18px;
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
  border-radius: 2px;
  font-family: var(--font-sans);
  font-size: 14px;
  cursor: pointer;
  transition: background 140ms ease;
}

.newsletter button:hover { background: var(--ink-soft); }

/* ============ ENTRY ANIMATIONS (ornament + number chip only, never body text) ============ */

@keyframes card-flicker {
  0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% { opacity: 1; }
  20%, 22%, 24%, 55% { opacity: 0.55; }
}
@keyframes card-drift {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(6px); }
}
@keyframes card-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}
@keyframes card-tremor {
  0%, 100% { transform: translate(0, 0); }
  25% { transform: translate(0.5px, -0.5px); }
  50% { transform: translate(-0.5px, 0.5px); }
  75% { transform: translate(0.5px, 0.5px); }
}
@keyframes card-breathe {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}
@keyframes card-slow-glow {
  0%, 100% { filter: brightness(1); }
  50% { filter: brightness(1.3); }
}

.catalog-card[data-anim-speed="slow"] { --anim-duration: 10s; }
.catalog-card[data-anim-speed="medium"] { --anim-duration: 5s; }
.catalog-card[data-anim-speed="fast"] { --anim-duration: 2s; }

/* Target: ornament */
.catalog-card[data-anim-target="ornament"][data-animation="flicker"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="flicker"] .card-dots { animation: card-flicker var(--anim-duration, 8s) infinite; }
.catalog-card[data-anim-target="ornament"][data-animation="drift"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="drift"] .card-dots { animation: card-drift var(--anim-duration, 8s) ease-in-out infinite; }
.catalog-card[data-anim-target="ornament"][data-animation="pulse"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="pulse"] .card-dots { animation: card-pulse var(--anim-duration, 8s) ease-in-out infinite; }
.catalog-card[data-anim-target="ornament"][data-animation="tremor"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="tremor"] .card-dots { animation: card-tremor calc(var(--anim-duration, 8s) * 0.3) infinite; }
.catalog-card[data-anim-target="ornament"][data-animation="breathe"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="breathe"] .card-dots { animation: card-breathe var(--anim-duration, 8s) ease-in-out infinite; display: inline-block; }
.catalog-card[data-anim-target="ornament"][data-animation="slow-glow"] .card-dots,
.catalog-card[data-anim-target="both"][data-animation="slow-glow"] .card-dots { animation: card-slow-glow var(--anim-duration, 8s) ease-in-out infinite; }

/* Target: number */
.catalog-card[data-anim-target="number"][data-animation="flicker"] .card-num,
.catalog-card[data-anim-target="both"][data-animation="flicker"] .card-num { animation: card-flicker var(--anim-duration, 8s) infinite; }
.catalog-card[data-anim-target="number"][data-animation="pulse"] .card-num,
.catalog-card[data-anim-target="both"][data-animation="pulse"] .card-num { animation: card-pulse var(--anim-duration, 8s) ease-in-out infinite; }
.catalog-card[data-anim-target="number"][data-animation="slow-glow"] .card-num,
.catalog-card[data-anim-target="both"][data-animation="slow-glow"] .card-num { animation: card-slow-glow var(--anim-duration, 8s) ease-in-out infinite; }
.catalog-card[data-anim-target="number"][data-animation="tremor"] .card-num,
.catalog-card[data-anim-target="both"][data-animation="tremor"] .card-num { animation: card-tremor calc(var(--anim-duration, 8s) * 0.3) infinite; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .catalog-card .card-dots,
  .catalog-card .card-num { animation: none !important; }
}

/* ============ CATALOG VOICE (margin line, speaks to you) ============ */

.catalog-voice {
  margin: 48px 0 0;
  padding: 18px 20px;
  border-top: 1px dotted var(--rule);
  border-bottom: 1px dotted var(--rule);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 17px;
  line-height: 1.55;
  color: var(--accent);
  background: transparent;
  max-width: 62ch;
  text-align: center;
}

/* ============ CATALOG MOOD (tiny line above hero) ============ */

.catalog-mood {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 13px;
  color: var(--ink-muted);
  text-align: center;
  margin-bottom: 16px;
  letter-spacing: 0.01em;
}

/* ============ CATALOG GUESS ============ */

.catalog-guess {
  margin-bottom: 24px;
  padding: 10px 14px;
  border: 1px dashed var(--rule);
  border-radius: 2px;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink-muted);
  max-width: 62ch;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.catalog-guess .guess-text em {
  font-family: var(--font-display);
  font-size: 15px;
  font-style: italic;
  color: var(--ink);
}

.catalog-guess .guess-btn {
  font-family: var(--font-sans);
  font-size: 12px;
  padding: 4px 10px;
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 2px;
  color: var(--ink-muted);
  cursor: pointer;
  transition: border-color 140ms, color 140ms;
}
.catalog-guess .guess-btn:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.catalog-guess .guess-ack {
  font-style: italic;
  color: var(--accent);
  font-family: var(--font-display);
  font-size: 15px;
}

/* ============ ON THIS DAY ============ */

.on-this-day {
  margin: 40px 0;
  padding: 14px 0;
  border-top: 1px solid var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
  font-family: var(--font-serif);
  font-size: 15px;
  color: var(--ink-muted);
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}

.on-this-day .eyebrow {
  font-family: var(--font-sans);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ink-faint);
}

.on-this-day a {
  color: var(--ink);
  border-bottom: none;
}
.on-this-day a em {
  font-family: var(--font-display);
  font-style: italic;
}
.on-this-day a:hover em { color: var(--accent); }

/* ============ WALL — LIT ENTRY ============ */

.wall-card-lit {
  background: linear-gradient(90deg, rgba(139, 26, 26, 0.04) 0%, transparent 100%);
  position: relative;
}

.wall-card-lit::before {
  content: "✦";
  position: absolute;
  left: -16px;
  top: 18px;
  color: var(--accent);
  font-size: 11px;
}

.wall-card-lit .n {
  color: var(--accent);
}

/* ============ PERSONAL STATS (for /you) ============ */

.personal-stats {
  margin-top: 28px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-muted);
  line-height: 1.9;
  max-width: 62ch;
}

.personal-stats > div {
  border-bottom: 1px dotted var(--rule-soft);
  padding: 4px 0;
}

.personal-stats .mono {
  color: var(--ink);
  background: transparent;
  padding: 0;
  border: none;
}

.personal-stats .personal-id {
  margin-top: 14px;
  border-bottom: none;
  color: var(--ink-faint);
  font-size: 11px;
  letter-spacing: 0.08em;
}

/* ============ AD SLOT ============ */

.ad-slot {
  margin: 44px auto;
  padding: 14px;
  border-top: 1px solid var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
  color: var(--ink-faint);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align: center;
}

/* ============ FLOATING RANDOM — removed. Random lives in nav. ============ */

.fab-random {
  display: none;
}

/* ============ FOOTER ============ */

footer {
  border-top: 1px solid var(--rule) !important;
  background: var(--paper) !important;
  color: var(--ink-muted) !important;
  padding: 42px clamp(20px, 4vw, 32px) !important;
  margin-top: 80px !important;
  font-family: var(--font-sans) !important;
  font-size: 12px !important;
  text-align: center !important;
}

footer a { color: var(--ink-muted) !important; border: none !important; }
footer a:hover { color: var(--ink) !important; }

/* ============ RESPONSIVE ============ */

@media (max-width: 640px) {
  html { font-size: 17px; }
  .codex-nav { padding: 16px 18px; }
  .codex-nav-links { gap: 14px; }
  .codex-nav-links a { font-size: 12px; }
  .codex-wrap, .codex-page { padding: 40px 20px 100px; }
  .pool-title, .codex-page h1, .codex-hero-head h1 { font-size: 24px; }
}
