:root{
  --paper:#efe6d4; --paper-2:#e7ddc6; --card:#f4ecdc;
  --ink:#221d15; --ink-soft:#5d5443; --ink-faint:#9b8f76;
  --rubric:#9a3b2a; --rubric-soft:#bd6a54;
  --proof:#3f5651; --sepia:#6a5f45;
  --line:#d7cbad; --line-strong:#c3b48f;
  --hl:#f1dd9c;
  --laid:rgba(120,95,50,.040); --vig:rgba(90,70,30,.07);
  --maxw:1240px;
  --read-scale:1;
  --body:"EB Garamond",Georgia,serif;
  --display:"Cinzel",Georgia,serif;
  --ui:"Spline Sans",system-ui,sans-serif;
  --shadow:0 18px 50px -28px rgba(40,28,10,.5);
}
:root[data-theme="noche"]{
  --paper:#15120d; --paper-2:#1e1a13; --card:#211c14;
  --ink:#e9e0cd; --ink-soft:#b1a78c; --ink-faint:#827858;
  --rubric:#dd8b6e; --rubric-soft:#b6634a;
  --proof:#9fc0b5; --sepia:#b3a585;
  --line:#352f1e; --line-strong:#443d28;
  --hl:#4a3c14;
  --laid:rgba(255,232,176,.028); --vig:rgba(0,0,0,.42);
  --shadow:0 18px 50px -26px rgba(0,0,0,.7);
}
/* Sepia — cálido tipo libro (más amarillo, recomendado para sesiones largas) */
:root[data-theme="sepia"]{
  --paper:#f3e9d2; --paper-2:#ece0c4; --card:#f7eed9;
  --ink:#463a28; --ink-soft:#6f6047; --ink-faint:#a08c6a;
  --rubric:#9c3b22; --rubric-soft:#c06a4f;
  --proof:#4f5b3f; --sepia:#6f6047;
  --line:#ddcdab; --line-strong:#cbb88f;
  --hl:#f0d99a;
  --laid:rgba(120,95,50,.050); --vig:rgba(90,70,30,.09);
  --shadow:0 18px 50px -28px rgba(40,28,10,.5);
}
/* Papel — off-white de alto contraste, máxima legibilidad */
:root[data-theme="papel"]{
  --paper:#f7f4ec; --paper-2:#efeadd; --card:#fdfbf4;
  --ink:#1c1a16; --ink-soft:#4a463d; --ink-faint:#8a8475;
  --rubric:#9a2f22; --rubric-soft:#c0503f;
  --proof:#2f5247; --sepia:#5a554a;
  --line:#e1dccd; --line-strong:#c9c3af;
  --hl:#ffe7a3;
  --laid:rgba(120,100,60,.022); --vig:rgba(80,70,40,.05);
  --shadow:0 18px 50px -28px rgba(40,30,10,.42);
}
/* Solarizado claro — Ethan Schoonover (base3/base01) */
:root[data-theme="solar-light"]{
  --paper:#fdf6e3; --paper-2:#eee8d5; --card:#fbf3df;
  --ink:#586e75; --ink-soft:#657b83; --ink-faint:#93a1a1;
  --rubric:#cb4b16; --rubric-soft:#dc322f;
  --proof:#2aa198; --sepia:#657b83;
  --line:#e3dcc4; --line-strong:#d3cbb0;
  --hl:#ece1bd;
  --laid:rgba(101,123,131,.04); --vig:rgba(101,123,131,.06);
  --shadow:0 18px 50px -28px rgba(88,110,117,.4);
}
/* Tinta — negro profundo (OLED), texto blanco cálido */
:root[data-theme="tinta"]{
  --paper:#0e0d0b; --paper-2:#17150f; --card:#1a1813;
  --ink:#e7e0d2; --ink-soft:#ab9f86; --ink-faint:#756d58;
  --rubric:#e0937a; --rubric-soft:#c06b50;
  --proof:#9fc3b6; --sepia:#b3a585;
  --line:#2a261c; --line-strong:#3a3426;
  --hl:#463814;
  --laid:rgba(255,235,180,.020); --vig:rgba(0,0,0,.5);
  --shadow:0 18px 50px -24px rgba(0,0,0,.8);
}
/* Solarizado oscuro — Ethan Schoonover (base03/base1) */
:root[data-theme="solar-dark"]{
  --paper:#002b36; --paper-2:#073642; --card:#063540;
  --ink:#93a1a1; --ink-soft:#839496; --ink-faint:#657b83;
  --rubric:#cb4b16; --rubric-soft:#b58900;
  --proof:#2aa198; --sepia:#839496;
  --line:#0d3b47; --line-strong:#155060;
  --hl:#14505f;
  --laid:rgba(147,161,161,.030); --vig:rgba(0,0,0,.4);
  --shadow:0 18px 50px -26px rgba(0,0,0,.7);
}
/* Pizarra — gris azulado frío (paleta Nord) */
:root[data-theme="pizarra"]{
  --paper:#2e3440; --paper-2:#3b4252; --card:#3b4252;
  --ink:#eceff4; --ink-soft:#d8dee9; --ink-faint:#929cb0;
  --rubric:#d08770; --rubric-soft:#bf616a;
  --proof:#8fbcbb; --sepia:#aeb6c6;
  --line:#434c5e; --line-strong:#4c566a;
  --hl:#434c5e;
  --laid:rgba(216,222,233,.022); --vig:rgba(0,0,0,.35);
  --shadow:0 18px 50px -26px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto} *{transition:none!important;animation:none!important}}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);font-size:19px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;min-height:100vh}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:repeating-linear-gradient(0deg,var(--laid) 0 1px,transparent 1px 4px),
  radial-gradient(120% 80% at 50% 38%,transparent 55%,var(--vig) 100%)}
