/* Christos reader — vanilla, framework-free, offline-first. */
:root{
  color-scheme:dark;
  --bg:#0f1110; --surface:#171817; --surface2:#20211f; --lift:#252620;
  --line:#363830; --ink:#f1eee8; --dim:#aaa69c; --faint:#77746c;
  --accent:#d8a441; --accent2:#3eb7a8; --danger:#d87564; --good:#71bf84;
  --src:#c9b7ff; --seam:#7ccf9b; --mark:rgba(216,164,65,.22);
  --shadow:0 18px 44px rgba(0,0,0,.32);
  --serif:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --source:"SBL Hebrew","SBL Greek","Ezra SIL","Noto Serif Hebrew","Noto Serif Ethiopic","Noto Serif",Georgia,serif;
  --radius:8px;
}
body.theme-light{
  color-scheme:light;
  --bg:#f6f7fb; --surface:#ffffff; --surface2:#edf2f3; --lift:#e8ece9;
  --line:#d7ddd8; --ink:#20242a; --dim:#59626a; --faint:#7d858b;
  --accent:#a96f14; --accent2:#087d73; --danger:#aa4838; --good:#327947;
  --src:#563d99; --seam:#1f7a50; --mark:rgba(216,164,65,.24);
  --shadow:0 18px 38px rgba(38,44,49,.14);
}
*{box-sizing:border-box}
html{height:100%;scroll-behavior:smooth}
body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}
button[disabled]{cursor:default}

.top{position:sticky;top:0;z-index:50;display:grid;grid-template-columns:auto minmax(72px,max-content) auto auto auto auto;
  align-items:center;gap:8px;padding:8px 10px calc(8px + env(safe-area-inset-top,0px));
  background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line)}
.brand{font-family:var(--serif);font-weight:700;font-size:20px;cursor:pointer;white-space:nowrap}
.brand::first-letter{color:var(--accent)}
#menuBtn{grid-column:1;grid-row:1}
.brand{grid-column:2;grid-row:1}
#themeBtn{grid-column:3;grid-row:1}
#askBtn{grid-column:4;grid-row:1}
#reviewBtn{grid-column:5;grid-row:1}
#layersBtn{grid-column:6;grid-row:1}
.icon{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  width:38px;height:38px;display:grid;place-items:center;font-size:17px;line-height:1;flex:0 0 auto}
.icon:hover,.icon:focus-visible{border-color:var(--accent2);outline:0}
.icon.on{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--surface) 84%,var(--accent))}
.icon.has-review{box-shadow:inset 0 -3px 0 var(--accent)}
.omni{grid-column:1 / -1;grid-row:2;min-width:0}
.omni input{width:100%;height:42px;background:var(--surface);border:1px solid var(--line);
  color:var(--ink);border-radius:var(--radius);padding:0 13px;font-size:16px;outline:none}
.omni input:focus{border-color:var(--accent2);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent2) 22%,transparent)}

.sidebar{position:fixed;top:0;left:0;height:100%;width:310px;max-width:86vw;z-index:70;
  background:var(--surface);border-right:1px solid var(--line);box-shadow:var(--shadow);
  overflow-y:auto;transform:translateX(-102%);transition:transform .2s ease;padding:14px 10px 44px}
.sidebar.open{transform:none}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:60}
.grp{font-size:11px;text-transform:uppercase;color:var(--faint);margin:18px 10px 6px}
.bk{display:flex;align-items:baseline;gap:8px;width:100%;text-align:left;background:none;border:0;
  border-radius:var(--radius);padding:9px 11px;font-size:15px}
.bk:hover,.bk:focus-visible{background:var(--surface2);outline:0}
.bk .nm{flex:1}
.bk .badge{font-size:10px;color:var(--faint);border:1px solid var(--line);border-radius:6px;
  padding:1px 6px;white-space:nowrap}
.bk.optional .badge{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 45%,var(--line))}
.bk.tradition .nm{color:var(--seam)}

