/* ────────────────────────────────────────────────────────
   IStory — style.css
   Two themes: light (parchment/editorial) & dark (ink/candlelit)
   ──────────────────────────────────────────────────────── */

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

/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
img { display: block; max-width: 100%; }
a { color: inherit; }

/* ── Theme tokens ──────────────────────────────────────── */
:root, [data-theme="light"] {
  --bg:          #f5f0e8;
  --bg-card:     #fffdf7;
  --bg-elevated: #fff;
  --border:      #d9d0be;
  --text:        #2a2218;
  --text-muted:  #7a6e5f;
  --text-faint:  #b0a898;
  --accent:      #8b4513;
  --accent-soft: #c4703a;
  --accent-bg:   #f5ece2;
  --choice-bg:   #faf5ed;
  --choice-hover:#ede3d0;
  --danger:      #c0392b;
  --success:     #2e7d32;
  --shadow:      0 2px 12px rgba(0,0,0,.08);
  --shadow-lg:   0 8px 32px rgba(0,0,0,.12);
  --radius:      6px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Lora', Georgia, serif;
  --font-mono:    'JetBrains Mono', monospace;
}

[data-theme="dark"] {
  --bg:          #141210;
  --bg-card:     #1e1a16;
  --bg-elevated: #252019;
  --border:      #3a3228;
  --text:        #e8e0d0;
  --text-muted:  #9a8e7e;
  --text-faint:  #5a5248;
  --accent:      #d4924a;
  --accent-soft: #e8a85e;
  --accent-bg:   #2a1f12;
  --choice-bg:   #221d16;
  --choice-hover:#2e2618;
  --danger:      #e57373;
  --success:     #81c784;
  --shadow:      0 2px 16px rgba(0,0,0,.4);
  --shadow-lg:   0 8px 40px rgba(0,0,0,.5);
}

/* ── Base ──────────────────────────────────────────────── */
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--text);
  background: var(--bg);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  transition: background .3s, color .3s;
}

/* ── Layout ────────────────────────────────────────────── */
.container { width:100%; max-width:860px; margin:0 auto; padding:2rem 1.5rem; flex:1; }
.container.narrow { max-width:560px; }
.story-layout { max-width:680px; }

/* ── Header ────────────────────────────────────────────── */
.site-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 1.5rem; border-bottom:1px solid var(--border);
  background:var(--bg-card); position:sticky; top:0; z-index:100;
  box-shadow:var(--shadow);
}
.header-logo {
  font-family:var(--font-display); font-size:1.4rem; font-weight:700;
  color:var(--accent); text-decoration:none; letter-spacing:.02em;
}
.header-nav { display:flex; align-items:center; gap:1rem; }
.nav-link { font-size:.88rem; color:var(--text-muted); text-decoration:none; transition:color .15s; }
.nav-link:hover { color:var(--accent); }
.nav-user { font-size:.88rem; color:var(--text-faint); }

/* ── Theme toggle ──────────────────────────────────────── */
.theme-toggle {
  background:none; border:1px solid var(--border); border-radius:20px;
  padding:.25rem .6rem; cursor:pointer; font-size:1rem; color:var(--text-muted);
  transition:border-color .15s, color .15s;
}
.theme-toggle:hover { border-color:var(--accent); color:var(--accent); }

/* ── Inventory bar ─────────────────────────────────────── */
.inventory-bar {
  background:var(--accent-bg); border-bottom:1px solid var(--border);
  padding:.4rem 1.5rem; position:sticky; top:57px; z-index:90;
}
.inventory-toggle {
  font-family:var(--font-mono); font-size:.8rem; color:var(--accent);
  text-decoration:none; display:inline-flex; align-items:center; gap:.4rem;
}
.inventory-toggle:hover { color:var(--accent-soft); }

/* ── Focal point / crop picker ─────────────────────────── */
.focal-picker-wrap { margin:.5rem 0; }
.focal-picker {
  position: relative;
  display: block;
  cursor: ns-resize;
  max-width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  user-select: none;
}
.focal-picker img {
  display: block;
  width: 100%;
  max-height: 300px;
  object-fit: contain;
  pointer-events: none;
}
.focal-crop {
  position: absolute;
  left: 0;
  right: 0;
  background: rgba(139, 69, 19, 0.15);
  border-top: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  pointer-events: none;
  transition: top .05s;
}
.focal-crop::before,
.focal-crop::after {
  content: '↕ drag to reposition';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size: .72rem;
  font-family: var(--font-mono);
  color: var(--accent);
  white-space: nowrap;
  pointer-events: none;
}