::selection{background:var(--hl);color:var(--ink)}
a{color:inherit;text-decoration:none}
button{font-family:var(--ui);cursor:pointer;border:none;background:none;color:inherit}
.skip{position:absolute;left:-999px;top:0;background:var(--rubric);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 10px 0}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--rubric);outline-offset:2px;border-radius:4px}

/* fleuron */
.fleuron{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--line-strong)}
.fleuron::before,.fleuron::after{content:"";height:1px;width:var(--fw,120px);background:linear-gradient(90deg,transparent,var(--line-strong))}
.fleuron::after{transform:scaleX(-1)}
.fleuron i{width:8px;height:8px;background:var(--rubric);transform:rotate(45deg);flex:none;display:block}
.fleuron--sm{--fw:60px}

/* ---------------- App bar ---------------- */
.appbar{position:sticky;top:0;z-index:60;backdrop-filter:saturate(1.1) blur(7px);
  background:color-mix(in srgb,var(--paper) 86%,transparent);border-bottom:1px solid var(--line)}
.appbar__in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:10px;
  padding:8px clamp(14px,3vw,28px);min-height:62px}
.brand{display:flex;align-items:baseline;gap:9px;margin-right:6px}
.brand__mark{font-family:var(--display);font-weight:700;color:var(--rubric);letter-spacing:.06em;font-size:17px}
.brand__txt{font-family:var(--ui);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.nav{display:flex;gap:2px;margin-right:auto}
.nav a{font-family:var(--ui);font-size:13.5px;color:var(--ink-soft);padding:8px 13px;border-radius:10px;transition:.15s}
.nav a:hover{color:var(--ink);background:var(--paper-2)}
.nav a.is-active{color:var(--rubric);background:var(--paper-2)}
.bar__tools{display:flex;align-items:center;gap:8px}
.iconbtn{display:inline-flex;align-items:center;gap:7px;font-family:var(--ui);font-size:13px;color:var(--ink-soft);
  padding:8px 12px;border:1px solid var(--line);border-radius:11px;background:var(--card);transition:.16s;white-space:nowrap}
.iconbtn:hover{border-color:var(--line-strong);color:var(--ink)}
.iconbtn[aria-pressed="true"]{border-color:var(--rubric);color:var(--rubric);box-shadow:inset 0 0 0 1px var(--rubric)}
.iconbtn svg{width:15px;height:15px;flex:none}
.iconbtn--sq{padding:8px 9px}
.iconbtn kbd{font-family:var(--ui);font-size:11px;border:1px solid var(--line-strong);border-radius:5px;padding:1px 5px;color:var(--ink-faint)}
#installBtn{display:none}
@media(max-width:860px){ .iconbtn .lbl{display:none} .iconbtn--search kbd{display:none} .iconbtn{padding:8px 10px} }
@media(max-width:560px){ .brand__txt{display:none} .nav a{padding:8px 10px} }

/* ---------------- App container ---------------- */
.app{max-width:var(--maxw);margin:0 auto;padding:0 clamp(14px,3vw,28px) 80px;min-height:60vh;outline:none}
.view-enter{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------------- Home: frontispiece + grid ---------------- */
.frontis{position:relative;text-align:center;margin:clamp(26px,5vw,52px) auto clamp(10px,3vw,26px);
  max-width:760px;padding:clamp(38px,6vw,68px) clamp(20px,4vw,46px)}
.frontis__rule{position:absolute;inset:14px;border:1px solid var(--line);pointer-events:none}
.frontis__rule::before,.frontis__rule::after{content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--line-strong)}
.frontis__rule::before{left:-1px;top:-1px;border-right:none;border-bottom:none}
.frontis__rule::after{right:-1px;bottom:-1px;border-left:none;border-top:none}
.frontis__eyebrow{font-family:var(--display);font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:var(--rubric);margin:0 0 24px}
.frontis__title{font-family:var(--display);font-weight:500;line-height:1.08;font-size:clamp(30px,5.2vw,50px);margin:0 0 10px;letter-spacing:.01em}
.frontis__attr{font-family:var(--body);font-style:italic;color:var(--ink-soft);font-size:clamp(15px,2vw,18px);max-width:40ch;margin:0 auto 22px;line-height:1.5}
.frontis .fleuron{margin:22px auto}
.frontis__year{font-family:var(--display);font-weight:600;color:var(--rubric);font-size:clamp(54px,12vw,104px);line-height:.92;letter-spacing:.04em;margin:4px 0}
.frontis__meta{font-family:var(--ui);font-size:13px;color:var(--ink-soft);letter-spacing:.03em;display:flex;flex-wrap:wrap;gap:5px 16px;justify-content:center;margin:16px 0 0}
.frontis__meta b{color:var(--ink);font-weight:600}
.frontis__credit{position:relative;font-family:var(--ui);font-size:13px;color:var(--ink-soft);margin:16px 0 0;letter-spacing:.01em}
.frontis__credit a{color:var(--rubric);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--rubric) 40%,transparent)}
.frontis__credit a:hover{border-bottom-color:var(--rubric)}

