:root{
  --bg:#f7f4ec;
  --paper:#fffdf8;
  --ink:#23201b;
  --muted:#7a7367;
  --rule:#e2dccf;
  --accent:#7c5a3a;
  --maxw:42rem;
}
:root[data-theme="dark"]{
  --bg:#16140f;
  --paper:#1d1a14;
  --ink:#e7e1d4;
  --muted:#9a9384;
  --rule:#332f26;
  --accent:#c79b6d;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:"EB Garamond",Georgia,"Times New Roman",serif;
  font-size:1.275rem;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* ---- top bar ---- */
.topbar{
  position:sticky;top:0;z-index:10;
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;
  padding:.7rem clamp(1rem,4vw,2rem);
  background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--rule);
  font-family:"Spectral",serif;
}
.bar-link{
  color:var(--muted);text-decoration:none;
  font-size:.82rem;letter-spacing:.02em;
}
.topbar > a.bar-link{font-weight:600;color:var(--ink);max-width:60vw;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.bar-right{display:flex;align-items:center;gap:1.1rem}
.bar-link:hover{color:var(--accent)}
.theme-btn{background:none;border:none;cursor:pointer;font-size:1rem;color:var(--muted);padding:0}
.bar-title{flex:0 1 auto;min-width:0}
.topbar > a.bar-title{max-width:32vw}

/* ---- header search ---- */
.bar-center{flex:1 1 auto;min-width:0;display:flex;justify-content:center;position:relative;padding:0 1rem}
.book-search-input{
  width:100%;max-width:24rem;box-sizing:border-box;
  font-family:"Spectral",serif;font-size:.85rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--rule);border-radius:1.2rem;
  padding:.4rem .9rem;outline:none;transition:border-color .15s,box-shadow .15s;
}
.book-search-input::placeholder{color:var(--muted)}
.book-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 14%,transparent)}
.book-search-results{
  position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);
  width:min(36rem,92vw);max-height:70vh;overflow-y:auto;z-index:60;
  background:var(--paper);border:1px solid var(--rule);border-radius:.6rem;
  box-shadow:0 8px 28px rgba(0,0,0,.2);padding:.3rem;
}
.book-search-results[hidden]{display:none}
.bs-item{display:block;text-decoration:none;color:var(--ink);padding:.5rem .6rem;border-radius:.4rem}
.bs-item:hover,.bs-item.sel{background:color-mix(in srgb,var(--accent) 10%,transparent)}
.bs-where{display:block;font-family:"Spectral",serif;font-size:.7rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--accent);margin-bottom:.15rem}
.bs-snip{display:block;font-family:"EB Garamond",Georgia,serif;font-size:.95rem;line-height:1.45;color:var(--muted)}
.bs-snip mark{background:color-mix(in srgb,var(--hl) 80%,transparent);color:var(--ink);border-radius:.12em;padding:0 .06em}
.bs-empty{padding:.6rem .7rem;font-family:"EB Garamond",Georgia,serif;font-size:.95rem;color:var(--muted)}

/* paragraph flash when jumping to a search result */
@keyframes para-flash{0%,60%{background:color-mix(in srgb,var(--accent) 14%,transparent)}100%{background:transparent}}
.prose p.para-flash{animation:para-flash 1.8s ease;border-radius:.2rem}

@media (max-width:680px){
  .bar-center{display:none}
  .topbar > a.bar-title{max-width:55vw}
}

/* ---- progress ---- */
.progress{position:sticky;top:0;height:2px;background:transparent;z-index:11;margin-top:-2px}
.progress-bar{height:2px;width:0;background:var(--accent);transition:width .1s linear}