/* ── Image popup ───────────────────────────────────────── */
.img-popup {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.85);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.img-popup-inner {
  position: relative;
  max-width: 92vw;
  max-height: 92vh;
  cursor: default;
}
.img-popup-inner img {
  display: block;
  max-width: 92vw;
  max-height: 88vh;
  object-fit: contain;
  border-radius: var(--radius);
  box-shadow: 0 8px 48px rgba(0,0,0,.6);
}
.img-popup-close {
  position: absolute;
  top: -14px;
  right: -14px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}

/* ── Splash overlay ────────────────────────────────────── */
#splash-overlay {
  position: fixed;
  inset: 0;
  z-index: 999;
  background: #0a0a0a;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .6s ease;
}
#splash-overlay img {
  max-width: min(600px, 92vw);
  max-height: 92vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 16px 64px rgba(0,0,0,.7);
}
#splash-overlay.hidden {
  opacity: 0;
  pointer-events: none;
}

/* ── Splash ────────────────────────────────────────────── */
.splash { margin:0 -1.5rem 2rem; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); }
.splash-img { width:100%; max-height:480px; object-fit:cover; object-position:center top; display:block; }

/* ── Book body wrapper ─────────────────────────────────── */
.book-body { padding:1.25rem 1.5rem 1.5rem; display:flex; flex-direction:column; flex:1; gap:8px; }

/* ── Write status badge ────────────────────────────────── */
.write-badge {
  display:inline-block; font-family:var(--font-mono); font-size:.68rem;
  letter-spacing:.06em; padding:.22rem .6rem; border-radius:20px;
  border:1px solid transparent; width:fit-content; margin-bottom:.25rem;
}
.badge-open   { background:#e8f5e9; color:#2e7d32; border-color:#c8e6c9; }
.badge-member { background:var(--accent-bg); color:var(--accent); border-color:var(--accent-soft); }
.badge-closed { background:var(--bg); color:var(--text-faint); border-color:var(--border); }
[data-theme="dark"] .badge-open   { background:#1a3a1a; color:#81c784; border-color:#2e5e2e; }
[data-theme="dark"] .badge-member { background:var(--accent-bg); color:var(--accent-soft); border-color:var(--accent); }

/* ── Book grid ─────────────────────────────────────────── */
.book-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:1.25rem; }
.book-card {
  display:flex; flex-direction:column; background:var(--bg-card);
  border:1px solid var(--border); border-radius:var(--radius);
  text-decoration:none; transition:box-shadow .2s, transform .2s, border-color .2s;
  box-shadow:var(--shadow); overflow:hidden;
}
.book-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-2px); border-color:var(--accent-soft); }
.book-title { font-family:var(--font-display); font-size:1.25rem; font-weight:700; color:var(--text); }
.book-desc { color:var(--text-muted); font-size:.95rem; flex:1; }
.book-meta {
  display:flex; justify-content:space-between; font-size:.8rem; color:var(--text-faint);
  border-top:1px solid var(--border); padding-top:.75rem; margin-top:auto;
}

/* ── Book cover image ──────────────────────────────────── */
.book-cover { margin:0; border-radius:0; overflow:hidden; border-bottom:1px solid var(--border); }
.book-cover img { width:100%; height:160px; object-fit:cover; display:block; transition:transform .3s ease; }
.book-card:hover .book-cover img { transform:scale(1.04); }

/* ── Breadcrumb ────────────────────────────────────────── */
.breadcrumb {
  display:flex; flex-wrap:wrap; align-items:center; gap:.4rem;
  font-size:.82rem; color:var(--text-faint); margin-bottom:2rem;
}
.breadcrumb a { color:var(--text-muted); text-decoration:none; transition:color .15s; }
.breadcrumb a:hover { color:var(--accent); }

/* ── Resume card ───────────────────────────────────────── */
.resume-card {
  background:var(--accent-bg); border:1px solid var(--accent-soft);
  border-radius:var(--radius); padding:1.25rem; margin-bottom:1.5rem;
}
.resume-card p { margin-bottom:.75rem; color:var(--text-muted); }
.resume-actions { display:flex; gap:.75rem; flex-wrap:wrap; }

/* ── Story book cover (first segment only) ─────────────── */
.story-book-cover {
  margin-bottom: 1.5rem;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  cursor: pointer;
}
.story-cover-img {
  display: block;
  width: 100%;
  height: 140px;
  object-fit: cover;
  transition: opacity .2s;
}
.story-cover-img:hover { opacity: .88; }

