:root{--font-size-base: 16px;--font-size-step: 2px;--font-family: Georgia, "Times New Roman", serif;--color-bg: #fafaf8;--color-text: #1a1a1a;--color-text-muted: #666;--color-border: #ddd;--color-accent: #2563eb;--color-highlight-yellow: #fff3a0;--color-highlight-green: #b8f0b8;--color-highlight-blue: #a0d4ff;--color-highlight-pink: #ffb8d4;--color-highlight-purple: #d4b8ff;--color-highlight-orange: #ffd4a0;--sidebar-width: 280px}@media(prefers-color-scheme:dark){:root:not(.theme-light){--color-bg: #1a1a1a;--color-text: #e0e0e0;--color-text-muted: #999;--color-border: #333;--color-accent: #60a5fa;--color-highlight-yellow: #665a00;--color-highlight-green: #1a5a1a;--color-highlight-blue: #003366;--color-highlight-pink: #661a33;--color-highlight-purple: #331a66;--color-highlight-orange: #663300}}:root.theme-dark{--color-bg: #1a1a1a;--color-text: #e0e0e0;--color-text-muted: #999;--color-border: #333;--color-accent: #60a5fa;--color-highlight-yellow: #665a00;--color-highlight-green: #1a5a1a;--color-highlight-blue: #003366;--color-highlight-pink: #661a33;--color-highlight-purple: #331a66;--color-highlight-orange: #663300}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg)}#app{display:flex;height:100%}#sidebar{width:var(--sidebar-width);border-right:1px solid var(--color-border);overflow-y:auto;flex-shrink:0}#sidebar:empty{display:none}#content{flex:1;overflow-y:auto}.btn{padding:6px 14px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);cursor:pointer;font-size:.9em}.btn:hover{background:var(--color-border)}.library-view{padding:24px;max-width:1200px;margin:0 auto}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.library-header h1{font-size:1.5em;font-weight:600}.library-search{margin-bottom:24px}.library-search input{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:6px;font-size:1em;background:var(--color-bg);color:var(--color-text)}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px}.book-card{position:relative;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;cursor:pointer;transition:box-shadow .15s}.book-card:hover{box-shadow:0 2px 8px #0000001f}.book-remove-btn{position:absolute;top:4px;right:4px;z-index:2;width:22px;height:22px;border:none;border-radius:50%;background:#00000080;color:#fff;font-size:14px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s}.book-card:hover .book-remove-btn{opacity:1}.book-remove-btn:hover{background:#dc2626e6}.book-card .cover{width:100%;aspect-ratio:2/3;background:var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:.85em}.book-card .cover img{width:100%;height:100%;object-fit:cover}.book-card .info{padding:10px}.book-card .info .title{font-weight:600;font-size:.9em;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.book-card .info .author{color:var(--color-text-muted);font-size:.8em}.book-card .progress-bar{height:3px;background:var(--color-border)}.book-card .progress-bar .fill{height:100%;background:var(--color-accent)}.library-toolbar{display:flex;gap:12px;margin-bottom:24px;align-items:center}.library-toolbar .library-search{flex:1;margin-bottom:0}.source-filter{padding:10px 14px;border:1px solid var(--color-border);border-radius:6px;font-size:.9em;background:var(--color-bg);color:var(--color-text)}.source-badge{font-size:.7em;padding:2px 6px;border-radius:3px;margin-top:4px;display:inline-block}.source-gospel_library{background:#e3f2fd;color:#1565c0}.source-deseret_bookshelf{background:#f3e5f5;color:#7b1fa2}.source-epub_import{background:#e8f5e9;color:#2e7d32}.context-menu{position:fixed;z-index:10000;min-width:180px;padding:4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;box-shadow:0 4px 16px #0000003d;font-size:.9em;color:var(--color-text);-webkit-user-select:none;user-select:none}.context-menu-item{display:block;width:100%;padding:8px 12px;border:none;border-radius:4px;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.context-menu-item:hover,.context-menu-item:focus{background:var(--color-border);outline:none}.context-menu-item.danger{color:#dc2626}.context-menu-item.danger:hover,.context-menu-item.danger:focus{background:#dc26261f}.context-menu-item.disabled,.context-menu-item[aria-disabled=true]{color:var(--color-text-muted);cursor:default;pointer-events:none}.library-category{margin-bottom:28px}.library-category-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.library-category-tile{width:48px;height:48px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:1.2em}.library-category-tile img{width:100%;height:100%;object-fit:cover}.library-category-name{font-size:1.1em;font-weight:600}.library-category-count{margin-left:6px;color:var(--color-text-muted);font-size:.85em;font-weight:400}.library-category-children{margin-left:20px;padding-left:16px;border-left:1px solid var(--color-border)}.library-uncategorized .library-category-name{color:var(--color-text-muted)}.catalog-view{padding:24px;max-width:1200px;margin:0 auto}.catalog-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.catalog-header h1{font-size:1.5em;font-weight:600}.catalog-search{margin-bottom:16px}.catalog-search input{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:6px;font-size:1em;background:var(--color-bg);color:var(--color-text)}.catalog-body{display:flex;gap:20px}.catalog-sidebar{width:220px;flex-shrink:0}.category-item{padding:8px 12px;cursor:pointer;border-radius:6px;font-size:.9em;margin-bottom:2px}.category-item:hover{background:var(--color-border)}.category-item.active{background:var(--color-accent);color:#fff}.catalog-items{flex:1}.catalog-item-card{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border:1px solid var(--color-border);border-radius:6px;margin-bottom:8px}.catalog-item-title{font-weight:600;font-size:.95em}.catalog-item-meta{font-size:.8em;color:var(--color-text-muted);margin-top:4px}.catalog-item-category{margin-right:8px}.catalog-downloaded{color:#2e7d32;font-size:.85em;font-weight:500}.catalog-error,.catalog-empty{color:var(--color-text-muted);text-align:center;padding:40px}.reader-view{padding:0 24px;overflow-y:auto;max-width:800px;margin:0 auto}.reader-main{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0}.reader-toolbar{display:flex;gap:8px;flex-shrink:0;padding-top:24px;padding-bottom:12px;border-bottom:1px solid var(--color-border);max-width:800px;margin-left:auto;margin-right:auto;width:100%;background:var(--color-bg)}.chapter-content{font-size:var(--font-size-base);line-height:1.7;max-width:800px;margin:0 auto;padding-bottom:24px}.chapter-content h1,.chapter-content h2,.chapter-content h3{margin-top:1.5em;margin-bottom:.5em}.chapter-content p{margin-bottom:1em;text-align:justify}.chapter-content img{max-width:100%;height:auto;margin:1em 0}.chapter-content blockquote{border-left:3px solid var(--color-border);padding-left:1em;margin:1em 0;color:var(--color-text-muted)}.chapter-content .header{text-align:center;margin-bottom:1.5em}.chapter-content .title{text-align:center}.chapter-content .subtitle{text-align:center;font-size:.9em;margin-bottom:.5em}.chapter-content .title-number{text-align:center;font-size:1.3em;font-weight:700;margin-top:1.5em;margin-bottom:.5em}.chapter-content .study-summary{font-style:italic;margin-bottom:1.5em}.chapter-content sup a{color:var(--color-accent);text-decoration:none;font-size:.8em}.toc-panel{padding:16px}.toc-panel h2{font-size:1.1em;margin-bottom:12px}.toc-panel ul{list-style:none}.toc-panel li{padding:6px 8px;border-radius:4px;cursor:pointer;font-size:.9em}.toc-panel li:hover{background:var(--color-border)}.toc-panel li.active{background:var(--color-accent);color:#fff}.toc-group{padding:0}.toc-group-header{padding:6px 8px;font-weight:600;font-size:.9em;cursor:pointer;border-radius:4px;-webkit-user-select:none;user-select:none}.toc-group-header:before{content:"▾ ";font-size:.8em}.toc-group.collapsed .toc-group-header:before{content:"▸ "}.toc-group-header:hover{background:var(--color-border)}.toc-group-children{list-style:none;padding-left:12px}.toc-group.collapsed .toc-group-children{display:none}.toc-group-children li{font-size:.85em}mark[data-annotation-id]{border-radius:2px;cursor:pointer;padding:0 1px}mark[data-synced-highlight]{border-radius:2px;padding:0 1px}.synced-note-indicator,.synced-indicator{position:absolute;left:-1.8em;cursor:pointer;font-size:.85em;-webkit-user-select:none;user-select:none}.synced-note-indicator:hover,.synced-indicator:hover{transform:scale(1.2)}.footnote-pane{position:sticky;bottom:0;left:0;right:0;max-height:200px;background:var(--color-bg, #fff);border-top:2px solid var(--color-border);display:none;flex-direction:column}.footnote-pane.visible{display:flex}.footnote-pane-header{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;border-bottom:1px solid var(--color-border);flex-shrink:0}.footnote-pane-label{font-weight:600;font-size:.85em;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.footnote-pane-close{background:none;border:none;font-size:1.2em;cursor:pointer;color:var(--color-text-muted);padding:0 4px}.footnote-pane-close:hover{color:var(--color-text)}.footnote-pane-content{padding:8px 12px;overflow-y:auto;flex:1;font-size:.9em;line-height:1.5}.footnote-pane-content p{margin:0 0 4px}.footnote-link{color:var(--color-accent);text-decoration:none;cursor:pointer}.reader-container{display:flex;height:100%;position:relative}.reader-main .reader-view{flex:1;min-height:0;min-width:0;max-width:none;margin:0}.notes-pane{display:none;width:300px;flex-shrink:0;border-left:1px solid var(--color-border);overflow:hidden;background:var(--color-bg)}.reader-container.notes-visible .notes-pane{display:flex;flex-direction:column}.notes-pane-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid var(--color-border);flex-shrink:0}.notes-pane-label{font-weight:600;font-size:.85em;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.notes-pane-close{background:none;border:none;font-size:1.2em;cursor:pointer;color:var(--color-text-muted);padding:0 4px}.notes-pane-close:hover{color:var(--color-text)}.notes-pane-content{flex:1;overflow:hidden;padding:8px}.notes-pane-content.notes-overflow{overflow-y:auto}.note-card{margin-bottom:8px;padding:10px 12px;cursor:pointer;border-left:4px solid var(--color-border);border-radius:6px;background:var(--color-bg-elevated, var(--color-bg));box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;transition:box-shadow .15s ease,background .15s ease;overflow:hidden}.note-card:hover{box-shadow:0 2px 6px #0000001f,0 1px 3px #0000000f}.note-card-header{font-weight:600;font-size:.85em;color:var(--color-text);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-card-body{font-size:.85em;line-height:1.5;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.note-card.compressed .note-card-body,.note-card.compressed .note-expand-btn{display:none}.note-card.compressed{padding:6px 12px}.note-expand-btn{position:absolute;top:6px;right:6px;background:none;border:1px solid var(--color-border);border-radius:4px;font-size:.8em;cursor:pointer;color:var(--color-text-muted);padding:2px 6px;opacity:0;transition:opacity .15s ease}.note-card:hover .note-expand-btn{opacity:1}.note-expand-btn:hover{color:var(--color-text);background:var(--color-border)}.notes-empty-state{padding:16px 12px;color:var(--color-text-muted);font-style:italic;font-size:.9em}.note-fullscreen-overlay{display:none;flex-direction:column;position:absolute;top:0;left:0;right:0;bottom:0;background:var(--color-bg);z-index:200}.note-fullscreen-overlay.visible{display:flex}.note-fullscreen-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.note-fullscreen-title{font-weight:600;font-size:1.1em;color:var(--color-text)}.note-fullscreen-close{background:none;border:none;font-size:1.5em;cursor:pointer;color:var(--color-text-muted);padding:0 8px}.note-fullscreen-close:hover{color:var(--color-text)}.note-fullscreen-body{flex:1;overflow-y:auto;padding:20px 24px;font-size:1em;line-height:1.7;max-width:720px;border-left:4px solid var(--color-border);margin-left:20px}.note-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.note-block-count{font-size:.7em;color:var(--color-text-muted);background:var(--color-bg-alt);padding:1px 6px;border-radius:8px}.note-block{padding:12px 0;border-bottom:1px solid var(--color-border)}.note-block:last-child{border-bottom:none}.note-block-author{font-size:.8em;font-weight:600;color:var(--color-text-muted);margin-bottom:4px}.note-block-content{line-height:1.6}.note-loading{color:var(--color-text-muted);font-style:italic}.note-editor-toolbar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.note-editor-toolbar-btn{min-width:28px;height:28px;padding:0 6px;font-size:.85em;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);cursor:pointer}.note-editor-toolbar-btn:hover{background:var(--color-bg-alt)}.note-editor .ProseMirror{outline:none;min-height:120px;line-height:1.6}.note-editor .ProseMirror:focus{outline:none}.collaboration-cursor__caret{position:relative;margin-left:-1px;margin-right:-1px;border-left:1px solid #0d0d0d;border-right:1px solid #0d0d0d;border-color:currentColor;word-break:normal;pointer-events:none}.collaboration-cursor__label{position:absolute;top:-1.4em;left:-1px;white-space:nowrap;border-radius:3px 3px 3px 0;padding:.1rem .3rem;font-size:.75rem;font-style:normal;font-weight:600;line-height:normal;color:#fff;-webkit-user-select:none;user-select:none;pointer-events:none;opacity:0;transition:opacity .12s ease-in-out}.collaboration-cursor__caret:hover .collaboration-cursor__label,.collaboration-cursor__caret.is-active .collaboration-cursor__label{opacity:1}.collaboration-cursor__selection{pointer-events:none;border-radius:1px}.note-presence-bar{display:contents}.note-presence-chips{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.note-presence-chips.is-empty{display:none}.note-presence-chip{display:inline-flex;align-items:center;gap:4px;max-width:12rem;padding:1px 7px 1px 1px;border-radius:999px;background-color:color-mix(in srgb,var(--chip-color, #888) 14%,transparent);border:1px solid color-mix(in srgb,var(--chip-color, #888) 45%,transparent);font-size:.72rem;line-height:1.4;color:var(--color-text, inherit);white-space:nowrap;-webkit-user-select:none;user-select:none}.note-presence-chip__initial{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:50%;background-color:var(--chip-color, #888);color:#fff;font-size:.66rem;font-weight:700}.note-presence-chip__name{overflow:hidden;text-overflow:ellipsis}.note-editor--create .ProseMirror{border:1px solid var(--color-border);border-radius:0 0 4px 4px;border-top:none;padding:8px;min-height:100px;max-height:40vh;overflow-y:auto}.note-card-body code,.note-block-content code,.note-fullscreen-body code,.note-editor .ProseMirror code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.9em;background:var(--color-bg-alt);padding:1px 4px;border-radius:3px}.note-card-body blockquote,.note-block-content blockquote,.note-fullscreen-body blockquote,.note-editor .ProseMirror blockquote{margin:.5em 0;padding-left:12px;border-left:3px solid var(--color-border);color:var(--color-text-muted)}.note-card-body ul,.note-card-body ol,.note-block-content ul,.note-block-content ol,.note-fullscreen-body ul,.note-fullscreen-body ol,.note-editor .ProseMirror ul,.note-editor .ProseMirror ol{padding-left:1.4em;margin:.4em 0}.note-add-block-container{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.note-add-block-btn{font-size:.85em;color:var(--color-accent);background:none;border:1px solid var(--color-accent);border-radius:4px;padding:4px 12px;cursor:pointer}.note-add-block-btn:hover{background:var(--color-accent);color:#fff}.note-block-editor{margin-top:12px;padding:12px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-alt)}.note-block-textarea{width:100%;font-family:inherit;font-size:.9em;padding:8px;border:1px solid var(--color-border);border-radius:4px;resize:vertical;background:var(--color-bg);color:var(--color-text)}.note-block-editor-actions{display:flex;gap:8px;margin-top:8px}.note-block-save,.note-block-cancel{font-size:.8em;padding:4px 12px;border-radius:4px;cursor:pointer;border:1px solid var(--color-border)}.note-block-save{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.note-block-cancel{background:none;color:var(--color-text-muted)}@keyframes highlight-pulse-anim{0%{outline:3px solid var(--color-accent);outline-offset:2px}to{outline:3px solid transparent;outline-offset:2px}}.highlight-pulse{animation:highlight-pulse-anim 1.5s ease-out}@media(max-width:768px){.reader-container.notes-visible .notes-pane{position:absolute;right:0;top:0;bottom:0;width:300px;max-width:80vw;z-index:100;box-shadow:-2px 0 8px #00000026}}.inline-note-group{margin:8px 0}.inline-note{margin:6px 0;padding:10px 14px;border-left:4px solid var(--color-border);border-radius:6px;background:var(--color-bg-elevated, color-mix(in srgb, var(--color-bg), var(--color-border) 8%));box-shadow:0 1px 3px #0000000f;cursor:pointer;font-size:.88em;line-height:1.5;transition:box-shadow .15s ease}.inline-note:hover{box-shadow:0 2px 6px #0000001a}.inline-note-header{font-weight:600;font-size:.85em;color:var(--color-text-muted);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-note-body{color:var(--color-text);white-space:pre-wrap}.inline-note-actions{display:flex;gap:8px;margin-top:8px}.inline-note-action{font-size:.75em;background:none;border:1px solid var(--color-border);border-radius:4px;padding:2px 8px;cursor:pointer;color:var(--color-text)}.inline-note-action:hover{background:color-mix(in srgb,var(--color-bg),var(--color-border) 20%)}.inline-note-action.inline-note-delete{color:#d33}.inline-note-editor{margin-top:6px}.inline-note-editor .ProseMirror{min-height:56px;max-height:40vh;overflow-y:auto;border:1px solid var(--color-border);border-radius:0 0 4px 4px;border-top:none;padding:6px 8px}.inline-note-editor-actions{display:flex;justify-content:flex-end;margin-top:6px}.inline-note-block-editor{margin-top:8px}.inline-note-block-textarea{width:100%;padding:6px;border:1px solid var(--color-border);border-radius:4px;resize:vertical;font-family:inherit;font-size:.9em}.inline-note-block-editor-actions{display:flex;gap:8px;margin-top:6px}.inline-note-block-editor-actions button{font-size:.75em;padding:2px 10px;border:1px solid var(--color-border);border-radius:4px;cursor:pointer}.inline-note-blocks{margin-top:8px;border-top:1px solid var(--color-border);padding-top:8px}.inline-note-block{margin-bottom:8px;padding-left:8px;border-left:2px solid var(--color-border)}.inline-note-block-author{font-size:.75em;font-weight:600;color:var(--color-text-muted);margin-bottom:2px}.inline-note-block-content{white-space:pre-wrap}.category-manager{display:flex;flex-direction:column;gap:4px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 8px 32px #0000004d;padding:16px;min-width:320px;max-width:460px;max-height:80vh;overflow:auto}.category-theme-editor{display:flex;flex-direction:column;gap:12px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 8px 32px #0000004d;padding:16px;min-width:280px}.category-theme-editor h3{margin:0}.category-theme-editor label{display:flex;align-items:center;justify-content:space-between;gap:8px}.category-theme-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.category-tree{list-style:none;margin:0;padding:0}.category-tree .category-tree{margin-left:18px;border-left:1px solid var(--color-border);padding-left:8px}.category-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px}.category-row:hover{background:var(--color-bg-elevated, var(--color-border))}.category-row .category-name{flex:1;color:var(--color-text)}.category-row .category-expand{width:16px;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.category-row .category-actions{display:flex;gap:4px;opacity:0}.category-row:hover .category-actions{opacity:1}.theme-swatch{width:14px;height:14px;border-radius:3px;border:1px solid var(--color-border);flex:0 0 auto;display:inline-block}.theme-swatch.underline{background:transparent;border-bottom:3px solid currentColor}.category-picker{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto}.category-picker .category-option{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;cursor:pointer;color:var(--color-text)}.category-picker .category-option:hover,.category-picker .category-option.selected{background:var(--color-bg-elevated, var(--color-border))}.category-picker .category-option .category-name{flex:1}.category-picker .category-option[data-depth="1"]{padding-left:22px}.category-picker .category-option[data-depth="2"]{padding-left:38px}.category-picker .category-option[data-depth="3"]{padding-left:54px}.accounts-view{padding:24px;max-width:700px;margin:0 auto}.accounts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.accounts-header h1{font-size:1.5em;font-weight:600}.accounts-section{margin-bottom:32px}.accounts-section h2{font-size:1.15em;font-weight:600;margin-bottom:12px;color:var(--color-text)}.account-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border:1px solid var(--color-border);border-radius:6px;margin-bottom:8px}.account-info{display:flex;flex-direction:column;gap:2px}.account-provider{font-size:.75em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.account-email{font-weight:600;font-size:.95em}.account-name{font-size:.85em;color:var(--color-text-muted)}.add-account-form{margin-top:20px;padding:16px;border:1px solid var(--color-border);border-radius:8px}.add-account-form h3{font-size:1em;margin-bottom:12px}.add-account-form input{display:block;width:100%;padding:8px 12px;margin-bottom:10px;border:1px solid var(--color-border);border-radius:4px;font-size:.95em;background:var(--color-bg);color:var(--color-text)}.btn-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#dc2626;color:#fff}.status-message{font-size:.85em;margin-top:8px;min-height:1.2em}.status-message.success{color:#16a34a}.status-message.error{color:#dc2626}.empty-message{color:var(--color-text-muted);font-size:.9em;padding:12px 0}.error-message{color:#dc2626;font-size:.9em}.bookshelf-import-view{padding:24px;max-width:900px;margin:0 auto}.bookshelf-import-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.bookshelf-import-header h1{font-size:1.5em;font-weight:600}.header-actions{display:flex;gap:8px;align-items:center}.bs-book-list{display:flex;flex-direction:column;gap:6px}.bs-book-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:background .1s}.bs-book-row:hover{background:color-mix(in srgb,var(--color-border) 30%,transparent)}.bs-book-row.already-imported{opacity:.6}.bs-book-checkbox{flex-shrink:0}.bs-book-checkbox input{width:16px;height:16px;cursor:pointer}.bs-book-cover{width:40px;height:60px;object-fit:cover;border-radius:3px;flex-shrink:0}.bs-book-cover.placeholder{background:var(--color-border)}.bs-book-info{flex:1;min-width:0}.bs-book-title{font-weight:600;font-size:.95em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bs-book-author{font-size:.85em;color:var(--color-text-muted)}.bs-book-meta{display:flex;gap:8px;align-items:center;margin-top:4px;font-size:.75em}.bs-ownership-badge{padding:1px 6px;border-radius:3px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.bs-ownership-badge.purchased{background:#dcfce7;color:#166534}.bs-ownership-badge.subscribed{background:#dbeafe;color:#1e40af}.bs-ownership-badge.sample{background:#fef3c7;color:#92400e}.bs-ownership-badge.available{background:var(--color-border);color:var(--color-text-muted)}@media(prefers-color-scheme:dark){:root:not(.theme-light) .bs-ownership-badge.purchased{background:#14532d;color:#86efac}:root:not(.theme-light) .bs-ownership-badge.subscribed{background:#1e3a5f;color:#93c5fd}:root:not(.theme-light) .bs-ownership-badge.sample{background:#78350f;color:#fcd34d}}.bs-price{color:var(--color-text-muted)}.bs-account-tag{color:var(--color-text-muted);font-style:italic}.bs-book-status{flex-shrink:0}.imported-badge{font-size:.75em;padding:2px 8px;border-radius:3px;background:var(--color-border);color:var(--color-text-muted)}.import-progress{margin-bottom:16px;padding:12px;border:1px solid var(--color-border);border-radius:6px}.import-progress .success{color:#16a34a}.import-progress .error{color:#dc2626;font-size:.9em}.import-errors{margin-top:8px}.loading-message{color:var(--color-text-muted);text-align:center;padding:40px 0}.store-view{padding:24px;max-width:1100px;margin:0 auto}.store-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.store-header h1{margin:0;flex-shrink:0}.store-search{flex:1;display:flex;justify-content:flex-end}.store-search input{width:280px;max-width:100%;padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text)}.store-breadcrumb{display:flex;align-items:center;gap:6px;font-size:.9em;color:var(--color-text-muted);margin-bottom:16px;flex-wrap:wrap}.store-breadcrumb .crumb{cursor:pointer;color:var(--color-text-muted)}.store-breadcrumb .crumb:hover{color:var(--color-text);text-decoration:underline}.store-breadcrumb .crumb-sep{opacity:.5}.store-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.store-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-elevated, var(--color-bg));cursor:pointer;transition:box-shadow .15s ease}.store-card:hover{box-shadow:0 2px 8px #0000001f}.store-thumb{width:100%;aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background:var(--color-border);border-radius:6px;overflow:hidden;margin-bottom:8px}.store-category .store-thumb{aspect-ratio:4 / 3}.store-thumb img{width:100%;height:100%;object-fit:cover}.store-thumb-placeholder{font-size:2.5em;opacity:.6}.store-card-title{font-size:.9em;font-weight:600;margin-bottom:6px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.store-badge{font-size:.72em;padding:2px 6px;border-radius:10px;margin-bottom:6px}.store-badge.downloaded{background:#2e7d32;color:#fff}.store-badge.update{background:#ed6c02;color:#fff}.store-book .store-download-btn{margin-top:auto;font-size:.82em;width:100%}.store-loading,.store-empty{color:var(--color-text-muted);text-align:center;padding:40px 0}
