:root {
  --bg: #14100d;
  --bg-elev: #1b1410;
  --bg-card: #221812;
  --bg-card-hover: #2c1e17;
  --border: #3a2a20;
  --text: #efe3d2;
  --text-dim: #b7a58f;
  --accent: #d7a15a;
  --accent-dim: #8a6436;
  --kw: #8ec7ff;            /* keyword link hue (distinct from card refs) */
  --kw-bg: rgba(142,199,255,.12);
  --card-ref: #d7a15a;
  --card-ref-bg: rgba(215,161,90,.14);
  --card-ref-bg-strong: rgba(215,161,90,.22);
  --xref: #d7a15a;
  --focus: #f1c37e;
  --shadow: 0 1px 2px rgba(0,0,0,.3), 0 4px 12px rgba(0,0,0,.25);
  --font-serif: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, "Times New Roman", serif;
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

@media (prefers-color-scheme: light) {
  :root {
    --bg: #faf5ec;
    --bg-elev: #f2e8d5;
    --bg-card: #fffaf0;
    --bg-card-hover: #f8ecd4;
    --border: #d7c6a5;
    --text: #221812;
    --text-dim: #65513a;
    --accent: #8a5a1a;
    --accent-dim: #b38851;
    --kw: #1b63a8;
    --kw-bg: rgba(27,99,168,.1);
    --card-ref: #8a5a1a;
    --card-ref-bg: rgba(138,90,26,.14);
    --card-ref-bg-strong: rgba(138,90,26,.22);
    --xref: #8a5a1a;
    --focus: #8a5a1a;
    --shadow: 0 1px 2px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.08);
  }
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overscroll-behavior: none;
}

body {
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ---------- topbar ---------- */

.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: linear-gradient(180deg, var(--bg-elev), color-mix(in srgb, var(--bg-elev) 92%, transparent));
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--border);
  padding: .75rem 1rem .5rem;
}

.topbar__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  flex-wrap: wrap;
}

.topbar__title {
  margin: 0;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: .02em;
}
.topbar__title span {
  color: var(--accent);
  font-style: italic;
}

.topbar__actions {
  display: flex;
  gap: .4rem;
}

.btn {
  font: inherit;
  font-size: .85rem;
  color: var(--accent);
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: .4rem .75rem;
  border-radius: 999px;
  cursor: pointer;
  text-decoration: none;
  transition: background .12s, color .12s;
}
.btn:hover,
.btn:focus-visible { background: var(--bg-card-hover); outline: none; }
.btn[aria-pressed="true"] {
  background: var(--accent);
  color: var(--bg-elev);
  border-color: var(--accent);
}
.btn--link { color: var(--accent); }

.search {
  margin-top: .6rem;
  position: relative;
}
.search input {
  width: 100%;
  padding: .75rem 2.3rem .75rem 1rem;
  font-size: 1rem;
  color: var(--text);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--shadow);
  -webkit-appearance: none;
  appearance: none;
}
.search input:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: 2px;
  border-color: transparent;
}
.search button#clear {
  position: absolute;
  right: .45rem;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  color: var(--text-dim);
  border: 0;
  font-size: 1.5rem;
  line-height: 1;
  width: 2rem;
  height: 2rem;
  cursor: pointer;
  border-radius: 8px;
}
.search button#clear:hover { color: var(--text); background: var(--bg-card-hover); }

.az {
  margin-top: .5rem;
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
}
.az a {
  flex: 1 0 auto;
  text-align: center;
  min-width: 1.5rem;
  padding: .2rem .3rem;
  font-size: .78rem;
  font-weight: 600;
  color: var(--text-dim);
  text-decoration: none;
  border-radius: 6px;
}
.az a[aria-disabled="true"] { opacity: .3; pointer-events: none; }
.az a:hover,
.az a:focus-visible {
  color: var(--text);
  background: var(--bg-card-hover);
  outline: none;
}

.status {
  margin-top: .4rem;
  font-size: .8rem;
  color: var(--text-dim);
  min-height: 1.1em;
}

/* ---------- list ---------- */

.list {
  flex: 1;
  padding: .5rem .75rem 2rem;
  max-width: 900px;
  width: 100%;
  margin: 0 auto;
}