/* ── Segment body ──────────────────────────────────────── */
.segment-body { font-size:1.1rem; line-height:1.85; color:var(--text); margin-bottom:1rem; }

/* ── Segment meta bar ──────────────────────────────────── */
.segment-meta-bar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding: .6rem 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: .75rem 0 1.5rem;
}
.meta-left {
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.meta-author {
  display: flex;
  align-items: baseline;
  gap: .35rem;
}
.meta-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .2rem;
}
.meta-rating-avg,
.meta-rating-user {
  display: flex;
  align-items: center;
  gap: .35rem;
}
.rating-row { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; }
.segment-author-block { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.author-label { font-size:.82rem; color:var(--text-faint); font-style:italic; }
.author-name {
  font-family:var(--font-display); font-size:.95rem; font-weight:700;
  color:var(--text-muted);
}
.segment-guid {
  font-family: var(--font-display);
  font-size: .82rem;
  font-style: italic;
  color: var(--text-faint);
}

/* ── Ratings ───────────────────────────────────────────── */
.rating-display { display:flex; align-items:center; gap:.4rem; }
.stars-display { color:var(--accent); font-size:1rem; letter-spacing:.05em; }
.rating-score { font-size:.8rem; color:var(--text-faint); font-family:var(--font-mono); }
.rating-input { display:flex; align-items:center; gap:.2rem; margin-left:auto; }
.rate-label { font-size:.78rem; color:var(--text-faint); margin-right:.3rem; }
.star-btn {
  background:none; border:none; cursor:pointer; font-size:1.2rem;
  color:var(--text-faint); padding:0 .1rem; transition:color .1s, transform .1s;
  line-height:1;
}
.star-btn:hover, .star-btn.active { color:var(--accent); transform:scale(1.2); }

/* ── Choices ───────────────────────────────────────────── */
.choices { margin:2rem 0; }
.choices-label {
  font-family:var(--font-display); font-size:.85rem; font-style:italic;
  color:var(--text-faint); margin-bottom:1rem; text-transform:uppercase; letter-spacing:.08em;
}
.choice-btn {
  display:flex; align-items:flex-start; gap:1rem; padding:1rem 1.25rem;
  margin-bottom:.6rem; background:var(--choice-bg); border:1px solid var(--border);
  border-radius:var(--radius); text-decoration:none; color:var(--text); font-size:1rem;
  transition:background .15s, border-color .15s, transform .15s;
}
.choice-btn:hover { background:var(--choice-hover); border-color:var(--accent-soft); transform:translateX(4px); }
.choice-circular { border-style:dashed; }
.choice-number {
  display:inline-flex; align-items:center; justify-content:center;
  width:1.6rem; height:1.6rem; border-radius:50%; border:1px solid var(--accent-soft);
  color:var(--accent); font-size:.8rem; font-family:var(--font-mono); flex-shrink:0; margin-top:.1rem;
}

/* ── Ending card ───────────────────────────────────────── */
.ending-card {
  margin:2rem 0; padding:1.5rem; background:var(--accent-bg);
  border:1px solid var(--border); border-radius:var(--radius); text-align:center;
}
.ending-label { display:block; font-family:var(--font-display); font-size:1.1rem; color:var(--accent); margin-bottom:.5rem; }

/* ── Write prompt ──────────────────────────────────────── */
.write-prompt { margin-top:2rem; padding-top:1.5rem; border-top:1px solid var(--border); }

/* ── Admin actions ─────────────────────────────────────── */
.admin-actions {
  margin-top:1.5rem; padding-top:1rem; border-top:1px dashed var(--border);
  display:flex; gap:.5rem; flex-wrap:wrap;
}

/* ── Item action blocks in write form ──────────────────── */
.item-action-block {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem;
  background: var(--choice-bg);
}
.new-item-panel {
  margin-top: .75rem;
  padding-top: .75rem;
  border-top: 1px dashed var(--border);
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

/* ── Link type tabs ────────────────────────────────────── */
.link-type-tabs { display:flex; gap:.5rem; margin-bottom:1.25rem; }
.tab-btn {
  padding:.45rem 1rem; background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius); cursor:pointer; font-family:var(--font-body);
  font-size:.88rem; color:var(--text-muted); transition:background .15s, color .15s;
}
.tab-btn.active { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ── Form row (side-by-side labels) ────────────────────── */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

/* ── Forms ─────────────────────────────────────────────── */
.form-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
  padding:1.75rem; display:flex; flex-direction:column; gap:1.25rem;
}
label { display:flex; flex-direction:column; gap:.4rem; font-size:.9rem; color:var(--text-muted); }
.hint { font-size:.8rem; color:var(--text-faint); font-style:italic; }
input[type="text"],input[type="email"],input[type="password"],input[type="number"],
textarea,select {
  width:100%; padding:.6rem .85rem; background:var(--bg); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--text); font-family:var(--font-body); font-size:1rem;
  transition:border-color .15s; appearance:auto;
}
input:focus,textarea:focus,select:focus { outline:none; border-color:var(--accent-soft); }
.checkbox-label { flex-direction:row; align-items:center; gap:.6rem; color:var(--text); cursor:pointer; }
.form-actions { display:flex; gap:.75rem; justify-content:flex-end; }
.form-footer { margin-top:1rem; font-size:.85rem; color:var(--text-faint); text-align:center; }
input[type="file"] { padding:.4rem 0; background:none; border:none; color:var(--text-muted); font-size:.9rem; }

