/* Palimpsest — Bible Text Archaeology | v0.1.4 */
:root {
  --bg:       #1a1510;
  --bg2:      #231c12;
  --bg3:      #2e2518;
  --gold:     #c9a84c;
  --gold2:    #e8c97a;
  --gold-dim: #7a6230;
  --ink:      #f2ead8;
  --ink2:     #b8a888;
  --ink3:     #6e5f45;
  --red:      #c04f3a;
  --teal:     #4a9e8e;
  --teal2:    #6dbfae;
  --border:   rgba(201,168,76,.15);
  --border2:  rgba(201,168,76,.30);
  --sidebar:  260px;
  --mono:     'IBM Plex Mono', monospace;
  --serif:    'Crimson Pro', Georgia, serif;
  --sans:     'DM Sans', sans-serif;
  --r:        8px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body { height:100%; overflow:hidden; }
body { background:var(--bg); color:var(--ink); font-family:var(--sans); font-size:15px; line-height:1.5; }

.screen { display:none; width:100%; height:100vh; }
.screen.active { display:flex; }

.sidebar { width:var(--sidebar); min-width:var(--sidebar); height:100vh; background:var(--bg2); border-right:.5px solid var(--border); display:flex; flex-direction:column; padding:22px 16px 18px; overflow:hidden; }
.sb-logo { display:flex; align-items:center; gap:10px; margin-bottom:22px; padding-bottom:18px; border-bottom:.5px solid var(--border); }
.sb-icon { width:30px; height:30px; background:var(--bg3); border:.5px solid var(--border2); border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.sb-name { font-family:var(--serif); font-size:16px; font-weight:600; color:var(--gold2); }
.sb-sub  { font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--ink3); }
.sb-body { flex:1; overflow-y:auto; }

.flabel { display:block; font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--ink3); margin-bottom:6px; }
.hint   { font-size:11px; color:var(--ink3); font-family:var(--mono); margin-top:4px; margin-bottom:12px; }
.err    { font-size:11px; color:var(--red); min-height:14px; margin-top:5px; font-family:var(--mono); }

input[type=text],input[type=password] { width:100%; padding:9px 11px; background:var(--bg3); border:.5px solid var(--border2); border-radius:var(--r); color:var(--ink); font-family:var(--mono); font-size:13px; outline:none; }
input:focus      { border-color:var(--gold-dim); }
input::placeholder { color:var(--ink3); }
.pi { font-family:var(--serif)!important; font-size:15px!important; color:var(--gold2)!important; }

select { width:100%; padding:8px 10px; background:var(--bg3); border:.5px solid var(--border2); border-radius:var(--r); color:var(--ink); font-family:var(--mono); font-size:11px; outline:none; cursor:pointer; color-scheme:dark; }
select option, select optgroup { background:var(--bg3); color:var(--ink); }

.btn-ex { display:block; width:100%; padding:9px; font-size:13px; font-weight:500; background:var(--gold); color:var(--bg); border:none; border-radius:var(--r); cursor:pointer; font-family:var(--sans); margin-top:8px; text-align:center; }
.btn-ex:hover { opacity:.85; }
.btn-sm { display:block; width:100%; padding:6px; font-size:11px; background:none; border:.5px solid var(--border2); color:var(--ink2); border-radius:var(--r); cursor:pointer; font-family:var(--mono); text-align:center; margin-top:6px; }
.btn-sm:hover { background:var(--bg3); color:var(--ink); }

.tsaved   { font-size:10px; color:var(--teal2); font-family:var(--mono); text-align:center; min-height:13px; margin-top:3px; }
.api-wrap { display:none; margin-top:6px; }
.api-hint { font-size:10px; color:var(--ink3); font-family:var(--mono); margin-top:4px; line-height:1.4; }
.api-hint a { color:var(--gold); text-decoration:none; }

.slist  { margin-top:16px; }
.slabel { font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--ink3); margin-bottom:6px; }
.slink  { display:block; font-family:var(--serif); font-size:13px; color:var(--ink3); cursor:pointer; padding:3px 0; border-bottom:.5px solid var(--border); transition:color .12s; }
.slink:hover { color:var(--gold); }

