.canvas-container[data-v-2b507e40]{flex:1;position:relative;display:flex;justify-content:center;background:var(--color-background);border-radius:var(--radius-lg);overflow:hidden;touch-action:pan-x pan-y}.shelf-canvas[data-v-2b507e40]{display:block;border-radius:var(--radius-md);max-width:100%;max-height:100%}.segmented-control[data-v-4a3bb16e]{display:flex;gap:2px;background:var(--btn-secondary-bg);border-radius:var(--radius-md);flex-shrink:0}.segmented-control.scrollable[data-v-4a3bb16e]{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.segmented-control.scrollable[data-v-4a3bb16e]::-webkit-scrollbar{display:none}.segment-btn[data-v-4a3bb16e]{padding:var(--padding-control);font-size:var(--font-size-sm);font-weight:var(--control-font-weight);font-variant-numeric:tabular-nums;background:transparent;color:var(--btn-secondary-text);border-radius:var(--radius-md);min-width:32px;flex-shrink:0;height:var(--control-height);white-space:nowrap}.segment-btn[data-v-4a3bb16e]:hover{background:var(--btn-secondary-bg-hover);color:var(--btn-secondary-text-hover)}.segment-btn.active[data-v-4a3bb16e]{background:var(--btn-primary-bg);color:var(--btn-primary-text)}@media(max-width:768px){.segment-btn[data-v-4a3bb16e]{padding:4px 10px;font-size:11px}}.app-btn[data-v-7e313644]{display:flex;align-items:center;justify-content:center;gap:6px;height:var(--control-height);padding:4px 12px;font-weight:var(--control-font-weight);font-size:var(--font-size-sm);border-radius:var(--radius-md);white-space:nowrap}.app-btn--primary[data-v-7e313644]{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.app-btn--primary[data-v-7e313644]:hover{background:var(--btn-primary-bg-hover)}.app-btn--secondary[data-v-7e313644]{background:var(--btn-secondary-bg);color:var(--btn-secondary-text)}.app-btn--secondary[data-v-7e313644]:hover{background:var(--btn-secondary-bg-hover);color:var(--btn-secondary-text-hover)}.app-btn svg[data-v-7e313644-s]{width:14px;height:14px;flex-shrink:0}.settings-panel[data-v-9e539a17]{position:fixed;top:0;right:0;width:320px;height:100%;background:var(--color-surface);transform:translate(100%);transition:transform .3s ease;z-index:100;display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000004d}@media(max-width:768px){.settings-panel[data-v-9e539a17]{width:100%;max-width:320px}}@media(max-width:480px){.settings-panel[data-v-9e539a17]{max-width:100%}}.settings-panel.open[data-v-9e539a17]{transform:translate(0)}.panel-header[data-v-9e539a17]{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid rgba(0,0,0,.1)}.panel-title[data-v-9e539a17]{font-weight:600;font-size:var(--font-size-lg);color:var(--color-text);margin:0}.close-btn[data-v-9e539a17]{font-size:1.5rem;width:var(--control-height);height:var(--control-height)}.panel-content[data-v-9e539a17]{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}.settings-section[data-v-9e539a17]{margin-bottom:12px}.section-title[data-v-9e539a17]{font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent);margin:0}.setting-group[data-v-9e539a17]{margin-bottom:8px}.setting-label[data-v-9e539a17]{display:block;font-size:var(--font-size-sm);color:var(--color-text);margin-bottom:4px}.setting-hint[data-v-9e539a17]{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:4px}@media(max-width:768px){.setting-group[data-v-9e539a17]{margin-bottom:12px}.setting-label[data-v-9e539a17]{font-size:13px;margin-bottom:8px}.setting-hint[data-v-9e539a17]{font-size:11px}}.dual-slider[data-v-9e539a17]{display:flex;flex-direction:column;gap:8px}input[type=range][data-v-9e539a17]{width:100%;height:8px;background:var(--slider-track-bg);border-radius:var(--radius-full);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative}input[type=range][data-v-9e539a17]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--slider-thumb-bg);border-radius:50%;cursor:pointer;transition:transform .15s ease;box-shadow:0 1px 3px #0000004d}input[type=range][data-v-9e539a17]::-webkit-slider-thumb:hover{transform:scale(1.1)}input[type=range][data-v-9e539a17]::-moz-range-thumb{width:18px;height:18px;background:var(--slider-thumb-bg);border-radius:50%;cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}input[type=range][data-v-9e539a17]::-moz-range-track{background:var(--slider-track-bg);border-radius:var(--radius-full);height:8px}@media(max-width:768px){input[type=range][data-v-9e539a17]{height:10px}input[type=range][data-v-9e539a17]::-webkit-slider-thumb{width:22px;height:22px}input[type=range][data-v-9e539a17]::-moz-range-thumb{width:22px;height:22px}input[type=range][data-v-9e539a17]::-moz-range-track{height:10px}}.setting-select[data-v-9e539a17]{width:100%;padding:10px 12px;background:var(--input-bg);border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer}.setting-select[data-v-9e539a17]:focus{outline:none;border-color:var(--color-accent)}.setting-select option[data-v-9e539a17]{background:var(--color-surface);color:var(--color-text)}.setting-select optgroup[data-v-9e539a17]{color:var(--color-text-muted);font-weight:600}.reset-btn[data-v-9e539a17]{width:100%;height:auto;padding:12px;border-radius:var(--radius-sm);margin-top:12px}.toggle-label[data-v-9e539a17]{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox[data-v-9e539a17]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-accent)}.modal-backdrop[data-v-d49bc0cb]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;display:flex;justify-content:center;padding-top:10vh;z-index:200}.modal-container[data-v-d49bc0cb]{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);width:100%;max-width:500px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.modal-header[data-v-d49bc0cb]{display:flex;align-items:center;gap:12px;padding:12px}.search-input-wrapper[data-v-d49bc0cb]{flex:1;display:flex;align-items:center;gap:8px;background:var(--color-background);border-radius:var(--radius-md);padding:0 12px}.search-icon[data-v-d49bc0cb]{color:var(--color-text-muted);flex-shrink:0}.search-input[data-v-d49bc0cb]{flex:1;border:none;background:transparent;padding:10px 0;font-size:14px;color:var(--color-text);outline:none}.search-input[data-v-d49bc0cb]::placeholder{color:var(--color-text-muted)}.clear-btn[data-v-d49bc0cb]{display:flex;align-items:center;justify-content:center;padding:4px;color:var(--color-text-muted);border-radius:var(--radius-md);transition:color .15s,background .15s}.clear-btn[data-v-d49bc0cb]:hover{color:var(--color-text);background:#0000001a}.close-btn[data-v-d49bc0cb]{display:none;flex-shrink:0;width:var(--control-height);height:var(--control-height)}.modal-content[data-v-d49bc0cb]{flex:1;overflow-y:auto;padding:12px}.section-header[data-v-d49bc0cb]{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted)}.book-list[data-v-d49bc0cb]{display:flex;flex-direction:column}.book-item[data-v-d49bc0cb]{display:flex;align-items:center;padding:8px 4px;margin-left:-4px;background:var(--color-surface);border-bottom:var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer}.book-item[data-v-d49bc0cb]:hover,.book-item[data-v-d49bc0cb]:focus,.book-item.is-focused[data-v-d49bc0cb]{background:var(--btn-secondary-bg-hover);outline:none}.book-item[data-v-d49bc0cb]:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.book-info[data-v-d49bc0cb]{flex:1;min-width:0;display:flex;flex-direction:column}.book-title[data-v-d49bc0cb]{font-size:var(--font-size-md);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-author[data-v-d49bc0cb]{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.book-meta[data-v-d49bc0cb]{font-size:11px;color:var(--color-text-muted)}.action-btn[data-v-d49bc0cb]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0}.add-btn[data-v-d49bc0cb]{color:var(--color-accent)}.add-btn.already-added[data-v-d49bc0cb],.remove-btn[data-v-d49bc0cb]{color:var(--color-text-muted)}.empty-state[data-v-d49bc0cb]{text-align:center;padding:32px 16px;color:var(--color-text-muted);font-size:14px}.modal-enter-active[data-v-d49bc0cb],.modal-leave-active[data-v-d49bc0cb]{transition:opacity .2s ease}.modal-enter-active .modal-container[data-v-d49bc0cb],.modal-leave-active .modal-container[data-v-d49bc0cb]{transition:transform .2s ease,opacity .2s ease}.modal-enter-from[data-v-d49bc0cb],.modal-leave-to[data-v-d49bc0cb]{opacity:0}.modal-enter-from .modal-container[data-v-d49bc0cb],.modal-leave-to .modal-container[data-v-d49bc0cb]{transform:translateY(-20px);opacity:0}@media(max-width:768px){.modal-backdrop[data-v-d49bc0cb]{padding:5vh 16px}.modal-container[data-v-d49bc0cb]{max-height:80vh}.close-btn[data-v-d49bc0cb]{display:flex}}@media(max-width:480px){.modal-backdrop[data-v-d49bc0cb]{padding:0}.modal-container[data-v-d49bc0cb]{max-width:100%;max-height:100%;border-radius:0}}.shelf-view[data-v-7d33590b]{height:100%;display:flex;flex-direction:column;padding:24px;gap:24px}.header[data-v-7d33590b]{display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.controls-row[data-v-7d33590b]{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}.control-group[data-v-7d33590b]{display:flex;flex-direction:column;gap:4px}.control-label[data-v-7d33590b]{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted)}.title[data-v-7d33590b]{font-family:var(--font-display);font-size:1.75rem;font-weight:500;letter-spacing:.02em;color:var(--color-accent)}.main[data-v-7d33590b]{flex:1;min-height:0;display:flex;flex-direction:column}.controls[data-v-7d33590b]{width:100%;display:flex;flex-direction:column;gap:8px}.status[data-v-7d33590b]{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:0 8px}@media(max-width:768px){.shelf-view[data-v-7d33590b]{padding:12px;gap:12px}.header[data-v-7d33590b]{flex-direction:column;align-items:stretch;gap:12px}.controls-row[data-v-7d33590b]{justify-content:flex-start;gap:8px;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding-bottom:4px}.controls-row[data-v-7d33590b]::-webkit-scrollbar{height:4px}.controls-row[data-v-7d33590b]::-webkit-scrollbar-thumb{background:var(--color-surface);border-radius:2px}.status[data-v-7d33590b]{font-size:.85rem}}:root{--color-background: #DAD9DB;--color-surface: #fff;--color-text: #000;--color-text-muted: #555;--color-accent: #444;--color-accent-hover: #4A4EB5;--border-subtle: 1px solid #eae9eb;--btn-primary-bg: var(--color-accent);--btn-primary-bg-hover: var(--color-accent-hover);--btn-primary-text: #fff;--btn-secondary-bg: var(--color-surface);--btn-secondary-bg-hover: #eee;--btn-secondary-text: var(--color-text-muted);--btn-secondary-text-hover: var(--color-text);--control-bg: var(--color-surface);--control-height: 28px;--control-font-weight: 500;--slider-track-bg: #3D3D3D;--slider-thumb-bg: #fff;--slider-dot-color: rgba(255, 255, 255, .4);--font-display: Inter, system-ui, sans-serif;--font-body: Inter, system-ui, sans-serif;--font-size-sm: 12px;--font-size-md: 14px;--radius-sm: 4px;--radius-md: 12px;--radius-lg: 12px;--radius-full: 9999px;--shadow-soft: 0 4px 20px rgba(0, 0, 0, .3);--padding-control: 6px 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-body);background:var(--color-background);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}#app{height:100%;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(max-width:768px){html,body{font-size:14px}}@media(max-width:480px){html,body{font-size:13px}}
