:root{--paper:#f8f1df;--ink:#2f2a22;--muted:#776b5d;--line:#dacdb8;--serif:Charter, "Iowan Old Style", "Palatino Linotype", Georgia, serif;--sans:Avenir Next, Optima, Candara, "Trebuchet MS", sans-serif;font-family:var(--sans);color:var(--ink);background:var(--paper);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-width:320px;min-height:100%;margin:0}body{min-height:100svh}h1,h2,h3{font-family:var(--serif);letter-spacing:0}button,input{font:inherit}.setup-shell,.loading-shell,.auth-shell,.library-shell,.reader-shell{min-height:100svh}.setup-shell,.loading-shell{background:var(--paper);color:var(--ink);place-items:center;display:grid}.setup-panel{border:1px solid var(--line);background:#fffdf8;border-radius:8px;width:min(560px,100vw - 32px);padding:36px}.setup-panel h1,.auth-card h1,.library-header h1{color:var(--ink);margin:0;line-height:1.02}.setup-panel p,.auth-card p,.library-header p,.upload-band p,.empty-shelf p{color:var(--muted);margin:0}.setup-panel pre{color:#fff7df;background:#27231f;border-radius:8px;margin:24px 0 0;padding:16px;overflow:auto}.loading-shell{gap:12px;font-size:18px}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-shell{background:#f6efe0;grid-template-columns:minmax(320px,.88fr) minmax(360px,1fr);display:grid}.auth-art{background:linear-gradient(135deg,#253d34eb,#504832db),radial-gradient(circle at 30% 30%,#e7c46e 0 12%,#0000 13%);place-items:center;display:grid;position:relative;overflow:hidden}.auth-art:before{content:"";border:1px solid #fff7df47;position:absolute;inset:9%}.book-stack{width:260px;height:330px;position:relative}.book-stack div{border-radius:6px;width:185px;height:265px;position:absolute;box-shadow:0 30px 80px #00000047}.book-stack div:first-child{background:linear-gradient(145deg,#a34f35,#e9c46a);inset:18px auto auto 0;transform:rotate(-9deg)}.book-stack div:nth-child(2){background:linear-gradient(145deg,#2f5f59,#d9b36b);inset:34px 20px auto auto;transform:rotate(8deg)}.book-stack div:nth-child(3){background:linear-gradient(145deg,#f8f1df,#b66a4a);inset:0 auto auto 42px}.auth-card{background:#fffaf0;flex-direction:column;justify-content:center;gap:24px;padding:clamp(32px,7vw,84px);display:flex}.auth-card h1{max-width:520px;font-size:clamp(42px,6vw,72px)}.auth-card form{gap:16px;max-width:440px;display:grid}label{color:var(--ink);gap:8px;font-weight:700;display:grid}input{box-sizing:border-box;border:1px solid var(--line);min-height:48px;color:var(--ink);font:inherit;background:#fffdf8;border-radius:8px;padding:0 14px}button,.upload-button{min-height:44px;font:inherit;cursor:pointer;border:0;border-radius:8px;font-weight:800}button:focus-visible,.upload-button:focus-within{outline-offset:3px;outline:3px solid #3e685859}.primary-action,.upload-button{color:#fffaf0;background:#294f45;justify-content:center;align-items:center;gap:10px;padding:0 18px;display:inline-flex}.primary-action:disabled{opacity:.65;cursor:wait}.upload-button:has(input:disabled){opacity:.65;cursor:wait}.ghost-action,.reader-button,.icon-action{color:var(--ink);border:1px solid var(--line);background:#fffaf0c2;justify-content:center;align-items:center;gap:8px;display:inline-flex}.ghost-action{padding:0 16px}.brand-row{color:var(--ink);align-items:center;gap:12px;font-weight:900;display:inline-flex}.mark{color:#fff8e8;background:#294f45;border-radius:8px;place-items:center;width:44px;height:44px;display:inline-grid}.notice{border-radius:8px;margin:0;padding:14px 16px;font-weight:700}.notice.good{color:#244b38;background:#deeadc}.notice.bad{color:#713225;background:#f6d9cf}.notice.plain{color:#4e463b;background:#eee4d2}.library-shell{background:linear-gradient(#fffaf0e0,#f4ecdbf0),repeating-linear-gradient(90deg,#334a3b0a 0 1px,#0000 1px 84px);padding:clamp(20px,4vw,48px)}.library-header{justify-content:space-between;align-items:flex-start;gap:20px;max-width:1180px;margin:0 auto 28px;display:flex}.library-header>div{gap:14px;display:grid}.library-header h1{font-size:clamp(44px,7vw,84px)}.upload-band{border:1px solid var(--line);background:#fffdf8c2;border-radius:8px;justify-content:space-between;align-items:center;gap:20px;max-width:1180px;margin:0 auto 24px;padding:18px;display:flex}.upload-band h2{color:var(--ink);margin:0 0 6px}.upload-button input{opacity:0;pointer-events:none;block-size:1px;inline-size:1px;position:absolute}.shelf-grid{grid-template-columns:repeat(auto-fill,minmax(174px,1fr));gap:22px;max-width:1180px;margin:0 auto;display:grid}.book-card{position:relative}.book-open{text-align:left;width:100%;color:var(--ink);background:0 0;gap:12px;padding:0;display:grid}.cover{aspect-ratio:.72;color:#fff8e8;background:linear-gradient(145deg, hsl(var(--cover-hue) 38% 38%), hsl(calc(var(--cover-hue) + 42deg) 48% 58%)), #8f5e43;border-radius:8px;place-items:center;width:100%;display:grid;box-shadow:0 20px 46px #31291f33}.cover span{border:1px solid #fff8e880;border-radius:50%;place-items:center;width:74px;height:74px;font-size:28px;display:grid}.book-title,.book-author{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.book-title{font-size:18px;font-weight:900}.book-author{color:var(--muted);font-size:14px}.icon-action{color:#713225;background:#fffaf0eb;width:42px;height:42px;position:absolute;top:10px;right:10px}.empty-shelf{min-height:320px;color:var(--muted);background:#fffdf89e;border:1px dashed #b7aa98;border-radius:8px;grid-column:1/-1;align-content:center;place-items:center;gap:10px;display:grid}.empty-shelf h2{color:var(--ink);margin:0}.reader-shell{color:var(--ink);grid-template-rows:auto 1fr auto;display:grid;overflow:hidden}.reader-shell.theme-paper{background:#f8f1df}.reader-shell.theme-warm{background:#ead9bf}.reader-shell.theme-night{--ink:#eee2ca;--muted:#bdb09a;--line:#3b4039;background:#171a18}.reader-topbar,.reader-footer{border-color:var(--line);align-items:center;gap:14px;padding:14px clamp(14px,3vw,28px);display:grid}.reader-topbar{border-bottom:1px solid var(--line);grid-template-columns:auto 1fr auto}.reader-topbar div{min-width:0;display:grid}.reader-topbar strong,.reader-topbar span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.reader-topbar span{color:var(--muted);font-size:14px}.reader-button{min-width:44px;padding:0 12px}.reader-body{grid-template-columns:260px 1fr;min-height:0;display:grid}.toc-panel{border-right:1px solid var(--line);min-height:0;padding:18px;overflow:auto}.toc-title{color:var(--muted);align-items:center;gap:8px;margin-bottom:14px;font-weight:900;display:flex}.toc-list{gap:6px;display:grid}.toc-list button{text-align:left;min-height:38px;color:var(--ink);background:0 0;padding:7px 9px}.toc-list button:hover{background:#7864411f}.page-stage{grid-template-columns:68px 1fr 68px;min-width:0;min-height:0;padding:22px;display:grid;position:relative}.epub-frame{background:#fffdf880;border-radius:8px;min-width:0;min-height:0;position:relative;overflow:hidden}.turn-zone{min-width:54px;height:100%;color:var(--muted);background:0 0;place-items:center;display:grid}.turn-zone:hover{color:var(--ink)}.reader-state{z-index:2;color:var(--muted);background:#fffdf8b8;align-content:center;place-items:center;gap:12px;font-weight:800;display:grid;position:absolute;inset:0}.reader-state.bad{color:#713225}.reader-footer{border-top:1px solid var(--line);grid-template-columns:auto 1fr auto}.font-controls{align-items:center;gap:8px;display:flex}.font-controls span{text-align:center;min-width:50px;font-weight:900}.progress-track{background:#5f574833;border-radius:999px;height:8px;overflow:hidden}.progress-track span{border-radius:inherit;background:#42695a;height:100%;display:block}@media (width<=820px){.auth-shell{grid-template-columns:1fr}.auth-art{min-height:220px}.book-stack{scale:.72}.library-header,.upload-band{flex-direction:column;align-items:stretch}.reader-body{grid-template-columns:1fr}.toc-panel{display:none}.page-stage{grid-template-columns:44px 1fr 44px;padding:10px}.reader-topbar,.reader-footer{grid-template-columns:auto 1fr auto;padding:10px}.reader-button{padding:0 10px}}
