@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Serif+TC:wght@400;500;700&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Outfit", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Microsoft JhengHei", sans-serif;--font-serif:"Noto Serif TC", Georgia, "Times New Roman", serif;--bg-app:#f4f6f8;--bg-panel:#fff;--bg-header:#ffffffd9;--text-primary:#2d3748;--text-secondary:#718096;--text-muted:#a0aec0;--color-primary:#4f46e5;--color-primary-hover:#4338ca;--color-primary-light:#e0e7ff;--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-success:#10b981;--border-color:#e2e8f0;--shadow-sm:0 1px 3px #0000000d, 0 1px 2px #00000008;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -1px #00000008;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-premium:0 20px 25px -5px #4f46e514, 0 10px 10px -5px #4f46e50a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:9999px;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast:all .15s ease}[data-theme=sepia]{--bg-app:#f5efe3;--bg-panel:#fcf8f0;--bg-header:#fcf8f0e0;--text-primary:#433422;--text-secondary:#7c6853;--text-muted:#bdaea0;--color-primary:#b45309;--color-primary-hover:#92400e;--color-primary-light:#fef3c7;--border-color:#e9dec9;--shadow-premium:0 20px 25px -5px #b4530914}[data-theme=green]{--bg-app:#e8f0e5;--bg-panel:#f1f7ef;--bg-header:#f1f7efe0;--text-primary:#1e3518;--text-secondary:#55724c;--text-muted:#9bb393;--color-primary:#15803d;--color-primary-hover:#166534;--color-primary-light:#dcfce7;--border-color:#d8e4d3;--shadow-premium:0 20px 25px -5px #15803d14}[data-theme=dark]{--bg-app:#0f1115;--bg-panel:#171a21;--bg-header:#171a21d9;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#475569;--color-primary:#818cf8;--color-primary-hover:#6366f1;--color-primary-light:#312e81;--border-color:#272c38;--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0006;--shadow-premium:0 20px 25px -5px #818cf826}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-primary);min-height:100vh;line-height:1.6;transition:background-color .4s,color .4s;overflow-x:hidden}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}.glass-effect{-webkit-backdrop-filter:blur(12px);background:var(--bg-header);border-bottom:1px solid var(--border-color)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:1s linear infinite spin}.bookshelf-container[data-v-e244e6c2]{flex-direction:column;min-height:100vh;display:flex}.bookshelf-header[data-v-e244e6c2]{z-index:50;width:100%;position:sticky;top:0}.header-content[data-v-e244e6c2]{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex}.logo-area[data-v-e244e6c2]{align-items:center;gap:.75rem;display:flex}.logo-icon[data-v-e244e6c2]{width:2rem;height:2rem;color:var(--color-primary)}.logo-area h1[data-v-e244e6c2]{letter-spacing:-.025em;color:var(--text-primary);font-size:1.5rem;font-weight:700}.user-profile[data-v-e244e6c2]{align-items:center;gap:.75rem;display:flex}.user-avatar[data-v-e244e6c2]{border-radius:var(--radius-full);border:2px solid var(--color-primary-light);object-fit:cover;width:2.25rem;height:2.25rem}.user-name[data-v-e244e6c2]{color:var(--text-primary);font-size:.9rem;font-weight:600}.btn-logout[data-v-e244e6c2]{cursor:pointer;border-radius:var(--radius-full);color:var(--text-muted);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.35rem;display:flex}.btn-logout[data-v-e244e6c2]:hover{color:var(--color-danger);background-color:#ef444414}.logout-icon[data-v-e244e6c2]{width:1.15rem;height:1.15rem}.bookshelf-content[data-v-e244e6c2]{flex-direction:column;gap:2.5rem;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:flex}.login-wrapper[data-v-e244e6c2]{justify-content:center;align-items:center;min-height:60vh;padding:1.5rem;display:flex}.login-card[data-v-e244e6c2]{background-color:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;width:100%;max-width:480px;transition:var(--transition-smooth);flex-direction:column;align-items:center;gap:1.5rem;padding:3.5rem 2rem;display:flex}.login-card[data-v-e244e6c2]:hover{box-shadow:var(--shadow-xl);border-color:var(--color-primary-light)}.login-logo[data-v-e244e6c2]{width:4rem;height:4rem;color:var(--color-primary);margin-bottom:.5rem}.login-card h2[data-v-e244e6c2]{color:var(--text-primary);font-size:1.5rem;font-weight:700}.login-card p[data-v-e244e6c2]{color:var(--text-secondary);margin-bottom:1rem;font-size:.95rem;line-height:1.6}.google-btn-container[data-v-e244e6c2]{justify-content:center;width:100%;margin-top:.5rem;display:flex}.add-book-section[data-v-e244e6c2]{width:100%}.input-card[data-v-e244e6c2]{background-color:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);padding:1.5rem}.input-card[data-v-e244e6c2]:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.input-card h3[data-v-e244e6c2]{color:var(--text-primary);margin-bottom:.25rem;font-size:1.125rem;font-weight:600}.input-card .subtitle[data-v-e244e6c2]{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.875rem}.input-group[data-v-e244e6c2]{gap:.75rem;display:flex}.input-group input[data-v-e244e6c2]{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:var(--transition-fast);outline:none;flex:1;padding:.75rem 1rem;font-size:.95rem}.input-group input[data-v-e244e6c2]:focus{border-color:var(--color-primary);background-color:var(--bg-panel);box-shadow:0 0 0 3px #4f46e526}.btn-add[data-v-e244e6c2]{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:0 1.5rem;font-weight:600;display:flex}.btn-add[data-v-e244e6c2]:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-add[data-v-e244e6c2]:active:not(:disabled){transform:translateY(0)}.btn-add[data-v-e244e6c2]:disabled{opacity:.6;cursor:not-allowed}.button-icon[data-v-e244e6c2]{width:1.25rem;height:1.25rem}.error-banner[data-v-e244e6c2]{border-radius:var(--radius-sm);color:var(--color-danger);background-color:#ef444414;border:1px solid #ef444433;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.error-icon[data-v-e244e6c2]{flex-shrink:0;width:1.1rem;height:1.1rem}.books-grid-section[data-v-e244e6c2]{min-height:300px}.loading-state[data-v-e244e6c2],.empty-state[data-v-e244e6c2]{text-align:center;background-color:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;justify-content:center;align-items:center;padding:5rem 2rem;display:flex}.loading-icon[data-v-e244e6c2]{width:3rem;height:3rem;color:var(--color-primary);margin-bottom:1rem}.empty-icon[data-v-e244e6c2]{width:4rem;height:4rem;color:var(--text-muted);margin-bottom:1.25rem}.empty-state h3[data-v-e244e6c2]{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.empty-state p[data-v-e244e6c2]{color:var(--text-secondary);max-width:400px;font-size:.95rem}.books-grid[data-v-e244e6c2]{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;display:grid}.book-card[data-v-e244e6c2]{background-color:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);flex-direction:column;display:flex;overflow:hidden}.book-card[data-v-e244e6c2]:hover{box-shadow:var(--shadow-lg);border-color:var(--color-primary-light);transform:translateY(-4px)}.book-cover-wrapper[data-v-e244e6c2]{cursor:pointer;background-color:#e2e8f0;width:100%;height:180px;position:relative;overflow:hidden}.book-cover-img[data-v-e244e6c2]{object-fit:cover;width:100%;height:100%;transition:transform .5s}.book-card:hover .book-cover-img[data-v-e244e6c2]{transform:scale(1.05)}.book-cover-placeholder[data-v-e244e6c2]{text-align:center;color:#fff;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:1.5rem;display:flex}.placeholder-title[data-v-e244e6c2]{-webkit-line-clamp:3;text-shadow:0 2px 4px #0000004d;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:1.15rem;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.placeholder-author[data-v-e244e6c2]{opacity:.85;text-shadow:0 1px 2px #0000004d;font-size:.85rem}.cover-overlay[data-v-e244e6c2]{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff;opacity:0;background:#0006;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;transition:opacity .3s;display:flex;position:absolute;inset:0}.book-cover-wrapper:hover .cover-overlay[data-v-e244e6c2]{opacity:1}.overlay-icon[data-v-e244e6c2]{width:1.75rem;height:1.75rem}.book-details[data-v-e244e6c2]{flex-direction:column;flex:1;padding:1.25rem;display:flex}.book-title[data-v-e244e6c2]{color:var(--text-primary);cursor:pointer;-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-bottom:.25rem;font-size:1.1rem;font-weight:700;line-height:1.35;transition:color .2s;display:-webkit-box;overflow:hidden}.book-title[data-v-e244e6c2]:hover{color:var(--color-primary)}.book-author[data-v-e244e6c2]{color:var(--text-secondary);margin-bottom:1rem;font-size:.85rem}.book-progress[data-v-e244e6c2]{flex-direction:column;flex:1;justify-content:flex-end;margin-bottom:1.25rem;display:flex}.progress-header[data-v-e244e6c2]{justify-content:space-between;align-items:center;margin-bottom:.35rem;font-size:.8rem;display:flex}.progress-chapter[data-v-e244e6c2]{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:75%;overflow:hidden}.progress-percent[data-v-e244e6c2]{color:var(--color-primary);font-weight:600}.progress-bar-bg[data-v-e244e6c2]{background-color:var(--bg-app);border-radius:var(--radius-full);height:5px;overflow:hidden}.progress-bar-fill[data-v-e244e6c2]{background-color:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width .4s}.card-footer[data-v-e244e6c2]{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;display:flex}.last-read-time[data-v-e244e6c2]{color:var(--text-secondary);font-size:.75rem}.delete-area[data-v-e244e6c2]{align-items:center;display:flex}.btn-delete-trigger[data-v-e244e6c2]{color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;padding:.25rem}.btn-delete-trigger[data-v-e244e6c2]:hover{color:var(--color-danger);background-color:#ef444414}.delete-icon[data-v-e244e6c2]{width:1.1rem;height:1.1rem}.delete-confirm-box[data-v-e244e6c2]{background-color:#ef44440f;border:1px solid #ef444426;border-radius:6px;align-items:center;gap:.35rem;padding:.15rem .35rem;font-size:.75rem;animation:.2s ease-out fadeIn-e244e6c2;display:flex}.btn-confirm-yes[data-v-e244e6c2],.btn-confirm-no[data-v-e244e6c2]{cursor:pointer;border:none;border-radius:4px;padding:.15rem .4rem;font-size:.75rem;font-weight:600}.btn-confirm-yes[data-v-e244e6c2]{background-color:var(--color-danger);color:#fff}.btn-confirm-yes[data-v-e244e6c2]:hover{background-color:var(--color-danger-hover)}.btn-confirm-no[data-v-e244e6c2]{background-color:var(--bg-app);color:var(--text-primary)}.btn-confirm-no[data-v-e244e6c2]:hover{background-color:var(--border-color)}@keyframes fadeIn-e244e6c2{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (width<=640px){.header-content[data-v-e244e6c2]{padding:.75rem 1rem}.bookshelf-content[data-v-e244e6c2]{gap:1.5rem;padding:1rem}.login-card[data-v-e244e6c2]{padding:2.5rem 1.5rem}.input-card[data-v-e244e6c2]{padding:1rem}.input-group[data-v-e244e6c2]{flex-direction:column;gap:.5rem}.btn-add[data-v-e244e6c2]{justify-content:center;padding:.75rem}.books-grid[data-v-e244e6c2]{grid-template-columns:1fr;gap:1.25rem}}.reader-page[data-v-45bcb536]{background-color:var(--bg-panel);color:var(--text-primary);z-index:100;flex-direction:column;transition:background-color .4s,color .4s;display:flex;position:fixed;inset:0;overflow:hidden}.reader-header[data-v-45bcb536]{z-index:110;width:100%;height:64px;position:absolute;top:0;left:0}.header-nav[data-v-45bcb536]{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 1.25rem;display:flex}.btn-icon-nav[data-v-45bcb536]{cursor:pointer;border-radius:var(--radius-full);color:var(--text-primary);transition:var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:flex}.btn-icon-nav[data-v-45bcb536]:hover{background-color:var(--border-color)}.header-title[data-v-45bcb536]{text-align:center;white-space:nowrap;flex:1;max-width:70%;overflow:hidden}.header-title h2[data-v-45bcb536]{color:var(--text-primary);text-overflow:ellipsis;font-size:1.05rem;font-weight:700;overflow:hidden}.chapter-sub[data-v-45bcb536]{color:var(--text-secondary);text-overflow:ellipsis;font-size:.75rem;font-weight:500;display:block;overflow:hidden}.reader-viewport[data-v-45bcb536]{cursor:pointer;-webkit-user-select:none;user-select:none;position:absolute;inset:80px 40px;overflow:hidden}.reader-content[data-v-45bcb536]{column-fill:auto;column-width:800px;column-count:auto;column-gap:40px;transition:transform .3s cubic-bezier(.25,.46,.45,.94);position:absolute;top:0;bottom:0;left:0}.chapter-content-title[data-v-45bcb536]{color:var(--text-primary);border-bottom:2px solid var(--border-color);break-after:avoid;margin-bottom:1.5em;padding-bottom:.5em;font-size:1.85em;font-weight:700;line-height:1.35}.reader-paragraph[data-v-45bcb536]{font-size:var(--reader-font-size);line-height:var(--reader-line-height);font-family:var(--reader-font-family);font-weight:var(--reader-font-weight,normal);text-indent:2em;text-align:justify;text-justify:inter-ideograph;word-wrap:break-word;word-break:break-all;orphans:1;widows:1;margin-bottom:1.25em}.reader-footer[data-v-45bcb536]{z-index:110;width:100%;height:64px;position:absolute;bottom:0;left:0}.footer-content[data-v-45bcb536]{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 1.25rem;display:flex}.btn-chapter-paging[data-v-45bcb536]{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);background:0 0;background-color:var(--bg-panel);transition:var(--transition-fast);align-items:center;gap:.35rem;padding:.35rem .85rem;font-size:.85rem;font-weight:600;display:flex}.btn-chapter-paging[data-v-45bcb536]:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background-color:var(--color-primary-light)}.btn-chapter-paging[data-v-45bcb536]:disabled{opacity:.4;cursor:not-allowed}.page-indicator[data-v-45bcb536]{color:var(--text-secondary);font-size:.85rem;font-weight:600}.settings-panel[data-v-45bcb536]{background-color:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:340px;box-shadow:var(--shadow-lg);z-index:120;flex-direction:column;display:flex;position:absolute;top:80px;right:1.5rem;overflow:hidden}.settings-header[data-v-45bcb536]{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.settings-header h3[data-v-45bcb536]{font-size:1rem;font-weight:700}.settings-close[data-v-45bcb536]{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;font-size:1.2rem}.settings-body[data-v-45bcb536]{flex-direction:column;gap:1.25rem;padding:1.25rem;display:flex}.setting-item[data-v-45bcb536]{flex-direction:column;gap:.5rem;display:flex}.setting-label[data-v-45bcb536]{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.font-size-adjuster[data-v-45bcb536],.line-height-adjuster[data-v-45bcb536]{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;display:flex;overflow:hidden}.btn-setting[data-v-45bcb536]{cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;padding:.5rem;font-weight:600;display:flex}.btn-setting[data-v-45bcb536]:hover:not(:disabled){background-color:var(--border-color)}.btn-setting[data-v-45bcb536]:disabled{opacity:.3;cursor:not-allowed}.font-size-val[data-v-45bcb536],.line-height-val[data-v-45bcb536]{text-align:center;min-width:80px;font-size:.9rem;font-weight:700}.icon-sm[data-v-45bcb536]{width:14px;height:14px}.icon-lg[data-v-45bcb536]{width:20px;height:20px}.segment-control[data-v-45bcb536]{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex}.btn-segment[data-v-45bcb536]{cursor:pointer;color:var(--text-secondary);transition:var(--transition-fast);background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:.35rem;padding:.5rem;font-size:.85rem;font-weight:600;display:flex}.btn-segment.active[data-v-45bcb536]{background-color:var(--bg-panel);color:var(--color-primary);box-shadow:var(--shadow-sm)}.btn-icon[data-v-45bcb536]{width:1rem;height:1rem}.theme-picker[data-v-45bcb536]{grid-template-columns:repeat(2,1fr);gap:.5rem;display:grid}.theme-btn[data-v-45bcb536]{border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);justify-content:center;align-items:center;gap:.35rem;padding:.75rem .5rem;font-size:.85rem;font-weight:600;display:flex}.theme-light[data-v-45bcb536]{color:#2d3748;background-color:#fff}.theme-sepia[data-v-45bcb536]{color:#433422;background-color:#fcf8f0;border-color:#e9dec9}.theme-green[data-v-45bcb536]{color:#1e3518;background-color:#f1f7ef;border-color:#d8e4d3}.theme-dark[data-v-45bcb536]{color:#e2e8f0;background-color:#171a21;border-color:#272c38}.theme-btn.selected[data-v-45bcb536]{box-shadow:0 0 0 2px var(--color-primary);border-color:var(--color-primary)}.theme-icon[data-v-45bcb536]{width:1rem;height:1rem}.loader-overlay[data-v-45bcb536],.error-container[data-v-45bcb536]{background-color:var(--bg-panel);z-index:150;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex;position:absolute;inset:0}.loader-icon[data-v-45bcb536]{width:3.5rem;height:3.5rem;color:var(--color-primary)}.loader-overlay p[data-v-45bcb536]{color:var(--text-secondary);font-weight:600}.error-container h3[data-v-45bcb536]{color:var(--color-danger);font-size:1.25rem;font-weight:700}.error-container p[data-v-45bcb536]{color:var(--text-secondary);max-width:400px}.error-buttons[data-v-45bcb536]{gap:.75rem;margin-top:1rem;display:flex}.btn-retry[data-v-45bcb536]{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:.6rem 1.25rem;font-weight:600}.btn-back[data-v-45bcb536]{background-color:var(--bg-app);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;padding:.6rem 1.25rem;font-weight:600}.toast-box[data-v-45bcb536]{color:#fff;border-radius:var(--radius-full);z-index:200;pointer-events:none;box-shadow:var(--shadow-md);background-color:#000c;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;position:absolute;bottom:80px;left:50%;transform:translate(-50%)}.slide-down-enter-active[data-v-45bcb536],.slide-down-leave-active[data-v-45bcb536],.slide-up-enter-active[data-v-45bcb536],.slide-up-leave-active[data-v-45bcb536],.fade-slide-enter-active[data-v-45bcb536],.fade-slide-leave-active[data-v-45bcb536]{transition:all .3s ease-out}.slide-down-enter-from[data-v-45bcb536],.slide-down-leave-to[data-v-45bcb536]{opacity:0;transform:translateY(-100%)}.slide-up-enter-from[data-v-45bcb536],.slide-up-leave-to[data-v-45bcb536]{opacity:0;transform:translateY(100%)}.fade-slide-enter-from[data-v-45bcb536],.fade-slide-leave-to[data-v-45bcb536]{opacity:0;transform:translateY(10px)}.toast-fade-enter-active[data-v-45bcb536],.toast-fade-leave-active[data-v-45bcb536]{transition:opacity .2s}.toast-fade-enter-from[data-v-45bcb536],.toast-fade-leave-to[data-v-45bcb536]{opacity:0}@media (width<=640px){.reader-viewport[data-v-45bcb536]{inset:70px 20px}.chapter-content-title[data-v-45bcb536]{font-size:1.45em}.settings-panel[data-v-45bcb536]{width:90%;top:75px;left:5%;right:5%}}.catalog-drawer-container[data-v-45bcb536]{z-index:130;display:flex;position:absolute;inset:0}.catalog-backdrop[data-v-45bcb536]{-webkit-backdrop-filter:blur(2px);background-color:#0006;animation:.2s fadeIn;position:absolute;inset:0}.catalog-drawer[data-v-45bcb536]{background-color:var(--bg-panel);width:340px;box-shadow:var(--shadow-lg);z-index:140;flex-direction:column;animation:.25s cubic-bezier(.4,0,.2,1) slideInLeft-45bcb536;display:flex;position:absolute;top:0;bottom:0;left:0}.catalog-header[data-v-45bcb536]{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.catalog-header h3[data-v-45bcb536]{font-size:1.15rem;font-weight:700}.btn-close-catalog[data-v-45bcb536]{cursor:pointer;border-radius:var(--radius-full);background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;display:flex}.btn-close-catalog[data-v-45bcb536]:hover{background-color:var(--border-color)}.icon-close[data-v-45bcb536]{width:1.25rem;height:1.25rem;color:var(--text-secondary)}.catalog-search-wrapper[data-v-45bcb536]{align-items:center;padding:.75rem 1.25rem;display:flex;position:relative}.catalog-search-wrapper input[data-v-45bcb536]{background-color:var(--bg-app);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);outline:none;padding:.5rem .75rem .5rem 2.25rem;font-size:.85rem}.catalog-search-wrapper input[data-v-45bcb536]:focus{border-color:var(--color-primary);background-color:var(--bg-panel)}.catalog-search-wrapper .icon-search[data-v-45bcb536]{width:.95rem;height:.95rem;color:var(--text-secondary);position:absolute;left:1.75rem}.catalog-meta[data-v-45bcb536]{color:var(--text-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:0 1.25rem .75rem;font-size:.8rem;display:flex}.chapters-count[data-v-45bcb536]{font-weight:600}.btn-sort[data-v-45bcb536]{cursor:pointer;color:var(--color-primary);background:0 0;border:none;align-items:center;gap:.25rem;font-weight:600;display:flex}.icon-sort[data-v-45bcb536]{width:.9rem;height:.9rem}.catalog-list-wrapper[data-v-45bcb536]{flex:1;overflow-y:auto}.catalog-loading[data-v-45bcb536]{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:3rem 0;font-size:.85rem;display:flex}.loader-icon-sm[data-v-45bcb536]{width:1.5rem;height:1.5rem;color:var(--color-primary)}.catalog-list[data-v-45bcb536]{list-style:none}.catalog-item[data-v-45bcb536]{cursor:pointer;color:var(--text-primary);transition:var(--transition-fast);border-bottom:1px solid #00000008;padding:.85rem 1.25rem;font-size:.925rem}.catalog-item[data-v-45bcb536]:hover{background-color:var(--bg-app)}.catalog-item.active-chapter[data-v-45bcb536]{background-color:var(--color-primary-light);color:var(--color-primary);border-left:4px solid var(--color-primary);padding-left:1rem;font-weight:700}.fade-slide-left-enter-active[data-v-45bcb536],.fade-slide-left-leave-active[data-v-45bcb536]{transition:all .25s cubic-bezier(.4,0,.2,1)}.fade-slide-left-enter-from[data-v-45bcb536],.fade-slide-left-leave-to[data-v-45bcb536]{opacity:0}.fade-slide-left-enter-from .catalog-drawer[data-v-45bcb536],.fade-slide-left-leave-to .catalog-drawer[data-v-45bcb536]{transform:translate(-100%)}@keyframes slideInLeft-45bcb536{0%{transform:translate(-100%)}to{transform:translate(0)}}@media (width<=640px){.catalog-drawer[data-v-45bcb536]{width:280px}}.app-root{min-height:100vh}.fade-enter-active,.fade-leave-active{transition:opacity .2s cubic-bezier(.4,0,.2,1)}.fade-enter-from,.fade-leave-to{opacity:0}