.tocband{display:flex;align-items:center;justify-content:center;gap:18px;margin:clamp(20px,4vw,40px) 0 22px}
.tocband h2{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);margin:0}
.tocband span{height:1px;flex:1;max-width:120px;background:var(--line-strong)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(216px,1fr));gap:14px}
.tile{position:relative;display:flex;flex-direction:column;gap:8px;padding:20px 20px 18px;border:1px solid var(--line);
  border-radius:14px;background:var(--card);transition:.18s;overflow:hidden;min-height:128px}
.tile:hover{border-color:var(--rubric);transform:translateY(-2px);box-shadow:var(--shadow)}
.tile__num{font-family:var(--display);font-weight:600;color:var(--rubric);font-size:13px;letter-spacing:.12em}
.tile__title{font-family:var(--display);font-weight:500;font-size:18px;line-height:1.18;color:var(--ink);margin-top:2px}
.tile__meta{font-family:var(--ui);font-size:11.5px;color:var(--ink-faint);margin-top:auto;letter-spacing:.02em}
.tile__ghost{position:absolute;right:-6px;bottom:-22px;font-family:var(--display);font-weight:700;font-size:78px;color:var(--ink);opacity:.05;line-height:1;pointer-events:none}

/* ---------------- Reader (chapter) ---------------- */
.reader{max-width:1180px;margin:0 auto}
.chrome{position:sticky;top:62px;z-index:30;display:flex;align-items:center;gap:12px;padding:12px 0;margin-bottom:6px;
  background:linear-gradient(var(--paper) 75%,transparent)}