.view{max-width:820px;margin:0 auto;padding:22px 16px 92px}
.home h1{font-family:var(--serif);font-weight:700;font-size:34px;line-height:1.05;margin:16px 0 10px}
.lede{color:var(--dim);font-size:17px;max-width:62ch}
.hint{color:var(--faint);font-size:14px;margin-top:24px;border-left:2px solid var(--line);padding-left:12px}

.rhead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 4px}
.booktitle{background:none;border:0;padding:0;text-align:left;font-family:var(--serif);font-size:30px;
  font-weight:700;line-height:1.05;color:var(--ink)}
.booktitle span{color:var(--accent);font-weight:600;margin-left:5px}
.booktitle:hover{color:var(--accent2)}
.rform{font-size:12px;color:var(--faint);margin:0 0 12px}
.badge,.tier,.localbadge{font-size:11px;border:1px solid var(--line);border-radius:6px;
  padding:2px 7px;white-space:nowrap;color:var(--faint);background:color-mix(in srgb,var(--surface) 78%,transparent)}
.chapnav{display:grid;grid-template-columns:42px minmax(0,1fr) 42px;gap:8px;align-items:center;margin:14px 0 10px}
.chapterstep,.chapterselect{height:40px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius)}
.chapterstep:hover,.chapterselect:hover{border-color:var(--accent2)}
.chapterstep[disabled]{opacity:.38}
.chapterselect{width:100%;padding:0 12px;color:var(--ink)}
.chips{display:flex;gap:7px;overflow-x:auto;padding:2px 0 12px;margin:0 0 12px;scrollbar-width:thin}
.chip{flex:0 0 auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  min-width:38px;height:34px;padding:0 9px;font-size:14px;color:var(--dim)}
.chip:hover{border-color:var(--accent2);color:var(--ink)}
.chip.cur{background:var(--accent);color:#17120a;border-color:var(--accent);font-weight:700}

.v{position:relative;border-top:1px solid color-mix(in srgb,var(--line) 72%,transparent);
  padding:14px 48px 15px 10px;scroll-margin-top:126px;border-radius:var(--radius)}
.v:first-of-type{border-top:0}
.v:hover{background:color-mix(in srgb,var(--surface) 62%,transparent)}
.v.flash{background:var(--surface2);box-shadow:inset 3px 0 0 var(--accent)}
.v.bookmarked{box-shadow:inset 3px 0 0 var(--accent2)}
.v .num{color:var(--accent);font-size:12px;font-weight:700;vertical-align:super;margin-right:7px;font-family:var(--sans)}
.v .d{font-family:var(--serif);font-size:20px;line-height:1.72;margin:0;max-width:66ch}
.v.marked .d{background:linear-gradient(transparent 58%,var(--mark) 58%,var(--mark) 88%,transparent 88%)}
.vtools{position:absolute;top:10px;right:8px;display:flex;flex-direction:column;gap:6px}
.vtool{width:31px;height:31px;border-radius:var(--radius);border:1px solid var(--line);
  background:var(--surface);color:var(--faint);display:grid;place-items:center;padding:0}
.vtool:hover,.vtool:focus-visible{border-color:var(--accent2);color:var(--ink);outline:0}
.vtool.on{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 58%,var(--line));background:color-mix(in srgb,var(--surface) 78%,var(--accent))}
.noteslot{margin-top:9px;max-width:66ch}
.notepreview{border-left:2px solid var(--accent2);padding:6px 0 6px 10px;color:var(--dim);font-size:14px;white-space:pre-wrap}
.noteedit{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px;margin-top:8px}
.noteedit textarea{width:100%;resize:vertical;background:transparent;border:0;outline:0;color:var(--ink);
  min-height:74px;line-height:1.45}
.noteacts{display:flex;justify-content:flex-end;gap:7px;margin-top:4px}