/* ---- cover ---- */
.cover{display:flex;justify-content:center;padding:clamp(3rem,12vh,8rem) 1.5rem 2rem}
.cover-inner{max-width:var(--maxw);text-align:center}
.kicker{font-family:"Spectral",serif;text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;color:var(--muted);margin:0 0 1.6rem}
.cover-title{
  font-family:"Spectral",serif;font-weight:600;
  font-size:clamp(2.1rem,6vw,3.4rem);line-height:1.12;margin:0;
  letter-spacing:-.01em;
}
.cover-sub{color:var(--muted);font-style:italic;font-size:1.2rem;margin:1.2rem auto 2rem;max-width:32rem}
.cover-author{font-family:"Spectral",serif;letter-spacing:.04em;margin:0 0 2.4rem;font-size:1rem}
.cover-blurb{text-align:left;color:var(--ink);max-width:34rem;margin:0 auto 2.6rem;font-size:1.12rem}
.begin{
  display:inline-block;font-family:"Spectral",serif;
  text-decoration:none;color:var(--paper);background:var(--accent);
  padding:.7rem 1.6rem;border-radius:2rem;font-size:.95rem;letter-spacing:.02em;
  transition:transform .15s ease,opacity .15s ease;
}
.begin:hover{transform:translateY(-1px);opacity:.92}

/* ---- contents block on cover ---- */
.contents-block{max-width:var(--maxw);margin:1rem auto 4rem;padding:0 1.5rem}
.contents-h,.page-h{font-family:"Spectral",serif;font-weight:600;font-size:1.05rem;
  text-transform:uppercase;letter-spacing:.16em;color:var(--muted);
  text-align:center;margin:2.5rem 0 1.5rem}
.toc{list-style:none;margin:0;padding:0;counter-reset:none}
.toc li{border-top:1px solid var(--rule)}
.toc li:last-child{border-bottom:1px solid var(--rule)}
.toc a{display:flex;align-items:baseline;gap:1rem;padding:.85rem .4rem;
  text-decoration:none;color:var(--ink);transition:background .15s,padding .15s}
.toc a:hover{background:var(--paper);padding-left:.9rem}
.toc-num{font-family:"Spectral",serif;color:var(--accent);font-size:.9rem;min-width:1.5rem}
.toc-title{font-size:1.08rem}
.ded-link{text-align:center;margin-top:1.6rem}
.ded-link a{color:var(--accent);text-decoration:none;font-size:.95rem;font-family:"Spectral",serif}

/* ---- reader ---- */
.reader{max-width:var(--maxw);margin:0 auto;padding:clamp(2rem,6vw,4rem) clamp(1.1rem,5vw,1.5rem) 1rem}
.chap-head{margin:1rem 0 2.6rem;text-align:center}
.chap-num{font-family:"Spectral",serif;text-transform:uppercase;letter-spacing:.24em;
  font-size:.72rem;color:var(--accent);margin:0 0 .8rem}
.chap-title{font-family:"Spectral",serif;font-weight:600;font-size:clamp(1.7rem,5vw,2.5rem);
  line-height:1.18;margin:0;letter-spacing:-.01em}
.prose p{margin:0 0 1.45rem;text-align:left;hanging-punctuation:first}
.prose p:first-of-type::first-letter{
  font-family:"Spectral",serif;font-size:3.1rem;line-height:.8;
  float:left;padding:.35rem .55rem 0 0;color:var(--accent);font-weight:600;
}
.toc-full{margin-bottom:1rem}
.rule{border:none;border-top:1px solid var(--rule);margin:3rem 0}

/* ---- chapter nav ---- */
.chap-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  margin:3.5rem 0 1rem;padding-top:1.6rem;border-top:1px solid var(--rule);
  font-family:"Spectral",serif;font-size:.9rem}
.chap-nav a{color:var(--accent);text-decoration:none}
.chap-nav a:hover{text-decoration:underline}
.nav-top{color:var(--muted)!important}

.site-foot{text-align:center;color:var(--muted);font-family:"Spectral",serif;
  font-size:.78rem;letter-spacing:.04em;padding:2.5rem 1rem 3.5rem;
  border-top:1px solid var(--rule);margin-top:2rem}

