/* ── Reset ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { overflow-x: hidden; }
:root {
  --green:      #2c5f2e;
  --green-dark: #1d4020;
  --green-light:#e8f4e8;
  --bg:         #f5f1eb;
  --surface:    #ffffff;
  --border:     #d4c9b8;
  --border-soft:#e8e2d8;
  --text:       #1f1f1f;
  --muted:      #6b6b6b;
  --danger:     #b91c1c;
  --danger-bg:  #fee2e2;
  --success-bg: #dcfce7;
  --info-bg:    #dbeafe;
  --radius:     8px;
  --radius-lg:  12px;
  --shadow:     0 1px 4px rgba(0,0,0,.1);
  --shadow-md:  0 4px 16px rgba(0,0,0,.12);
}
body { font-family: Georgia,'Times New Roman',serif; background:var(--bg); color:var(--text); min-height:100vh; font-size:15px; line-height:1.6; }

/* ── Utilities ──────────────────────────────────────── */
.hidden       { display:none !important; }
.dim          { color:var(--muted); }
.req          { color:var(--danger); }
.hint         { color:var(--muted); font-size:.8rem; font-weight:normal; }
.text-center  { text-align:center; }
.mt-sm        { margin-top:.5rem; }
.mt-lg        { margin-top:2rem; }
.mb-lg        { margin-bottom:1.5rem; }
.row          { display:flex; align-items:center; }
.gap-sm       { gap:.6rem; }
.flex-wrap    { flex-wrap:wrap; }
.btn-full     { width:100%; }

/* ── Buttons ────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; justify-content:center; padding:.55rem 1.25rem; border:none; border-radius:var(--radius); cursor:pointer; font:inherit; font-size:.9rem; transition:background .15s,opacity .15s; white-space:nowrap; }
.btn:disabled { opacity:.45; cursor:not-allowed; }
.btn-primary   { background:var(--green); color:#fff; }
.btn-primary:hover:not(:disabled) { background:var(--green-dark); }
.btn-secondary { background:var(--border); color:var(--text); }
.btn-secondary:hover { background:#c4b9a8; }
.btn-danger    { background:var(--danger); color:#fff; }
.btn-danger:hover { background:#991b1b; }
.btn-ghost     { background:transparent; color:var(--muted); border:1px solid var(--border); }
.btn-ghost:hover { background:var(--border-soft); }
.btn-sm  { padding:.3rem .75rem; font-size:.82rem; }
.btn-xs  { padding:.2rem .5rem;  font-size:.78rem; }

/* ── Login ──────────────────────────────────────────── */
#login-page, #quick-login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:1.5rem; }
.login-card { background:var(--surface); padding:2rem; border-radius:var(--radius-lg); width:min(420px,100%); box-shadow:var(--shadow-md); }
.login-card h1 { color:var(--green); margin-bottom:.25rem; }
.login-card > .dim { margin-bottom:1.5rem; }