.entry {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  margin: .5rem 0;
  overflow: hidden;
  box-shadow: var(--shadow);
}
.entry[open] { background: var(--bg-card-hover); }

.entry > summary {
  list-style: none;
  cursor: pointer;
  padding: .75rem 1rem;
  font-family: var(--font-serif);
  font-size: 1.08rem;
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: baseline;
  gap: .6rem;
  position: relative;
}
.entry > summary::-webkit-details-marker { display: none; }
.entry > summary::after {
  content: "";
  margin-left: auto;
  width: .55em;
  height: .55em;
  border-right: 2px solid var(--text-dim);
  border-bottom: 2px solid var(--text-dim);
  transform: rotate(-45deg);
  transition: transform .15s;
  flex: 0 0 auto;
  align-self: center;
}
.entry[open] > summary::after { transform: rotate(45deg); }

.entry > summary:focus-visible {
  outline: 2px solid var(--focus);
  outline-offset: -2px;
}

.entry .letter {
  color: var(--accent);
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-family: var(--font-sans);
  font-weight: 700;
}

.entry__body {
  padding: 0 1rem 1rem;
  line-height: 1.55;
  color: var(--text);
  font-size: .97rem;
}

/* Portable-Text block elements */
.entry__body p {
  margin: .55rem 0;
}
.entry__body p:first-child { margin-top: 0; }
.entry__body p:last-child { margin-bottom: 0; }
.entry__body strong {
  color: var(--accent);
  font-weight: 700;
}
.entry__body ul,
.entry__body ol {
  margin: .35rem 0 .8rem;
  padding-left: 1.4rem;
}
.entry__body li {
  margin: .2rem 0;
}
.entry__body ul ul,
.entry__body ol ol,
.entry__body ul ol,
.entry__body ol ul {
  margin: .2rem 0;
}
.entry__body h4,
.entry__body h3 {
  margin: 1rem 0 .35rem;
  font-family: var(--font-serif);
  color: var(--accent);
  font-weight: 600;
  letter-spacing: .01em;
}
.entry__body h3 { font-size: 1rem; }
.entry__body h4 { font-size: .95rem; }

/* A paragraph tagged by the renderer as a "flavor quote" — i.e., a single
   italic span that stands alone — is treated like card token rules text.
   Tagging happens in app.js (isFlavorQuoteBlock) rather than via CSS child
   selectors, which can't tell "<p><em>x</em></p>" apart from
   "<p>text <em>x</em> text</p>". */
.entry__body p.flavor-quote {
  margin: .6rem 0;
  padding: .55rem .85rem;
  border-left: 3px solid var(--accent);
  background: var(--card-ref-bg);
  border-radius: 0 8px 8px 0;
  color: var(--text);
}
.entry__body p.flavor-quote > em {
  font-style: italic;
}

.entry__body blockquote {
  margin: .6rem 0;
  padding: .55rem .85rem;
  border-left: 3px solid var(--accent);
  background: var(--card-ref-bg);
  border-radius: 0 8px 8px 0;
  font-style: italic;
}

.entry__body .ext-link {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: color-mix(in srgb, var(--accent) 50%, transparent);
}
.entry__body .ext-link:hover { text-decoration-color: currentColor; }

/* Sub-codex block */
.entry__sub {
  margin-top: .9rem;
  padding: .7rem .85rem;
  background: color-mix(in srgb, var(--bg) 50%, transparent);
  border-left: 3px solid var(--accent-dim);
  border-radius: 0 8px 8px 0;
}
.entry__sub-label {
  display: block;
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--accent);
  margin: 0 0 .4rem;
  font-size: 1rem;
}

/* Damage / realm grids */
.damage-grid {
  display: grid;
  grid-template-columns: repeat(var(--cols, 3), minmax(1.8rem, 2.3rem));
  gap: 2px;
  margin: .7rem 0;
  width: fit-content;
  padding: 4px;
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.damage-grid__cell {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-card);
  border-radius: 3px;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: .85rem;
  color: var(--text-dim);
}
.damage-grid__cell--filled {
  background: var(--accent);
  color: #1b1410;
}

/* ---------- inline tokens ---------- */