.alt-read{margin:1.3rem 0 0}
.alt-read a{color:var(--muted);text-decoration:none;font-family:"Spectral",serif;
  font-size:.92rem;border-bottom:1px solid var(--rule);padding-bottom:1px}
.alt-read a:hover{color:var(--accent)}

@media (max-width:480px){
  body{font-size:1.18rem}
  .toc-title{font-size:1rem}
}

/* ===== flip-book view ===== */
.flip-body{height:100vh;overflow:hidden;display:flex;flex-direction:column}
.loader{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;
  background:var(--bg);font-family:"Spectral",serif;color:var(--muted);letter-spacing:.04em;font-size:1rem}
.stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem}
/* the [hidden] rules must beat the display rules above so toggling works in every browser */
.loader[hidden],.stage[hidden],.flip-foot[hidden]{display:none!important}
.flipbook{touch-action:none}
.flip-arrow{flex:0 0 auto;background:none;border:1px solid var(--rule);
  color:var(--muted);width:2.4rem;height:2.4rem;border-radius:50%;cursor:pointer;
  font-size:1.4rem;line-height:1;display:flex;align-items:center;justify-content:center;
  transition:color .15s,border-color .15s;font-family:"Spectral",serif}
.flip-arrow:hover{color:var(--accent);border-color:var(--accent)}

/* individual leaves */
.page{background:var(--paper);overflow:hidden}
.page.--left{box-shadow:inset -14px 0 22px -16px rgba(0,0,0,.45)}
.page.--right{box-shadow:inset 14px 0 22px -16px rgba(0,0,0,.45)}
.page-content{position:relative;width:100%;height:100%;
  padding:3.2rem 2.3rem 2.9rem;color:var(--ink);
  font-family:"EB Garamond",Georgia,serif;font-size:1.07rem;line-height:1.58;
  text-align:justify;hyphens:auto}