.main-empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; }
.ei { font-size:44px; opacity:.3; }
.et { font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--ink3); }

.main-load  { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; }
.scroll-anim { width:46px; height:60px; border:1.5px solid var(--gold-dim); border-radius:5px 5px 23px 23px; position:relative; overflow:hidden; }
.sl { position:absolute; left:7px; right:7px; height:1.5px; background:var(--gold-dim); border-radius:1px; animation:sr 2s ease-in-out infinite; }
.sl:nth-child(1){top:11px;animation-delay:0s}
.sl:nth-child(2){top:20px;animation-delay:.25s}
.sl:nth-child(3){top:29px;animation-delay:.5s}
.sl:nth-child(4){top:38px;animation-delay:.75s}
@keyframes sr { 0%,100%{opacity:.15;transform:scaleX(.4)} 50%{opacity:.8;transform:scaleX(1)} }
.ll { font-family:var(--mono); font-size:11px; letter-spacing:.14em; color:var(--ink3); }
.lp { font-family:var(--serif); font-size:20px; color:var(--gold); }

.main-res { flex:1; overflow-y:auto; padding:28px 44px 60px; }
.main-res::-webkit-scrollbar { width:4px; }
.main-res::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }

.rhead  { margin-bottom:20px; padding-bottom:16px; border-bottom:.5px solid var(--border); }
.pbig   { font-family:var(--serif); font-size:28px; font-weight:600; color:var(--gold2); line-height:1.3; }
.vblock { background:var(--bg2); border:.5px solid var(--border); border-left:3px solid var(--gold-dim); border-radius:0 var(--r) var(--r) 0; padding:18px 22px; margin-bottom:8px; }
.vlabel { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--ink3); margin-bottom:10px; }
.vtext  { font-family:var(--serif); font-size:18px; color:var(--ink); line-height:1.9; font-style:italic; }
.vtext .w { cursor:pointer; border-radius:3px; padding:1px 3px; transition:background .12s,color .12s; }
.vtext .w:hover { background:rgba(201,168,76,.18); color:var(--gold2); }
.vtext .w.sel   { background:rgba(109,191,174,.22); color:var(--teal2); }
.chint { font-family:var(--mono); font-size:10px; color:var(--ink3); letter-spacing:.06em; margin-bottom:20px; }

.tabs { display:flex; border-bottom:.5px solid var(--border); }
.tab  { padding:12px 0; flex:1; text-align:center; font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--ink3); background:none; border:none; border-bottom:2px solid transparent; cursor:pointer; transition:color .15s,border-color .15s; white-space:nowrap; }
.tab:hover  { color:var(--ink2); }
.tab.on     { color:var(--gold);  border-bottom-color:var(--gold); }
.tab.teal.on{ color:var(--teal2); border-bottom-color:var(--teal2); }

.pane    { display:none; padding:26px 0 10px; }
.pane.on { display:block; }
.picon   { font-size:26px; margin-bottom:12px; }
.ph      { font-family:var(--serif); font-size:24px; color:var(--gold2); font-weight:600; margin-bottom:4px; }
.ph.teal { color:var(--teal2); }
.psub    { font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--ink3); margin-bottom:18px; }
.pbody   { font-size:15px; line-height:1.8; color:var(--ink2); max-width:680px; }
.pbody p { margin-bottom:14px; }
.pbody p:last-child { margin-bottom:0; }
.stag    { display:inline-block; padding:2px 9px; border-radius:4px; font-family:var(--mono); font-size:11px; background:rgba(201,168,76,.1); color:var(--gold); border:.5px solid var(--border2); margin-bottom:16px; }

.tcards { display:flex; flex-direction:column; gap:14px; max-width:680px; }
.tcard  { background:var(--bg2); border:.5px solid var(--border); border-radius:var(--r); padding:16px 18px; }
.tname  { font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--gold-dim); margin-bottom:7px; }
.tbody  { font-size:14px; color:var(--ink2); line-height:1.7; }

.fbox { border:.5px solid rgba(192,79,58,.4); background:rgba(192,79,58,.05); border-radius:var(--r); padding:20px 24px; max-width:680px; }
.flbl { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--red); margin-bottom:12px; }

