:root{--bg:#faf9f5;--surface:#ffffff;--surface-2:#f1efe8;--text:#2c2c2a;--text-2:#5f5e5a;--text-3:#888780;--border:rgba(0,0,0,0.12);--border-2:rgba(0,0,0,0.22);--accent:#1d9e75;--accent-weak:#e1f5ee;--danger:#a32d2d;--radius:12px;--radius-sm:8px;--maxw:760px}@media (prefers-color-scheme:dark){:root{--bg:#1f1e1c;--surface:#2a2926;--surface-2:#34332f;--text:#ecebe5;--text-2:#b4b2a9;--text-3:#888780;--border:rgba(255,255,255,0.14);--border-2:rgba(255,255,255,0.26);--accent:#5dcaa5;--accent-weak:#0f3a30}}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,Noto Sans TC,Roboto,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input,textarea{font-family:inherit}.app{max-width:var(--maxw);margin:0 auto;padding:20px 16px 96px}.row{display:flex;align-items:center}.between{justify-content:space-between}.muted{color:var(--text-2)}.hint{color:var(--text-3)}.h-title{font-size:22px;font-weight:600;margin:0}.section-title{font-size:16px;font-weight:600;margin:22px 0 12px}.searchbar{display:flex;align-items:center;gap:10px;padding:11px 14px;margin-top:16px;color:var(--text-3);font-size:15px;cursor:pointer}.card,.searchbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.card{padding:14px}.book-row{display:flex;gap:14px;margin-bottom:12px;align-items:stretch}.cover{width:52px;min-width:52px;height:72px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;object-fit:cover}.book-title{font-size:16px;font-weight:500}.book-author{font-size:13px;color:var(--text-2);margin-top:2px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{font-size:12px;background:var(--surface-2);color:var(--text-2);padding:3px 9px;border-radius:20px}.chip{font-size:13px;border:1px solid var(--border-2);color:var(--text);padding:6px 13px;border-radius:20px;cursor:pointer;background:transparent}.chip.add{border-color:var(--border)}.chip.add,.empty{color:var(--text-2)}.empty{text-align:center;padding:36px 16px;border:1px dashed var(--border-2);border-radius:var(--radius)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;border:none;cursor:pointer;padding:12px 18px;border-radius:var(--radius-sm);font-size:15px;font-weight:500}.btn.block{width:100%}.btn.ghost{background:transparent}.btn.ghost,.input{color:var(--text);border:1px solid var(--border-2)}.input{width:100%;background:var(--surface);border-radius:var(--radius-sm);padding:12px 14px;font-size:16px}.input:focus{outline:2px solid var(--accent);border-color:transparent}.nav{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-top:1px solid var(--border);justify-content:space-around;padding:9px 0 calc(9px + env(safe-area-inset-bottom))}.nav,.nav a{display:flex}.nav a{flex-direction:column;align-items:center;gap:2px;color:var(--text-3);font-size:11px}.nav a.active{color:var(--text)}.nav .ico{font-size:20px;line-height:1}.center-screen{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;max-width:360px;margin:0 auto}.error{color:var(--danger);font-size:14px}.field{margin-top:14px}.label{font-size:13px;color:var(--text-2);margin-bottom:6px;display:block}textarea.input{resize:vertical;min-height:90px}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.seg{display:flex;gap:8px;margin-top:12px}.seg button{flex:1 1;padding:9px;border-radius:var(--radius-sm);border:1px solid var(--border-2);background:transparent;color:var(--text-2);cursor:pointer;font-size:14px}.seg button.on{background:var(--accent);color:#fff;border-color:transparent}.result{display:flex;gap:12px;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:8px;cursor:pointer;background:var(--surface)}.result:hover{border-color:var(--accent)}.result .cover{width:40px;min-width:40px;height:56px;font-size:16px}.taginput{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:8px;background:var(--surface)}.taginput input{border:none;outline:none;background:transparent;color:var(--text);font-size:15px;flex:1 1;min-width:90px}.tag-removable{display:inline-flex;align-items:center;gap:5px;font-size:13px;background:var(--accent-weak);color:var(--accent);padding:3px 6px 3px 10px;border-radius:20px}.tag-removable button{border:none;background:transparent;color:inherit;cursor:pointer;font-size:15px;line-height:1;padding:0}.suggest{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.suggest .chip{padding:4px 10px;font-size:12px}.status-badge{font-size:12px;padding:3px 10px;border-radius:20px;background:var(--surface-2);color:var(--text-2)}.book-head{display:flex;gap:16px;margin-top:8px}.book-head .cover{width:84px;min-width:84px;height:116px;font-size:30px}.desc{color:var(--text-2);font-size:14px;line-height:1.7;margin-top:12px;white-space:pre-wrap}.link-row{display:flex;gap:16px;margin-top:16px;flex-wrap:wrap}.text-link{color:var(--accent)}.danger-link,.text-link{font-size:14px;cursor:pointer}.danger-link{color:var(--danger);background:none;border:none;padding:0}.tool-links{display:flex;flex-direction:column;gap:8px}.tool-link{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-size:15px}.tool-link .meta,.tool-link.disabled{color:var(--text-3)}.tool-link .meta{font-size:13px}.chapter-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px 14px;margin-bottom:8px}.chapter-row .ttl{font-size:15px}.chapter-row .sub{font-size:12px;color:var(--text-3);margin-top:2px}.editor{width:100%;min-height:50vh;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;font-size:16px;line-height:1.7;color:var(--text);resize:vertical;font-family:inherit}.editor:focus{outline:2px solid var(--accent);border-color:transparent}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;position:-webkit-sticky;position:sticky;top:0;background:var(--bg);padding:8px 0;z-index:5}.toolbar .save-state{font-size:12px;color:var(--text-3);margin-left:auto}.btn.sm{padding:7px 12px;font-size:13px}.md-body{font-size:16px;line-height:1.7;color:var(--text)}.md-body h1,.md-body h2,.md-body h3{line-height:1.4;margin:18px 0 8px}.md-body h1{font-size:20px}.md-body h2{font-size:18px}.md-body h3{font-size:16px}.md-body p{margin:8px 0}.md-body ol,.md-body ul{padding-left:22px;margin:8px 0}.md-body li{margin:3px 0}.md-body blockquote{border-left:3px solid var(--accent);margin:10px 0;padding:2px 0 2px 12px;color:var(--text-2)}.md-body code{padding:1px 5px;border-radius:4px;font-size:14px}.md-body code,.md-body pre{background:var(--surface-2)}.md-body pre{padding:12px;border-radius:var(--radius-sm);overflow-x:auto}.md-body pre code{background:none;padding:0}.md-body a{color:var(--accent)}.md-body img{max-width:100%;border-radius:var(--radius-sm)}.md-body table{border-collapse:collapse;width:100%}.md-body td,.md-body th{border:1px solid var(--border);padding:6px 10px;text-align:left}.card-item{margin-bottom:10px}.card-item .card-title{font-size:15px;font-weight:500}.card-item .card-origin{font-size:12px;color:var(--text-3);margin-top:2px}.card-actions{display:flex;gap:14px;margin-top:10px}.thread-switch{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px}.thread-switch a{white-space:nowrap;font-size:13px;padding:6px 12px;border-radius:20px;border:1px solid var(--border-2);color:var(--text-2)}.thread-switch a.on{background:var(--accent);color:#fff;border-color:transparent}.chat{display:flex;flex-direction:column;gap:12px;padding-bottom:12px}.bubble{max-width:86%;padding:10px 14px;border-radius:14px;font-size:15px;line-height:1.7}.bubble.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}.bubble.ai{align-self:flex-start;background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px}.bubble.ai .md-body{font-size:15px}.bubble.ai .md-body :first-child{margin-top:0}.bubble.ai .md-body :last-child{margin-bottom:0}.chat-input-wrap{position:-webkit-sticky;position:sticky;bottom:0;background:var(--bg);padding:10px 0 8px;border-top:1px solid var(--border)}.chat-input{display:flex;gap:8px;align-items:flex-end}.chat-input textarea{flex:1 1;resize:none;max-height:140px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:10px 12px;font-size:16px;color:var(--text);line-height:1.5}.chat-input textarea:focus{outline:2px solid var(--accent);border-color:transparent}.mode-toggle{display:flex;gap:6px;margin-bottom:8px;align-items:center}.mode-toggle .lbl{font-size:12px;color:var(--text-3)}.mode-pill{font-size:12px;padding:4px 10px;border-radius:20px;cursor:pointer;border:1px solid var(--border-2);background:transparent;color:var(--text-2)}.mode-pill.on{background:var(--accent-weak);color:var(--accent);border-color:transparent}.typing{align-self:flex-start;color:var(--text-3);font-size:14px;padding:4px 6px}.diagram-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;overflow-x:auto;text-align:center}.diagram-box svg{max-width:100%;height:auto}.gen-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:16px}.gen-row{display:flex;gap:8px;flex-wrap:wrap}.gen-row select{flex:1 1;min-width:120px}.diagram-src{width:100%;min-height:120px;margin-top:10px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--radius-sm);padding:10px;font-family:var(--font-mono,monospace);font-size:13px;color:var(--text);resize:vertical}.saved-diagram{margin-bottom:18px}.saved-diagram .dhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.dtype{font-size:14px;font-weight:500}.dscope{font-size:12px;color:var(--text-3)}