.layerset{display:none;margin:12px 0 0;max-width:70ch}
body.layers .layerset{display:block}
.layer{display:grid;grid-template-columns:58px minmax(0,1fr);column-gap:8px;margin:7px 0;border-left:2px solid var(--line);
  padding:8px 10px;background:color-mix(in srgb,var(--surface) 62%,transparent);
  border-radius:0 var(--radius) var(--radius) 0;font-size:14px}
.layer .tag{grid-column:1;color:var(--faint);font-size:10px;text-transform:uppercase;font-family:var(--sans);direction:ltr}
.layer.src{color:var(--src);font-family:var(--source);font-size:17px;line-height:1.65}
.layer.tr{color:var(--dim);font-style:italic}
.layer.seam{color:var(--seam);font-size:13.5px}
.srcwords{grid-column:2;display:block;word-break:normal;overflow-wrap:anywhere;direction:auto;unicode-bidi:plaintext}
.wordlink{color:inherit;text-decoration:none;border-bottom:1px dotted currentColor;border-radius:4px;padding:0 1px}
.wordlink:hover,.wordlink:focus-visible{background:color-mix(in srgb,var(--src) 18%,transparent);outline:0}
.extmark{grid-column:2;display:block;margin-top:7px;color:var(--faint);font-family:var(--sans);font-size:11px;direction:ltr}

.navrow{display:flex;justify-content:space-between;gap:10px;margin:28px 0 0}
.navrow button,.altbtn{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:9px 14px;font-size:14px;color:var(--accent2)}
.navrow button:hover,.altbtn:hover{border-color:var(--accent2);color:var(--ink)}
.navrow button[disabled]{opacity:.35;pointer-events:none}

.results h2,.sources-view h2,.review-view h2{font-family:var(--serif);font-weight:700;font-size:24px;margin:6px 0 8px}
.rcount{color:var(--faint);font-size:13px;margin-bottom:16px}
.hit,.reviewitem{display:block;width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:12px 13px;margin:8px 0}
.hit:hover,.reviewitem:hover{border-color:var(--accent2)}
.hit .ref,.reviewitem .ref{color:var(--accent2);font-size:13px;font-weight:700;margin-bottom:3px}
.reviewitem .ref span{float:right;color:var(--accent)}
.hit .snip,.reviewitem .snip{color:var(--dim);font-size:15.5px;font-family:var(--serif);line-height:1.55}
.reviewitem .note{margin-top:8px;color:var(--seam);font-size:14px;white-space:pre-wrap;border-left:2px solid var(--line);padding-left:9px}
.hit mark{background:color-mix(in srgb,var(--accent) 26%,transparent);color:var(--ink);border-radius:3px;padding:0 2px}

.asktiles{margin-top:30px;border-top:1px solid var(--line);padding-top:20px}
.askhead{color:var(--dim);font-size:14.5px;max-width:64ch;line-height:1.58}
.askhead b{color:var(--accent)}
.exrow{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.ex{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:7px 11px;font-size:13.5px;color:var(--dim)}
.ex:hover{border-color:var(--accent);color:var(--ink)}

.answer .qline{font-family:var(--serif);font-size:24px;color:var(--accent);margin:2px 0 16px}
.answer .lead{color:var(--dim);font-size:15.5px;font-style:italic;border-left:2px solid var(--line);
  padding-left:13px;margin:0 0 20px}
.answer .closing{color:var(--faint);font-size:13.5px;margin-top:22px;border-top:1px solid var(--line);padding-top:14px}
.sec{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;margin:12px 0}
.sechead{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.sechead h3{font-family:var(--serif);font-weight:700;font-size:18px;margin:0}
.tier.ta{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 44%,var(--line))}
.tier.tb{color:var(--seam);border-color:color-mix(in srgb,var(--seam) 44%,var(--line))}
.tier.tc{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 44%,var(--line))}
.tier.td{color:var(--accent2);border-color:color-mix(in srgb,var(--accent2) 44%,var(--line))}
.sec .mk{font-size:15.5px;color:var(--ink);line-height:1.62}
.sec.seam{border-left:3px solid var(--danger)}
.sec.held{border-left:3px solid var(--accent2)}
.sec.witness{border-left:3px solid var(--seam)}
.sec.orders{border-left:3px solid var(--accent)}
.sec.word .mk{font-family:var(--source);font-size:16px}
.cites{margin-top:11px;display:flex;flex-direction:column;gap:7px}
.cite{display:block;width:100%;text-align:left;background:var(--surface2);border:1px solid var(--line);
  border-radius:var(--radius);padding:9px 11px}