/* ── Header ─────────────────────────────────────────── */
header { background:var(--green); color:#fff; padding:.85rem 1.5rem; position:fixed; top:0; left:0; right:0; z-index:50; box-shadow:0 2px 8px rgba(0,0,0,.2); }
.header-inner { max-width:1300px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.header-left  { display:flex; align-items:center; gap:1rem; }
.header-right { display:flex; align-items:center; gap:.75rem; font-size:.9rem; }
header h1 { font-size:1.4rem; }
header .btn-ghost.btn-sm { color:#fff; border-color:rgba(255,255,255,.4); }
header .btn-ghost.btn-sm:hover { background:rgba(255,255,255,.15); }
.club-switcher select, .club-select-input {
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.35); color:#fff; border-radius:var(--radius); padding:.3rem .65rem; font:inherit; font-size:.88rem; cursor:pointer;
}
.club-switcher select option, .club-select-input option { background:var(--green-dark); }

/* ── Tab Bar ─────────────────────────────────────────── */
.tab-bar { background:var(--surface); border-bottom:2px solid var(--border); position:fixed; top:60px; left:0; right:0; z-index:40; padding:.65rem 0; }
.tab-bar-inner { max-width:1300px; margin:0 auto; padding:0 1rem; display:flex; gap:.3rem; align-items:center; }
.tab { padding:.42rem 1.1rem; border:none; background:transparent; font:inherit; font-size:.9rem; color:var(--text); cursor:pointer; border-radius:20px; font-weight:500; white-space:nowrap; transition:background .15s,color .15s; }
.tab:hover { background:var(--green-light); color:var(--green); }
.tab.active { background:var(--green); color:#fff; font-weight:600; }

/* ── Main ────────────────────────────────────────────── */
.main-content { max-width:1300px; margin:0 auto; padding:132px 1.5rem 2rem; }
#public-home .main-content { padding-top:68px; }
.tab-pane  { display:none; }
.tab-pane.active { display:block; }
.tab-pane > h2 { margin-bottom:1.25rem; color:var(--green); }

/* ── Cards ───────────────────────────────────────────── */
.card { background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:1.5rem; }
.card h3 { color:var(--green); margin-bottom:.85rem; }

/* ── Forms ───────────────────────────────────────────── */
.form-card { max-width:720px; }
.form-card h2, .form-card h3 { color:var(--green); margin-bottom:1rem; }
.field { margin-bottom:1rem; }
.field label { display:block; font-size:.88rem; color:var(--muted); margin-bottom:.35rem; }
.field input, .field select { width:100%; padding:.65rem .9rem; border:2px solid var(--border); border-radius:var(--radius); font:inherit; font-size:.93rem; transition:border-color .15s; background:var(--surface); }
.field input:focus, .field select:focus { outline:none; border-color:var(--green); }
.field textarea { width:100%; padding:.65rem .9rem; border:2px solid var(--border); border-radius:var(--radius); font:inherit; font-size:.93rem; transition:border-color .15s; background:var(--surface); resize:vertical; }
.field textarea:focus { outline:none; border-color:var(--green); }
.field input[type="date"] { font-family:inherit; }
.two-col   { display:grid; grid-template-columns:1fr 1fr;           gap:1rem; }
.three-col { display:grid; grid-template-columns:1fr 1fr 1fr;      gap:1rem; }
.four-col  { display:grid; grid-template-columns:1fr 1fr 1fr 1fr;  gap:1rem; }

/* ── Section head ────────────────────────────────────── */
.section-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.25rem; flex-wrap:wrap; gap:.5rem; }
.section-head h2 { color:var(--green); }
.toggle-label { display:flex; align-items:center; gap:.4rem; font-size:.88rem; color:var(--muted); cursor:pointer; }

/* ── Filter bar ──────────────────────────────────────── */
.filter-bar {
  display:flex; align-items:center; gap:.65rem; flex-wrap:wrap;
  margin-bottom:1rem; padding:.55rem .9rem;
  background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow);
}
.filter-bar input[type="text"] {
  flex:1; min-width:180px; padding:.38rem .75rem;
  border:1px solid var(--border); border-radius:var(--radius);
  font:inherit; font-size:.88rem; background:var(--bg);
  transition:border-color .15s;
}
.filter-bar input[type="text"]:focus { outline:none; border-color:var(--green); }
.filter-bar select {
  padding:.38rem .65rem; border:1px solid var(--border);
  border-radius:var(--radius); font:inherit; font-size:.88rem;
  background:var(--bg); cursor:pointer;
}

/* ── Table ───────────────────────────────────────────── */
.table-scroll { overflow-x:auto; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
table { width:100%; border-collapse:collapse; background:var(--surface); }
thead { background:var(--green); color:#fff; }
th { padding:.65rem .9rem; text-align:left; font-size:.82rem; font-weight:600; white-space:nowrap; }
td { padding:.65rem .9rem; border-bottom:1px solid var(--border-soft); vertical-align:middle; font-size:.88rem; }

/* Sortable headers */
th.th-sort { cursor:pointer; user-select:none; }
th.th-sort:hover { background:rgba(255,255,255,.18); }
th.th-sort::after { content:' ⇕'; opacity:.35; font-size:.68rem; }
th.th-sort-asc::after  { content:' ↑'; opacity:1; }
th.th-sort-desc::after { content:' ↓'; opacity:1; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:#faf8f4; }
tr.inactive td { opacity:.55; }
.td-voting { text-align:center; }
.voting-cb { width:16px; height:16px; accent-color:var(--green); cursor:pointer; vertical-align:middle; }
.voting-cb:disabled { cursor:not-allowed; opacity:.45; }
/* Keep the checkbox clearly interactive even in dimmed (inactive) rows */
tr.inactive td.td-voting { opacity:1; }
.thumb { width:36px; height:54px; object-fit:cover; border-radius:3px; display:block; }
.thumb-ph { width:36px; height:54px; background:var(--border-soft); border-radius:3px; display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:1rem; }
.action-group { display:flex; gap:.35rem; flex-wrap:wrap; }

/* Sticky Actions column — always visible on wide tables */
.table-scroll table th:last-child,
.table-scroll table td:last-child {
  position: sticky;
  right: 0;
  z-index: 1;
  background: var(--surface);
}
.table-scroll table thead th:last-child { background: var(--green); }
.table-scroll table tr:hover td:last-child { background: #faf8f4; }
.table-scroll table tr.inactive td:last-child { background: var(--surface); }

/* Badges */
.badge { display:inline-block; padding:.15rem .5rem; border-radius:20px; font-size:.76rem; font-weight:600; white-space:nowrap; }
.badge-active   { background:#dbeafe; color:#1e40af; }
.badge-selected { background:var(--success-bg); color:#166534; }
.badge-removed  { background:var(--danger-bg);  color:#991b1b; }
.badge-on-hold  { background:#fef9c3; color:#854d0e; }

/* ── Autocomplete ────────────────────────────────────── */
.autocomplete-wrap { position:relative; }
.dropdown { position:absolute; top:100%; left:0; right:0; background:var(--surface); border:1px solid var(--border); border-top:none; border-radius:0 0 var(--radius) var(--radius); max-height:380px; overflow-y:auto; z-index:100; box-shadow:0 6px 20px rgba(0,0,0,.12); }
.drop-item { display:flex; align-items:center; gap:.75rem; padding:.6rem .85rem; cursor:pointer; transition:background .12s; }
.drop-item:hover { background:var(--bg); }
.drop-item img { width:32px; height:48px; object-fit:cover; border-radius:3px; flex-shrink:0; }
.drop-thumb-ph { width:32px; height:48px; background:var(--border-soft); border-radius:3px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--muted); }
.drop-title  { font-size:.88rem; font-weight:600; }
.drop-meta   { font-size:.78rem; color:var(--muted); }
.drop-msg    { padding:.75rem; color:var(--muted); font-size:.88rem; font-style:italic; }

/* Preview card */
.preview-card { display:flex; align-items:flex-start; gap:1rem; padding:.85rem 1rem; background:var(--green-light); border:1px solid #b8d8b8; border-radius:var(--radius); margin-bottom:1rem; }
.preview-card img { width:52px; height:78px; object-fit:cover; border-radius:4px; flex-shrink:0; }
.preview-text { flex:1; display:flex; flex-direction:column; gap:.2rem; }
.preview-pages { font-size:.8rem; }
.preview-desc  { font-size:.8rem; line-height:1.5; font-style:italic; margin-top:.2rem; }

/* ── Messages ────────────────────────────────────────── */
.msg { padding:.65rem .9rem; border-radius:var(--radius); font-size:.9rem; margin-top:.75rem; }
.msg-error   { background:var(--danger-bg); color:#991b1b; }
.msg-success { background:var(--success-bg); color:#166534; }
.alert { padding:.9rem 1.1rem; border-radius:var(--radius); margin-bottom:1.25rem; font-size:.93rem; }
.alert-info    { background:var(--info-bg);    color:#1e40af; }
.alert-success { background:var(--success-bg); color:#166534; }

/* ── Voting ──────────────────────────────────────────── */
.vote-hint    { font-size:1rem; margin-bottom:.5rem; }
.vote-counter { color:var(--muted); font-size:.9rem; margin-bottom:1.25rem; }
.vote-grid { margin-bottom:1.5rem; }

/* Vote table (replaces card grid) */
.vote-table { width:100%; border-collapse:collapse; }
.vote-table thead th { text-align:left; padding:.4rem .6rem; font-size:.78rem; color:var(--muted); border-bottom:2px solid var(--border); white-space:nowrap; }
.vote-row { cursor:pointer; transition:background .12s; user-select:none; }
.vote-row:hover:not(.locked) { background:var(--green-light); }
.vote-row.chosen { background:var(--green-light); }
.vote-row.locked:not(.chosen) { opacity:.4; cursor:default; pointer-events:none; }
.vote-row td { padding:.5rem .6rem; border-bottom:1px solid var(--border-soft); vertical-align:middle; font-size:.84rem; }
.vote-row.locked:not(.chosen) td button { pointer-events:all; }
.vote-check-cell { text-align:center; width:32px; }
.vote-check-icon { display:none; color:var(--green); font-size:1.1rem; font-weight:700; line-height:1; }
.vote-row.chosen .vote-check-icon { display:inline; }

/* ── Results ─────────────────────────────────────────── */
#results-list, #admin-results-list { display:flex; flex-direction:column; gap:.6rem; margin-top:.75rem; }
.result-row { display:flex; align-items:center; gap:.85rem; background:var(--surface); border-radius:var(--radius); padding:.6rem .85rem; box-shadow:var(--shadow); }
.result-row img { width:34px; height:50px; object-fit:cover; border-radius:3px; flex-shrink:0; }
.result-row .rr-ph { width:34px; height:50px; background:var(--border-soft); border-radius:3px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--muted); }
.rr-info { flex:1; min-width:0; }
.rr-title  { font-weight:600; font-size:.88rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rr-author { font-size:.78rem; color:var(--muted); }
.rr-bar-wrap { width:130px; flex-shrink:0; }
.rr-bar { height:14px; background:var(--green); border-radius:7px; transition:width .5s; min-width:3px; }
.rr-count { font-weight:700; color:var(--green); font-size:.88rem; white-space:nowrap; }

/* ── Book Details Modal ──────────────────────────────── */
.modal { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:200; align-items:center; justify-content:center; padding:1rem; }
.modal.open { display:flex; }
.modal-box { background:var(--surface); padding:2rem; border-radius:var(--radius-lg); width:min(460px,100%); box-shadow:var(--shadow-md); max-height:90vh; overflow-y:auto; }
.modal-wide { width:min(700px,100%); }
.modal-box h2 { color:var(--green); margin-bottom:.75rem; }
.detail-header { display:flex; gap:1.25rem; margin-bottom:1.25rem; }
.detail-header img { width:100px; height:150px; object-fit:cover; border-radius:6px; flex-shrink:0; }
.detail-cover-ph { width:100px; height:150px; background:var(--border-soft); border-radius:6px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:2.5rem; color:var(--muted); }
.detail-meta { flex:1; display:flex; flex-direction:column; gap:.35rem; }
.detail-meta h2 { font-size:1.1rem; }
.detail-links { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.5rem; }
.detail-desc { font-size:.9rem; line-height:1.7; border-top:1px solid var(--border-soft); padding-top:1rem; white-space:pre-line; }
.detail-desc:empty::before { content:'No description available.'; color:var(--muted); font-style:italic; }

/* Password modal */
.pwd-box { background:var(--bg); border-radius:var(--radius); padding:1rem; text-align:center; margin:.75rem 0; }
.pwd-label { font-size:.85rem; color:var(--muted); margin-bottom:.35rem; }
.pwd-code { font-size:1.4rem; letter-spacing:.1rem; font-family:monospace; color:var(--green); }

/* ── Admin ───────────────────────────────────────────── */
.admin-card { margin-bottom:1.25rem; }
.status-box { padding:.65rem .9rem; border-radius:var(--radius); font-size:.92rem; }
.admin-two-col { display:grid; grid-template-columns:1fr 1.1fr; gap:1.5rem; align-items:start; }
.admin-members-forms { display:flex; flex-wrap:wrap; gap:1.25rem; align-items:start; }
.admin-members-forms > .card { flex:1; min-width:260px; }

/* Clubs grid */
.clubs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1rem; }
.club-card { background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:1.25rem; }
.club-card h3 { color:var(--green); margin-bottom:.3rem; }
.club-card .dim { font-size:.85rem; }
.club-card-actions { display:flex; gap:.5rem; margin-top:.85rem; flex-wrap:wrap; }

/* Members list */
.members-list { display:flex; flex-direction:column; gap:.5rem; }
.users-cards  { display:none; }
.member-row { background:var(--surface); border-radius:var(--radius); padding:.65rem .85rem; box-shadow:var(--shadow); display:flex; justify-content:space-between; align-items:center; gap:.5rem; }
.member-info strong { display:block; font-size:.9rem; }
.member-info span   { font-size:.8rem; color:var(--muted); }

/* Analytics */
.stat-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.stat-card { background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:1.1rem 1.25rem; text-align:center; }
.stat-card.clickable { cursor:pointer; transition:transform .15s,box-shadow .15s; }
.stat-card.clickable:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.stat-value { font-size:2rem; font-weight:700; color:var(--green); }
.stat-label { font-size:.82rem; color:var(--muted); margin-top:.2rem; }
.analytics-section { background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:1.25rem; margin-bottom:1.25rem; }
.analytics-section h3 { color:var(--green); margin-bottom:1rem; }
.bar-row { display:flex; align-items:center; gap:.75rem; margin-bottom:.6rem; font-size:.88rem; }
.bar-row.clickable { cursor:pointer; border-radius:var(--radius); padding:.2rem .4rem; margin:0 -.4rem; transition:background .12s; }
.bar-row.clickable:hover { background:var(--green-light); }
.clickable-count { cursor:pointer; text-decoration:underline dotted var(--muted); }
.clickable-count:hover { color:var(--green); text-decoration-color:var(--green); }
.bar-label { width:140px; flex-shrink:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.bar-track { flex:1; background:var(--border-soft); border-radius:4px; height:16px; }
.bar-fill  { height:16px; background:var(--green); border-radius:4px; transition:width .5s; min-width:2px; }
.bar-count { width:30px; text-align:right; color:var(--muted); }
.month-grid { display:flex; flex-wrap:wrap; gap:.5rem; }
.month-pill { background:var(--green-light); border:1px solid #b8d8b8; border-radius:20px; padding:.2rem .65rem; font-size:.82rem; color:var(--green); }
.month-pill.clickable { cursor:pointer; transition:background .12s,color .12s; }
.month-pill.clickable:hover { background:var(--green); color:#fff; }

/* Analytics drilldown panel */
.analytics-drilldown {
  margin-top:1.25rem; background:var(--surface);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-md); overflow:hidden;
}
.drilldown-head {
  display:flex; justify-content:space-between; align-items:center;
  padding:.65rem 1rem; background:var(--green-light); border-bottom:1px solid var(--border);
}
.drilldown-head h4 { color:var(--green); margin:0; font-size:.92rem; }
.drilldown-body { max-height:460px; overflow-y:auto; overflow-x:auto; }
.drilldown-book-item {
  display:flex; align-items:center; gap:.65rem;
  padding:.4rem .2rem; border-bottom:1px solid var(--border-soft);
}
.drilldown-book-item:last-child { border-bottom:none; }
.drilldown-thumb { width:28px; height:42px; object-fit:cover; border-radius:2px; flex-shrink:0; }
.drilldown-thumb-ph {
  width:28px; height:42px; background:var(--border-soft); border-radius:2px;
  flex-shrink:0; display:flex; align-items:center; justify-content:center;
  color:var(--muted); font-size:.8rem;
}
.drilldown-book-info { flex:1; min-width:0; }
.drilldown-book-title { font-size:.84rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.drilldown-book-meta  { font-size:.75rem; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.drilldown-book-desc  { font-size:.73rem; color:var(--muted); margin-top:.2rem; line-height:1.4; }
.drilldown-member-item {
  display:flex; justify-content:space-between; align-items:center; gap:.5rem;
  padding:.4rem .2rem; border-bottom:1px solid var(--border-soft); flex-wrap:wrap;
}
.drilldown-member-item:last-child { border-bottom:none; }
.drilldown-member-info { display:flex; flex-direction:column; gap:.1rem; }

/* Date range (from/to pair) — stays on one row even in stacked filter bar */
.date-range { display:flex; align-items:center; gap:.4rem; flex-wrap:nowrap; }
.date-range input[type="date"] { flex:1; min-width:0; }
.filter-label { font-size:.82rem; color:var(--muted); white-space:nowrap; }

/* Stats/Analytics filter date inputs */
.filter-bar input[type="date"], .date-range input[type="date"] {
  padding:.38rem .65rem; border:1px solid var(--border); border-radius:var(--radius);
  font:inherit; font-size:.88rem; background:var(--bg); cursor:pointer;
}

/* ── Misc ────────────────────────────────────────────── */
.empty-state { text-align:center; padding:3rem; color:var(--muted); font-style:italic; }

/* ── Mobile Vote Cards ───────────────────────────────── */
.vote-cards { display:none; flex-direction:column; gap:.65rem; }
.vote-card { background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; cursor:pointer; transition:background .12s,border-color .12s; user-select:none; border:2px solid transparent; }
.vote-card:hover:not(.locked) { background:var(--green-light); }
.vote-card.chosen { background:var(--green-light); border-color:var(--green); }
.vote-card.locked:not(.chosen) { opacity:.4; cursor:default; pointer-events:none; }
.vote-card.locked:not(.chosen) button { pointer-events:all; }
.vc-main { display:flex; gap:.65rem; padding:.7rem; }
.vc-check { display:flex; align-items:center; justify-content:center; width:22px; flex-shrink:0; }
.vc-cover { flex-shrink:0; display:flex; flex-direction:column; align-items:center; gap:.3rem; }
.vc-cover-img { width:55px; height:82px; object-fit:cover; border-radius:4px; display:block; }
.vc-cover-ph { width:55px; height:82px; background:var(--border-soft); border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; color:var(--muted); }
.vc-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:.2rem; }
.vc-title { font-weight:700; font-size:.95rem; line-height:1.3; }
.vc-author { font-size:.82rem; color:var(--muted); }
.vc-meta { font-size:.78rem; color:var(--muted); }
.vc-actions { display:flex; gap:.3rem; flex-wrap:wrap; margin-top:.2rem; }

/* ── Mobile Book Cards ───────────────────────────────── */
/* Hidden on desktop — CSS shows them only on mobile */
.books-cards { display:none; flex-direction:column; gap:.65rem; }
.book-card { background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
.book-card-inactive { opacity:.55; }
.bc-main { display:flex; gap:.7rem; padding:.7rem; }
/* Cover column: image stacked above Details button (tables + mobile cards) */
.cover-cell { display:flex; flex-direction:column; align-items:center; gap:.3rem; }
.cover-cell .btn { font-size:.72rem; padding:.18rem .35rem; width:100%; justify-content:center; }
.bc-cover { flex-shrink:0; display:flex; flex-direction:column; align-items:center; gap:.3rem; }
.bc-cover-img { width:62px; height:93px; object-fit:cover; border-radius:4px; display:block; }
.bc-cover-ph { width:62px; height:93px; background:var(--border-soft); border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; color:var(--muted); }
.bc-info { flex:1; min-width:0; display:flex; flex-direction:column; gap:.22rem; }
.bc-title { font-weight:700; font-size:.95rem; line-height:1.3; }
.bc-author { font-size:.82rem; color:var(--muted); }
.bc-meta { font-size:.78rem; color:var(--muted); }
.bc-badges { display:flex; align-items:center; gap:.45rem; flex-wrap:wrap; margin-top:.1rem; }
.bc-submitted { font-size:.75rem; color:var(--muted); }
.bc-actions { display:flex; gap:.3rem; flex-wrap:wrap; margin-top:.2rem; }
.bc-synopsis-btn { background:none; border:none; padding:0; font:inherit; font-size:.78rem; color:var(--green); cursor:pointer; text-align:left; margin-top:.18rem; }
.bc-cover .btn, .vc-cover .btn { font-size:.72rem; padding:.18rem .4rem; width:100%; justify-content:center; }
.bc-synopsis { padding:.6rem .7rem; border-top:1px solid var(--border-soft); font-size:.83rem; line-height:1.65; color:var(--text); white-space:pre-line; }

/* ── Public Home ─────────────────────────────────────── */
#public-home > header { background:var(--green); color:#fff; padding:.85rem 1.5rem; box-shadow:0 2px 8px rgba(0,0,0,.2); }
.public-clubs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(min(520px,100%),1fr)); gap:1.25rem; }
.public-club-card { background:var(--surface); border-radius:var(--radius-lg); box-shadow:var(--shadow); padding:1.25rem; min-width:0; }
.public-club-card h3 { color:var(--green); margin-bottom:.5rem; }
.public-books-list { display:flex; flex-direction:column; gap:.5rem; margin-top:.5rem; }
.public-book-item { display:flex; align-items:center; gap:.65rem; padding:.35rem 0; border-bottom:1px solid var(--border-soft); }
.public-book-item:last-child { border-bottom:none; }
.public-book-item img { width:28px; height:42px; object-fit:cover; border-radius:2px; flex-shrink:0; }
.pub-book-ph { width:28px; height:42px; background:var(--border-soft); border-radius:2px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:.8rem; }
.pub-book-info { flex:1; min-width:0; }
.pub-book-title { font-size:.85rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pub-book-author { font-size:.76rem; color:var(--muted); }
.pub-book-desc  { font-size:.74rem; color:var(--muted); margin-top:.18rem; line-height:1.4; }
.pub-book-count { font-size:.8rem; margin-bottom:.4rem; }
.pub-expand-btn { margin-top:.6rem; width:100%; justify-content:center; font-size:.82rem; }

/* Shared small thumbnail (used in all book tables) */
.thumb-sm    { width:34px; height:50px; object-fit:cover; border-radius:3px; display:block; }
.thumb-sm-ph { width:34px; height:50px; background:var(--border-soft); border-radius:3px; display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:.9rem; flex-shrink:0; }

/* Public home book table / card swap */
.pub-books-cards  { display:none; margin-top:.5rem; }
.pub-book-item-right { display:flex; flex-direction:column; align-items:flex-end; gap:.3rem; flex-shrink:0; }
.pub-table-wrap   { overflow-x:auto; margin-top:.5rem; }
.pub-books-table  { width:100%; border-collapse:collapse; font-size:.82rem; }
.pub-books-table thead th { text-align:left; padding:.38rem .5rem; font-size:.75rem; color:var(--muted); border-bottom:2px solid var(--border); white-space:nowrap; }
.pub-books-table tbody tr { border-bottom:1px solid var(--border-soft); }
.pub-books-table tbody tr:last-child { border-bottom:none; }
.pub-books-table tbody td { padding:.42rem .5rem; vertical-align:middle; }

/* Analytics drilldown table */
.drilldown-table-wrap { overflow-x:auto; }
.drilldown-table { width:100%; border-collapse:collapse; font-size:.82rem; }
.drilldown-table thead th { text-align:left; padding:.38rem .6rem; font-size:.75rem; color:var(--muted); border-bottom:2px solid var(--border); white-space:nowrap; }
.drilldown-table tbody tr { border-bottom:1px solid var(--border-soft); }
.drilldown-table tbody tr:last-child { border-bottom:none; }
.drilldown-table tbody td { padding:.42rem .6rem; vertical-align:middle; }
.drilldown-cards { display:none; flex-direction:column; gap:.65rem; padding:.5rem 0; }

/* Ballot config table */
/* Genre multiselect picker */
.genre-picker { display:grid; grid-template-columns:repeat(3,1fr); gap:.15rem .4rem; max-height:152px; overflow-y:auto; padding:.5rem .6rem; border:2px solid var(--border); border-radius:var(--radius); background:var(--surface); }
.genre-picker:focus-within { border-color:var(--green); }
.genre-cb-item { display:flex; align-items:center; gap:.3rem; font-size:.8rem; cursor:pointer; padding:.1rem 0; line-height:1.3; }
.genre-cb-item input[type="checkbox"] { flex-shrink:0; accent-color:var(--green); width:13px; height:13px; }

.session-book-table { width:100%; border-collapse:collapse; font-size:.82rem; }
.session-book-table thead th { text-align:left; padding:.35rem .5rem; font-size:.75rem; color:var(--muted); border-bottom:2px solid var(--border); white-space:nowrap; }
.session-book-table tbody tr { border-bottom:1px solid var(--border-soft); }
.session-book-table tbody tr:last-child { border-bottom:none; }
.session-book-table tbody td { padding:.35rem .5rem; vertical-align:middle; }

/* ── Login divider ───────────────────────────────────── */
.divider { display:flex; align-items:center; gap:.75rem; margin:1.25rem 0; }
.divider::before, .divider::after { content:''; flex:1; height:1px; background:var(--border); }
.divider span { color:var(--muted); font-size:.82rem; white-space:nowrap; }

/* ── Role badges ─────────────────────────────────────── */
.role-badge { display:inline-block; padding:.15rem .5rem; border-radius:20px; font-size:.74rem; font-weight:600; background:var(--border-soft); color:var(--muted); white-space:nowrap; }
.role-badge-superadmin { background:#ede9fe; color:#5b21b6; }
.role-badge-admin { background:#fef3c7; color:#92400e; }

/* ── Voter tracking ──────────────────────────────────── */
.voter-status { background:var(--bg); border-radius:var(--radius); padding:.65rem .85rem; margin-top:.5rem; }
.voter-status-head { font-size:.8rem; font-weight:600; color:var(--muted); margin-bottom:.5rem; }
.voter-count { font-weight:700; color:var(--text); }
.voter-grid { display:flex; flex-wrap:wrap; gap:.3rem; }
.voter-chip { display:inline-flex; align-items:center; padding:.18rem .55rem; border-radius:20px; font-size:.76rem; font-weight:500; white-space:nowrap; }
.voter-chip-voted   { background:var(--success-bg); color:#166534; }
.voter-chip-pending { background:var(--border-soft); color:var(--muted); }

/* Voting session history */
.session-history-card {
  background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:.65rem .9rem; margin-bottom:.5rem;
}
.sh-header { display:flex; justify-content:space-between; align-items:center; gap:.5rem; flex-wrap:wrap; }
.sh-info { display:flex; flex-direction:column; gap:.1rem; }
.sh-date { font-size:.88rem; font-weight:600; }
.sh-status { font-size:.78rem; }
.sh-votes { margin-top:.6rem; }
.sh-votes-table { width:100%; border-collapse:collapse; font-size:.82rem; }
.sh-votes-table th { text-align:left; color:var(--muted); padding:.25rem .5rem; border-bottom:1px solid var(--border-soft); font-weight:600; }
.sh-votes-table td { padding:.25rem .5rem; border-bottom:1px solid var(--border-soft); }
.sh-votes-table tr:last-child td { border-bottom:none; }

/* ── Session config form ─────────────────────────────── */
.session-config-inner { background:var(--bg); border-radius:var(--radius); padding:.85rem; }
.session-picks-input { width:100%; padding:.4rem .65rem; border:2px solid var(--border); border-radius:var(--radius); font:inherit; }
.session-picks-input:focus { outline:none; border-color:var(--green); }
.session-book-list { margin-top:.75rem; max-height:320px; overflow-y:auto; overflow-x:auto; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); }
.session-book-list-head { display:flex; justify-content:space-between; align-items:center; padding:.45rem .7rem; border-bottom:1px solid var(--border-soft); position:sticky; top:0; background:var(--surface); }
.session-book-item { display:flex; align-items:flex-start; gap:.55rem; padding:.4rem .7rem; border-bottom:1px solid var(--border-soft); cursor:pointer; transition:background .1s; }
.session-book-item:last-child { border-bottom:none; }
.session-book-item:hover { background:var(--bg); }
.session-voter-list { padding:.35rem .7rem; display:flex; flex-wrap:wrap; gap:.35rem .85rem; }
.session-voter-row { display:flex; align-items:center; gap:.4rem; cursor:pointer; font-size:.9rem; padding:.2rem 0; }
.session-book-item input[type="checkbox"] { flex-shrink:0; accent-color:var(--green); width:15px; height:15px; margin-top:.15rem; }
.session-book-title  { font-size:.86rem; font-weight:600; display:block; }
.session-book-details { display:flex; flex-direction:column; min-width:0; }
.session-book-meta   { font-size:.74rem; color:var(--muted); }
.sh-picks { font-size:.75rem; }

/* ── Genre Manager ───────────────────────────────────── */
.genre-manager-section { border-top:1px solid var(--border-soft); padding-top:1rem; }
.genre-add-form { display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; padding:.65rem 0 .75rem; }
.genre-add-input { flex:1; min-width:180px; padding:.4rem .65rem; border:2px solid var(--border); border-radius:var(--radius); font:inherit; }
.genre-add-input:focus { outline:none; border-color:var(--green); }
.genre-manage-list { border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); max-height:420px; overflow-y:auto; }
.genre-manage-row { display:flex; align-items:center; justify-content:space-between; gap:.5rem; padding:.4rem .75rem; border-bottom:1px solid var(--border-soft); }
.genre-manage-row:last-child { border-bottom:none; }
.genre-manage-row:hover { background:var(--bg); }
.genre-manage-name { font-size:.88rem; font-weight:500; }
.genre-rename-input { font:inherit; font-size:.88rem; padding:.2rem .45rem; border:2px solid var(--green); border-radius:var(--radius); flex:1; }

/* ── Cover Upload ────────────────────────────────────── */
.cover-upload-row { display:flex; align-items:flex-start; gap:.75rem; flex-wrap:wrap; }
.cover-upload-thumb { flex-shrink:0; }
.cover-upload-thumb img { width:60px; height:90px; object-fit:cover; border-radius:var(--radius); border:1px solid var(--border); display:block; }
.cover-upload-actions { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; }
.cover-upload-label { cursor:pointer; position:relative; overflow:hidden; display:inline-flex; }
.cover-file-input { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }

/* ── Next Meeting Banner ─────────────────────────────── */
.next-meeting-banner {
  background:linear-gradient(135deg, var(--green-light) 0%, #f0faf0 100%);
  border:2px solid var(--green);
  border-radius:var(--radius-lg);
  padding:1rem 1.25rem;
  margin-bottom:1.25rem;
  box-shadow:var(--shadow);
}
.nm-banner-inner {
  display:flex;
  gap:1.5rem;
  align-items:flex-start;
  flex-wrap:wrap;
}
.nm-book-side {
  display:flex;
  gap:.85rem;
  flex:1;
}
.nm-cover { flex-shrink:0; }
.nm-cover-img { width:70px; height:105px; object-fit:cover; border-radius:6px; display:block; box-shadow:var(--shadow); }
.nm-cover-ph { width:70px; height:105px; background:var(--border-soft); border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:1.8rem; color:var(--muted); }
.nm-book-info { display:flex; flex-direction:column; gap:.2rem; }
.nm-label { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--green); margin-bottom:.15rem; }
.nm-title { font-size:1.1rem; font-weight:700; line-height:1.25; color:var(--text); }
.nm-meta { font-size:.82rem; color:var(--muted); }
.nm-when-side {
  display:flex;
  flex-direction:column;
  gap:.45rem;
  padding-left:1rem;
  border-left:2px solid var(--border-soft);
}
.nm-when, .nm-where {
  display:flex;
  align-items:flex-start;
  gap:.4rem;
  font-size:.88rem;
  line-height:1.4;
}
.nm-icon { flex-shrink:0; }
/* Form inside Manage tab */
.nm-form { margin-top:.75rem; }
.nm-current { background:var(--green-light); border-radius:var(--radius); padding:.55rem .85rem; border:1px solid var(--border-soft); }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width:768px) {
  /* Global spacing */
  body { font-size:14px; }
  .main-content { padding:88px .75rem 1rem; }
  #public-home .main-content { padding-top:52px; }

  /* Header */
  header { padding:.6rem .85rem; }
  .header-inner { flex-wrap:wrap; gap:.4rem; }
  .header-right { gap:.4rem; flex-wrap:wrap; }
  header h1 { font-size:1.1rem; }
  #member-welcome { display:none; }

  /* Tab bar — horizontal scroll (overflow on inner, not the fixed element — iOS Safari fix) */
  .tab-bar { top:48px; padding:.4rem 0; }
  .tab-bar-inner { max-width:none; margin:0; padding:0 .5rem; width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; gap:0; }
  .tab-bar-inner::-webkit-scrollbar { display:none; }
  .tab { padding:.38rem .85rem; font-size:.82rem; flex-shrink:0; }

  /* Layout grids */
  .two-col, .three-col, .four-col, .admin-two-col { grid-template-columns:1fr; }
  .form-card { max-width:100%; }
  .card { padding:1.1rem; }

  /* Section heads */
  .section-head { flex-direction:column; align-items:flex-start; gap:.5rem; }

  /* (table→card swap moved to 900px breakpoint below) */

  /* Tables — bleed full width (admin / other tables still scroll) */
  .table-scroll { margin:0 -.75rem; border-radius:0; box-shadow:none;
    border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

  /* Modals — bottom sheet */
  .modal { padding:0; align-items:flex-end; }
  .modal-box { width:100%; max-width:100%;
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    padding:1.5rem 1.25rem 2rem;
    max-height:90vh; overflow-y:auto; }
  .modal-wide { width:100%; max-width:100%; }

  /* Public home — swap table for card list */
  .public-clubs-grid { grid-template-columns:1fr; }
  .pub-table-wrap  { display:none; }
  .pub-books-cards { display:block; }

  /* Genre picker — 2 columns */
  .genre-picker { grid-template-columns:repeat(2,1fr); }

  /* Voting */
  .rr-bar-wrap { width:70px; }

  /* Analytics */
  .stat-cards { grid-template-columns:repeat(2,1fr); }
  .bar-label { width:110px; }

  /* Login */
  .login-card { padding:1.5rem 1.25rem; }

  /* Members */
  .member-row { flex-wrap:wrap; }
  .member-row .action-group { margin-top:.25rem; }

  /* Preview card */
  .preview-card { flex-wrap:wrap; }

  /* Detail modal header */
  .detail-header { flex-wrap:wrap; }

  /* Filter bar — stack vertically on tablet and below */
  .filter-bar { flex-direction:column; align-items:stretch; }
  .filter-bar input[type="text"], .filter-bar select { width:100%; min-width:0; }
}

@media (max-width:480px) {
  .main-content { padding:88px .6rem 1rem; }
  .table-scroll { margin:0 -.6rem; }

  /* Stat cards stay 2-col on tiny screens */
  .stat-cards { grid-template-columns:1fr 1fr; }

  /* Smaller action buttons in table rows */
  .action-group .btn { font-size:.75rem; padding:.25rem .5rem; }

  /* Allow header to wrap to two rows so nothing gets clipped */
  .header-inner { flex-wrap:wrap; gap:.3rem; }
  .header-left { flex:1; min-width:0; }
  .header-right { flex-shrink:1; min-width:0; flex-wrap:nowrap; gap:.3rem; justify-content:flex-end; }
  .club-select-input { min-width:0; max-width:100px; }
  header h1 { font-size:.95rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  /* Tab bar and content shift down to clear the taller two-row header (~84px) */
  .tab-bar { top:84px; }
  .main-content { padding-top:124px; }

  /* Club card actions stack */
  .club-card-actions { flex-direction:column; }
  .club-card-actions .btn { width:100%; }

  /* Result rows */
  .result-row { flex-wrap:wrap; }
  .rr-bar-wrap { width:100%; }
}

/* ── Next Meeting Banner: stack on small screens ─────── */
@media (max-width:600px) {
  .nm-banner-inner { flex-direction:column; gap:.85rem; }
  .nm-when-side { border-left:none; border-top:1px solid var(--border-soft); padding-left:0; padding-top:.65rem; }
}

/* ── Card view: swap table → cards at 900px (covers tablets + landscape phones) ── */
@media (max-width:900px) {
  #tab-books .table-scroll { display:none; }
  .books-cards { display:flex; }
  #vote-grid .table-scroll { display:none; }
  .vote-cards { display:flex; }
  #admin-tab-books #admin-table-wrap { display:none; }
  #admin-books-cards { display:flex; }
  .drilldown-table-wrap { display:none; }
  .drilldown-cards { display:flex; }
  #users-table-wrap { display:none; }
  .users-cards { display:flex; }
}
