/* Bible Comics — mobile-first stylesheet
   Palette mirrors the parable comics' "paper + amber + deep umber" world. */

:root {
  --paper:        #f0e8db;
  --paper-warm:   #e6d8b8;
  --ink:          #2a221c;
  --ink-soft:     #5a4a3a;
  --amber:        #66401c;
  --amber-bright: #a85820;
  --rule:         rgba(58, 32, 18, 0.15);

  --serif: ui-serif, Georgia, "Iowan Old Style", "Apple Garamond", "Palatino Linotype", Cambria, serif;
  --serif-zh: "Noto Serif SC", "Source Han Serif SC", "PingFang SC", "Songti SC", "SimSun", var(--serif);
  --sans:  -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --sans-zh: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", var(--sans);

  --max-w: 720px;
  --pad:   1rem;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

html[data-lang="zh"] body { font-family: var(--sans-zh); }
html[data-lang="zh"] h1, html[data-lang="zh"] h2, html[data-lang="zh"] h3 { font-family: var(--serif-zh); }

html[data-lang="zh"] [data-lang="en"] { display: none; }
html:not([data-lang="zh"]) [data-lang="zh"] { display: none; }

img { max-width: 100%; height: auto; display: block; }

a { color: var(--amber); text-decoration: none; }
a:hover { color: var(--amber-bright); text-decoration: underline; text-underline-offset: 3px; }

h1, h2, h3 { font-family: var(--serif); color: var(--ink); margin: 0 0 .5em; }

h1 { font-size: 2rem; line-height: 1.15; letter-spacing: -0.01em; }
h2 { font-size: 1.4rem; }
h3 { font-size: 1.15rem; }

p { margin: 0 0 1em; }
.lede { font-size: 1.1rem; color: var(--ink-soft); }

main { max-width: var(--max-w); margin: 0 auto; padding: var(--pad); }

/* ---- Header ---- */
.site-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .6rem;
  padding: .8rem var(--pad);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  position: sticky; top: 0; z-index: 10;
}
.brand {
  font-family: var(--serif);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
html[data-lang="zh"] .brand { font-family: var(--serif-zh); }
.brand span { color: var(--amber); }
.search { flex: 1; min-width: 0; }
.search input {
  font: inherit;
  padding: .35rem .7rem;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  border-radius: 999px;
  color: var(--ink);
  width: 100%;
  max-width: 12rem;
  transition: max-width .2s;
}
.search input:focus { outline: none; max-width: 16rem; border-color: var(--amber); }

.lang-toggle {
  font: inherit;
  font-size: .85rem;
  padding: .3rem .6rem;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  border-radius: 999px;
  color: var(--ink);
  cursor: pointer;
  white-space: nowrap;
  transition: border-color .15s, background .15s;
}
.lang-toggle:hover { border-color: var(--amber); color: var(--amber); }
.lang-toggle b { color: var(--amber); font-weight: 700; }

/* ---- Footer ---- */
.site-footer {
  margin: 3rem auto 1.5rem;
  padding: 1rem var(--pad);
  text-align: center;
  font-size: .9rem;
  color: var(--ink-soft);
  border-top: 1px solid var(--rule);
  max-width: var(--max-w);
}
.site-footer span { margin: 0 .4rem; }

/* ---- Hero / homepage ---- */
.hero { padding: 1.5rem 0 1rem; }
.hero h1 { font-size: 2.4rem; }
.hero-strip {
  display: flex;
  gap: .5rem;
  margin: 1.5rem -1rem 0;
  padding: 0 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.hero-strip::-webkit-scrollbar { display: none; }
.hero-tile {
  flex: 0 0 auto;
  scroll-snap-align: start;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper-warm);
  transition: transform .15s, border-color .15s;
}
.hero-tile:hover { border-color: var(--amber); transform: translateY(-2px); text-decoration: none; }
.hero-tile img { width: 140px; height: 210px; object-fit: cover; display: block; }
@media (min-width: 720px) {
  .hero-strip { margin: 1.5rem 0 0; padding: 0; }
  .hero-tile img { width: 160px; height: 240px; }
}
.section-h {
  font-size: .9rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--ink-soft);
  margin: 2.5rem 0 1rem;
  border-bottom: 1px solid var(--rule);
  padding-bottom: .5rem;
}
html[data-lang="zh"] .section-h { text-transform: none; letter-spacing: .05em; }