.lhead  { display:flex; align-items:baseline; gap:14px; margin-bottom:20px; padding-bottom:16px; border-bottom:.5px solid var(--border); flex-wrap:wrap; }
.lorig  { font-family:var(--serif); font-size:42px; color:var(--teal2); font-weight:400; line-height:1; }
.lsn    { font-family:var(--mono); font-size:13px; color:var(--ink3); background:var(--bg2); border:.5px solid var(--border2); border-radius:4px; padding:3px 9px; }
.ltrans { font-family:var(--mono); font-size:14px; color:var(--ink2); font-style:italic; }
.lbadge { font-family:var(--mono); font-size:10px; padding:3px 8px; border-radius:4px; background:rgba(74,158,142,.15); color:var(--teal2); border:.5px solid rgba(74,158,142,.3); }

.gblock { background:var(--bg2); border:.5px solid var(--border); border-radius:var(--r); padding:14px 16px; margin-bottom:12px; max-width:680px; }
.glbl   { font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--ink3); margin-bottom:6px; }
.gtext  { font-size:15px; color:var(--ink); line-height:1.6; }

.wgrid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; max-width:680px; }
.wcell { background:var(--bg2); border:.5px solid var(--border); border-radius:var(--r); padding:11px 13px; }
.wclbl { font-family:var(--mono); font-size:9px; letter-spacing:.08em; color:var(--ink3); margin-bottom:4px; }
.wcval { font-size:13px; color:var(--ink2); }

.ublock { background:var(--bg2); border:.5px solid var(--border); border-radius:var(--r); padding:14px 16px; margin-bottom:14px; max-width:680px; }
.unote  { font-size:14px; color:var(--ink2); line-height:1.7; }

.chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.chip  { font-family:var(--mono); font-size:11px; padding:5px 12px; border-radius:4px; background:var(--bg3); border:.5px solid var(--border2); color:var(--ink2); cursor:pointer; transition:border-color .15s,color .15s; }
.chip:hover { border-color:var(--teal2); color:var(--teal2); }

.trace-h { margin-bottom:20px; padding-bottom:16px; border-bottom:.5px solid rgba(74,158,142,.3); }
.tcon    { font-family:var(--serif); font-size:28px; color:var(--teal2); font-weight:600; margin-bottom:5px; }
.tsum    { font-size:14px; color:var(--ink2); line-height:1.6; max-width:640px; }
.tthread { margin-bottom:24px; }
.tera    { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--teal2); margin-bottom:12px; padding-bottom:6px; border-bottom:.5px solid rgba(74,158,142,.2); }
.tocc    { display:flex; gap:14px; margin-bottom:11px; padding:14px 16px; background:var(--bg2); border:.5px solid var(--border); border-left:2.5px solid var(--teal); border-radius:0 var(--r) var(--r) 0; max-width:700px; }
.tref    { font-family:var(--mono); font-size:11px; color:var(--teal2); min-width:130px; flex-shrink:0; padding-top:2px; letter-spacing:.04em; }
.tvs     { font-family:var(--serif); font-size:14px; color:var(--ink); font-style:italic; margin-bottom:4px; line-height:1.5; }
.tnote   { font-size:13px; color:var(--ink2); line-height:1.6; }
.tins    { background:rgba(74,158,142,.06); border:.5px solid rgba(74,158,142,.25); border-radius:var(--r); padding:20px 24px; margin-top:18px; max-width:700px; }
.tilbl   { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--teal2); margin-bottom:10px; }
.tibody  { font-size:14px; color:var(--ink2); line-height:1.75; }
.tibody p { margin-bottom:10px; }
.tibody p:last-child { margin-bottom:0; }

.spin-wrap  { display:flex; flex-direction:column; align-items:center; gap:16px; padding:50px 0; }
.spin       { width:34px; height:34px; border-radius:50%; border:1.5px solid var(--border2); border-top-color:var(--teal2); animation:sp .9s linear infinite; }
@keyframes sp { to { transform:rotate(360deg); } }
.spin-lbl   { font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--ink3); }

