/* ============================================================
   PEOPLE.CSS
   Bloodline · Life Stories · Book Summaries
   ============================================================ */

/* ════════════════════════════════════════════════════════════
   BOOK SUMMARY BANNER (shown at chapter 1)
   ════════════════════════════════════════════════════════════ */
.book-summary-banner {
  background: linear-gradient(135deg, rgba(139,90,43,0.08), rgba(184,134,11,0.05));
  border: 1px solid rgba(184,134,11,0.2);
  border-left: 3px solid var(--gold-light);
  border-radius: 0 4px 4px 0;
  padding: 12px 14px;
  margin: 8px 0 16px;
  position: relative; z-index: 2;
}

.summary-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

.summary-icon {
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.summary-title {
  font-family: var(--font-title);
  font-size: 1.1rem;
  color: var(--ink);
  line-height: 1.2;
}

.summary-period {
  font-family: var(--font-sc);
  font-size: 0.6rem;
  color: var(--gold-light);
  letter-spacing: 0.15em;
  margin-top: 2px;
}

.summary-text {
  font-family: var(--font-body);
  font-size: 0.78rem;
  line-height: 1.75;
  color: var(--ink-fade);
  font-style: italic;
  margin-bottom: 8px;
}

.summary-figures {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  margin-top: 6px;
}

.summary-figures-label {
  font-family: var(--font-sc);
  font-size: 0.6rem;
  color: var(--ink-light);
  letter-spacing: 0.1em;
}

.summary-person {
  background: rgba(184,134,11,0.12);
  border: 1px solid rgba(184,134,11,0.3);
  color: var(--ink-fade);
  padding: 2px 8px;
  font-family: var(--font-sc);
  font-size: 0.62rem;
  letter-spacing: 0.06em;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.15s;
}
.summary-person:hover {
  background: var(--gold);
  color: var(--ink);
  border-color: var(--gold-shine);
}

/* ════════════════════════════════════════════════════════════
   BLOODLINE MODAL
   ════════════════════════════════════════════════════════════ */
.bloodline-box {
  max-width: 700px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}

.bloodline-intro {
  padding: 8px 22px 12px;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.82rem;
  color: var(--ink-fade);
  line-height: 1.65;
  border-bottom: 1px solid rgba(139,105,30,0.15);
}

.bloodline-content {
  overflow-y: auto;
  flex: 1;
  padding: 16px 22px;
  scrollbar-width: thin;
  scrollbar-color: var(--gold) rgba(0,0,0,0.1);
}

/* Individual bloodline node */
.bl-node {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.bl-connector {
  width: 2px;
  height: 20px;
  background: linear-gradient(180deg, var(--border-color), var(--gold));
  margin: 0 auto;
}

.bl-card {
  width: 100%;
  background: rgba(255,255,255,0.25);
  border: 1px solid rgba(139,105,30,0.25);
  border-radius: 4px;
  padding: 10px 14px;
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.bl-card:hover {
  background: rgba(184,134,11,0.1);
  border-color: var(--gold);
  transform: translateX(3px);
}

.bl-card-inner { flex: 1; }

.bl-special .bl-card {
  border-color: var(--gold);
  background: rgba(184,134,11,0.07);
}

.bl-terminal .bl-card {
  border-color: var(--gold-shine);
  background: linear-gradient(135deg, rgba(184,134,11,0.15), rgba(139,26,26,0.08));
  border-width: 2px;
}

.bl-name {
  font-family: var(--font-sc);
  font-size: 0.82rem;
  color: var(--ink);
  letter-spacing: 0.08em;
  font-weight: bold;
}

.bl-hebrew {
  font-family: var(--font-hebrew);
  font-size: 0.9rem;
  color: var(--gold-light);
  direction: rtl;
  margin: 2px 0;
}

.bl-ref {
  font-family: var(--font-sc);
  font-size: 0.58rem;
  color: var(--red-letter);
  letter-spacing: 0.1em;
  margin-bottom: 4px;
}

.bl-desc {
  font-family: var(--font-body);
  font-size: 0.75rem;
  color: var(--ink-fade);
  line-height: 1.55;
  font-style: italic;
}

.bl-star {
  color: var(--gold-shine);
  font-size: 0.9rem;
  flex-shrink: 0;
  margin-top: 4px;
}

/* Compressed generation pill */
.bl-compressed {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.bl-connector-line {
  width: 2px;
  height: 12px;
  background: var(--border-color);
  margin: 0 auto;
}

.bl-compressed-pill {
  background: rgba(139,105,30,0.1);
  border: 1px dashed rgba(139,105,30,0.3);
  border-radius: 20px;
  padding: 6px 18px;
  font-family: var(--font-sc);
  font-size: 0.65rem;
  color: var(--ink-light);
  letter-spacing: 0.08em;
  text-align: center;
  max-width: 90%;
}

.bl-compressed-ref {
  display: block;
  font-size: 0.6rem;
  color: var(--red-letter);
  margin-top: 2px;
  letter-spacing: 0.1em;
}

/* ════════════════════════════════════════════════════════════
   LIFE STORIES BROWSER GRID
   ════════════════════════════════════════════════════════════ */
.life-browser-box {
  max-width: 900px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
}

/* ── Search bar ─────────────────────────────────────────── */
.browser-search-wrap {
  padding: 10px 20px 0;
}
.browser-search-input {
  width: 100%;
  box-sizing: border-box;
  padding: 9px 14px;
  border: 1px solid rgba(139,105,30,0.3);
  border-radius: 6px;
  background: rgba(255,255,255,0.5);
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--ink);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.browser-search-input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(184,134,11,0.15);
}
.browser-search-input::placeholder { color: var(--ink-light); opacity: 0.6; }

/* ── Tabs ───────────────────────────────────────────────── */
.browser-tabs {
  display: flex;
  gap: 4px;
  padding: 10px 20px 0;
  flex-wrap: wrap;
}
.browser-tab {
  padding: 6px 14px;
  border: 1px solid rgba(139,105,30,0.25);
  border-radius: 20px;
  background: transparent;
  font-family: var(--font-sc);
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  color: var(--ink-light);
  cursor: pointer;
  transition: all 0.18s;
  white-space: nowrap;
}
.browser-tab:hover {
  background: rgba(184,134,11,0.08);
  border-color: rgba(139,105,30,0.5);
  color: var(--ink);
}
.browser-tab.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
  font-weight: 700;
}
.browser-tab-count {
  display: inline-block;
  background: rgba(0,0,0,0.15);
  border-radius: 10px;
  padding: 0 5px;
  font-size: 0.62rem;
  margin-left: 4px;
  min-width: 16px;
  text-align: center;
}
.browser-tab.active .browser-tab-count {
  background: rgba(255,255,255,0.3);
}

/* ── Results label ──────────────────────────────────────── */
.browser-results-label {
  padding: 6px 22px 2px;
  font-family: var(--font-sc);
  font-size: 0.65rem;
  letter-spacing: 0.07em;
  color: var(--ink-light);
  opacity: 0.7;
}

/* ── Card grid ──────────────────────────────────────────── */
.life-browser-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: 10px;
  padding: 10px 20px 20px;
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: var(--gold) rgba(0,0,0,0.1);
}

.person-card {
  background: rgba(255,255,255,0.2);
  border: 1px solid rgba(139,105,30,0.25);
  border-radius: 6px;
  padding: 13px 11px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}
.person-card:hover {
  background: rgba(184,134,11,0.1);
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(184,134,11,0.2);
}

/* Top row: avatar + testament badge */
.person-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  position: relative;
  margin-bottom: 6px;
}
.person-avatar {
  font-size: 1.9rem;
  line-height: 1;
}