.chrome__loc{font-family:var(--display);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--rubric)}
.chrome__sep{color:var(--ink-faint)}
.chrome__title{font-family:var(--body);color:var(--ink-soft);font-size:15px;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chrome__spacer{margin-left:auto}
.chip{font-family:var(--ui);font-size:13px;color:var(--ink-soft);border:1px solid var(--line);background:var(--card);
  border-radius:10px;padding:7px 11px;transition:.15s;display:inline-flex;align-items:center;gap:6px}
.chip:hover{border-color:var(--line-strong);color:var(--ink)}
.chip svg{width:15px;height:15px}
.chip:disabled{opacity:.35;cursor:default}
.progress{position:fixed;left:0;top:0;height:3px;background:var(--rubric);width:0;z-index:70;transition:width .1s linear}

.ch__head{text-align:center;margin:clamp(20px,4vw,40px) 0 clamp(26px,4vw,42px)}
.ch__num{font-family:var(--display);font-weight:600;color:var(--rubric);font-size:15px;letter-spacing:.26em;margin-bottom:12px}
.ch__title{font-family:var(--display);font-weight:500;font-size:clamp(26px,4vw,40px);line-height:1.12;margin:0 auto 18px;max-width:24ch}
.ch__head .fleuron{margin:0 auto}

.para{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,240px);gap:36px;align-items:start;padding:16px 0;
  border-bottom:1px solid color-mix(in srgb,var(--line) 50%,transparent)}
.para:last-of-type{border-bottom:none}
.para__main{position:relative;padding-left:56px;min-width:0}
.para__tools{position:absolute;left:0;top:5px;display:flex;flex-direction:column;align-items:flex-start;gap:3px;margin-left:-6px}
.para__cite{font-family:var(--display);font-size:14px;color:var(--ink-faint);letter-spacing:.02em;padding:2px 6px;border-radius:7px;transition:.14s;line-height:1.4;white-space:nowrap}
.para__cite:hover{color:var(--rubric);background:var(--paper-2)}
.para__cite.copied{color:var(--rubric)}
.para__share{display:grid;place-items:center;width:26px;height:24px;border-radius:7px;color:var(--ink-faint);opacity:.5;transition:.14s}
.para__share svg{width:15px;height:15px}
.para__share:hover{color:var(--rubric);opacity:1;background:var(--paper-2)}
.para:hover .para__share,.para:focus-within .para__share{opacity:.8}
.para__text{margin:0;min-width:0;font-size:calc(19.5px * var(--read-scale));line-height:1.68;overflow-wrap:break-word;hanging-punctuation:first}
.para--lead .para__text::first-letter{font-family:var(--display);font-weight:500;color:var(--rubric);font-size:3.4em;line-height:.78;float:left;margin:.06em .1em -.04em 0}
.para--target{animation:flash 1.9s ease}
@keyframes flash{0%,16%{background:color-mix(in srgb,var(--hl) 72%,transparent)}100%{background:transparent}}