.page-content .measurer,.measurer{position:absolute;left:-9999px;top:0;visibility:hidden}
.page-content p{margin:0 0 .85rem}
.run-head{position:absolute;top:1.15rem;left:2.3rem;right:2.3rem;
  font-family:"Spectral",serif;font-size:.62rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.page-num{position:absolute;bottom:1.2rem;left:0;right:0;text-align:center;
  font-family:"Spectral",serif;font-size:.72rem;color:var(--muted)}
.bk-chaphead{margin:.5rem 0 1.4rem;text-align:center}
.bk-chapnum{font-family:"Spectral",serif;text-transform:uppercase;letter-spacing:.2em;
  font-size:.62rem;color:var(--accent);margin:0 0 .5rem}
.bk-chaptitle{font-family:"Spectral",serif;font-weight:600;font-size:1.3rem;
  line-height:1.2;margin:0}

/* cover leaf */
.page-cover{background:
  linear-gradient(145deg,color-mix(in srgb,var(--accent) 16%,var(--paper)),var(--paper))}
.cover-face{height:100%;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:1rem}
.bk-kicker{font-family:"Spectral",serif;text-transform:uppercase;letter-spacing:.22em;
  font-size:.6rem;color:var(--muted);margin:0 0 1rem}
.bk-title{font-family:"Spectral",serif;font-weight:600;font-size:1.55rem;line-height:1.15;
  margin:0 0 .8rem;color:var(--ink)}
.bk-author{font-family:"Spectral",serif;font-size:.85rem;letter-spacing:.05em;
  color:var(--muted);margin:0 0 1.4rem}
.bk-toc{list-style:none;margin:0;padding:0;text-align:left;max-width:80%;
  font-size:.74rem;line-height:1.9;color:var(--ink);columns:1}
.bk-toc li{display:flex;gap:.5rem}
.bk-toc li span{color:var(--accent);min-width:1.1rem;font-family:"Spectral",serif}

.flip-foot{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;
  align-items:center;gap:1.4rem;padding:.7rem 1rem;border-top:1px solid var(--rule);
  background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(8px);
  font-family:"Spectral",serif;font-size:.74rem;color:var(--muted)}
.flip-hint{color:var(--muted);opacity:.75}
@media (max-width:560px){.flip-hint{display:none}}

/* bookmark button */
.bk-mark-btn{display:inline-flex;align-items:center;gap:.15rem;background:none;
  border:1px solid var(--rule);color:var(--muted);font-family:"Spectral",serif;
  font-size:.72rem;letter-spacing:.04em;padding:.26rem .7rem;border-radius:2rem;
  cursor:pointer;transition:color .15s,border-color .15s,background .15s}
.bk-mark-btn:hover{color:var(--accent);border-color:var(--accent)}
.bk-mark-btn.is-marked{color:var(--accent);border-color:var(--accent);
  background:color-mix(in srgb,var(--accent) 13%,transparent)}

/* resume banner */
.resume-bar{position:fixed;top:62px;left:50%;transform:translateX(-50%);z-index:45;
  display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;justify-content:center;
  max-width:92vw;background:var(--paper);border:1px solid var(--rule);border-radius:.6rem;
  padding:.5rem .7rem;box-shadow:0 8px 28px rgba(0,0,0,.16);font-family:"Spectral",serif}
.resume-bar[hidden]{display:none!important}
.resume-msg{font-size:.78rem;color:var(--muted)}
.resume-go{background:var(--accent);color:var(--paper);border:none;border-radius:2rem;
  padding:.34rem .9rem;font-family:"Spectral",serif;font-size:.76rem;cursor:pointer;
  transition:opacity .15s}
.resume-go:hover{opacity:.9}
.resume-x{background:none;border:none;color:var(--muted);font-size:1.15rem;line-height:1;
  cursor:pointer;padding:0 .15rem}
.resume-x:hover{color:var(--accent)}

/* ===== scripture links + modal ===== */
.scripture{color:var(--accent);text-decoration:none;cursor:pointer;
  border-bottom:1px dotted color-mix(in srgb,var(--accent) 55%,transparent);
  white-space:nowrap;transition:background .15s}
.scripture:hover{background:color-mix(in srgb,var(--accent) 13%,transparent)}
body.sx-open{overflow:hidden}
.sx-modal{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.sx-modal[hidden]{display:none!important}
.sx-backdrop{position:absolute;inset:0;background:rgba(20,16,10,.5);backdrop-filter:blur(2px)}
.sx-card{position:relative;z-index:1;width:min(40rem,94vw);max-height:82vh;display:flex;flex-direction:column;
  background:var(--paper);color:var(--ink);border:1px solid var(--rule);border-radius:.7rem;
  box-shadow:0 18px 50px rgba(0,0,0,.32);padding:1.6rem 1.7rem 1.3rem}
.sx-close{position:absolute;top:.6rem;right:.8rem;background:none;border:none;font-size:1.5rem;
  line-height:1;color:var(--muted);cursor:pointer}
.sx-close:hover{color:var(--accent)}
.sx-ref{font-family:"Spectral",serif;font-weight:600;font-size:1.15rem;color:var(--ink);
  margin:0 1.5rem .9rem 0;letter-spacing:.01em}
.sx-verses{overflow-y:auto;font-family:"EB Garamond",Georgia,serif;font-size:1.12rem;line-height:1.62;
  flex:1 1 auto;min-height:4rem}
.sx-more{flex:0 0 auto;display:block;width:100%;background:none;border:none;cursor:pointer;
  font-family:"Spectral",serif;font-size:.74rem;letter-spacing:.04em;color:var(--accent);
  padding:.5rem .5rem;border-radius:.35rem;transition:background .15s,color .15s}
.sx-more:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 12%,transparent)}
.sx-up{margin-bottom:.3rem;border-bottom:1px solid var(--rule)}
.sx-down{margin-top:.3rem;border-top:1px solid var(--rule)}
.sx-more:disabled{color:var(--muted);cursor:default;font-style:italic;opacity:.8;letter-spacing:.02em}
.sx-v{margin:0 0 .5rem;color:var(--muted)}
.sx-v sup{color:var(--accent);font-size:.66em;font-weight:600;margin-right:.25em;vertical-align:super}
.sx-v.hl{color:var(--ink);background:color-mix(in srgb,var(--accent) 12%,transparent);
  border-left:2px solid var(--accent);padding:.18rem .5rem;border-radius:0 .2rem .2rem 0;margin-left:-.5rem}