/* Small badge on card */
.pc-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  font-size: 0.5rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  padding: 1px 5px;
  border-radius: 10px;
  text-transform: uppercase;
}
.pc-badge.badge-ot   { background: rgba(139,105,30,0.18); color: #7a5c1e; border: 1px solid rgba(139,105,30,0.35); }
.pc-badge.badge-nt   { background: rgba(30,80,139,0.14);  color: #1e4c8a; border: 1px solid rgba(30,80,139,0.28); }
.pc-badge.badge-apoc { background: rgba(80,30,120,0.14);  color: #4a1e78; border: 1px solid rgba(80,30,120,0.28); }

.person-name {
  font-family: var(--font-sc);
  font-size: 0.74rem;
  color: var(--ink);
  letter-spacing: 0.06em;
  margin-bottom: 3px;
}
.person-title {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.67rem;
  color: var(--ink-fade);
  line-height: 1.35;
  margin-bottom: 5px;
}
.person-period {
  font-family: var(--font-sc);
  font-size: 0.57rem;
  color: var(--gold-light);
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.person-teaser {
  font-family: var(--font-sc);
  font-size: 0.57rem;
  color: var(--ink-light);
  letter-spacing: 0.06em;
  opacity: 0.7;
}

/* ── Empty state ────────────────────────────────────────── */
.browser-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 50px 20px;
  color: var(--ink-light);
  font-family: var(--font-body);
  font-size: 0.9rem;
  opacity: 0.7;
}
.browser-empty-icon { font-size: 2.5rem; margin-bottom: 12px; }

/* ════════════════════════════════════════════════════════════
   SINGLE LIFE STORY MODAL
   ════════════════════════════════════════════════════════════ */
.life-story-box {
  max-width: 680px;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
}

.life-story-content {
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: var(--gold) rgba(0,0,0,0.1);
  padding: 0 0 20px;
}

/* Hero section */
.life-story-hero {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 24px;
  background: linear-gradient(135deg, rgba(139,90,43,0.08), rgba(184,134,11,0.05));
  border-bottom: 1px solid rgba(139,105,30,0.2);
}

.story-avatar {
  font-size: 3rem;
  line-height: 1;
  flex-shrink: 0;
}

.story-name {
  font-family: var(--font-title);
  font-size: 1.8rem;
  color: var(--ink);
  line-height: 1.1;
}

.story-hebrew {
  font-family: var(--font-hebrew);
  font-size: 1.1rem;
  color: var(--gold-light);
  direction: rtl;
  margin: 2px 0;
}

.story-title {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.85rem;
  color: var(--ink-fade);
}

.story-period {
  font-family: var(--font-sc);
  font-size: 0.62rem;
  color: var(--gold);
  letter-spacing: 0.12em;
  margin-top: 3px;
}

/* Sections */
.story-section {
  padding: 14px 24px;
}

.story-section-label {
  font-family: var(--font-sc);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.suffering-section .story-section-label { color: #8b3a3a; }
.favor-section    .story-section-label  { color: #3a6b3a; }

.story-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.story-list-item {
  display: flex;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.83rem;
  line-height: 1.65;
  color: var(--ink);
}

.story-bullet {
  flex-shrink: 0;
  margin-top: 2px;
  font-size: 0.6rem;
}

.suffering-item { border-left: 2px solid rgba(139,26,26,0.25); padding-left: 10px; }
.favor-item     { border-left: 2px solid rgba(26,100,26,0.3);  padding-left: 10px; }

.suffering-item .story-bullet { color: var(--red-letter); }
.favor-item     .story-bullet { color: #3a8a3a; }

/* Arc divider */
.story-arc-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 24px;
}

.arc-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-color), transparent);
}

.arc-text {
  font-family: var(--font-sc);
  font-size: 0.65rem;
  color: var(--gold);
  letter-spacing: 0.15em;
  white-space: nowrap;
}

/* Lesson */
.story-lesson {
  margin: 4px 24px 12px;
  background: rgba(184,134,11,0.06);
  border: 1px solid rgba(184,134,11,0.2);
  border-radius: 4px;
  padding: 12px 16px;
}

.lesson-label {
  font-family: var(--font-sc);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  color: var(--gold);
  margin-bottom: 7px;
  text-transform: uppercase;
}

.lesson-text {
  font-family: var(--font-body);
  font-style: italic;
  font-size: 0.83rem;
  line-height: 1.75;
  color: var(--ink);
}

/* Stats */
.story-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding: 10px 24px;
}

.stat-pill {
  background: rgba(139,90,43,0.08);
  border: 1px solid rgba(139,90,43,0.2);
  border-radius: 20px;
  padding: 4px 12px;
  font-family: var(--font-sc);
  font-size: 0.6rem;
  letter-spacing: 0.06em;
  display: flex;
  gap: 6px;
  align-items: center;
}

.stat-key { color: var(--ink-light); }
.stat-val { color: var(--gold-light); font-weight: bold; }

/* Key verses */
.story-verses {
  padding: 10px 24px 4px;
}

.verse-links {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.key-verse-btn {
  background: rgba(139,26,26,0.08);
  border: 1px solid rgba(139,26,26,0.25);
  color: var(--red-letter);
  padding: 4px 12px;
  font-family: var(--font-sc);
  font-size: 0.65rem;
  letter-spacing: 0.08em;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.15s;
}
.key-verse-btn:hover {
  background: var(--red-letter);
  color: var(--parchment);
}

/* ════════════════════════════════════════════════════════════
   DARK MODE OVERRIDES
   ════════════════════════════════════════════════════════════ */
:root.dark-mode .book-summary-banner {
  background: linear-gradient(135deg, rgba(80,50,20,0.12), rgba(120,90,20,0.08));
  border-color: rgba(200,150,12,0.2);
}

:root.dark-mode .bl-card {
  background: rgba(0,0,0,0.2);
  border-color: rgba(139,105,30,0.2);
}
:root.dark-mode .bl-card:hover {
  background: rgba(200,150,12,0.08);
}
:root.dark-mode .bl-special .bl-card {
  background: rgba(200,150,12,0.06);
}
:root.dark-mode .bl-terminal .bl-card {
  background: linear-gradient(135deg, rgba(200,150,12,0.1), rgba(100,26,26,0.08));
}

:root.dark-mode .person-card {
  background: rgba(0,0,0,0.2);
  border-color: rgba(139,105,30,0.2);
}
:root.dark-mode .person-card:hover {
  background: rgba(200,150,12,0.08);
}
:root.dark-mode .person-name  { color: var(--parchment); }
:root.dark-mode .person-title { color: rgba(245,232,208,0.55); }
:root.dark-mode .person-period{ color: rgba(200,160,40,0.7); }

:root.dark-mode .browser-search-input {
  background: rgba(0,0,0,0.25);
  border-color: rgba(200,160,40,0.25);
  color: var(--parchment);
}
:root.dark-mode .browser-search-input:focus {
  border-color: var(--gold);
}
:root.dark-mode .browser-tab {
  border-color: rgba(200,160,40,0.2);
  color: rgba(245,232,208,0.6);
}
:root.dark-mode .browser-tab:hover {
  background: rgba(200,160,40,0.1);
  color: var(--parchment);
}
:root.dark-mode .browser-tab.active {
  background: var(--gold);
  color: #1a0f00;
}
:root.dark-mode .pc-badge.badge-ot   { background: rgba(200,160,40,0.15); color: #d4aa50; }
:root.dark-mode .pc-badge.badge-nt   { background: rgba(80,140,220,0.12); color: #80aadd; }
:root.dark-mode .pc-badge.badge-apoc { background: rgba(160,80,220,0.12); color: #c080ee; }
:root.dark-mode .browser-empty       { color: rgba(245,232,208,0.5); }

:root.dark-mode .story-lesson {
  background: rgba(120,90,20,0.08);
  border-color: rgba(200,150,12,0.15);
}

:root.dark-mode .suffering-item { border-left-color: rgba(180,60,60,0.3); }
:root.dark-mode .favor-item     { border-left-color: rgba(60,140,60,0.3); }

/* ── RELATED FIGURES ──────────────────────────────────────── */
.story-related {
  margin-top: 20px;
}

.related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.related-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: rgba(139,105,30,0.06);
  border: 1px solid rgba(139,105,30,0.18);
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.18s, border-color 0.18s, transform 0.15s;
}
.related-card:hover {
  background: rgba(139,105,30,0.13);
  border-color: rgba(139,105,30,0.35);
  transform: translateY(-1px);
}
.related-avatar {
  font-size: 1.5rem;
  line-height: 1;
  flex-shrink: 0;
}
.related-name {
  font-family: var(--font-heading, 'IM Fell English SC', serif);
  font-size: 0.82rem;
  color: var(--ink, #2c1810);
  font-weight: 600;
}
.related-rel {
  font-size: 0.72rem;
  color: var(--ink-light, #6b4c2a);
  margin-top: 2px;
  line-height: 1.3;
}

/* ── TESTAMENT BADGE ─────────────────────────────────────── */
.testament-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-family: var(--font-ui, sans-serif);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 20px;
  margin-left: 8px;
  vertical-align: middle;
  position: relative;
  top: -2px;
}
.badge-ot   { background: rgba(139,105,30,0.15); color: #7a5c1e; border: 1px solid rgba(139,105,30,0.3); }
.badge-nt   { background: rgba(30,80,139,0.12);  color: #1e4c8a; border: 1px solid rgba(30,80,139,0.25); }
.badge-apoc { background: rgba(80,30,120,0.12);  color: #4a1e78; border: 1px solid rgba(80,30,120,0.25); }

/* dark mode */
:root.dark-mode .related-card {
  background: rgba(200,160,40,0.05);
  border-color: rgba(200,160,40,0.15);
}
:root.dark-mode .related-card:hover {
  background: rgba(200,160,40,0.1);
}
:root.dark-mode .related-name { color: var(--parchment, #f5e8d0); }
:root.dark-mode .related-rel  { color: rgba(245,232,208,0.6); }
:root.dark-mode .badge-ot   { background: rgba(200,160,40,0.15); color: #d4aa50; border-color: rgba(200,160,40,0.3); }
:root.dark-mode .badge-nt   { background: rgba(80,140,220,0.12); color: #80aadd; border-color: rgba(80,140,220,0.25); }
:root.dark-mode .badge-apoc { background: rgba(160,80,220,0.12); color: #c080ee; border-color: rgba(160,80,220,0.25); }