.mk{font-family:var(--ui);font-size:.6em;font-weight:600;vertical-align:.55em;line-height:0;color:var(--rubric);padding:0 .12em;border-radius:4px;transition:.14s;position:relative;top:-1px}
.mk:hover,.mk:focus-visible{color:#fff;background:var(--rubric);outline:none}
.mk.is-active{color:#fff;background:var(--rubric)}
.proofs{position:relative;min-width:0;padding-top:4px}
.proofs::before{content:"";position:absolute;left:-18px;top:6px;bottom:6px;width:1px;background:var(--line)}
.proofs ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.pf{display:grid;grid-template-columns:20px 1fr;gap:8px;align-items:baseline;padding:3px 6px 3px 4px;border-radius:7px;transition:.16s;border-left:2px solid transparent;margin-left:-6px}
.pf__n{font-family:var(--ui);font-size:11px;font-weight:600;color:var(--proof);opacity:.7;text-align:right;line-height:1.5}
.pf__ref{font-family:var(--body);font-style:italic;font-size:calc(15px * var(--read-scale));line-height:1.45;color:var(--proof)}
.pf.is-active{background:var(--paper-2);border-left-color:var(--rubric)}
.pf.is-active .pf__n{color:var(--rubric);opacity:1}
.pf:hover{background:var(--paper-2)}

.endnav{display:flex;justify-content:space-between;gap:14px;margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}
.endnav a{font-family:var(--ui);font-size:13.5px;color:var(--ink-soft);max-width:46%;line-height:1.3;transition:.14s}
.endnav a:hover{color:var(--rubric)}
.endnav .next{text-align:right;margin-left:auto}
.endnav .disabled{visibility:hidden}

body.refs-off .para{grid-template-columns:minmax(0,1fr)}
body.refs-off .proofs{display:none}
body.refs-off .mk{color:var(--ink-faint);pointer-events:none;background:none}

/* ---------------- Scripture index ---------------- */
.sx{max-width:1000px;margin:0 auto;padding:clamp(24px,4vw,46px) 0}
.sx__lead{text-align:center;margin-bottom:clamp(26px,4vw,46px)}
.sx__eyebrow{font-family:var(--display);font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--rubric);margin:0 0 14px}
.sx__h1{font-family:var(--display);font-weight:500;font-size:clamp(26px,4vw,40px);margin:0 0 14px}
.sx__intro{font-family:var(--body);font-style:italic;color:var(--ink-soft);max-width:56ch;margin:0 auto 18px;font-size:16px;line-height:1.55}
.sx__intro b{font-style:normal;color:var(--ink)}
.sx__lead .fleuron{margin:18px auto 0}
.sx__group{margin-top:clamp(26px,4vw,44px)}
.sx__grouptitle{font-family:var(--display);font-weight:600;color:var(--ink);font-size:15px;letter-spacing:.18em;text-transform:uppercase;text-align:center;margin:0 0 24px}
.sx__grouptitle span{display:inline-block;width:40px;height:1px;background:var(--line-strong);vertical-align:middle;margin:0 16px}
.sx__books{columns:280px 3;column-gap:30px}
.sx__book{break-inside:avoid;margin:0 0 22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.sx__bookhead{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:9px}
.sx__name{font-family:var(--display);font-weight:500;font-size:18px;color:var(--ink)}
.sx__count{font-family:var(--ui);font-size:11px;color:var(--ink-faint);background:var(--paper-2);border-radius:20px;padding:2px 9px;flex:none}
.sx__chips{display:flex;flex-wrap:wrap;gap:5px}
.sx__chip{font-family:var(--ui);font-size:12px;color:var(--proof);background:var(--card);border:1px solid var(--line);border-radius:7px;padding:3px 8px;transition:.14s}
.sx__chip:hover{border-color:var(--rubric);color:var(--rubric);background:var(--paper-2)}

/* ---------------- Drawer (chapter index slide-over) ---------------- */
.scrim{position:fixed;inset:0;background:rgba(20,18,12,.5);z-index:90;opacity:0;pointer-events:none;transition:.22s;backdrop-filter:blur(2px)}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:360px;max-width:88vw;z-index:95;background:var(--paper);
  border-left:1px solid var(--line-strong);box-shadow:var(--shadow);transform:translateX(104%);transition:transform .26s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column}
.drawer.is-open{transform:none}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 12px}
.drawer__title{font-family:var(--display);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
.drawer__close{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--ink-soft);border:1px solid var(--line)}
.drawer__close:hover{color:var(--rubric);border-color:var(--line-strong)}
.drawer__list{overflow:auto;padding:6px 14px 30px;flex:1}
.drawer__item{display:grid;grid-template-columns:34px 1fr;align-items:baseline;gap:10px;padding:8px 10px;border-radius:9px;color:var(--ink-soft);transition:.14s}
.drawer__item:hover{background:var(--paper-2);color:var(--ink)}
.drawer__item.is-active{background:var(--paper-2);color:var(--ink)}
.drawer__item.is-active .drawer__num{color:var(--rubric)}
.drawer__num{font-family:var(--display);font-size:12px;color:var(--ink-faint);text-align:right}
.drawer__name{font-family:var(--body);font-size:16px;line-height:1.25}