.prompt-box  { display:flex; flex-direction:column; align-items:center; gap:14px; padding:50px 20px; text-align:center; }
.prompt-icon { font-size:38px; opacity:.5; }
.prompt-txt  { font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--ink3); line-height:1.8; }

.ws-result,.tr-result,.cv-result { animation:fi .3s ease; }
@keyframes fi { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }

.clist-wrap { margin-top:14px; padding-top:12px; border-top:.5px solid var(--border); }
.clist { max-height:190px; overflow-y:auto; margin-top:6px; padding-right:2px; }
.clist::-webkit-scrollbar       { width:3px; }
.clist::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }
.citem { display:flex; align-items:center; gap:6px; padding:4px 2px; border-bottom:.5px solid rgba(201,168,76,.07); cursor:pointer; }
.citem:last-child { border-bottom:none; }
.citem input[type=checkbox] { width:12px; height:12px; accent-color:var(--gold); cursor:pointer; flex-shrink:0; margin:0; }
.citem-name { font-family:var(--mono); font-size:11px; color:var(--ink2); flex:1; line-height:1.3; }
.citem-era  { font-family:var(--mono); font-size:9px; color:var(--ink3); white-space:nowrap; }
.csaved  { font-size:10px; color:var(--teal2); font-family:var(--mono); text-align:center; min-height:13px; margin-top:3px; }
.climit  { font-size:10px; color:var(--ink3); font-family:var(--mono); margin-top:4px; text-align:center; }

.cvcards   { display:flex; flex-direction:column; gap:16px; max-width:680px; }
.cvcard    { background:var(--bg2); border:.5px solid var(--border); border-radius:var(--r); padding:16px 18px; }
.cvcard-name { font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--gold-dim); margin-bottom:3px; }
.cvcard-era  { font-family:var(--mono); font-size:9px; color:var(--ink3); margin-bottom:9px; }
.cvcard-body { font-size:14px; color:var(--ink2); line-height:1.75; }

/* ── Passage Picker ─────────────────────────────────────────────────────── */
.picker-wrap  { margin-top:14px; padding-top:12px; border-top:.5px solid var(--border); }
.picker-row   { display:flex; gap:6px; margin-top:6px; }
.picker-row select { flex:1; min-width:0; }
.picker-col   { display:flex; flex-direction:column; gap:2px; flex:1; min-width:0; }
.picker-micro { font-family:var(--mono); font-size:8px; letter-spacing:.08em; color:var(--ink3); }
.picker-warn  { font-family:var(--mono); font-size:10px; color:var(--red); min-height:13px; margin-top:5px; }
.picker-set   { display:block; width:100%; padding:6px; font-size:11px; background:none;
                border:.5px solid var(--gold-dim); color:var(--gold); border-radius:var(--r);
                cursor:pointer; font-family:var(--mono); text-align:center; margin-top:7px; }
.picker-set:hover { background:rgba(201,168,76,.08); }

/* ── Auth screens ─────────────────────────────────────────────────────────── */
.auth-bg  { flex:1; display:flex; align-items:center; justify-content:center; background:var(--bg); }
.auth-box { width:320px; background:var(--bg2); border:.5px solid var(--border2); border-radius:var(--r); padding:36px 32px 28px; }
.auth-logo { text-align:center; margin-bottom:28px; }
.auth-logo-icon { font-size:32px; display:block; margin-bottom:8px; }
.auth-logo-name { font-family:var(--serif); font-size:22px; font-weight:600; color:var(--gold2); }
.auth-logo-sub  { font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--ink3); }
.auth-title { font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--ink3); margin-bottom:18px; text-align:center; }
.auth-err   { font-family:var(--mono); font-size:11px; color:var(--red); min-height:16px; margin-bottom:8px; text-align:center; }
.auth-ok    { font-family:var(--mono); font-size:11px; color:var(--teal2); min-height:16px; margin-bottom:8px; text-align:center; }
.auth-link  { display:block; text-align:center; font-family:var(--mono); font-size:10px; color:var(--gold-dim); cursor:pointer; margin-top:14px; }
.auth-link:hover { color:var(--gold); }

