:root{--bg: #e8e4dd;--panel: #f4f1ec;--panel-2: #efebe4;--ink: #4b463f;--ink-soft: #6f685f;--muted: #9c958b;--line: #d8d2c7;--accent: #8f9a8c;--accent-ink: #fbfaf7;--shadow: 0 8px 28px rgba(75, 70, 63, .14);--safe-t: env(safe-area-inset-top, 0px);--safe-b: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,PingFang SC,Helvetica Neue,system-ui,sans-serif;color:var(--ink);background:var(--bg);overscroll-behavior:none}.app{height:100%}.login{height:100%;display:grid;place-items:center;padding:calc(20px + var(--safe-t)) 20px}.login-card{width:340px;max-width:100%;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:28px 24px;display:flex;flex-direction:column}.login-card h1{margin:0;font-size:26px;letter-spacing:3px;text-align:center}.login-sub{text-align:center;color:var(--muted);font-size:13px;margin:6px 0 18px}.login-card label{font-size:12.5px;color:var(--muted);margin:10px 0 5px}.login-card input{padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#fff}.login-err{color:#a8634f;font-size:12.5px;margin-top:10px}.login-btn{margin-top:18px;padding:11px}button{font-family:inherit;cursor:pointer;color:inherit}.btn{border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:8px 15px;border-radius:11px;font-size:14px;transition:.15s}.btn:hover{border-color:var(--accent)}.btn:disabled{opacity:.5}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.btn-ai{background:#cdd2c9;border-color:#b9c2b6}.btn-notion{width:100%;background:var(--panel-2)}.icon-btn{border:none;background:transparent;padding:7px 11px;border-radius:9px;font-size:15px;line-height:1}.icon-btn:hover{background:#00000008}.hint{color:var(--muted);font-size:13px}.hint-small{font-size:12px}.dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex:0 0 auto}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#28252147;z-index:30}.shelf{max-width:1080px;margin:0 auto;padding:calc(20px + var(--safe-t)) 20px calc(40px + var(--safe-b))}.shelf-head{display:flex;align-items:center;margin-bottom:16px}.shelf-head h1{flex:1;font-size:23px;margin:0;letter-spacing:3px;font-weight:600}.shelf-actions{display:flex;align-items:center;gap:8px}.seg{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}.seg button{border:none;background:var(--panel);padding:7px 12px;font-size:15px}.seg button.on{background:var(--accent);color:var(--accent-ink)}.import-row{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}.import-progress{font-size:13px;color:var(--muted);margin-bottom:10px}.banner-error{background:#e6d6cf;color:#8a4b3a;padding:9px 13px;border-radius:9px;font-size:13px;margin-bottom:12px}.empty{text-align:center;padding:72px 20px;color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:22px}.card{position:relative;cursor:pointer}.card-cover{width:100%;aspect-ratio:3/4.4;border-radius:9px;overflow:hidden;box-shadow:var(--shadow);transition:transform .18s}.card:hover .card-cover{transform:translateY(-4px)}.cover-img{width:100%;height:100%;object-fit:cover;display:block}.cover-default{display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(150deg,hsl(var(--h, 40) 16% 72%),hsl(var(--h, 40) 14% 58%));color:#fff8ef;font-size:46px;font-weight:600}.cover-badge{position:absolute;right:8px;bottom:8px;font-size:18px;opacity:.85}.card-title{font-size:13.5px;font-weight:600;line-height:1.3;margin-top:8px;max-height:2.6em;overflow:hidden}.card-author{font-size:12px;color:var(--muted);margin-top:2px}.card-cover,.row-cover{position:relative}.dl-badge{position:absolute;left:6px;top:6px;z-index:3;font-size:11px;border-radius:7px;padding:1px 6px;font-weight:600;line-height:1.5;box-shadow:0 1px 3px #00000040}.row-cover .dl-badge{left:-4px;top:-4px;font-size:10px;padding:0 4px}.dl-cloud{background:#2825218c;color:#fff8ef}.dl-done{background:var(--accent);color:var(--accent-ink)}.dl-prog{background:#282521c7;color:#fff8ef;font-variant-numeric:tabular-nums}.card-del,.row-del{position:absolute;border:none;border-radius:50%;background:#28252180;color:#fff;width:24px;height:24px;font-size:15px;line-height:1;opacity:0;transition:.15s}.card-del{top:7px;right:7px}.card:hover .card-del,.row:hover .row-del{opacity:1}.list{display:flex;flex-direction:column;gap:2px}.row{position:relative;display:flex;align-items:center;gap:14px;padding:11px 10px;border-radius:11px;cursor:pointer}.row:hover{background:var(--panel)}.row-cover{width:44px;height:62px;border-radius:5px;overflow:hidden;flex:0 0 auto;box-shadow:0 2px 6px #4b463f2e}.row-cover .cover-default{font-size:22px}.row-main{flex:1;min-width:0}.row-title{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-sub{font-size:12.5px;color:var(--muted);margin-top:2px}.row-meta{display:flex;gap:5px;align-items:center;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;max-width:48%}.row-del{position:static;opacity:.35}.tag{font-size:11px;background:var(--panel-2);color:var(--ink-soft);padding:2px 8px;border-radius:6px;white-space:nowrap}.tag-cat{background:#e4ddec;color:#6a5d7a}.tag-soft{background:#d8e0d4;color:#5d6f57}.shelf-tabs{display:flex;gap:6px;margin-bottom:14px;border-bottom:1px solid var(--line)}.shelf-tab{border:none;background:transparent;padding:9px 14px 11px;font-size:15px;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px}.shelf-tab.on{color:var(--ink);border-bottom-color:var(--accent);font-weight:600}.shelf-tab i{font-style:normal;font-size:11px;color:var(--muted);margin-left:5px;background:var(--panel-2);padding:1px 6px;border-radius:8px;vertical-align:1px}.genre-row{padding:0 0 12px!important}.card.folder .folder-cover{position:relative}.card.folder .card-cover{box-shadow:0 6px 18px #4b463f24}.folder-cover:before,.folder-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:9px;background:var(--panel);border:1px solid var(--line);z-index:-1}.folder-cover:before{transform:translate(5px,5px)}.folder-cover:after{transform:translate(10px,10px);opacity:.7}.folder-count{position:absolute;right:7px;bottom:7px;background:#282521bd;color:#fff8ef;font-size:11px;padding:2px 8px;border-radius:8px;z-index:2}.card.folder{margin-right:8px;margin-bottom:8px}.folder-cover-sm{position:relative}.folder-count-sm{position:absolute;right:-3px;bottom:-3px;background:var(--accent);color:var(--accent-ink);font-size:10px;min-width:16px;height:16px;line-height:16px;text-align:center;border-radius:8px}.row-chevron{color:var(--muted);font-size:20px;flex:0 0 auto;padding-left:2px}.series-head{display:flex;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--line)}.series-title{font-size:17px;font-weight:600}.series-title span{color:var(--muted);font-weight:400;font-size:14px}.card-menu,.row-menu{border:none;background:#28252180;color:#fff;border-radius:50%;width:26px;height:26px;font-size:17px;line-height:1}.card-menu{position:absolute;top:7px;right:7px;opacity:0;transition:.15s}.card:hover .card-menu{opacity:1}.row-menu{background:transparent;color:var(--muted);font-size:20px;flex:0 0 auto}.classify-sheet{max-width:520px}.classify-title{font-size:15px;font-weight:600;margin-bottom:14px}.classify-label{font-size:12.5px;color:var(--muted);margin:14px 0 7px}.seg-wide{width:100%}.seg-wide button{flex:1;padding:9px}.classify-genres{padding:0!important}.classify-foot{display:flex;align-items:center;gap:9px;margin-top:20px}.link-danger-btn{color:#a8634f;border-color:#d8c3ba}.reader{height:100%;display:flex;flex-direction:column;background:var(--panel)}.reader-loading{display:grid;place-items:center;height:100%;color:var(--muted)}.reader-bar{display:flex;align-items:center;gap:2px;padding:calc(6px + var(--safe-t)) 8px 6px;border-bottom:1px solid var(--line);background:var(--panel-2)}.reader-title{flex:1;text-align:center;font-size:13.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 6px}.reader-bar-actions{display:flex;gap:2px}.marks-btn b{color:var(--accent);margin-left:3px;font-weight:700}.reader-body{flex:1;display:flex;min-height:0;position:relative}.reader-stage{flex:1;position:relative;display:flex;min-width:0}.reader-stage.scrolled{display:block}.reader-stage.scrolled .epub-view{height:100%;overflow:auto;-webkit-overflow-scrolling:touch}.epub-view{flex:1;min-width:0}.page-nav{border:none;background:transparent;color:var(--muted);font-size:26px;width:50px;flex:0 0 50px}.page-nav:hover{background:#00000006;color:var(--ink)}.reader-progress{height:4px;background:#ddd6ca;flex:0 0 auto}.reader-progress span{display:block;height:100%;background:var(--accent);transition:width .25s}.unsupported{margin:auto;max-width:420px;text-align:center;padding:40px;color:var(--muted)}.unsupported h3{color:var(--ink)}.toc{position:absolute;top:0;left:0;bottom:0;width:290px;z-index:31;background:var(--panel);border-right:1px solid var(--line);overflow-y:auto;padding:8px;box-shadow:var(--shadow)}.toc-item{display:block;width:100%;text-align:left;border:none;background:transparent;padding:10px 12px;border-radius:8px;font-size:13.5px;line-height:1.4;color:var(--ink)}.toc-item:hover{background:var(--panel-2)}.selbar{position:fixed;left:0;right:0;bottom:0;z-index:40;background:linear-gradient(180deg,#5e574d,#4b463e);border-radius:20px 20px 0 0;box-shadow:0 -12px 36px #28252157;padding:15px 16px calc(15px + var(--safe-b));animation:selbar-up .2s cubic-bezier(.2,.8,.3,1)}@keyframes selbar-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.selbar-inner{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:15px}.selbar-colors{display:flex;justify-content:space-between;gap:8px;padding:2px 4px}.swatch{width:34px;height:34px;border-radius:50%;border:2px solid transparent;box-shadow:inset 0 0 0 1px #ffffff38,0 2px 4px #00000047;transition:transform .15s,border-color .15s}.swatch.on{border-color:#fffaf2;box-shadow:0 0 0 3px #fffaf247,0 2px 6px #0000004d;transform:translateY(-3px)}.selbar-actions{display:flex;gap:10px}.act{flex:1;height:52px;border:none;border-radius:15px;display:grid;place-items:center;color:#f2ede3;background:#ffffff1a;transition:background .15s,transform .1s}.act:hover{background:#ffffff2e}.act:active{transform:scale(.93)}.act:disabled{opacity:.3}.act svg{width:24px;height:24px}.act-ai{background:#b8ccb838}.act-ai:hover{background:#b8ccb857}.act-close{flex:0 0 48px;color:#c9c2b6;background:transparent}.act-close:hover{background:#ffffff14}.act-remove{flex:1.6;display:flex;gap:6px;color:#ecc9bd;background:#b06c5842;font-size:13.5px}.act-remove svg{width:18px;height:18px}.act-remove:hover{background:#b06c5866}.u-mark rect{fill:transparent!important;stroke:none!important}.u-mark line{stroke:var(--u, #555)!important;stroke-width:2px!important;stroke-opacity:.95}.scrim-side{z-index:35}.side{width:360px;flex:0 0 360px;border-left:1px solid var(--line);display:flex;flex-direction:column;background:var(--panel-2);min-height:0}.side-head{display:flex;align-items:center;padding:13px 15px;border-bottom:1px solid var(--line)}.side-head strong{flex:1;font-size:15px}.filter{display:flex;flex-wrap:wrap;gap:7px;padding:11px 13px}.fchip{display:flex;align-items:center;gap:5px;border:1px solid var(--line);background:var(--panel);border-radius:20px;padding:4px 11px;font-size:12.5px}.fchip.on{background:var(--ink);color:var(--accent-ink);border-color:var(--ink)}.anno-list{flex:1;overflow-y:auto;padding:0 13px}.anno{border-left:3px solid;background:var(--panel);border-radius:9px;padding:11px 13px;margin-bottom:10px;box-shadow:0 1px 3px #4b463f0f}.anno-text{font-size:13.5px;line-height:1.55;cursor:pointer}.anno-text:hover{color:var(--accent)}.anno-note{font-size:12.5px;color:var(--ink-soft);margin-top:7px;background:var(--panel-2);padding:7px 9px;border-radius:7px}.anno-foot{display:flex;align-items:center;gap:10px;margin-top:9px;font-size:12px}.anno-type{color:var(--muted)}.spacer{flex:1}.link{border:none;background:none;color:var(--accent);font-size:12.5px;padding:2px}.link.danger{color:#a8634f}.export{border-top:1px solid var(--line);padding:13px;display:flex;flex-direction:column;gap:9px;padding-bottom:calc(13px + var(--safe-b))}.export-title{font-size:12px;color:var(--muted)}.export-row{display:flex;gap:9px}.export-row .btn{flex:1}.side-ai .ai-source{padding:11px 14px;font-size:13px;color:var(--ink-soft);background:var(--panel);margin:11px 13px;border-radius:9px}.ai-tabs{display:flex;gap:9px;padding:0 13px}.ai-tabs button{flex:1;border:1px solid var(--line);background:var(--panel);padding:8px;border-radius:9px}.ai-tabs button.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.ai-body{flex:1;overflow-y:auto;padding:13px}.ai-result{white-space:pre-wrap;font-family:inherit;font-size:13.5px;line-height:1.65;margin:0}.note-sheet{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:520px;max-width:100%;background:var(--panel);border-radius:18px 18px 0 0;box-shadow:var(--shadow);z-index:45;padding:18px 18px calc(18px + var(--safe-b))}.note-quote{font-size:13px;color:var(--ink-soft);background:var(--panel-2);padding:9px 11px;border-radius:8px;margin-bottom:11px;max-height:4.5em;overflow:auto}.note-sheet textarea{width:100%;min-height:110px;border:1px solid var(--line);border-radius:10px;padding:11px;font:inherit;font-size:14.5px;resize:vertical;background:#fff}.note-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:13px}.pdf-body{flex:1;overflow:auto;display:flex;justify-content:center;padding:16px;background:#ddd8cf}.pdf-canvas{box-shadow:var(--shadow);height:fit-content;background:#fff}.pdf-msg{margin:auto}.pdf-foot{display:flex;align-items:center;justify-content:center;gap:16px;padding:10px;border-top:1px solid var(--line);background:var(--panel-2)}.pdf-num{font-size:13.5px;color:var(--ink-soft);min-width:70px;text-align:center}.pdf-note{text-align:center;padding:6px 0 calc(6px + var(--safe-b));background:var(--panel-2);margin:0}.img-viewport{flex:1;position:relative;overflow:hidden;background:#2b2824;display:grid;place-items:center;touch-action:none;-webkit-user-select:none;user-select:none}.img-wrap{will-change:transform;transform-origin:center center}.img-canvas{display:block;box-shadow:0 4px 24px #0006}.img-msg{position:absolute;color:#cfc8bc}.img-viewport .unsupported{color:#cfc8bc}.img-viewport .unsupported h3{color:#f2ede3}.img-nav{position:absolute;top:0;bottom:0;width:16%;display:grid;place-items:center;color:#ffffff80;font-size:30px;z-index:5;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.55)}.img-nav.left{left:0}.img-nav.right{right:0}.img-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 14px calc(8px + var(--safe-b));background:var(--panel-2);border-top:1px solid var(--line);font-size:12px;color:var(--muted)}.img-zoom{font-variant-numeric:tabular-nums}.img-foot-btn{border:1px solid var(--line);background:var(--panel);color:var(--ink-soft);padding:6px 13px;border-radius:9px;font-size:13px;white-space:nowrap}.img-foot-btn.on{color:var(--accent);border-color:var(--accent)}.img-foot-btn b{color:var(--accent);font-weight:700}.img-dir-hint{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bm-colors{display:flex;gap:11px;justify-content:center;margin:6px 0 13px}.bm-swatch{width:30px;height:30px;border-radius:50%;border:2px solid transparent;box-shadow:0 1px 3px #0003}.bm-swatch.on{border-color:var(--ink);box-shadow:0 0 0 3px #00000016}.audio-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px calc(24px + var(--safe-b));text-align:center}.audio-cover{width:220px;height:220px;border-radius:18px;display:grid;place-items:center;font-size:88px;color:#fff8ef;background:linear-gradient(150deg,#b2bdb0,#8f9a8c);box-shadow:var(--shadow);margin-bottom:16px}.audio-title{font-size:19px;font-weight:600;max-width:360px}.audio-author{font-size:14px;color:var(--muted);margin-bottom:16px}.audio-scrub{width:min(420px,86vw);accent-color:var(--accent)}.audio-time{width:min(420px,86vw);display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}.audio-ctrls{display:flex;align-items:center;gap:22px;margin-top:14px}.icon-btn.big{font-size:15px;color:var(--ink-soft);padding:10px}.play-btn{width:68px;height:68px;border-radius:50%;border:none;background:var(--accent);color:var(--accent-ink);font-size:26px;box-shadow:var(--shadow)}.text-body{flex:1;overflow-y:auto;padding:24px max(24px,calc((100% - 720px)/2)) calc(40px + var(--safe-b))}.text-content{white-space:pre-wrap;font-family:inherit;line-height:1.85;margin:0;color:#3f3a35}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#28252157;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--panel);border-radius:16px;padding:22px;width:400px;max-width:100%;max-height:88vh;overflow-y:auto}.modal h3{margin:0 0 12px}.modal label{display:block;font-size:13px;color:var(--muted);margin:12px 0 5px}.modal input,.modal select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;background:#fff}.color-names{display:flex;flex-direction:column;gap:7px}.color-name-row{display:flex;align-items:center;gap:10px}.color-name-row input{flex:1}.modal-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:18px}@media (max-width: 820px){.grid{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:16px}.page-nav{width:38px;flex-basis:38px;font-size:22px}.side{position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;flex:none;height:78vh;border-left:none;border-top:1px solid var(--line);border-radius:18px 18px 0 0;z-index:40;box-shadow:var(--shadow)}.note-sheet{width:100%}.reader-title{max-width:40vw}}@media (max-width: 420px){.reader-bar .icon-btn{padding:7px 8px;font-size:14px}}