/* ---------------- Command palette ---------------- */
.palette{position:fixed;inset:0;z-index:100;display:none;justify-content:center;align-items:flex-start;padding:12vh 16px 16px;
  background:rgba(20,18,12,.5);backdrop-filter:blur(3px)}
.palette.is-open{display:flex}
.palette__box{width:min(620px,96vw);background:var(--paper);border:1px solid var(--line-strong);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;max-height:76vh;display:flex;flex-direction:column}
.palette__top{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.palette__top svg{width:18px;height:18px;color:var(--ink-faint);flex:none}
.palette__input{flex:1;font-family:var(--body);font-size:18px;color:var(--ink);background:none;border:none;outline:none}
.palette__hint{font-family:var(--ui);font-size:11px;color:var(--ink-faint);border:1px solid var(--line);border-radius:6px;padding:2px 6px}
.palette__results{overflow:auto;padding:8px}
.pres{display:block;width:100%;text-align:left;padding:10px 12px;border-radius:10px;transition:.12s;border:1px solid transparent}
.pres:hover,.pres.is-sel{background:var(--paper-2);border-color:var(--line)}
.pres__k{font-family:var(--ui);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--rubric);display:block;margin-bottom:2px}
.pres__t{font-family:var(--body);font-size:16px;color:var(--ink);line-height:1.35}
.pres__t mark{background:var(--hl);color:var(--ink);border-radius:2px}
.pres__t i{font-style:italic;color:var(--proof)}
.palette__empty{font-family:var(--body);font-style:italic;color:var(--ink-faint);text-align:center;padding:28px}