/* Card reference */
.card-ref {
  color: var(--card-ref);
  background: var(--card-ref-bg);
  padding: 0 .3rem;
  border-radius: 4px;
  font-size: .96em;
  font-style: italic;
  font-weight: 600;
  white-space: nowrap;
  border-bottom: 1px solid transparent;
}
.card-ref.has-img {
  cursor: pointer;
  border-bottom-color: var(--card-ref);
}
.card-ref.has-img:hover,
.card-ref.has-img:focus-visible {
  background: var(--card-ref-bg-strong);
  outline: none;
}

/* Keyword auto-link (first occurrence only) */
.kw-link {
  color: var(--kw);
  background: var(--kw-bg);
  padding: 0 .25rem;
  border-radius: 4px;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px dotted currentColor;
}
.kw-link:hover,
.kw-link:focus-visible {
  background: color-mix(in srgb, var(--kw) 25%, transparent);
  outline: none;
}

/* Explicit ((cross reference)) (still used if that markup appears) */
.xref {
  color: var(--xref);
  text-decoration: none;
  border-bottom: 1px dotted currentColor;
}
.xref:hover,
.xref:focus-visible {
  background: var(--card-ref-bg);
  outline: none;
}

mark.hit {
  background: var(--accent);
  color: #1b1410;
  padding: 0 .1em;
  border-radius: 3px;
}

.entry.hidden { display: none; }
.entry.flash { animation: flash 1.2s ease; }
@keyframes flash {
  0% { box-shadow: 0 0 0 2px var(--accent), var(--shadow); }
  100% { box-shadow: 0 0 0 0 transparent, var(--shadow); }
}

.empty {
  text-align: center;
  color: var(--text-dim);
  padding: 3rem 1rem;
  font-style: italic;
}

/* ---------- footer ---------- */

.foot {
  border-top: 1px solid var(--border);
  padding: .6rem 1rem calc(.6rem + env(safe-area-inset-bottom));
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .6rem;
  font-size: .8rem;
  color: var(--text-dim);
  background: var(--bg-elev);
}
.foot span { flex: 1 1 auto; }

/* ---------- tooltip ---------- */

.tip {
  position: fixed;
  z-index: 100;
  pointer-events: none;
  background: #0e0907;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .35rem;
  box-shadow: 0 6px 24px rgba(0,0,0,.55);
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .12s, transform .12s;
  max-width: min(260px, 60vw);
}
.tip[data-visible="true"] {
  opacity: 1;
  transform: translateY(0);
}
.tip img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 6px;
}

/* Hide tooltips on touch devices (modal handles the UX). */
@media (hover: none) {
  .tip { display: none !important; }
}

/* ---------- keyword popover ---------- */

.pop {
  position: fixed;
  z-index: 90;               /* below card tooltip (100) + modal (200) */
  width: min(440px, calc(100vw - 24px));
  max-height: 62vh;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.55);
  display: none;
  flex-direction: column;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .12s, transform .12s;
}
.pop[data-visible="true"] {
  display: flex;
  opacity: 1;
  transform: translateY(0);
}

/* No popover on touch-only devices — clicking the link jumps directly. */
@media (hover: none) {
  .pop { display: none !important; }
}

.pop__head {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .55rem .75rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
  border-radius: 12px 12px 0 0;
}
.pop__head h3 {
  margin: 0;
  flex: 1 1 auto;
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .01em;
}
.pop__close {
  background: transparent;
  color: var(--text-dim);
  border: 0;
  font-size: 1.3rem;
  line-height: 1;
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 6px;
  cursor: pointer;
}
.pop__close:hover { color: var(--text); background: var(--bg-card-hover); }

.pop__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: .55rem .85rem .4rem;
  line-height: 1.52;
  color: var(--text);
  font-size: .93rem;
  scrollbar-color: var(--accent-dim) transparent;
  scrollbar-width: thin;
}