/* ---- Testament cards ---- */
.testament-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.testament-card {
  display: block;
  padding: 1.2rem;
  background: var(--paper-warm);
  border-radius: 10px;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid transparent;
  transition: border-color .15s, transform .15s;
}
.testament-card:hover {
  border-color: var(--amber);
  text-decoration: none;
  transform: translateY(-1px);
}
.testament-card h3 { margin: 0 0 .2rem; color: var(--amber); }
.testament-card p { margin: 0; font-size: .9rem; color: var(--ink-soft); }

/* ---- Series grid (homepage sections) ---- */
.series-grid, .comic-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1.2rem;
  grid-template-columns: 1fr;
}
.series-card a, .comic-card a {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: .8rem;
  padding: .6rem;
  background: var(--paper-warm);
  border-radius: 8px;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid transparent;
  transition: border-color .15s;
}
.series-card a:hover, .comic-card a:hover { border-color: var(--amber); text-decoration: none; }
.series-card img, .comic-card img {
  width: 96px;
  height: 144px;
  object-fit: cover;
  border-radius: 4px;
  background: var(--paper);
  border: 1px solid var(--rule);
}
.series-card .meta h3, .comic-card .meta h3 { margin: 0 0 .15rem; color: var(--ink); }
.series-card .meta p, .comic-card .meta p {
  margin: 0; font-size: .92rem; color: var(--ink-soft);
}
.series-card .count { display: inline-block; margin-top: .4rem; font-size: .8rem; color: var(--amber); }
.comic-card .ref { color: var(--amber); font-size: .85rem; margin: 0 0 .15rem; }

/* ---- Series header / breadcrumbs ---- */
.crumbs { font-size: .9rem; color: var(--ink-soft); margin: 0 0 1rem; }
.crumbs a { color: var(--ink-soft); }
.crumbs a:hover { color: var(--amber); }
.crumbs span { margin: 0 .35em; opacity: .6; }
.series-header { padding: 1rem 0 1.5rem; border-bottom: 1px solid var(--rule); margin-bottom: 1.5rem; }
.series-header .count { color: var(--amber); font-size: .9rem; }

/* ---- Comic page (single comic viewer) ---- */
.comic header { margin-bottom: 1rem; }
.comic .ref { color: var(--amber); margin: 0 0 .5em; }
.comic .page {
  margin: 1rem -1rem;       /* full-bleed on phones */
  background: var(--paper);
}
.comic .page img {
  width: 100%;
  max-width: none;
  display: block;
  -webkit-user-select: none; user-select: none;
}

.panel-lang-note {
  font-size: .85rem;
  color: var(--ink-soft);
  text-align: center;
  margin: .5rem 0 0;
  padding: .5rem 0;
  border-top: 1px dashed var(--rule);
}

/* ---- Pager ---- */
.pager {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: .5rem;
  align-items: center;
  margin-top: 1.5rem;
  padding: 1rem 0;
  border-top: 1px solid var(--rule);
  font-size: .9rem;
}
.pager .prev, .pager .next, .pager .up {
  padding: .5rem .6rem;
  border-radius: 6px;
  background: var(--paper-warm);
  color: var(--ink);
  text-decoration: none;
  text-align: center;
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pager .next { text-align: right; }
.pager .up { font-size: .8rem; color: var(--ink-soft); padding: .5rem 1rem; }
.pager a:hover { background: var(--amber); color: var(--paper); text-decoration: none; }
.pager .disabled {
  display: inline-block;
  padding: .5rem .6rem;
  color: var(--ink-soft);
  opacity: .35;
}

/* ---- Search results ---- */
.search-results { margin-top: 1.5rem; }
.search-results h2 { font-size: 1rem; color: var(--ink-soft); }

/* ---- Prose (about page) ---- */
.prose { max-width: 38rem; }
.prose h1 { margin-top: .5rem; }
.prose h2 { margin-top: 2rem; font-size: 1.2rem; color: var(--amber); }
.prose p { font-size: 1.05rem; color: var(--ink); }

/* ---- Wider screens ---- */
@media (min-width: 720px) {
  :root { --pad: 1.5rem; }
  .hero h1 { font-size: 3rem; }
  .comic .page { margin: 1.5rem 0; border: 1px solid var(--rule); border-radius: 4px; }
  .series-card a, .comic-card a { grid-template-columns: 120px 1fr; }
  .series-card img, .comic-card img { width: 120px; height: 180px; }
}