/* ---------------- Share sheet ---------------- */
.sheet{position:fixed;inset:0;z-index:110;display:none;align-items:center;justify-content:center;padding:22px;background:rgba(20,18,12,.55);backdrop-filter:blur(3px)}
.sheet.is-open{display:flex}
.sheet__panel{background:var(--paper);border:1px solid var(--line-strong);border-radius:18px;padding:18px;max-width:min(440px,94vw);width:100%;max-height:92vh;overflow:auto;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.sheet__head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.sheet__title{font-family:var(--ui);font-size:13px;color:var(--ink-soft);margin:0}
.sheet__close{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;color:var(--ink-soft);border:1px solid var(--line)}
.sheet__close:hover{color:var(--rubric)}
.sheet__preview{border-radius:12px;overflow:hidden;border:1px solid var(--line);display:grid;place-items:center;background:var(--paper-2);min-height:120px}
.sheet__preview img{display:block;width:auto;height:auto;max-width:100%;max-height:56vh;object-fit:contain;margin:0 auto}
.sheet__opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{font-family:var(--ui);font-size:12.5px;padding:7px 12px;border-radius:10px;border:1px solid var(--line);color:var(--ink-soft);background:var(--card);transition:.14s}
.opt:hover{border-color:var(--line-strong);color:var(--ink)}
.opt[aria-pressed="true"]{border-color:var(--rubric);color:var(--rubric);box-shadow:inset 0 0 0 1px var(--rubric)}
.sheet__actions{display:flex;gap:10px}
.sheet__btn{flex:1;font-family:var(--ui);font-size:14px;padding:12px 14px;border-radius:12px;border:1px solid var(--line-strong);color:var(--ink);background:var(--card);transition:.16s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.sheet__btn:hover{border-color:var(--ink)}
.sheet__btn--solid{background:var(--rubric);color:#fff;border-color:var(--rubric)}
.sheet__btn svg{width:16px;height:16px}
.sheet__spin{font-family:var(--ui);font-size:13px;color:var(--ink-faint);text-align:center;padding:30px 0}

/* popover, toast, totop */
.pop{position:absolute;z-index:80;display:none;max-width:min(82vw,340px);background:var(--card);border:1px solid var(--line-strong);border-radius:12px;padding:11px 13px;box-shadow:var(--shadow);font-family:var(--body);font-style:italic;font-size:15.5px;line-height:1.45;color:var(--proof)}
.pop.is-open{display:block}
.pop__n{font-family:var(--ui);font-style:normal;font-weight:600;font-size:11px;color:var(--rubric);letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:4px}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:var(--paper);font-family:var(--ui);font-size:13.5px;padding:11px 18px;border-radius:12px;opacity:0;pointer-events:none;transition:.22s;z-index:120}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.totop{position:fixed;right:20px;bottom:22px;z-index:50;width:44px;height:44px;border-radius:50%;background:var(--card);border:1px solid var(--line-strong);color:var(--ink-soft);display:grid;place-items:center;opacity:0;pointer-events:none;transition:.2s;box-shadow:var(--shadow)}
.totop.show{opacity:1;pointer-events:auto}
.totop:hover{color:var(--rubric);border-color:var(--rubric)}

.colophon{text-align:center;max-width:620px;margin:clamp(36px,6vw,72px) auto 10px;padding-top:28px}

/* not-found view */
.missing{max-width:560px;margin:clamp(60px,12vw,140px) auto;text-align:center}
.missing__eyebrow{font-family:var(--display);font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--rubric);margin:0 0 14px}
.missing__h1{font-family:var(--display);font-weight:500;font-size:clamp(26px,4vw,38px);margin:0 0 14px}
.missing__text{font-family:var(--body);color:var(--ink-soft);font-size:17px;margin:0 0 26px;line-height:1.55}
.cta{display:inline-block;font-family:var(--ui);font-size:14px;padding:11px 22px;border-radius:12px;border:1px solid var(--line-strong);color:var(--ink);background:var(--card);transition:.16s}
.cta:hover{border-color:var(--ink);transform:translateY(-1px)}
.cta--solid{background:var(--rubric);color:#fff;border-color:var(--rubric)}
.cta--solid:hover{background:#822f20;border-color:#822f20}

/* visually-hidden live region */
.sr-live{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* credit line in reader + links */
.credit{text-align:center;font-family:var(--ui);font-size:12px;color:var(--ink-faint);margin:26px 0 0;line-height:1.5}
.credit a, .colophon a, .about a{color:var(--rubric);text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--rubric) 35%,transparent)}
.credit a:hover, .colophon a:hover, .about a:hover{border-bottom-color:var(--rubric)}

/* About / credits page */
.about{max-width:680px;margin:0 auto;padding:clamp(24px,4vw,46px) 0 40px}
.about__head{text-align:center;margin-bottom:clamp(26px,4vw,40px)}
.about__eyebrow{font-family:var(--display);font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--rubric);margin:0 0 14px}
.about__h1{font-family:var(--display);font-weight:500;font-size:clamp(26px,4vw,40px);margin:0 0 14px}
.about__head .fleuron{margin:16px auto 0}
.about__h2{font-family:var(--display);font-weight:500;font-size:clamp(18px,2.4vw,22px);color:var(--rubric);margin:30px 0 10px}
.about p{font-family:var(--body);font-size:calc(18px * var(--read-scale));line-height:1.66;color:var(--ink);margin:0 0 12px}
.about b{font-weight:600}
.about__cta{margin:18px 0 4px}
.about__foot{text-align:center;margin-top:40px;padding-top:24px;border-top:1px solid var(--line)}
.about__foot .fleuron{margin:0 auto 20px}

/* ---------- Palette picker ---------- */
.pmenu{position:absolute;z-index:100;display:none;width:268px;background:var(--paper);
  border:1px solid var(--line-strong);border-radius:16px;box-shadow:var(--shadow);padding:14px}
.pmenu.is-open{display:block}
.pmenu__title{font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:0 2px 10px}
.pmenu__group + .pmenu__group{margin-top:12px}
.pmenu__grouptitle{font-family:var(--display);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--rubric);margin:0 2px 8px}
.pmenu__grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.popt{display:flex;align-items:center;gap:9px;padding:7px 9px;border:1px solid var(--line);border-radius:11px;background:var(--card);transition:.14s;text-align:left}
.popt:hover{border-color:var(--line-strong)}
.popt[aria-checked="true"]{border-color:var(--rubric);box-shadow:inset 0 0 0 1px var(--rubric)}
.popt__sw{width:26px;height:26px;border-radius:8px;flex:none;position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.15)}
.popt__sw i{position:absolute;display:block}
.popt__sw .ink{left:5px;top:6px;width:11px;height:3px;border-radius:2px}
.popt__sw .rub{right:4px;bottom:4px;width:7px;height:7px;border-radius:50%}
.popt__name{font-family:var(--ui);font-size:12.5px;color:var(--ink);line-height:1.1}
.popt__check{margin-left:auto;color:var(--rubric);display:none}
.popt[aria-checked="true"] .popt__check{display:block}