.sx-foot{font-family:"Spectral",serif;font-size:.72rem;color:var(--muted);
  margin:1rem 0 0;padding-top:.8rem;border-top:1px solid var(--rule)}

/* ============ user highlights ============ */
:root{--hl:#ffe49b;--hl-edge:#e8b73a}
:root[data-theme="dark"]{--hl:#5a4a1e;--hl-edge:#caa64f}
mark.hl{
  background:var(--hl);color:inherit;border-radius:.12em;
  padding:.02em 0;cursor:pointer;
  box-shadow:0 0 0 .5px color-mix(in srgb,var(--hl-edge) 55%,transparent);
  transition:background .15s;
}
mark.hl:hover{background:color-mix(in srgb,var(--hl) 78%,var(--hl-edge))}
.scripture mark.hl{color:var(--accent)}
mark.hl.hl-flash{animation:hl-flash 1.6s ease}
@keyframes hl-flash{0%,55%{box-shadow:0 0 0 3px color-mix(in srgb,var(--hl-edge) 70%,transparent)}100%{box-shadow:0 0 0 .5px color-mix(in srgb,var(--hl-edge) 55%,transparent)}}

/* count badge on the top-bar button */
.hl-open-btn{background:none;border:none;cursor:pointer;font-family:inherit;
  font-size:.82rem;letter-spacing:.02em;color:var(--muted);padding:0;display:inline-flex;align-items:center;gap:.32em}
.hl-open-btn:hover{color:var(--accent)}
.hl-count{display:inline-flex;align-items:center;justify-content:center;
  min-width:1.15rem;height:1.15rem;padding:0 .3em;border-radius:1rem;
  background:var(--accent);color:var(--paper);font-size:.66rem;font-weight:600;line-height:1}
.hl-count[hidden]{display:none}

/* floating "Highlight" button */
.hl-fab{position:absolute;z-index:90;display:none;
  font-family:"Spectral",serif;font-size:.8rem;letter-spacing:.02em;
  background:var(--ink);color:var(--paper);border:none;border-radius:.4rem;
  padding:.4rem .75rem;cursor:pointer;box-shadow:0 3px 12px rgba(0,0,0,.25)}
.hl-fab.show{display:block}
.hl-fab:hover{background:var(--accent)}

/* noted highlights: subtle underline + a small dot marker */
mark.hl.hl-noted{box-shadow:0 0 0 .5px color-mix(in srgb,var(--hl-edge) 55%,transparent),inset 0 -2px 0 var(--hl-edge)}
mark.hl.hl-noted-first::after{content:"";display:inline-block;width:.42em;height:.42em;
  margin-left:.18em;border-radius:50%;background:var(--accent);vertical-align:.55em}

/* note editor popup when clicking an existing highlight */
.hl-pop{position:absolute;z-index:90;width:min(20rem,86vw);background:var(--paper);
  border:1px solid var(--rule);border-radius:.5rem;box-shadow:0 6px 22px rgba(0,0,0,.2);padding:.55rem}
.hl-note-input{width:100%;box-sizing:border-box;resize:vertical;min-height:3.2rem;
  font-family:"EB Garamond",Georgia,serif;font-size:.98rem;line-height:1.45;color:var(--ink);
  background:var(--bg);border:1px solid var(--rule);border-radius:.35rem;padding:.45rem .55rem}
.hl-note-input:focus{outline:none;border-color:var(--accent)}
.hl-pop-actions{display:flex;justify-content:space-between;gap:.5rem;margin-top:.5rem}
.hl-note-save{background:var(--accent);color:var(--paper);border:none;cursor:pointer;
  font-family:"Spectral",serif;font-size:.78rem;padding:.4rem .8rem;border-radius:.35rem}
.hl-note-save:hover{filter:brightness(1.08)}
.hl-pop-remove{background:none;border:1px solid var(--rule);cursor:pointer;font-family:"Spectral",serif;
  font-size:.78rem;color:var(--muted);padding:.4rem .7rem;border-radius:.35rem}
.hl-pop-remove:hover{color:var(--accent);border-color:var(--accent)}

/* notes inside the slide-out panel */
.hl-item-row{display:flex;align-items:flex-start;gap:.4rem}
.hl-note-disp{font-family:"EB Garamond",Georgia,serif;font-size:.95rem;line-height:1.45;
  color:var(--muted);font-style:italic;cursor:pointer;margin:.15rem 0 0 .55rem;
  padding-left:.55rem;border-left:2px solid var(--rule)}
.hl-note-disp:hover{color:var(--ink);border-left-color:var(--accent)}
.hl-note-edit-wrap{margin:.3rem 0 0 .55rem}
.hl-note-ta{width:100%;box-sizing:border-box;resize:vertical;min-height:2.6rem;
  font-family:"EB Garamond",Georgia,serif;font-size:.95rem;line-height:1.45;color:var(--ink);
  background:var(--bg);border:1px solid var(--rule);border-radius:.35rem;padding:.4rem .5rem}
.hl-note-ta:focus{outline:none;border-color:var(--accent)}
.hl-note-edit-actions{display:flex;gap:.5rem;margin-top:.35rem}
.hl-note-savep{background:var(--accent);color:var(--paper);border:none;cursor:pointer;
  font-family:"Spectral",serif;font-size:.74rem;padding:.32rem .7rem;border-radius:.3rem}
.hl-note-cancel{background:none;border:1px solid var(--rule);color:var(--muted);cursor:pointer;
  font-family:"Spectral",serif;font-size:.74rem;padding:.32rem .6rem;border-radius:.3rem}
.hl-note-cancel:hover{color:var(--accent);border-color:var(--accent)}
.hl-note-toggle{background:none;border:none;cursor:pointer;font-family:"Spectral",serif;
  font-size:.72rem;color:var(--accent);padding:.25rem .55rem;margin:.05rem 0 0 .3rem;border-radius:.3rem;opacity:.85}
.hl-note-toggle:hover{opacity:1;text-decoration:underline}

/* slide-out panel */
body.hl-panel-open{overflow:hidden}
.hl-panel{position:fixed;inset:0;z-index:85}
.hl-panel[hidden]{display:none!important}
.hl-backdrop{position:absolute;inset:0;background:rgba(20,16,10,.45);backdrop-filter:blur(2px)}
.hl-aside{position:absolute;top:0;right:0;height:100%;width:min(24rem,90vw);
  background:var(--paper);border-left:1px solid var(--rule);
  display:flex;flex-direction:column;box-shadow:-6px 0 28px rgba(0,0,0,.18);
  animation:hl-slide .22s ease}
@keyframes hl-slide{from{transform:translateX(100%)}to{transform:translateX(0)}}
.hl-head{display:flex;align-items:center;justify-content:space-between;
  padding:1rem 1.2rem;border-bottom:1px solid var(--rule)}
.hl-head-t{font-family:"Spectral",serif;font-weight:600;font-size:1.05rem;color:var(--ink)}
.hl-x{background:none;border:none;font-size:1.5rem;line-height:1;color:var(--muted);cursor:pointer;padding:0}
.hl-x:hover{color:var(--accent)}
.hl-groupbar{flex:0 0 auto;padding:.7rem 1.2rem;border-bottom:1px solid var(--rule);
  display:flex;flex-direction:column;gap:.5rem}
.hl-group-select{width:100%;box-sizing:border-box;font-family:"Spectral",serif;font-size:.9rem;
  color:var(--ink);background:var(--bg);border:1px solid var(--rule);border-radius:.4rem;padding:.4rem .55rem}
.hl-group-select:focus{outline:none;border-color:var(--accent)}
.hl-group-actions{display:flex;gap:.4rem}
.hl-group-new,.hl-group-rename,.hl-group-del{flex:1 1 0;background:none;border:1px solid var(--rule);
  border-radius:.35rem;cursor:pointer;font-family:"Spectral",serif;font-size:.74rem;color:var(--muted);padding:.35rem .4rem}
.hl-group-new:hover,.hl-group-rename:hover,.hl-group-del:hover{color:var(--accent);border-color:var(--accent)}
.hl-group-del:disabled{opacity:.4;cursor:default;color:var(--muted);border-color:var(--rule)}
.hl-asnew{display:flex;align-items:center;gap:.4rem;margin:0 0 .55rem;
  font-family:"Spectral",serif;font-size:.74rem;color:var(--muted);cursor:pointer}
.hl-asnew input{cursor:pointer}
.hl-list{flex:1 1 auto;overflow-y:auto;padding:.6rem 1.2rem 1rem}
.hl-empty{font-family:"EB Garamond",Georgia,serif;color:var(--muted);font-size:1rem;line-height:1.55;margin-top:1rem}
.hl-group{margin-top:1.1rem}
.hl-group-h{font-family:"Spectral",serif;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);margin:0 0 .5rem;font-weight:600}
.hl-item{display:flex;align-items:flex-start;gap:.4rem;margin:0 0 .55rem}
.hl-go{flex:1 1 auto;text-align:left;background:none;border:none;cursor:pointer;
  font-family:"EB Garamond",Georgia,serif;font-size:1rem;line-height:1.45;color:var(--ink);
  padding:.45rem .55rem;border-radius:.35rem;border-left:3px solid var(--hl-edge)}
.hl-go:hover{background:color-mix(in srgb,var(--accent) 9%,transparent)}
.hl-del{flex:0 0 auto;background:none;border:none;cursor:pointer;color:var(--muted);
  font-size:1.1rem;line-height:1;padding:.35rem .4rem;border-radius:.3rem}
.hl-del:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent)}
.hl-foot{flex:0 0 auto;padding:.8rem 1.2rem;border-top:1px solid var(--rule)}
.hl-io{display:flex;gap:.5rem;margin-bottom:.55rem}
.hl-export,.hl-import{flex:1 1 0;background:none;border:1px solid var(--rule);border-radius:.4rem;cursor:pointer;
  font-family:"Spectral",serif;font-size:.78rem;color:var(--ink);padding:.45rem .6rem}
.hl-export:hover,.hl-import:hover{color:var(--accent);border-color:var(--accent)}
.hl-io-msg{margin:0 0 .55rem;font-family:"EB Garamond",Georgia,serif;font-size:.86rem;
  line-height:1.4;color:var(--muted)}
.hl-io-msg.is-err{color:#b4452f}
:root[data-theme="dark"] .hl-io-msg.is-err{color:#e08a72}
.hl-io-msg[hidden]{display:none}
.hl-clear{background:none;border:1px solid var(--rule);border-radius:.4rem;cursor:pointer;
  font-family:"Spectral",serif;font-size:.78rem;color:var(--muted);padding:.45rem .8rem;width:100%}
.hl-clear:hover{color:var(--accent);border-color:var(--accent)}
