:root{--bg-primary: #faf8f5;--bg-secondary: #f0ece4;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-muted: #888;--border-color: #d4cfc4;--gutter-bg: #f5f2eb;--note-color: #6b5c4d;--heading-color: #2d2d2d;--ruby-color: #666;--accent-color: #8b4513;--selection-bg: rgba(139, 69, 19, .2);--column-width: 3em;--column-gap: .5em;--gutter-width: 1.2em;--block-spacing: 0;--page-padding: 1.5rem;--font-main: "Noto Serif CJK SC", "Noto Serif SC", "Source Han Serif SC", "Source Han Serif", "Songti SC", serif;--font-note: "Noto Sans CJK SC", "Noto Sans SC", "Source Han Sans SC", "PingFang SC", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-base: 20px;--font-size-small: .75rem;--font-size-note: .65rem;--font-size-h1: 1.75rem;--font-size-h2: 1.5rem;--font-size-h3: 1.25rem;--line-height: 1.8}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #242424;--text-primary: #e8e4dc;--text-secondary: #b8b4ac;--text-muted: #777;--border-color: #3a3a3a;--gutter-bg: #222;--note-color: #a89880;--heading-color: #f0ece4;--ruby-color: #999;--accent-color: #d4a574;--selection-bg: rgba(212, 165, 116, .3)}::view-transition-old(root){animation:none}::view-transition-new(root){animation:none}body,.vertical-reader,.settings-panel,.settings-btn,.nav-hint,.column-indicator{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.vertical-reader{writing-mode:vertical-rl;text-orientation:mixed;height:100vh;width:100vw;overflow-x:auto;overflow-y:hidden;background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-main);font-size:var(--font-size-base);line-height:var(--line-height);padding:var(--page-padding);box-sizing:border-box;-webkit-overflow-scrolling:touch;overscroll-behavior:none;touch-action:pan-x pan-y;scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-secondary)}.vertical-reader::-webkit-scrollbar{height:8px}.vertical-reader::-webkit-scrollbar-track{background:var(--bg-secondary)}.vertical-reader::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.vertical-reader::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.reader-content{display:flex;flex-direction:column;gap:var(--block-spacing);min-height:max-content;overflow-anchor:auto}.text-block{overflow-anchor:auto}.virtual-placeholder{overflow-anchor:none}.text-block{display:flex;flex-direction:column;align-items:flex-start;position:relative}.text-block.gutter-note-style{margin-left:1em}.block-main{flex-shrink:0}.block-gutter{position:relative;min-width:var(--gutter-width);width:var(--gutter-width);flex-shrink:0;min-height:0}.gutter-note{font-family:var(--font-note);font-size:var(--font-size-note);color:var(--note-color);line-height:1.4;word-break:break-all;writing-mode:vertical-rl;display:block;margin-top:.3em}.gutter-note.appended-note{margin-top:.5em}.note-anchor{display:none}.end-note{display:block;font-family:var(--font-note);font-size:var(--font-size-note);color:var(--note-color);line-height:var(--line-height);margin-top:.3em;max-height:calc(100vh - 5rem);overflow-wrap:break-word;word-break:break-all}.end-note:first-of-type{margin-top:.5em}.text-block.inline-note-style{display:flex;flex-direction:column}.text-block.inline-note-style .block-main{flex-shrink:0}.text-block.inline-note-style .block-gutter{min-width:var(--gutter-width);width:var(--gutter-width);flex-shrink:0;display:none}.inline-note-spacer{display:inline;font-family:var(--font-note);font-size:var(--font-size-note);color:var(--note-color);line-height:var(--line-height)}.inline-note-spacer.appended{display:block}.inline-gutter-note{display:none}.vertical-heading{color:var(--heading-color);font-weight:600;margin:0}h1.vertical-heading{font-size:var(--font-size-h1)}h2.vertical-heading{font-size:var(--font-size-h2)}h3.vertical-heading{font-size:var(--font-size-h3)}.vertical-paragraph{margin:0;text-align:justify;max-height:calc(100vh - 5rem);text-justify:inter-ideograph;word-break:break-all}ruby{ruby-align:center}ruby rt{font-size:.5em;color:var(--ruby-color);font-family:var(--font-note)}strong{font-weight:700}em{font-style:normal;text-decoration:underline;text-decoration-style:wavy;text-underline-offset:.2em}::selection{background-color:var(--selection-bg)}.vertical-column{display:flex;flex-direction:column;min-height:100%;position:relative}.column-content{flex:1}.column-number{position:absolute;bottom:0;left:50%;transform:translate(-50%);font-size:var(--font-size-small);color:var(--text-muted);font-family:var(--font-mono);writing-mode:horizontal-tb}@media (max-height: 600px){:root{--font-size-base: 1rem;--font-size-note: .55rem}}@media (max-width: 768px){.vertical-reader{padding:1rem}:root{--gutter-width: 2em}}.virtual-placeholder{flex-shrink:0}.reader-content{transition:opacity .15s ease-out;view-transition-name:reader-content}::view-transition-old(reader-content),::view-transition-new(reader-content){animation-duration:.25s;animation-timing-function:ease-in-out}::view-transition-old(reader-content){animation-name:fade-out}::view-transition-new(reader-content){animation-name:fade-in}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.reader-content.virtual-fade-out{opacity:0;transition:opacity .12s ease-out}.reader-content.virtual-fade-in{opacity:1;transition:opacity .18s ease-in}@media print{.reader-content{display:none!important}}.bookmark-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-family:var(--font-note);font-size:.875rem;transition:all .2s ease;opacity:.6;writing-mode:horizontal-tb}.bookmark-btn:hover{opacity:1;background:var(--bg-primary);border-color:var(--text-muted)}.bookmark-panel{position:fixed;top:3.5rem;left:1rem;z-index:100;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease;opacity:0;width:240px;writing-mode:horizontal-tb}.bookmark-panel[data-open=true]{max-height:500px;padding:.75rem;opacity:1;overflow-y:auto}.bookmark-panel{view-transition-name:bookmark-panel}::view-transition-old(bookmark-panel),::view-transition-new(bookmark-panel){animation:none;mix-blend-mode:normal}.bookmark-panel-header{font-family:var(--font-note);font-size:.9rem;font-weight:500;color:var(--text-primary);padding-bottom:.5rem;border-bottom:1px solid var(--border-color);margin-bottom:.5rem}.bookmark-section{margin-bottom:.75rem}.bookmark-section:last-child{margin-bottom:0}.bookmark-section-title{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4rem;padding:.25rem 0;border-bottom:1px dashed var(--border-color)}.resume-item{display:flex;align-items:flex-start;padding:.5rem;background:var(--bg-primary);border-radius:4px;cursor:pointer;transition:background .2s ease}.resume-item:hover{background:var(--selection-bg)}.resume-item-icon{font-size:1rem;margin-right:.5rem;color:var(--accent-color)}.resume-item-content{flex:1}.resume-item-title{font-family:var(--font-note);font-size:.8rem;font-weight:500;color:var(--text-primary)}.resume-item-meta{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);margin-top:.15rem}.bookmark-list{list-style:none;padding:0;margin:0}.bookmark-item{display:flex;align-items:center;padding:.4rem .5rem;border-radius:4px;cursor:pointer;transition:background .2s ease}.bookmark-item:hover{background:var(--bg-primary)}.bookmark-item-number{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);width:1.2em;margin-right:.5rem}.bookmark-item-info{flex:1;min-width:0}.bookmark-item-column{font-family:var(--font-note);font-size:.75rem;color:var(--text-primary)}.bookmark-item-label{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);margin-left:.25rem}.bookmark-item-empty{font-family:var(--font-note);font-size:.75rem;color:var(--text-muted);font-style:italic}.bookmark-item-delete{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem;font-size:.8rem;transition:opacity .2s ease,color .2s ease}.bookmark-item:hover .bookmark-item-delete{opacity:1}.bookmark-item-delete:hover{color:#e74c3c}.add-bookmark-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:.4rem;margin-top:.4rem;background:var(--bg-primary);border:1px dashed var(--border-color);border-radius:4px;color:var(--text-muted);font-family:var(--font-note);font-size:.75rem;cursor:pointer;transition:all .2s ease}.add-bookmark-btn:hover{background:var(--selection-bg);border-color:var(--accent-color);color:var(--text-primary)}.storage-notice{font-family:var(--font-note);font-size:.65rem;color:var(--text-muted);text-align:center;padding-top:.5rem;border-top:1px solid var(--border-color);margin-top:.5rem}.nav-trigger{position:fixed;bottom:1.25rem;left:1rem;z-index:100;background:transparent;border:none;color:var(--text-muted);font-size:.75rem;line-height:1;cursor:pointer;opacity:.5;transition:opacity .2s ease;padding:0;writing-mode:horizontal-tb}.nav-trigger:hover{opacity:1}.nav-popover{position:fixed;bottom:2.5rem;left:1rem;z-index:100;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;width:220px;max-height:0;overflow:hidden;opacity:0;transition:max-height .2s ease,opacity .2s ease;writing-mode:horizontal-tb;view-transition-name:nav-popover}.nav-popover[data-open=true]{max-height:350px;opacity:1}::view-transition-old(nav-popover),::view-transition-new(nav-popover){animation:none;mix-blend-mode:normal}.nav-popover-content{padding:.75rem}.nav-section{margin-bottom:.75rem}.nav-section:last-child{margin-bottom:0}.nav-section-header{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.nav-jump-section{padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.nav-progress-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.nav-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:var(--bg-primary);border-radius:2px;outline:none}.nav-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:10px;height:10px;background:var(--accent-color);border-radius:50%;cursor:pointer}.nav-slider::-moz-range-thumb{width:10px;height:10px;background:var(--accent-color);border:none;border-radius:50%;cursor:pointer}.nav-percent{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);min-width:2.5rem;text-align:right}.nav-jump-row{display:flex;align-items:center;gap:.4rem}.nav-jump-label{font-family:var(--font-note);font-size:.7rem;color:var(--text-secondary)}.nav-jump-input{width:3rem;padding:.2rem .3rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:.7rem;text-align:center}.nav-jump-input:focus{outline:none;border-color:var(--accent-color)}.nav-jump-total{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.nav-chapters-section{max-height:200px;display:flex;flex-direction:column}.nav-search-input{width:100%;padding:.35rem .5rem;margin-bottom:.4rem;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.75rem}.nav-search-input:focus{outline:none;border-color:var(--accent-color)}.nav-search-input::placeholder{color:var(--text-muted)}.nav-chapter-list{list-style:none;padding:0;margin:0;max-height:150px;overflow-y:auto;flex:1}.nav-chapter-item{padding:.3rem .4rem;border-radius:3px;cursor:pointer;transition:background .15s ease}.nav-chapter-item:hover{background:var(--bg-primary)}.nav-chapter-title{font-family:var(--font-note);font-size:.75rem;color:var(--text-primary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-chapter-title[data-level="1"]{font-weight:500}.nav-chapter-title[data-level="2"]{padding-left:.75em;font-size:.7rem}.nav-chapter-title[data-level="3"],.nav-chapter-title[data-level="4"],.nav-chapter-title[data-level="5"],.nav-chapter-title[data-level="6"]{padding-left:1.5em;font-size:.65rem;color:var(--text-secondary)}.nav-no-results{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);font-style:italic;padding:.5rem;text-align:center}.nav-more-hint{font-family:var(--font-note);font-size:.65rem;color:var(--text-muted);text-align:center;padding-top:.3rem}.bookmark-toast{position:fixed;bottom:3rem;left:50%;transform:translate(-50%) translateY(100%);background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;font-family:var(--font-note);font-size:.8rem;z-index:200;opacity:0;transition:transform .3s ease,opacity .3s ease;writing-mode:horizontal-tb}.bookmark-toast.show{transform:translate(-50%) translateY(0);opacity:1}.bookshelf-view{width:100vw;height:100vh;overflow-y:auto;background:var(--bg-primary);color:var(--text-primary);writing-mode:horizontal-tb}.bookshelf-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.bookshelf-header-left{display:flex;align-items:center;gap:1rem}.bookshelf-title{font-family:var(--font-main);font-size:1.5rem;color:var(--text-primary);margin:0}.bookshelf-header-right{display:flex;align-items:center;gap:.75rem}.wallet-btn{position:relative;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-family:var(--font-note);font-size:.8rem;transition:all .2s ease;display:flex;align-items:center;gap:.4rem}.wallet-btn:hover{border-color:var(--text-muted)}.wallet-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.wallet-status-dot.connected{background:#4caf50}.wallet-status-dot.disconnected{background:#f44336}.bookshelf-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.bookshelf-icon-btn:hover{color:var(--text-primary);border-color:var(--text-muted);background:var(--bg-secondary)}.bookshelf-lang-wrapper{position:relative}.bookshelf-lang-dropdown{position:absolute;top:calc(100% + .4rem);right:0;z-index:200;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:0;min-width:130px;max-height:0;overflow:hidden;opacity:0;transition:max-height .2s ease,padding .2s ease,opacity .2s ease}.bookshelf-lang-dropdown[data-open=true]{max-height:300px;padding:.3rem;opacity:1}.bookshelf-lang-option{display:block;width:100%;padding:.45rem .7rem;border:none;background:none;color:var(--text-primary);font-family:var(--font-note);font-size:.8rem;text-align:left;border-radius:4px;cursor:pointer;transition:background .15s ease}.bookshelf-lang-option:hover{background:var(--bg-primary)}.bookshelf-lang-option.active{color:var(--accent-color);font-weight:500}.add-book-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;transition:opacity .2s ease}.add-book-btn:hover{opacity:.85}.bookshelf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,180px));gap:1.5rem;padding:2rem;justify-content:center}.book-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:1rem;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;min-height:220px;position:relative;overflow:hidden}.book-card:hover{border-color:var(--accent-color);box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.book-card-title-area{flex:1;display:flex;align-items:center;justify-content:center;padding:.5rem 0;min-height:120px}.book-card-title{writing-mode:vertical-rl;font-family:var(--font-main);font-size:1.1rem;color:var(--text-primary);line-height:1.6;max-height:120px;overflow:hidden;text-overflow:ellipsis;letter-spacing:.05em}.book-card-meta{border-top:1px solid var(--border-color);padding-top:.5rem;margin-top:.5rem}.book-card-excerpt{font-family:var(--font-note);font-size:.7rem;color:var(--text-muted);line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.4rem}.book-card-info{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted)}.book-card-version{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:3px;padding:.1rem .3rem;font-size:.6rem}.book-card-actions{display:flex;gap:.3rem;margin-top:.5rem}.book-card-actions button{flex:1;padding:.3rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-family:var(--font-note);font-size:.65rem;border-radius:3px;cursor:pointer;transition:all .15s ease}.book-card-actions button:hover{border-color:var(--text-muted);color:var(--text-primary)}.book-card-actions .delete-btn:hover{border-color:#e74c3c;color:#e74c3c}.book-card-shared{position:relative}.shared-badge{position:absolute;top:.4rem;right:.4rem;font-family:var(--font-note);font-size:.55rem;padding:.15rem .4rem;border-radius:3px;background:var(--accent-color);color:#fff;letter-spacing:.02em;line-height:1;z-index:1}.book-card-owner{font-size:.6rem;color:var(--text-muted);font-family:var(--font-mono)}.bookshelf-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:60vh}.bookshelf-empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.3}.bookshelf-empty h2{font-family:var(--font-main);font-size:1.25rem;color:var(--text-secondary);margin-bottom:.5rem}.bookshelf-empty p{font-family:var(--font-note);font-size:.85rem;color:var(--text-muted)}.bookshelf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;min-height:60vh}.bookshelf-loading .spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.bookshelf-loading p{font-family:var(--font-note);font-size:.85rem;color:var(--text-muted)}@keyframes spin{to{transform:rotate(360deg)}}.bookshelf-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:60vh}.bookshelf-error p{font-family:var(--font-note);font-size:.85rem;color:#e74c3c;margin-bottom:1rem}.bookshelf-error button{padding:.5rem 1.5rem;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-note);font-size:.8rem;border-radius:4px;cursor:pointer}.wallet-panel{position:absolute;top:calc(100% + .5rem);right:0;z-index:200;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:0;min-width:280px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease;opacity:0;writing-mode:horizontal-tb}.wallet-panel[data-open=true]{max-height:500px;padding:1rem;opacity:1;overflow-y:auto}.wallet-panel-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.wallet-panel-group:last-child{margin-bottom:0}.wallet-panel-label{font-family:var(--font-note);font-size:.75rem;color:var(--text-muted)}.wallet-address-display{font-family:var(--font-mono);font-size:.7rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:.4rem .5rem;word-break:break-all;line-height:1.4}.wallet-copy-btn{width:100%;margin-top:.3rem;text-align:center}.wallet-panel-row{display:flex;gap:.4rem}.wallet-panel-btn{flex:1;padding:.4rem .6rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.7rem;border-radius:4px;cursor:pointer;transition:all .15s ease}.wallet-panel-btn:hover{border-color:var(--text-muted)}.wallet-panel-btn.danger:hover{border-color:#e74c3c;color:#e74c3c}.wallet-import-row{display:flex;gap:.4rem}.wallet-import-input{flex:1;padding:.4rem .5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:.65rem;border-radius:4px;min-width:0}.wallet-import-input:focus{outline:none;border-color:var(--accent-color)}.wallet-balance-display{font-family:var(--font-mono);font-size:.8rem;color:var(--text-primary);padding:.2rem 0}.wallet-generate-btn{font-size:.65rem;color:var(--text-muted);padding:.3rem .5rem}.wallet-generate-confirm{margin-top:.4rem}.wallet-generate-warning{font-family:var(--font-note);font-size:.7rem;color:#e74c3c;margin-bottom:.3rem}.wallet-panel-divider{height:1px;background:var(--border-color);margin:.5rem 0}.wallet-panel-hint{font-family:var(--font-note);font-size:.65rem;color:var(--text-muted);font-style:italic}.wallet-connection-status{display:flex;align-items:center;gap:.4rem;font-family:var(--font-note);font-size:.7rem}.upload-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center;writing-mode:horizontal-tb}.upload-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;width:90%;max-width:500px;max-height:80vh;overflow-y:auto}.upload-modal h3{font-family:var(--font-main);font-size:1.1rem;color:var(--text-primary);margin-bottom:1rem}.upload-modal-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.upload-modal-label{font-family:var(--font-note);font-size:.8rem;color:var(--text-secondary)}.upload-modal-hint{font-family:var(--font-note);font-size:.65rem;color:var(--text-muted)}.upload-textarea{width:100%;min-height:150px;padding:.5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:.75rem;border-radius:4px;resize:vertical}.upload-textarea:focus{outline:none;border-color:var(--accent-color)}.upload-docid-input{width:100%;padding:.4rem .5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:.75rem;border-radius:4px}.upload-docid-input:focus{outline:none;border-color:var(--accent-color)}.upload-size-info{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted)}.upload-size-info.over-limit{color:#e74c3c;font-weight:500}.upload-modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.upload-modal-actions button{padding:.5rem 1.2rem;border-radius:4px;font-family:var(--font-note);font-size:.8rem;cursor:pointer;transition:all .15s ease}.upload-cancel-btn{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary)}.upload-cancel-btn:hover{border-color:var(--text-muted)}.upload-submit-btn{border:none;background:var(--accent-color);color:#fff}.upload-submit-btn:hover{opacity:.85}.upload-submit-btn:disabled{opacity:.5;cursor:not-allowed}.upload-pending{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;text-align:center}.upload-pending .spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.upload-pending p{font-family:var(--font-note);font-size:.85rem;color:var(--text-muted)}.back-to-bookshelf-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-family:var(--font-note);font-size:.875rem;transition:all .2s ease;opacity:.6;writing-mode:horizontal-tb}.back-to-bookshelf-btn:hover{opacity:1;background:var(--bg-primary);border-color:var(--text-muted)}.bookshelf-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:2000;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:.6rem 1.2rem;font-family:var(--font-note);font-size:.8rem;color:var(--text-primary);box-shadow:0 4px 12px #00000026;animation:toast-in .3s ease,toast-out .3s ease 2.7s;writing-mode:horizontal-tb}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(10px)}}@media print{.bookshelf-view,.bookshelf-header,.bookshelf-grid,.bookshelf-empty,.bookshelf-loading,.bookshelf-error,.wallet-panel,.upload-modal-backdrop,.back-to-bookshelf-btn,.bookshelf-toast{display:none!important}}.editor-view{width:100vw;height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);color:var(--text-primary);writing-mode:horizontal-tb;overflow:hidden}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.editor-header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.editor-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.editor-back-btn:hover{color:var(--text-primary);border-color:var(--text-muted)}.editor-doc-title{font-family:var(--font-main);font-size:1.1rem;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.editor-header-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.editor-byte-count{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);white-space:nowrap}.editor-byte-count.over-limit{color:#e74c3c;font-weight:500}.editor-fuel-estimate{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);white-space:nowrap}.editor-save-btn{padding:.4rem 1rem;border:none;background:var(--accent-color);color:#fff;font-family:var(--font-note);font-size:.8rem;border-radius:4px;cursor:pointer;transition:opacity .15s ease;white-space:nowrap}.editor-save-btn:hover{opacity:.85}.editor-save-btn:disabled{opacity:.5;cursor:not-allowed}.editor-save-btn.saving{opacity:.7;cursor:wait}.editor-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.editor-tab{padding:.5rem 1.5rem;border:none;background:none;color:var(--text-muted);font-family:var(--font-note);font-size:.8rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease}.editor-tab:hover{color:var(--text-primary)}.editor-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-color);font-weight:500}.editor-content{flex:1;position:relative;overflow:hidden}.editor-edit-panel{position:absolute;top:0;right:0;bottom:0;left:0}.editor-textarea{width:100%;height:100%;padding:1.5rem;border:none;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-mono);font-size:.85rem;line-height:1.7;resize:none;outline:none;-moz-tab-size:2;tab-size:2}.editor-textarea::placeholder{color:var(--text-muted)}.editor-preview-panel{position:absolute;top:0;right:0;bottom:0;left:0;writing-mode:vertical-rl;text-orientation:mixed;overflow-x:auto;overflow-y:hidden;padding:var(--page-padding, 1.5rem);display:none;scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-secondary)}.editor-preview-panel::-webkit-scrollbar{height:8px}.editor-preview-panel::-webkit-scrollbar-track{background:var(--bg-secondary)}.editor-preview-panel::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.editor-preview-panel::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.editor-preview-panel.active{display:block}.editor-preview{height:100%;min-width:max-content;font-family:var(--font-main);font-size:var(--font-size-base, 20px);line-height:var(--line-height, 1.8);color:var(--text-primary)}.editor-preview h1,.editor-preview h2,.editor-preview h3,.editor-preview h4,.editor-preview h5,.editor-preview h6{color:var(--heading-color, var(--text-primary));margin-left:.8em;line-height:1.3}.editor-preview h1{font-size:1.8em}.editor-preview h2{font-size:1.5em}.editor-preview h3{font-size:1.25em}.editor-preview p{margin-left:.5em}.editor-preview blockquote{border-right:3px solid var(--accent-color);padding-right:.8em;margin-left:1em;color:var(--text-secondary)}.editor-preview code{font-family:var(--font-mono);font-size:.85em;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:3px;padding:.15em .3em}.editor-preview pre{writing-mode:horizontal-tb;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:1em;overflow-x:auto;margin-left:1em;max-height:80%}.editor-preview pre code{background:none;border:none;padding:0}.editor-preview ul,.editor-preview ol{padding-top:1.5em;margin-left:.5em}.editor-preview li{margin-top:.3em}.editor-preview a{color:var(--accent-color);text-decoration:underline}.editor-preview img{max-height:80%;width:auto}.editor-preview hr{border:none;border-left:1px solid var(--border-color);margin-left:1em;height:auto}.editor-preview table{writing-mode:horizontal-tb;border-collapse:collapse;margin-left:1em}.editor-preview th,.editor-preview td{border:1px solid var(--border-color);padding:.5em .75em;text-align:left}.editor-preview th{background:var(--bg-secondary);font-weight:600}.editor-preview ruby rt{font-size:.6em;color:var(--ruby-color, var(--text-muted))}.editor-preview .note-marker{display:block;color:var(--note-color, var(--text-muted));margin-top:.3em}.editor-preview .note-marker:after{content:attr(data-note)}.editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem}.editor-loading .spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}.editor-loading p{font-family:var(--font-note);font-size:.85rem;color:var(--text-muted)}.editor-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.75rem}.editor-error p{font-family:var(--font-note);font-size:.85rem;color:#e74c3c}@media print{.editor-view{display:none!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}body{margin:0;padding:0;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}#app{width:100vw;height:100vh;overflow:hidden}.nav-hint{position:fixed;bottom:1rem;left:2rem;z-index:100;font-family:var(--font-note);font-size:.75rem;color:var(--text-muted);opacity:.6;transition:opacity .2s ease;writing-mode:horizontal-tb}.nav-hint:hover{opacity:1}.nav-hint kbd{display:inline-block;padding:.15em .4em;font-family:var(--font-mono);font-size:.85em;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:3px}.nav-hint-chapters{cursor:pointer;padding:.2em .3em;border-radius:3px;transition:background .15s ease}.nav-hint-chapters:hover{background:var(--bg-secondary)}.column-indicator{position:fixed;bottom:1rem;right:1rem;z-index:100;font-family:var(--font-mono);font-size:.875rem;color:var(--text-muted);opacity:.6;transition:opacity .2s ease;writing-mode:horizontal-tb}.column-indicator:hover{opacity:1}.top-button-bar{position:fixed;top:1rem;left:1rem;z-index:100;display:flex;gap:.5rem;writing-mode:horizontal-tb}.settings-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-family:var(--font-note);font-size:.875rem;transition:all .2s ease;opacity:.6;writing-mode:horizontal-tb}.settings-btn:hover{opacity:1;background:var(--bg-primary);border-color:var(--text-muted)}.settings-panel{position:fixed;top:3.5rem;left:1rem;z-index:100;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .3s ease;opacity:0;writing-mode:horizontal-tb}.settings-panel[data-open=true]{max-height:calc(100vh - 5rem);padding:1rem;opacity:1;overflow-y:auto}.settings-panel{view-transition-name:settings}::view-transition-old(settings),::view-transition-new(settings){animation:none;mix-blend-mode:normal}.settings-content{display:flex;flex-direction:column;gap:1rem;min-width:150px}.settings-group{display:flex;flex-direction:column;gap:.5rem}.settings-label{font-family:var(--font-note);font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;cursor:pointer}.segmented-control{display:flex;position:relative;background:var(--bg-primary);border-radius:8px;padding:3px;border:1px solid var(--border-color)}.segmented-control input[type=radio]{position:absolute;opacity:0;width:0;height:0}.segmented-control label{flex:1;padding:.4rem .8rem;font-family:var(--font-note);font-size:.75rem;text-align:center;cursor:pointer;color:var(--text-muted);transition:color .2s ease;z-index:1;-webkit-user-select:none;user-select:none}.segmented-control input[type=radio]:checked+label{color:var(--text-primary);font-weight:500}.segmented-slider{position:absolute;top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px);background:var(--bg-secondary);border-radius:6px;transition:transform .25s cubic-bezier(.4,0,.2,1),background-color .3s ease;box-shadow:0 1px 3px #0000001a}.segmented-control input[type=radio]:nth-of-type(2):checked~.segmented-slider{transform:translate(100%)}.segmented-control.two-options .segmented-slider{width:calc(50% - 2px)}.segmented-control.two-options input[type=radio]:nth-of-type(2):checked~.segmented-slider{transform:translate(100%)}.segmented-control.three-options .segmented-slider{width:calc(33.333% - 2px)}.segmented-control.three-options input[type=radio]:nth-of-type(2):checked~.segmented-slider{transform:translate(100%)}.segmented-control.three-options input[type=radio]:nth-of-type(3):checked~.segmented-slider{transform:translate(200%)}.toggle-switch{display:flex;align-items:center;gap:.6rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-switch input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;width:36px;height:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:20px;transition:all .2s ease;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-muted);border-radius:50%;transition:all .2s ease}.toggle-switch input[type=checkbox]:checked+.toggle-slider{background:var(--accent-color);border-color:var(--accent-color)}.toggle-switch input[type=checkbox]:checked+.toggle-slider:before{transform:translate(16px);background:#fff}.toggle-label{font-family:var(--font-note);font-size:.8rem;color:var(--text-primary)}.font-size-stepper{display:flex;align-items:center;justify-content:space-between;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:3px}.stepper-btn{width:32px;height:28px;border:none;background:transparent;color:var(--text-primary);font-size:1rem;font-weight:400;cursor:pointer;border-radius:6px;transition:background .15s ease;flex-shrink:0}.stepper-btn:hover{background:var(--bg-secondary)}.stepper-btn:active{background:var(--border-color)}.stepper-value{flex:1;text-align:center;font-family:var(--font-mono);font-size:.8rem;color:var(--text-primary)}.stepper-divider{width:1px;height:20px;background:var(--border-color);margin:0 2px}.stepper-reset{color:var(--text-muted);font-size:.85rem;transform:translateY(-1px)}.stepper-reset:hover{color:var(--text-primary)}.settings-divider{height:1px;background:var(--border-color);margin:.5rem 0}.load-controls{margin-bottom:.5rem}.load-btn{padding:.4rem .8rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.75rem;border-radius:4px;cursor:pointer;transition:all .15s ease}.load-btn:hover{background:var(--bg-secondary);border-color:var(--text-muted)}.load-url-row{display:flex;gap:.4rem}.load-url-input{flex:1;padding:.4rem .5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.75rem;border-radius:4px;min-width:0}.load-url-input:focus{outline:none;border-color:var(--accent-color)}.load-url-input::placeholder{color:var(--text-muted)}.load-url-btn{flex-shrink:0}.custom-font-row{display:flex;gap:.4rem}.custom-font-input{flex:1;padding:.4rem .5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.75rem;border-radius:4px;min-width:0}.custom-font-input:focus{outline:none;border-color:var(--accent-color)}.custom-font-input::placeholder{color:var(--text-muted)}.language-select{width:100%;padding:.4rem .5rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-note);font-size:.75rem;border-radius:4px;cursor:pointer;transition:all .15s ease}.language-select:hover{border-color:var(--text-muted)}.language-select:focus{outline:none;border-color:var(--accent-color)}.advanced-font-controls{display:flex;flex-direction:column;gap:.5rem}.advanced-font-row{display:flex;align-items:center;gap:.5rem}.advanced-font-label{font-family:var(--font-note);font-size:.75rem;color:var(--text-secondary);min-width:5em;flex-shrink:0;text-align:right}.advanced-font-range{flex:1;min-width:0;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:2px;outline:none;cursor:pointer}.advanced-font-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-color);border:none;cursor:pointer;transition:transform .1s ease}.advanced-font-range::-webkit-slider-thumb:hover{transform:scale(1.2)}.advanced-font-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-color);border:none;cursor:pointer}.advanced-font-value{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);width:3em;text-align:right;flex-shrink:0}.advanced-font-reset{margin-left:auto}[data-hide-punctuation=true] .punctuation{display:none}[data-text-mode=default]{--font-size-base: 30px;--font-size-note: 24px;--font-size-h1: 42px;--font-size-h2: 36px;--font-size-h3: 30px}[data-uniform-font=true]{--font-main: var(--font-note)}.print-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;align-items:flex-end;justify-content:center;padding-bottom:2rem;background:var(--bg-primary);color:var(--text-muted);font-family:var(--font-note);font-size:1.25rem;letter-spacing:.1em;writing-mode:horizontal-tb}@media print{@page{size:A4 portrait;margin:1.5cm 2cm}.settings-btn,.settings-panel,.bookmark-btn,.bookmark-panel,.bookmark-toast,.nav-trigger,.nav-popover,.nav-hint,.column-indicator,.top-button-bar,.print-overlay{display:none!important}html,body{background:#fff!important;color:#000!important;margin:0!important;padding:0!important}#app{width:auto!important;height:auto!important;overflow:visible!important}.vertical-reader{writing-mode:horizontal-tb!important;width:auto!important;height:auto!important;overflow:visible!important;padding:0!important;background:#fff!important;color:#000!important}.print-pages-container{writing-mode:horizontal-tb}.print-page-wrapper:last-child{break-after:auto}.print-page .gutter-note,.print-page .end-note,.print-page .inline-note-spacer{color:#aaa}.print-page ruby rt{display:none}.print-page-wrapper{break-after:page;position:relative}.print-page .text-block{margin:0!important}.print-page *{font-size:inherit!important}.print-page-number{writing-mode:horizontal-tb;text-align:center;font-family:var(--font-main),serif;font-size:10pt!important;color:#999;letter-spacing:.05em;position:absolute;bottom:-1.3cm;left:0;right:0}}