/* ---------- Text size control ---------- */
.iconbtn .aa{font-family:var(--display);font-weight:600;line-height:1;letter-spacing:.02em;display:inline-flex;align-items:baseline}
.iconbtn .aa b{font-weight:600}
.iconbtn .aa .s{font-size:11px}
.iconbtn .aa .l{font-size:15px}
.tsize{position:absolute;z-index:100;display:none;width:248px;background:var(--paper);border:1px solid var(--line-strong);border-radius:16px;box-shadow:var(--shadow);padding:14px}
.tsize.is-open{display:block}
.tsize__title{font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:0 2px 12px}
.tsize__row{display:flex;align-items:center;gap:10px}
.tstep{width:46px;height:44px;border:1px solid var(--line);border-radius:12px;background:var(--card);display:grid;place-items:center;font-family:var(--display);font-weight:600;color:var(--ink);transition:.14s}
.tstep .big{font-size:21px}.tstep .small{font-size:14px}
.tstep:hover:not(:disabled){border-color:var(--rubric);color:var(--rubric)}
.tstep:disabled{opacity:.4;cursor:default}
.tsize__val{flex:1;text-align:center;font-family:var(--ui);font-size:15px;color:var(--ink);font-variant-numeric:tabular-nums}
.tsize__val small{display:block;font-size:11px;color:var(--ink-faint);letter-spacing:.04em;margin-top:2px}
.tsize__reset{display:block;width:100%;text-align:center;margin-top:12px;font-family:var(--ui);font-size:12.5px;color:var(--ink-soft);padding:7px;border-radius:9px;transition:.14s}
.tsize__reset:hover{color:var(--rubric);background:var(--paper-2)}
.colophon .fleuron{margin:0 auto 20px}
.colophon p{font-family:var(--body);font-style:italic;color:var(--ink-soft);font-size:15px;line-height:1.6;margin:0 0 6px}
.colophon b{font-family:var(--display);font-style:normal;font-weight:600;color:var(--rubric)}

/* responsive reader */
@media(max-width:980px){
  .para{grid-template-columns:minmax(0,1fr)}
  .proofs{display:none}
  .para__main{padding-left:48px}
  .para__text{font-size:calc(18.5px * var(--read-scale))}
  body{font-size:18px}
  .chrome{top:62px}
}
@media(max-width:520px){
  .para__main{padding-left:0}
  .para__tools{position:static;flex-direction:row;align-items:center;gap:8px;margin:0 0 6px}
  .para__cite{background:var(--paper-2)}
  .para--lead .para__text::first-letter{font-size:2.8em}
  .endnav{flex-direction:column}
  .endnav .next{text-align:left;margin-left:0}
  .sx__books{columns:1}
  .chrome__title{display:none}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
}

@media print{
  body{background:#fff;color:#000;font-size:11.5pt}
  body::before,.appbar,.chrome,.progress,.totop,.toast,.pop,.sheet,.drawer,.scrim,.palette,.para__share,.endnav,.tocband,.grid,.frontis__rule{display:none!important}
  .app{max-width:none;padding:0}
  .ch__head{margin:1cm 0}
  .para{display:block;border:none;padding:.15cm 0}
  .para__main{padding-left:0}
  .para__text{text-align:justify}
  .proofs{display:block}
  .proofs::before{display:none}
  .proofs ol{flex-direction:row;flex-wrap:wrap;gap:.3cm}
  .pf__ref{color:#333;font-size:9pt}
  .mk{color:#000}
}