.cite:hover{border-color:var(--accent2)}
.cite .ref{color:var(--accent2);font-size:12.5px;font-weight:700;margin-bottom:3px}
.cite .ctx{color:var(--dim);font-size:14.5px;font-family:var(--serif)}
.refuse{background:var(--surface);border:1px solid color-mix(in srgb,var(--danger) 55%,var(--line));
  border-radius:var(--radius);padding:16px;color:var(--dim);font-size:15px;line-height:1.6}
.refuse b{color:var(--danger)}
.guard{color:var(--danger);font-size:13px;border:1px dashed color-mix(in srgb,var(--danger) 55%,var(--line));
  border-radius:var(--radius);padding:9px 12px;margin-top:14px}

.linkbtn{background:none;border:0;color:var(--accent2);text-decoration:underline;padding:0;font:inherit}
.srcline{margin-top:18px}
.srcnote{color:var(--dim);font-size:14px;line-height:1.6;border-left:2px solid var(--line);padding-left:13px;max-width:66ch}
.srcnote b{color:var(--danger)}
.srcq{color:var(--dim);font-size:14px;margin:14px 0 4px}
.srccard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;margin:12px 0}
.srccard .dom{color:var(--accent2);font-size:12.5px;margin:-2px 0 9px}
.srcrow{font-size:14px;color:var(--ink);margin:5px 0;line-height:1.5}
.srcrow.bias{color:var(--dim)}
.srcrow .k{font-size:10px;text-transform:uppercase;color:var(--faint);margin-right:9px;display:inline-block;min-width:42px}
.srcacts{display:flex;flex-wrap:wrap;gap:8px;margin-top:11px}
.extbtn{display:inline-flex;gap:8px;align-items:center;background:var(--surface2);border:1px solid var(--line);
  border-radius:var(--radius);padding:8px 11px;font-size:13.5px;color:var(--accent2);text-decoration:none}
.extbtn:hover{border-color:var(--accent2)}
.exttier{color:var(--danger);font-size:11px}

.reviewhead{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.localbadge{color:var(--seam)}
.reviewcounts{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}
.reviewcounts span{font-size:12px;color:var(--dim);border:1px solid var(--line);border-radius:var(--radius);padding:4px 8px;background:var(--surface)}

.foot{position:fixed;bottom:0;left:0;right:0;text-align:center;font-size:11px;color:var(--faint);
  padding:6px;pointer-events:none}
.empty{color:var(--faint);padding:30px 0;text-align:center}

@media(min-width:720px){
  .top{grid-template-columns:auto minmax(88px,max-content) auto minmax(280px,1fr) auto auto auto}
  #menuBtn{grid-column:1}
  .brand{grid-column:2}
  #themeBtn{grid-column:3}
  .omni{grid-column:4;grid-row:1}
  #askBtn{grid-column:5}
  #reviewBtn{grid-column:6}
  #layersBtn{grid-column:7}
}
@media(min-width:1040px){
  .top{z-index:80}
  .sidebar{transform:none;box-shadow:none;top:55px;height:calc(100% - 55px);z-index:30}
  .scrim{display:none!important}
  .view{margin-left:310px;max-width:900px;padding-left:34px;padding-right:34px}
  #menuBtn{display:none}
  .v{padding-left:18px}
}