/* ── Context box ───────────────────────────────────────── */
.context-box {
  margin-bottom:1.5rem; padding:1rem 1.25rem; background:var(--choice-bg);
  border-left:3px solid var(--accent); border-radius:0 var(--radius) var(--radius) 0;
}
.context-label { font-size:.8rem; color:var(--text-faint); text-transform:uppercase; letter-spacing:.06em; margin-bottom:.5rem; }
blockquote { font-style:italic; color:var(--text-muted); font-size:.95rem; }

/* ── Page titles ───────────────────────────────────────── */
.page-title { font-family:var(--font-display); font-size:1.9rem; font-weight:700; color:var(--text); margin-bottom:.25rem; }
.page-subtitle { color:var(--text-muted); font-style:italic; margin-bottom:1.75rem; }

.alert-warning {
  padding:.75rem 1rem; border-radius:var(--radius); font-size:.9rem;
  margin-bottom:1rem; background:#fff8e1; color:#7c5a00;
  border:1px solid #ffe082;
}
[data-theme="dark"] .alert-warning { background:#2a2000; color:#ffe082; border-color:#7c5a00; }

/* ── Alerts ────────────────────────────────────────────── */
.alert { padding:.75rem 1rem; border-radius:var(--radius); font-size:.9rem; margin-bottom:1rem; list-style:none; }
.alert-error   { background:#fde8e8; color:var(--danger); border:1px solid #f5c6c6; }
.alert-success { background:#e8f5e9; color:var(--success); border:1px solid #c8e6c9; }
[data-theme="dark"] .alert-error   { background:#3a1a1a; color:#ef9a9a; border-color:#6d2020; }
[data-theme="dark"] .alert-success { background:#1a3a1a; color:#a5d6a7; border-color:#1b5e20; }

/* ── Buttons ───────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.4rem; padding:.55rem 1.1rem;
  border-radius:var(--radius); font-family:var(--font-body); font-size:.9rem;
  font-weight:500; border:1px solid transparent; cursor:pointer;
  text-decoration:none; transition:background .15s, color .15s, border-color .15s, transform .1s; white-space:nowrap;
}
.btn:active { transform:scale(.97); }
.btn-primary { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover { background:var(--accent-soft); border-color:var(--accent-soft); }
.btn-secondary { background:var(--bg-card); color:var(--text-muted); border-color:var(--border); }
.btn-secondary:hover { border-color:var(--accent-soft); color:var(--accent); }
.btn-write {
  background:var(--accent-bg); color:var(--accent); border-color:var(--accent-soft);
  font-style:italic; font-family:var(--font-display); font-size:1rem;
}
.btn-write:hover { background:var(--accent); color:#fff; }
.btn-danger { background:transparent; color:var(--danger); border-color:var(--danger); }
.btn-danger:hover { background:var(--danger); color:#fff; }
.btn-sm,.btn-xs { padding:.35rem .75rem; font-size:.82rem; }
.btn-xs { padding:.25rem .6rem; font-size:.78rem; }

/* ── Status row ────────────────────────────────────────── */
.status-row { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:.5rem; }

/* ── Segment image ─────────────────────────────────────── */
.segment-image { margin-bottom:1.5rem; border-radius:var(--radius); overflow:hidden; border:1px solid var(--border); }
.segment-image img { width:100%; max-height:420px; object-fit:cover; display:block; }

/* ── Item grid ─────────────────────────────────────────── */
.item-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(110px,1fr)); gap:1rem; margin-top:.75rem; }
.item-card {
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
  padding:.75rem .5rem; text-decoration:none; color:var(--text); text-align:center;
  transition:box-shadow .15s, border-color .15s;
}
.item-card:hover { box-shadow:var(--shadow); border-color:var(--accent-soft); }
.item-thumb { width:64px; height:64px; border-radius:var(--radius); overflow:hidden; }
.item-thumb img { width:100%; height:100%; object-fit:cover; }
.item-thumb-placeholder { display:flex; align-items:center; justify-content:center; background:var(--bg); border:1px solid var(--border); font-size:1.6rem; }
.item-name { font-size:.8rem; color:var(--text-muted); line-height:1.3; }
.item-detail { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:1.5rem; }
.item-detail .item-image { margin-bottom:1rem; border-radius:var(--radius); overflow:hidden; }
.item-detail .item-image img { max-height:300px; object-fit:contain; width:100%; }
.item-title { font-family:var(--font-display); font-size:1.4rem; margin-bottom:.5rem; }
.item-desc { color:var(--text-muted); }

/* ── Admin thumbnail ───────────────────────────────────── */
.admin-thumb { display:block; max-width:200px; max-height:120px; object-fit:cover; border-radius:var(--radius); border:1px solid var(--border); margin:.4rem 0; }

/* ── Admin ─────────────────────────────────────────────── */
.admin-section { margin-bottom:2.5rem; }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
.section-header h2 { font-family:var(--font-display); font-size:1.3rem; }
.admin-table {
  width:100%; border-collapse:collapse; font-size:.9rem;
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden;
}
.admin-table th {
  text-align:left; padding:.65rem 1rem; background:var(--bg-elevated); color:var(--text-muted);
  font-size:.78rem; text-transform:uppercase; letter-spacing:.06em; border-bottom:1px solid var(--border);
}
.admin-table td { padding:.7rem 1rem; border-bottom:1px solid var(--border); vertical-align:middle; }
.admin-table tr:last-child td { border-bottom:none; }
.admin-table td.actions { display:flex; gap:.4rem; flex-wrap:wrap; }
.role-badge { display:inline-block; padding:.2rem .5rem; border-radius:20px; font-size:.75rem; font-family:var(--font-mono); }
.role-admin  { background:var(--accent-bg); color:var(--accent); }
.role-writer { background:var(--choice-bg); color:var(--text-muted); }

/* ── Book request cards ────────────────────────────────── */
.request-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #fff;
  border-radius: 20px;
  font-size: .72rem;
  font-family: var(--font-mono);
  padding: .1rem .5rem;
  margin-left: .5rem;
}
.request-card {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.5rem;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem;
  margin-bottom: .75rem;
  flex-wrap: wrap;
}
.request-info { flex: 1; display: flex; flex-direction: column; gap: .3rem; }
.request-info strong { font-size: 1rem; color: var(--text); }
.request-meta { font-size: .8rem; color: var(--text-faint); font-family: var(--font-mono); }
.request-desc { font-size: .9rem; color: var(--text-muted); }
.request-msg  { font-size: .88rem; color: var(--text-faint); }
.request-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .5rem;
  min-width: 120px;
}

/* ── Top book blocks ───────────────────────────────────── */
.top-book-block {
  margin-bottom: 2.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.top-book-header {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .75rem 1rem;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.top-book-rank {
  font-family: var(--font-mono);
  font-size: .8rem;
  color: var(--text-faint);
  min-width: 1.5rem;
}
.top-book-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  flex: 1;
}
.top-book-title:hover { color: var(--accent); }
.top-book-score {
  font-size: .9rem;
  color: var(--accent);
  font-family: var(--font-mono);
}
.top-book-block .admin-table { border: none; border-radius: 0; }

/* ── Empty state ───────────────────────────────────────── */
.empty-state { text-align:center; padding:3rem 1rem; color:var(--text-faint); font-style:italic; }
.empty-state a { color:var(--accent); }

/* ── Footer ────────────────────────────────────────────── */
.site-footer {
  text-align:center; padding:1.5rem; font-size:.8rem;
  color:var(--text-faint); border-top:1px solid var(--border);
}

/* ── Responsive ────────────────────────────────────────── */
@media (max-width:600px) {
  .book-grid { grid-template-columns:1fr; }
  .form-actions { flex-direction:column; }
  .form-row { grid-template-columns:1fr; }
  .admin-table { font-size:.8rem; }
  .admin-table th,.admin-table td { padding:.5rem .75rem; }
  .admin-table td.actions { flex-wrap:wrap; }
  .item-grid { grid-template-columns:repeat(auto-fill, minmax(90px,1fr)); }
  .rating-input { margin-left:0; }
  .segment-meta-bar { flex-direction:column; align-items:flex-start; }
}