/* ── Admin modal ──────────────────────────────────────────────────────────── */
.admin-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.65); z-index:100; align-items:center; justify-content:center; }
.admin-overlay.open { display:flex; }
.admin-panel { background:var(--bg2); border:.5px solid var(--border2); border-radius:var(--r); width:480px; max-height:80vh; overflow-y:auto; padding:24px 28px; }
.admin-panel::-webkit-scrollbar { width:4px; }
.admin-panel::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }
.admin-head  { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; padding-bottom:14px; border-bottom:.5px solid var(--border); }
.admin-title { font-family:var(--serif); font-size:20px; color:var(--gold2); font-weight:600; }
.admin-close { background:none; border:none; color:var(--ink3); font-size:18px; cursor:pointer; line-height:1; padding:0; }
.admin-close:hover { color:var(--ink); }
.admin-slabel { font-family:var(--mono); font-size:9px; letter-spacing:.1em; color:var(--ink3); margin-bottom:8px; margin-top:18px; }
.admin-empty  { font-family:var(--mono); font-size:11px; color:var(--ink3); padding:10px 0; }
.user-row { display:flex; align-items:center; gap:8px; padding:8px 0; border-bottom:.5px solid var(--border); }
.user-row:last-child { border-bottom:none; }
.user-name { font-family:var(--mono); font-size:12px; color:var(--ink); flex:1; }
.status-badge    { font-family:var(--mono); font-size:9px; padding:2px 7px; border-radius:3px; letter-spacing:.05em; }
.status-pending  { background:rgba(192,79,58,.15);  color:var(--red);   border:.5px solid rgba(192,79,58,.3); }
.status-approved { background:rgba(74,158,142,.15); color:var(--teal2); border:.5px solid rgba(74,158,142,.3); }
.status-admin    { background:rgba(201,168,76,.15); color:var(--gold);  border:.5px solid rgba(201,168,76,.3); }
.btn-approve { font-family:var(--mono); font-size:10px; padding:3px 10px; background:rgba(74,158,142,.1); color:var(--teal2); border:.5px solid rgba(74,158,142,.35); border-radius:4px; cursor:pointer; }
.btn-approve:hover { background:rgba(74,158,142,.22); }
.btn-reject  { font-family:var(--mono); font-size:10px; padding:3px 10px; background:rgba(192,79,58,.08); color:var(--red); border:.5px solid rgba(192,79,58,.3); border-radius:4px; cursor:pointer; }
.btn-reject:hover  { background:rgba(192,79,58,.18); }

/* ── Sidebar user footer ──────────────────────────────────────────────────── */
.sb-user     { padding-top:12px; border-top:.5px solid var(--border); margin-top:14px; }
.sb-username { font-family:var(--mono); font-size:10px; color:var(--ink3); margin-bottom:6px; }
.sb-username span { color:var(--gold2); }

/* ══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE / MOBILE  (≤ 680px)
   Strategy:
     • Sidebar → fixed slide-in drawer from left, toggled by hamburger
     • Backdrop → dim overlay that closes sidebar on tap
     • screen-input main → shows inline excavate card instead of "enter a passage"
     • Tabs → horizontal scroll instead of flex-wrap
     • Auth / admin → full-width
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Mobile top bar (hidden on desktop) ───────────────────────────────────── */
.mob-bar {
  display: none;
  align-items: center;
  justify-content: space-between;
  padding: 0 14px;
  height: 52px;
  min-height: 52px;
  background: var(--bg2);
  border-bottom: .5px solid var(--border);
  flex-shrink: 0;
  z-index: 10;
  position: relative;
}
.mob-bar-logo {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--gold2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: calc(100% - 50px);
}
.mob-bar-logo span { color: var(--gold2); }
.mob-ham {
  background: none;
  border: .5px solid var(--border2);
  color: var(--ink2);
  font-size: 18px;
  width: 36px;
  height: 36px;
  border-radius: 6px;
  cursor: pointer;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.mob-ham:hover { border-color: var(--gold-dim); color: var(--gold); }

/* Close button inside sidebar (hidden on desktop) */
.mob-close {
  display: none;
  background: none;
  border: none;
  color: var(--ink3);
  font-size: 18px;
  cursor: pointer;
  padding: 0;
  margin-left: auto;
  line-height: 1;
}
.mob-close:hover { color: var(--ink); }

/* Sidebar backdrop (hidden on desktop) */
.sb-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 49;
}