/* Reuse the same block styles we defined for entry bodies. */
.pop__body p { margin: .45rem 0; }
.pop__body p:first-child { margin-top: 0; }
.pop__body p:last-child { margin-bottom: 0; }
.pop__body strong { color: var(--accent); font-weight: 700; }
.pop__body ul, .pop__body ol { margin: .3rem 0 .55rem; padding-left: 1.2rem; }
.pop__body li { margin: .15rem 0; }
.pop__body h3, .pop__body h4 {
  margin: .7rem 0 .25rem;
  font-family: var(--font-serif);
  color: var(--accent);
  font-weight: 600;
}
.pop__body h3 { font-size: .95rem; }
.pop__body h4 { font-size: .9rem; }
.pop__body p.flavor-quote {
  margin: .4rem 0;
  padding: .45rem .7rem;
  border-left: 3px solid var(--accent);
  background: var(--card-ref-bg);
  border-radius: 0 6px 6px 0;
}
.pop__body p.flavor-quote > em { font-style: italic; }
.pop__body .entry__sub {
  margin-top: .6rem;
  padding: .5rem .65rem;
  background: color-mix(in srgb, var(--bg) 50%, transparent);
  border-left: 3px solid var(--accent-dim);
  border-radius: 0 6px 6px 0;
}
.pop__body .entry__sub-label {
  display: block;
  margin: 0 0 .3rem;
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--accent);
  font-size: .92rem;
}
.pop__body .damage-grid {
  grid-template-columns: repeat(var(--cols, 3), minmax(1.5rem, 1.9rem));
  margin: .45rem 0;
}
.pop__hint {
  margin-top: .5rem;
  padding-top: .4rem;
  border-top: 1px dashed var(--border);
  font-size: .8rem;
  color: var(--text-dim);
  font-style: italic;
}

.pop__foot {
  display: flex;
  justify-content: space-between;
  gap: .4rem;
  padding: .5rem .6rem;
  border-top: 1px solid var(--border);
  background: var(--bg-card);
  border-radius: 0 0 12px 12px;
}
.pop__btn {
  font: inherit;
  font-size: .82rem;
  color: var(--accent);
  background: transparent;
  border: 1px solid var(--border);
  padding: .35rem .7rem;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: none;
  transition: background .12s;
}
.pop__btn:hover, .pop__btn:focus-visible {
  background: var(--bg-card-hover);
  outline: none;
}
.pop__btn--primary {
  color: var(--bg-elev);
  background: var(--accent);
  border-color: var(--accent);
}
.pop__btn--primary:hover, .pop__btn--primary:focus-visible {
  background: var(--focus);
  border-color: var(--focus);
}

/* ---------- modal ---------- */

.modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.modal[data-open="true"] { display: flex; }

.modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .72);
  backdrop-filter: blur(4px);
}

.modal__panel {
  position: relative;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 16px;
  max-width: min(480px, 92vw);
  width: 100%;
  max-height: min(92vh, 820px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
}

.modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  padding: .7rem .9rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
}
.modal__head h2 {
  margin: 0;
  font-family: var(--font-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text);
}
.modal__close {
  background: transparent;
  border: 0;
  color: var(--text-dim);
  font-size: 1.6rem;
  line-height: 1;
  width: 2rem;
  height: 2rem;
  border-radius: 8px;
  cursor: pointer;
}
.modal__close:hover { background: var(--bg-card-hover); color: var(--text); }

.modal__body {
  position: relative;
  flex: 1;
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0e0907;
  min-height: 0;
}
.modal__body img {
  display: block;
  max-width: 100%;
  max-height: min(75vh, 700px);
  height: auto;
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.4);
}

.modal__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,.55);
  color: #fff;
  border: 1px solid rgba(255,255,255,.2);
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 999px;
  font-size: 1.4rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.modal__nav--prev { left: .6rem; }
.modal__nav--next { right: .6rem; }
.modal__nav:hover { background: rgba(0,0,0,.8); }
.modal__nav[disabled] { opacity: .25; cursor: not-allowed; }

.modal__foot {
  padding: .55rem .9rem;
  font-size: .8rem;
  color: var(--text-dim);
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
}

/* ---------- wider screens ---------- */

@media (min-width: 780px) {
  .topbar { padding: 1rem 1.5rem .75rem; }
  .topbar__title { font-size: 1.8rem; }
  .list { padding: 1rem 1.5rem 3rem; }
  .entry > summary { padding: .9rem 1.2rem; font-size: 1.15rem; }
  .entry__body { padding: 0 1.2rem 1.2rem; font-size: 1rem; }
  .tip { max-width: 320px; }
}
