*{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#fff;--fg:#111;--mut:#666;--bd:#e5e5e5;--ac:#2563eb;--cd:#f5f5f5}
body.dark{--bg:#111;--fg:#eee;--mut:#999;--bd:#333;--cd:#1a1a1a}
body.sepia{--bg:#f4ecd8;--fg:#5b4636;--mut:#8a7459;--bd:#d8cdb6;--cd:#ebe2cb}
body{background:var(--bg);color:var(--fg);font-family:system-ui,sans-serif;min-height:100vh}
a{color:var(--ac);text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit}
button{background:var(--ac);color:#fff;border:0;padding:.55rem 1rem;border-radius:6px;cursor:pointer}
button.sec{background:transparent;color:var(--fg);border:1px solid var(--bd)}
button.danger{background:#dc2626}
button:hover{opacity:.9}
input,textarea,select{background:var(--bg);border:1px solid var(--bd);border-radius:6px;padding:.55rem;width:100%}
textarea{min-height:240px;font-family:ui-monospace,monospace;resize:vertical}
.wrap{max-width:900px;margin:0 auto;padding:1rem}
.row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.row.between{justify-content:space-between}
.col{display:flex;flex-direction:column;gap:.75rem}
.card{background:var(--cd);border:1px solid var(--bd);border-radius:8px;padding:1rem}
.book{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border:1px solid var(--bd);border-radius:6px;margin-bottom:.5rem;background:var(--cd);cursor:pointer}
.book:hover{border-color:var(--ac)}
.book .meta{font-size:.85rem;color:var(--mut)}
.bar{font-size:.8rem;color:var(--mut)}
.prog{height:3px;background:var(--bd);border-radius:2px;overflow:hidden;margin-top:.35rem}
.prog>i{display:block;height:100%;background:var(--ac)}
header{position:sticky;top:0;background:var(--bg);border-bottom:1px solid var(--bd);padding:.75rem 1rem;z-index:10}
nav.btns{display:flex;gap:.4rem;flex-wrap:wrap}
.hide{display:none!important}
label{font-size:.85rem;color:var(--mut);display:block;margin-bottom:.25rem}
.mb{margin-bottom:.75rem}
.tabs{display:flex;gap:.4rem;margin-bottom:.75rem}
.tabs button{background:transparent;color:var(--fg);border:1px solid var(--bd)}
.tabs button.on{background:var(--ac);color:#fff;border-color:var(--ac)}
.read{padding:1.5rem;max-width:780px;margin:0 auto;white-space:pre-wrap;word-wrap:break-word;line-height:1.7}
.read[dir=rtl]{text-align:right}
.toolbar{position:sticky;top:0;background:var(--bg);border-bottom:1px solid var(--bd);padding:.5rem;z-index:5}
.toolbar .row{justify-content:center}
.toolbar select,.toolbar input{width:auto}
button.ic,a.sec.ic{padding:.4rem .55rem;min-width:2.1rem;font-size:.9rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}
.ic svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round;display:block}
button.ic.on{background:var(--ac);color:#fff;border-color:var(--ac)}
body.fs .toolbar,body.fs #prog{display:none}
body.fs .read{padding-top:1rem}
.popup{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}
.popup .card{max-width:520px;width:100%;max-height:90vh;overflow:auto}
.err{color:#dc2626;font-size:.85rem}
.ok{color:#16a34a;font-size:.85rem}
small{color:var(--mut)}