/* Mobile excavate card (hidden on desktop) */
.mob-excavate {
  display: none;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  padding: 24px 20px 0;
}
/* Desktop empty state (hidden on mobile) */
.desk-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

@media (max-width: 680px) {

  /* ── Base ────────────────────────────────────────────────────────────────── */
  html, body { overflow: auto; height: auto; }

  .screen         { height: auto; min-height: 100vh; }
  .screen.active  { flex-direction: column; }

  /* ── Mobile bar visible, desktop empty hidden ────────────────────────────── */
  .mob-bar    { display: flex; }
  .mob-close  { display: block; }
  .desk-empty { display: none; }
  .mob-excavate { display: flex; }

  /* ── Sidebar becomes a fixed drawer ──────────────────────────────────────── */
  .sidebar {
    position: fixed;
    top: 0; left: 0;
    width: 88vw;
    max-width: 320px;
    height: 100%;
    height: 100dvh;
    z-index: 50;
    transform: translateX(-110%);
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    border-right: .5px solid var(--border2);
    overflow-y: auto;
    /* keep padding but remove fixed dimensions */
    min-width: 0;
  }
  .sidebar.open {
    transform: translateX(0);
  }
  .sb-backdrop.open { display: block; }

  /* ── Main content areas ──────────────────────────────────────────────────── */
  .main-empty {
    flex:1;
    flex-direction: column;
    padding: 0;
    min-height: calc(100vh - 52px);
  }
  .main-load {
    flex: 1;
    min-height: calc(100vh - 52px);
  }
  .main-res {
    padding: 18px 16px 80px;
    overflow-y: visible;   /* page scrolls, not inner div */
    flex: 1;
  }

  /* ── Results header ──────────────────────────────────────────────────────── */
  .pbig { font-size: 20px; line-height: 1.25; }
  .rhead { margin-bottom: 14px; padding-bottom: 12px; }

  /* ── Verse block ─────────────────────────────────────────────────────────── */
  .vblock { padding: 14px 14px; }
  .vtext  { font-size: 16px; line-height: 1.75; }

  /* ── Tabs — horizontal scroll, no shrink ────────────────────────────────── */
  .tabs {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    margin: 0 -16px;
    padding: 0 16px;
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tab {
    flex: none;
    min-width: 72px;
    padding: 10px 4px;
    font-size: 9px;
    letter-spacing: .06em;
  }

  /* ── Pane content ─────────────────────────────────────────────────────────── */
  .pane { padding: 18px 0 10px; }
  .ph   { font-size: 20px; }
  .pbody, .fbox, .tins, .gblock, .ublock { max-width: 100%; }
  .cvcards { max-width: 100%; }
  .tcards  { max-width: 100%; }
  .tcon    { font-size: 22px; }
  .tocc    { max-width: 100%; }
  .wgrid   { max-width: 100%; grid-template-columns: 1fr 1fr; }

  .lorig   { font-size: 32px; }

  /* ── Auth screens ─────────────────────────────────────────────────────────── */
  .auth-bg  { align-items: flex-start; padding: 0; }
  .auth-box {
    width: 100%;
    max-width: 100%;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-top: none;
    padding: 32px 24px 28px;
    min-height: 100vh;
  }

  /* ── Admin modal ──────────────────────────────────────────────────────────── */
  .admin-panel {
    width: 100%;
    max-width: 100%;
    border-radius: 0;
    min-height: 100%;
    align-self: flex-end;
  }

  /* ── Picker row — give selects more room ─────────────────────────────────── */
  .picker-row { gap: 4px; }
  .picker-row select { font-size: 10px; padding: 6px 4px; }

  /* ── Word grid on very small screens ─────────────────────────────────────── */
  @media (max-width: 380px) {
    .wgrid { grid-template-columns: 1fr; }
    .tab   { min-width: 58px; font-size: 8px; }
  }
}
