:root{--color-primary: #5856d6;--color-primary-hover: #4745b5;--color-text: #333;--color-text-secondary: #666;--color-border: #ddd;--color-bg: #ffffff;--color-bg-card: #fff;--color-success: #34c759;--color-warning: #ff9500;--color-danger: #ff3b30;--color-error-bg: #fff5f5;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--border-radius: 4px;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--modal-overlay-bg: rgba(0, 0, 0, .5);--modal-shadow: 0 4px 12px rgba(0, 0, 0, .15)}@media (prefers-color-scheme: dark){:root{--color-text: #e8e8e8;--color-text-secondary: #a0a0a0;--color-border: #404040;--color-bg: #1a1a1a;--color-bg-card: #2a2a2a;--color-error-bg: #3a1f1f;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--modal-overlay-bg: rgba(0, 0, 0, .7);--modal-shadow: 0 4px 12px rgba(0, 0, 0, .5)}}*{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);overflow-x:hidden;max-width:100vw}#app{min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{margin:0 0 var(--spacing-md) 0;font-weight:600;color:var(--color-text)}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin:0 0 var(--spacing-md) 0}button,.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:500;line-height:1.5;text-align:center;text-decoration:none;cursor:pointer;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:var(--color-bg-card);color:var(--color-text);transition:all .15s ease}button:hover,.btn:hover{background-color:var(--color-bg);border-color:var(--color-text-secondary)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-danger{background-color:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{opacity:.9}.btn-small{padding:var(--spacing-xs) var(--spacing-sm);font-size:12px}input,select,textarea{width:100%;max-width:100%;min-width:0;display:block;padding:var(--spacing-sm);font-size:14px;font-family:inherit;line-height:1.5;color:var(--color-text);background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);transition:border-color .15s ease}@media (max-width: 768px){input,select,textarea{font-size:16px}}input[type=date],input[type=datetime-local],input[type=time]{min-width:0;max-width:100%;width:100%;-webkit-appearance:none}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary)}label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--color-text)}.form-group{margin-bottom:var(--spacing-md);min-width:0}.form-row{display:flex;gap:var(--spacing-md);width:100%}.form-row .form-group{flex:1;min-width:0}.card{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.container{max-width:1200px;margin:0 auto;padding:var(--spacing-lg);overflow-x:hidden}.container-narrow{max-width:600px;margin:0 auto;padding:var(--spacing-lg)}.text-center{text-align:center}.text-muted{color:var(--color-text-secondary)}.text-small{font-size:12px}.mt-1{margin-top:var(--spacing-md)}.mt-2{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-md)}.mb-2{margin-bottom:var(--spacing-lg)}.modal-overlay{position:fixed;inset:0;background-color:var(--modal-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-sm)}.modal{background-color:var(--color-bg-card);border-radius:var(--border-radius);box-shadow:var(--modal-shadow);max-width:600px;width:min(600px,calc(100vw - 2 * var(--spacing-sm)));max-height:90vh;overflow-y:auto;overflow-x:hidden;margin:0 auto}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0}.modal-body{padding:var(--spacing-lg);width:100%;max-width:100%;overflow-x:hidden}.modal-body form{width:100%}.modal-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.loading{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.error{color:var(--color-danger);background-color:var(--color-error-bg);border:1px solid var(--color-danger);border-radius:var(--border-radius);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-lg)}.pagination button{padding:var(--spacing-sm) var(--spacing-md)}@media (max-width: 768px){.container{padding:var(--spacing-md)}.form-row{flex-direction:column}}@media (max-width: 600px){.modal-overlay{padding:var(--spacing-sm);align-items:flex-start}.modal{width:calc(100vw - 2 * var(--spacing-sm));max-width:calc(100vw - 2 * var(--spacing-sm));border-radius:0}}@media (max-width: 480px){.container{padding:var(--spacing-md)}}.book-card[data-v-2d30031d]{background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);transition:box-shadow .15s ease;overflow:hidden}.book-card[data-v-2d30031d]:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.book-content[data-v-2d30031d]{display:flex;gap:var(--spacing-lg)}.book-cover-link[data-v-2d30031d]{text-decoration:none;display:block;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.book-title-link[data-v-2d30031d]{text-decoration:none;color:inherit;display:block}.book-cover[data-v-2d30031d],.book-cover-placeholder[data-v-2d30031d]{width:120px;height:auto;border-radius:var(--border-radius);flex-shrink:0;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.book-cover[data-v-2d30031d]{display:block}.book-cover-clickable[data-v-2d30031d]{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.book-cover-clickable[data-v-2d30031d]:hover{transform:scale(1.02);box-shadow:0 4px 8px #0003}.book-cover-placeholder[data-v-2d30031d]{aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:12px;text-align:center}.book-details[data-v-2d30031d]{flex:1;min-width:0}.book-header[data-v-2d30031d]{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.book-header h3[data-v-2d30031d]{margin:0;font-size:1.25rem;flex:1;word-break:break-word}.book-title-clickable[data-v-2d30031d]{cursor:pointer;transition:color .15s ease}.book-title-clickable[data-v-2d30031d]:hover{color:var(--color-primary)}.book-author[data-v-2d30031d]{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:14px;word-break:break-word}.book-description[data-v-2d30031d]{margin-bottom:var(--spacing-md);line-height:1.6;color:var(--color-text);word-break:break-word;overflow-wrap:anywhere}.book-meta[data-v-2d30031d]{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.meta-item[data-v-2d30031d]{font-size:12px;color:var(--color-text-secondary);word-break:break-word;overflow-wrap:anywhere}.meta-item strong[data-v-2d30031d]{color:var(--color-text)}.book-status[data-v-2d30031d]{margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-sm)}.book-status-label[data-v-2d30031d]{font-size:14px;color:var(--color-text-secondary)}.book-status-pill[data-v-2d30031d]{border:1px solid var(--color-border);border-radius:999px;padding:4px 12px;font-size:13px;font-weight:600}.book-dates[data-v-2d30031d]{padding-top:var(--spacing-sm);display:flex;gap:var(--spacing-md);flex-wrap:wrap}@media (max-width: 768px){.book-content[data-v-2d30031d]{flex-direction:column}.book-cover[data-v-2d30031d],.book-cover-placeholder[data-v-2d30031d]{width:100%;height:auto}.book-header[data-v-2d30031d]{flex-direction:column}.book-status[data-v-2d30031d]{align-items:flex-start;flex-direction:column}}.grid-item[data-v-bd8a41a8]{display:flex;flex-direction:column;justify-content:flex-end;min-width:0;width:100%;max-width:100%;overflow:visible}.grid-cover-link[data-v-bd8a41a8]{padding:0;border:none;background:transparent;text-decoration:none;display:block;cursor:grab;width:100%;text-align:left;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation;position:relative}.grid-cover[data-v-bd8a41a8]{width:100%;max-width:100%;height:auto;border-radius:var(--border-radius);cursor:pointer;transition:transform .2s ease;box-shadow:var(--shadow);display:block;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.grid-cover[data-v-bd8a41a8]:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0003}.grid-cover-placeholder[data-v-bd8a41a8]{width:100%;max-width:100%;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:transform .2s ease;box-shadow:var(--shadow);padding:var(--spacing-md);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.grid-cover-placeholder[data-v-bd8a41a8]:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0003}.grid-no-cover-text[data-v-bd8a41a8]{text-align:center;color:var(--color-text);font-size:14px;font-weight:500;word-break:break-word;line-height:1.4}.grid-progress-badge[data-v-bd8a41a8]{position:absolute;right:6px;bottom:6px;z-index:2;background:#14181fd9;color:#fff;font-size:12px;font-weight:700;padding:4px 7px;border-radius:999px;letter-spacing:.02em;box-shadow:0 4px 10px #00000040;pointer-events:none;transition:transform .2s ease,box-shadow .2s ease}.grid-cover-link:hover .grid-progress-badge[data-v-bd8a41a8]{transform:translateY(-4px);box-shadow:0 8px 16px #00000040}.search-section[data-v-14173938]{margin-bottom:var(--spacing-lg)}.search-description[data-v-14173938]{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:14px}.search-input-group[data-v-14173938]{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.search-input[data-v-14173938]{flex:1}.results-section[data-v-14173938]{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.results-section h4[data-v-14173938]{margin:0 0 var(--spacing-md) 0;color:var(--color-text)}.results-list[data-v-14173938]{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:400px;overflow-y:auto}.result-item[data-v-14173938]{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius)}.result-content[data-v-14173938]{display:flex;gap:var(--spacing-md);flex:1;min-width:0}.book-thumbnail[data-v-14173938],.book-thumbnail-placeholder[data-v-14173938]{width:80px;height:auto;border-radius:var(--border-radius);flex-shrink:0}.book-thumbnail[data-v-14173938]{display:block}.book-thumbnail-placeholder[data-v-14173938]{aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:12px;text-align:center}.book-info[data-v-14173938]{flex:1;min-width:0}.book-title[data-v-14173938]{margin:0 0 4px;font-size:16px;color:var(--color-text)}.book-author[data-v-14173938]{margin:0 0 8px;color:var(--color-text-secondary);font-size:14px}.book-details[data-v-14173938]{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:8px}.detail[data-v-14173938]{font-size:12px;color:var(--color-text-secondary);padding:2px 8px;background-color:var(--color-bg);border-radius:4px}.book-description[data-v-14173938]{margin:0;font-size:13px;color:var(--color-text-secondary);line-height:1.4}.btn-select[data-v-14173938]{flex-shrink:0;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;height:fit-content}.btn-select[data-v-14173938]:hover{opacity:.9}.empty-state[data-v-14173938]{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}@media (max-width: 768px){.search-input-group[data-v-14173938]{flex-direction:column}.search-input-group button[data-v-14173938]{width:100%}.result-content[data-v-14173938]{flex-direction:column}.result-item[data-v-14173938]{flex-direction:column;width:100%}.results-list[data-v-14173938]{overflow-x:hidden}.btn-select[data-v-14173938]{width:100%}}.search-header[data-v-54821d59]{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);align-items:center;justify-content:space-between;border-radius:var(--border-radius);max-width:100%;overflow:visible}.search-bar[data-v-54821d59]{flex:1 1 auto;min-width:0;max-width:500px;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background-color:#ffffff0a;border:1px solid var(--color-border);border-radius:var(--border-radius);transition:border-color .15s ease,box-shadow .15s ease}.search-bar[data-v-54821d59]:hover{border-color:var(--color-text-secondary)}.search-bar[data-v-54821d59]:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 1px #5856d659}.search-icon[data-v-54821d59]{color:var(--color-text-secondary);flex-shrink:0}.search-actions[data-v-54821d59]{display:flex;align-items:center;gap:var(--spacing-sm);padding:0 var(--spacing-xs)}.search-input[data-v-54821d59]{flex:1;border:none;background:transparent;padding:0;font-size:14px}.search-input[data-v-54821d59]:focus{outline:none;border:none}.filter-dropdown-wrapper[data-v-54821d59]{position:relative}.filter-btn[data-v-54821d59]{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;color:var(--color-text-secondary);transition:all .15s ease;min-width:36px;min-height:36px}.filter-btn[data-v-54821d59]:hover{color:var(--color-text);background-color:var(--color-bg);border-color:var(--color-text-secondary)}.view-toggle[data-v-54821d59]{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--border-radius);overflow:hidden;background-color:var(--color-bg-card)}.view-btn[data-v-54821d59]{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm);background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);transition:all .15s ease;min-width:36px;min-height:36px;position:relative}.view-btn[data-v-54821d59]:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:60%;width:1px;background-color:var(--color-border)}.view-btn[data-v-54821d59]:hover:not(.active){color:var(--color-text);background-color:var(--color-bg)}.filter-dropdown[data-v-54821d59]{position:absolute;top:calc(100% + 4px);right:0;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--modal-shadow);padding:var(--spacing-md);min-width:200px;z-index:100}.filter-dropdown-section[data-v-54821d59]{display:flex;flex-direction:column;gap:var(--spacing-xs)}.filter-dropdown-label[data-v-54821d59]{font-size:13px;font-weight:600;color:var(--color-text);margin-bottom:0}.filter-dropdown-select[data-v-54821d59]{width:100%;padding:var(--spacing-xs) var(--spacing-sm);font-size:14px;border:1px solid var(--color-border);border-radius:var(--border-radius);background-color:var(--color-bg-card);color:var(--color-text)}.view-btn.active[data-v-54821d59]{background-color:var(--color-primary);color:#fff}.view-btn.active[data-v-54821d59]:after{display:none}.view-btn.active[data-v-54821d59]:hover{background-color:var(--color-primary-hover);color:#fff}@media (max-width: 768px){.search-header[data-v-54821d59]{flex-wrap:wrap}.search-bar[data-v-54821d59]{flex:1 1 100%;max-width:100%;order:-1}.search-input[data-v-54821d59]{font-size:16px}.filter-btn[data-v-54821d59],.view-toggle[data-v-54821d59],.view-btn[data-v-54821d59]{flex:1}}.navbar[data-v-8b75ab7c]{background-color:var(--color-bg-card);overflow:visible;width:100%;position:relative;z-index:200}.navbar-content[data-v-8b75ab7c]{max-width:1200px;margin:0 auto;padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;overflow:visible}.navbar-left[data-v-8b75ab7c]{display:flex;align-items:center;gap:var(--spacing-xl)}.navbar-right[data-v-8b75ab7c]{display:flex;align-items:center;gap:var(--spacing-lg)}.navbar-brand[data-v-8b75ab7c]{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.125rem;font-weight:700;letter-spacing:.5px;color:var(--color-text);text-decoration:none;text-transform:uppercase}.navbar-icon[data-v-8b75ab7c]{width:24px;height:24px;color:var(--color-primary)}.navbar-links[data-v-8b75ab7c]{display:flex;align-items:center;gap:var(--spacing-md)}.navbar-link[data-v-8b75ab7c]{color:var(--color-text);text-decoration:none;font-size:14px;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);transition:background-color .15s ease}.navbar-link[data-v-8b75ab7c]:hover{background-color:var(--color-bg)}.navbar-link.router-link-active[data-v-8b75ab7c]{color:var(--color-primary)}.navbar-link-btn[data-v-8b75ab7c]{background:none;border:none;color:var(--color-text);font-size:14px;font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);cursor:pointer;border-radius:var(--border-radius);transition:background-color .15s ease}.navbar-link-btn[data-v-8b75ab7c]:hover{background-color:var(--color-bg)}.navbar-user[data-v-8b75ab7c]{display:flex;align-items:center;position:relative}.btn-add[data-v-8b75ab7c]{padding:var(--spacing-sm) var(--spacing-lg);font-weight:600}.menu-toggle[data-v-8b75ab7c]{background:none;border:none;width:36px;height:36px;padding:6px;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;border-radius:var(--border-radius);transition:background-color .15s ease}.menu-toggle[data-v-8b75ab7c]:hover{background-color:var(--color-bg)}.menu-toggle span[data-v-8b75ab7c]{display:block;width:18px;height:2px;background-color:var(--color-text);border-radius:999px}.menu-backdrop[data-v-8b75ab7c]{position:fixed;inset:0;background:transparent;z-index:10}.menu-panel[data-v-8b75ab7c]{position:absolute;top:calc(100% + 8px);right:0;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:0 10px 30px #0000001f;min-width:160px;z-index:11;padding:var(--spacing-xs)}.menu-item[data-v-8b75ab7c]{display:block;width:100%;text-align:left;background:none;border:none;color:var(--color-text);font-size:14px;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);cursor:pointer;text-decoration:none;transition:background-color .15s ease}.menu-item[data-v-8b75ab7c]:hover{background-color:var(--color-bg)}@media (max-width: 768px){.navbar-content[data-v-8b75ab7c]{flex-wrap:nowrap;gap:var(--spacing-sm);padding:var(--spacing-md)}.navbar-left[data-v-8b75ab7c]{flex:0 1 auto;min-width:0;gap:var(--spacing-sm)}.navbar-right[data-v-8b75ab7c]{flex:0 0 auto;gap:var(--spacing-sm)}.navbar-links[data-v-8b75ab7c]{display:none}.btn-add[data-v-8b75ab7c]{font-size:13px;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap}.menu-toggle[data-v-8b75ab7c]{width:32px;height:32px;padding:5px}.menu-toggle span[data-v-8b75ab7c]{width:16px}}.books-view[data-v-f6b9a1b7]{min-height:100svh;padding-bottom:112px;box-sizing:border-box;background-color:var(--color-bg)}.books-view[data-v-f6b9a1b7] .navbar{z-index:200}.bottom-bar[data-v-f6b9a1b7]{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom));transform:translate(-50%);width:min(92vw,420px);display:flex;align-items:center;justify-content:center;z-index:20}.bottom-bar-button[data-v-f6b9a1b7]{width:100%;height:58px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #1b2639;border-radius:999px;box-shadow:0 10px 26px #1b26392e;font-family:Inter,Segoe UI,sans-serif;font-size:1.2rem;font-weight:700;color:#1b2639;gap:10px;padding:0 22px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.bottom-bar-button[data-v-f6b9a1b7]:hover{transform:translateY(-1px);box-shadow:0 12px 28px #1b26393d}.bottom-bar-button[data-v-f6b9a1b7]:focus-visible{outline:2px solid #1b2639;outline-offset:3px}.bottom-menu[data-v-f6b9a1b7]{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);width:min(86vw,360px);background:#fff;border:2px solid #1b2639;border-radius:18px;box-shadow:0 12px 30px #1b263933;padding:8px;display:flex;gap:8px}.bottom-menu-item[data-v-f6b9a1b7]{flex:1;border:1px solid #1b2639;background:transparent;color:#1b2639;font-weight:700;font-size:1rem;padding:10px 12px;border-radius:999px;cursor:pointer;transition:background .15s ease,color .15s ease;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.bottom-menu-item.active[data-v-f6b9a1b7]{background:#1b2639;color:#fff}.bar-text[data-v-f6b9a1b7]{display:inline-flex;align-items:baseline;gap:.12em;letter-spacing:.03em;text-transform:uppercase;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.bar-arrow[data-v-f6b9a1b7]{width:20px;height:20px;display:inline-flex;align-items:center}.bar-arrow svg[data-v-f6b9a1b7]{width:100%;height:100%;fill:currentColor}.active-filters[data-v-f6b9a1b7]{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap}.filter-tag[data-v-f6b9a1b7]{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary);color:#fff;border-radius:var(--border-radius);font-size:13px;font-weight:500}.filter-tag-remove[data-v-f6b9a1b7]{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:20px;line-height:1;font-weight:300;opacity:.8;transition:opacity .15s ease}.filter-tag-remove[data-v-f6b9a1b7]:hover{opacity:1}.empty-state[data-v-f6b9a1b7]{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.books-container[data-v-f6b9a1b7]{margin-top:var(--spacing-lg);overflow-x:clip;overflow-y:visible}.books-container.sectioned[data-v-f6b9a1b7]{margin-top:0}.shelf-section[data-v-f6b9a1b7]{margin-top:var(--spacing-lg)}.shelf-section[data-v-f6b9a1b7]:first-child{margin-top:0}.shelf-section-title[data-v-f6b9a1b7]{margin:0 0 var(--spacing-sm);font-size:.95rem;font-weight:700;color:var(--color-text);letter-spacing:.04em;text-transform:uppercase}.books-list[data-v-f6b9a1b7]{display:flex;flex-direction:column}.books-grid[data-v-f6b9a1b7]{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1.25rem;align-items:center;width:100%;max-width:100%;padding-top:6px;padding-bottom:var(--spacing-sm);overflow-x:clip;overflow-y:visible}.books-grid[data-v-f6b9a1b7] .sortable-ghost .grid-cover,.books-grid[data-v-f6b9a1b7] .sortable-ghost .grid-cover-placeholder,.books-grid[data-v-f6b9a1b7] .sortable-chosen .grid-cover,.books-grid[data-v-f6b9a1b7] .sortable-chosen .grid-cover-placeholder,.books-grid[data-v-f6b9a1b7] .sortable-drag .grid-cover,.books-grid[data-v-f6b9a1b7] .sortable-drag .grid-cover-placeholder{transform:none;box-shadow:var(--shadow)}.infinite-sentinel[data-v-f6b9a1b7]{display:flex;justify-content:center;align-items:center;padding:var(--spacing-lg) 0;min-height:48px}.infinite-loading[data-v-f6b9a1b7]{color:var(--color-text-secondary);font-size:14px}@media (max-width: 768px){.books-grid[data-v-f6b9a1b7]{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:1.25rem}}@media (max-width: 480px){.books-grid[data-v-f6b9a1b7]{grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}}@media (min-width: 600px){.books-view[data-v-f6b9a1b7]{padding-bottom:120px}}.grid-ghost[data-v-f6b9a1b7]{opacity:0}.grid-drag[data-v-f6b9a1b7],.grid-chosen[data-v-f6b9a1b7]{opacity:1!important}.book-notes[data-v-8cf96b9b]{margin-bottom:var(--spacing-xl)}.book-notes h2[data-v-8cf96b9b]{margin:0 0 var(--spacing-md) 0;font-size:1.25rem}.notes-textarea[data-v-8cf96b9b]{width:100%;min-height:120px;resize:vertical;padding:var(--spacing-sm);border-radius:var(--border-radius);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-family:inherit;font-size:.95rem;line-height:1.5}.notes-actions[data-v-8cf96b9b]{margin-top:var(--spacing-sm);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.notes-rendered[data-v-8cf96b9b]{padding:var(--spacing-sm);border-radius:var(--border-radius);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);line-height:1.5}.notes-rendered[data-v-8cf96b9b] :first-child{margin-top:0}.notes-rendered[data-v-8cf96b9b] :last-child{margin-bottom:0}.notes-empty[data-v-8cf96b9b]{margin:0;color:var(--color-text-muted, #888);font-style:italic}.status-card[data-v-144b4fd1]{background:#0c081073;border:1px solid rgba(255,255,255,.12);border-radius:var(--border-radius);padding:var(--spacing-lg);box-shadow:0 10px 20px #07050833;display:inline-flex;flex-direction:column;gap:var(--spacing-md);width:fit-content;max-width:100%}.status-row[data-v-144b4fd1],.progress-edit[data-v-144b4fd1]{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap;font-size:.9rem}.status-row>.btn-link[data-v-144b4fd1]{margin-left:auto}.status-row>.progress-edit[data-v-144b4fd1]{flex-basis:100%}.status-label[data-v-144b4fd1]{font-weight:600;color:var(--color-text)}.status-subtitle[data-v-144b4fd1]{color:var(--color-text-secondary)}.progress-input[data-v-144b4fd1]{width:70px;padding:4px var(--spacing-sm);border-radius:var(--border-radius);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-family:inherit;font-size:.9rem;appearance:textfield;-moz-appearance:textfield}.progress-input[data-v-144b4fd1]::-webkit-outer-spin-button,.progress-input[data-v-144b4fd1]::-webkit-inner-spin-button{margin:0;-webkit-appearance:none}.progress-total[data-v-144b4fd1]{color:var(--color-text-secondary);font-size:.9rem}.btn-link[data-v-144b4fd1]{background:none;border:none;padding:0;color:var(--color-primary);font-size:.9rem;cursor:pointer}.btn-link[data-v-144b4fd1]:hover:not(:disabled){text-decoration:underline}.btn-link[data-v-144b4fd1]:disabled{color:var(--color-text-secondary);cursor:not-allowed}.btn-link-cancel[data-v-144b4fd1]{color:var(--color-danger)}.status-pill-wrap[data-v-3844be98]{position:relative;display:inline-block}.status-pill[data-v-3844be98]{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:4px 10px 4px 8px;border-radius:999px;border:1px solid var(--color-border);background:#ffffff0a;color:var(--color-text);font-size:.85rem;font-family:inherit;cursor:pointer;line-height:1.2}.status-pill[data-v-3844be98]:hover:not(:disabled){background:#ffffff14}.status-pill[data-v-3844be98]:disabled{opacity:.6;cursor:not-allowed}.pill-caret[data-v-3844be98]{font-size:.7rem;color:var(--color-text-secondary)}.status-menu[data-v-3844be98]{position:absolute;top:calc(100% + 4px);left:0;z-index:10;margin:0;padding:4px;list-style:none;background:var(--color-bg-card, #1a1520);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:0 8px 24px #0006;min-width:180px}.menu-item[data-v-3844be98]{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:6px 10px;border:none;background:none;color:var(--color-text);font-family:inherit;font-size:.9rem;text-align:left;border-radius:var(--radius-sm, 4px);cursor:pointer}.menu-item[data-v-3844be98]:hover{background:#ffffff14}.menu-item.active[data-v-3844be98]{color:var(--color-primary)}.check[data-v-3844be98]{margin-left:auto;font-size:.85rem}.event-timeline[data-v-5a2e9016]{margin-top:var(--spacing-xl)}.event-timeline h3[data-v-5a2e9016]{margin:0 0 var(--spacing-md) 0;font-size:1.25rem}.no-events[data-v-5a2e9016]{color:var(--color-text-secondary);font-size:14px}.timeline[data-v-5a2e9016]{position:relative;padding-left:var(--spacing-lg)}.timeline-item[data-v-5a2e9016]{position:relative;padding-bottom:var(--spacing-md)}.timeline-item[data-v-5a2e9016]:before{content:"";position:absolute;left:calc(-1 * var(--spacing-lg) + 5px);top:14px;bottom:0;width:2px;background-color:var(--color-border)}.timeline-item[data-v-5a2e9016]:last-child{padding-bottom:0}.timeline-item[data-v-5a2e9016]:last-child:before{display:none}.timeline-dot[data-v-5a2e9016]{position:absolute;left:calc(-1 * var(--spacing-lg) + 1px);top:4px;width:10px;height:10px;border-radius:50%;background-color:var(--color-primary);border:2px solid var(--color-bg-card);box-shadow:0 0 0 2px var(--color-primary)}.timeline-content[data-v-5a2e9016]{padding-left:var(--spacing-sm);position:relative;top:-3px}.event-label[data-v-5a2e9016]{font-weight:500;color:var(--color-text);font-size:14px}.event-date[data-v-5a2e9016]{color:var(--color-text-secondary);font-size:12px;margin-top:2px}.event-note[data-v-5a2e9016]{margin-top:var(--spacing-xs);white-space:pre-wrap;color:var(--color-text);font-size:.95rem;line-height:1.5}.book-detail-page[data-v-84b1aea6]{min-height:100vh;background-color:var(--color-bg)}.book-detail[data-v-84b1aea6]{background:transparent;border-radius:var(--border-radius);box-shadow:none;overflow:hidden;max-width:100%}.book-header[data-v-84b1aea6]{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr);column-gap:var(--spacing-xl);padding:var(--spacing-xl);background:transparent;align-items:flex-start;width:100%;max-width:100%}.book-cover-section[data-v-84b1aea6]{flex-shrink:0;max-width:100%}.book-cover-large[data-v-84b1aea6]{width:min(240px,100%);max-width:100%;height:auto;border-radius:var(--border-radius);box-shadow:var(--shadow);display:block;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.book-cover-placeholder[data-v-84b1aea6]{aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:14px;text-align:center;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.book-info[data-v-84b1aea6]{display:flex;flex-direction:column;min-width:0;width:100%}.book-info h1[data-v-84b1aea6]{margin:0 0 var(--spacing-sm) 0;font-size:2rem;line-height:1.2;word-break:break-word}.book-author[data-v-84b1aea6]{margin:0 0 var(--spacing-lg) 0;color:var(--color-text-secondary);font-size:1.125rem;word-break:break-word}.book-actions[data-v-84b1aea6]{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-xl);flex-wrap:wrap;justify-content:flex-start}.book-actions button[data-v-84b1aea6]{flex:0 0 auto;min-width:140px;max-width:220px;width:auto}.book-status-section[data-v-84b1aea6]{margin-bottom:var(--spacing-lg);padding:0;background-color:transparent;border:none;display:flex;flex-direction:column;gap:var(--spacing-md)}.book-dates[data-v-84b1aea6]{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-item[data-v-84b1aea6]{font-size:14px;color:var(--color-text-secondary)}.date-item strong[data-v-84b1aea6]{color:var(--color-text)}.book-body[data-v-84b1aea6]{padding:var(--spacing-xl);overflow-x:hidden;background:transparent}.book-description[data-v-84b1aea6]{margin-bottom:var(--spacing-xl);position:relative}.book-description h2[data-v-84b1aea6]{margin:0 0 var(--spacing-md) 0;font-size:1.25rem}.book-description .description-text[data-v-84b1aea6]{line-height:1.6;color:var(--color-text);white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;overflow:hidden;position:relative;max-height:none;transition:max-height .24s ease;will-change:max-height}.book-description .description-text.clamped[data-v-84b1aea6]{opacity:1}.book-description .description-text.clamped[data-v-84b1aea6]:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.8rem;pointer-events:none;background:linear-gradient(to bottom,rgba(0,0,0,0),var(--color-bg))}@supports (mask-image: linear-gradient(#000,transparent)){.book-description .description-text.clamped[data-v-84b1aea6]{mask-image:linear-gradient(180deg,#000 0%,#000 70%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 70%,transparent 100%);mask-size:100% 100%;-webkit-mask-size:100% 100%;mask-repeat:no-repeat;-webkit-mask-repeat:no-repeat}.book-description .description-text.clamped[data-v-84b1aea6]:after{content:none}}.description-toggle[data-v-84b1aea6]{margin-top:var(--spacing-xs);padding:0;border:none;background:none;color:var(--color-primary);font-size:.95rem;cursor:pointer}.description-toggle[data-v-84b1aea6]:hover{text-decoration:underline}.book-metadata h2[data-v-84b1aea6]{margin:0 0 var(--spacing-md) 0;font-size:1.25rem}.metadata-grid[data-v-84b1aea6]{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md);width:100%}.metadata-item[data-v-84b1aea6]{font-size:14px;color:var(--color-text-secondary);min-width:0;word-break:break-word;overflow-wrap:anywhere}.metadata-item strong[data-v-84b1aea6]{color:var(--color-text)}@media (max-width: 768px){.book-detail-page[data-v-84b1aea6]{border-radius:0;min-height:100%}.book-detail[data-v-84b1aea6]{border:none;border-radius:0;box-shadow:none;background:transparent}.book-header[data-v-84b1aea6]{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg);flex-wrap:wrap}.book-cover-section[data-v-84b1aea6]{display:flex;justify-content:center;width:100%;margin-bottom:var(--spacing-lg)}.book-cover-large[data-v-84b1aea6]{width:min(200px,100%);height:auto}.book-info h1[data-v-84b1aea6]{font-size:1.5rem}.book-info[data-v-84b1aea6]{width:100%}.book-actions[data-v-84b1aea6]{flex-direction:column}.book-actions button[data-v-84b1aea6]{width:100%;flex:0 0 auto}.book-status-section[data-v-84b1aea6]{align-items:center}.book-status-section select[data-v-84b1aea6]{max-width:100%}.book-body[data-v-84b1aea6]{padding:var(--spacing-lg)}.metadata-grid[data-v-84b1aea6]{grid-template-columns:1fr}}.search-fields[data-v-cafa897a]{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.search-fields input[data-v-cafa897a]:nth-child(3),.search-fields button[data-v-cafa897a]{grid-column:span 2}.cover-grid[data-v-cafa897a]{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md);max-height:60vh;overflow-y:auto}.cover-tile[data-v-cafa897a]{display:flex;flex-direction:column;gap:6px;padding:6px;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;text-align:left;transition:border-color .15s ease,transform .15s ease}.cover-tile[data-v-cafa897a]:hover{border-color:var(--color-primary);transform:translateY(-2px)}.cover-tile img[data-v-cafa897a]{width:100%;aspect-ratio:2 / 3;object-fit:cover;border-radius:4px;background-color:var(--color-bg)}.cover-caption[data-v-cafa897a]{display:flex;flex-direction:column;gap:2px;font-size:12px;min-height:2.4em}.cover-title[data-v-cafa897a]{color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cover-author[data-v-cafa897a]{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state[data-v-cafa897a]{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}@media (max-width: 768px){.search-fields[data-v-cafa897a]{grid-template-columns:1fr}.search-fields input[data-v-cafa897a]:nth-child(3),.search-fields button[data-v-cafa897a]{grid-column:span 1}}.cover-grid[data-v-fabd4ebb]{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-md);max-height:60vh;overflow-y:auto}.cover-tile[data-v-fabd4ebb]{display:flex;flex-direction:column;gap:6px;padding:6px;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;text-align:left;transition:border-color .15s ease,transform .15s ease}.cover-tile[data-v-fabd4ebb]:hover{border-color:var(--color-primary);transform:translateY(-2px)}.cover-tile img[data-v-fabd4ebb]{width:100%;aspect-ratio:2 / 3;object-fit:cover;border-radius:4px;background-color:var(--color-bg)}.cover-caption[data-v-fabd4ebb]{display:flex;flex-direction:column;gap:2px;font-size:12px}.cover-size[data-v-fabd4ebb]{color:var(--color-text);font-weight:600}.cover-meta[data-v-fabd4ebb]{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quality.exact[data-v-fabd4ebb]{color:var(--color-success, #2a9d4a);font-weight:600}.quality.likely[data-v-fabd4ebb]{color:var(--color-text-secondary)}.empty-state[data-v-fabd4ebb]{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}.book-edit-page[data-v-d2b56e4e]{min-height:100vh;background-color:var(--color-bg)}.breadcrumb[data-v-d2b56e4e]{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);font-size:.9rem;color:var(--color-text-secondary);flex-wrap:wrap}.breadcrumb-link[data-v-d2b56e4e]{color:var(--color-text);text-decoration:none;font-weight:600}.breadcrumb-link[data-v-d2b56e4e]:hover{color:var(--color-primary)}.breadcrumb-separator[data-v-d2b56e4e]{color:var(--color-text-secondary)}.breadcrumb-current[data-v-d2b56e4e]{color:var(--color-text-secondary);max-width:min(420px,60vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-content[data-v-d2b56e4e]{max-width:720px}.edit-content h1[data-v-d2b56e4e]{margin:0 0 var(--spacing-lg) 0;font-size:1.75rem}.cover-row[data-v-d2b56e4e]{display:flex;gap:var(--spacing-md);align-items:flex-start}.cover-preview[data-v-d2b56e4e]{width:90px;aspect-ratio:2 / 3;flex-shrink:0;border-radius:var(--border-radius);background-color:var(--color-bg);border:1px solid var(--color-border);overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:12px}.cover-preview img[data-v-d2b56e4e]{width:100%;height:100%;object-fit:cover}.cover-actions[data-v-d2b56e4e]{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm);min-width:0}.cover-buttons[data-v-d2b56e4e]{display:flex;gap:var(--spacing-sm)}.form-actions[data-v-d2b56e4e]{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl)}.form-actions .delete-action[data-v-d2b56e4e]{margin-right:auto}.settings-section[data-v-f0247d69]{margin-top:var(--spacing-lg)}.settings-section h2[data-v-f0247d69]{font-size:1.125rem;margin-bottom:var(--spacing-md)}.import-zone[data-v-f0247d69]{border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-lg)}.import-item[data-v-f0247d69]{display:flex;flex-direction:column;gap:var(--spacing-md)}.import-controls[data-v-f0247d69]{display:flex;align-items:center;gap:var(--spacing-md)}.import-success[data-v-f0247d69]{color:var(--color-success);margin:0;font-weight:500}.import-error[data-v-f0247d69]{color:var(--color-danger);margin:0;font-weight:500}.imports-history[data-v-f0247d69]{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.imports-history h3[data-v-f0247d69]{margin:0 0 var(--spacing-md) 0;font-size:1rem}.imports-list[data-v-f0247d69]{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.imports-item[data-v-f0247d69]{display:flex;flex-direction:column;gap:var(--spacing-xs);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.imports-item[data-v-f0247d69]:last-child{padding-bottom:0;border-bottom:none}.imports-item-main[data-v-f0247d69]{display:flex;justify-content:space-between;gap:var(--spacing-md);align-items:baseline;flex-wrap:wrap}.imports-item-date[data-v-f0247d69]{color:var(--color-text-secondary);font-size:13px}.imports-item-counts[data-v-f0247d69]{font-size:13px}.danger-zone[data-v-f0247d69]{border:1px solid var(--color-danger);border-radius:var(--border-radius);padding:var(--spacing-lg)}.danger-item[data-v-f0247d69]{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.danger-item p[data-v-f0247d69]{margin:var(--spacing-xs) 0 0;font-size:13px}.danger-item .btn-danger[data-v-f0247d69]{flex-shrink:0}@media (max-width: 600px){.danger-item[data-v-f0247d69],.import-controls[data-v-f0247d69]{flex-direction:column;align-items:flex-start}}
